.site-navbar{background:#0000;color:#7e7474;font-size:15px;font-size:var(--nav-font-size,14px);height:70px;position:-webkit-sticky;position:sticky;top:0;transition:background-color .22s ease,box-shadow .22s ease,padding .22s ease,min-height .22s ease,transform .26s ease,-webkit-backdrop-filter .22s ease;transition:background-color .22s ease,box-shadow .22s ease,backdrop-filter .22s ease,padding .22s ease,min-height .22s ease,transform .26s ease;transition:background-color .22s ease,box-shadow .22s ease,backdrop-filter .22s ease,padding .22s ease,min-height .22s ease,transform .26s ease,-webkit-backdrop-filter .22s ease;z-index:50}:root{--nav-font-size:15px;--nav-padding-y:0.8rem;--nav-padding-x:1rem;--nav-min-height:72px;--nav-center-min-width:560px;--brand-font-size:1.05rem;--toggle-size:1.2rem;--links-gap:0.8rem;--link-pad-y:0.35rem;--link-pad-x:0.6rem}.site-navbar.scrolled{--nav-min-height:56px;--nav-padding-y:0.45rem;background:#0000;box-shadow:0 8px 30px #1018280f}.nav-container{align-items:center;display:flex;justify-content:center;margin:0 auto;max-width:1000px;min-height:72px;min-height:var(--nav-min-height);padding:.8rem 1rem;padding:var(--nav-padding-y) var(--nav-padding-x);transition:padding .22s ease,min-height .22s ease}.nav-brand{color:var(--text);font-size:1.05rem;font-weight:700;letter-spacing:.5px;transition:transform .22s ease}.nav-pill{align-items:center;background:#fffffff2;border-radius:999px;box-shadow:0 6px 22px #1018280f;color:var(--text);display:inline-flex;font-size:.9rem;gap:.6rem;padding:.45rem .9rem}.nav-left{left:8px;margin-right:.6rem;position:absolute;top:50%;transform:translateY(-50%);z-index:30}.nav-right .pill-link{color:var(--text);font-weight:600;text-decoration:none}.nav-right{position:absolute;right:8px;top:50%;transform:translateY(-50%);z-index:30}.status-dot{background:#2ecc71;border-radius:50%;box-shadow:0 0 0 4px #2ecc7114;display:inline-block;height:10px;width:10px}.nav-center{background:#fffffffa;border-radius:999px;box-shadow:0 10px 30px #10182812;gap:.85rem;justify-content:space-between;margin:0 auto;min-width:560px;min-width:var(--nav-center-min-width);padding:.4rem .8rem;z-index:20}.brand-circle,.nav-center{align-items:center;display:flex}.brand-circle{background:#0b0b0b;border-radius:50%;box-shadow:0 6px 18px #1018281f;color:#fff;flex:0 0 auto;font-weight:700;height:44px;justify-content:center;margin-right:.6rem;width:44px}.brand-initials{font-size:.95rem;letter-spacing:.6px}.nav-toggle{background:#0000;border:none;color:var(--text);cursor:pointer;display:none;font-size:1.2rem;font-size:var(--toggle-size);line-height:1;padding:8px}.nav-links{display:flex;flex:0 0 auto;gap:.6rem;list-style:none;margin:0;padding:0}.nav-links li a{border-radius:8px;color:var(--text);font-size:.95rem;padding:.35rem .6rem;padding:var(--link-pad-y) var(--link-pad-x);text-decoration:none}.nav-links li a:hover{background:#ffffff0f}.mobile-only{display:none}@media (max-width:720px){.nav-toggle{display:inline-flex}.site-navbar.nav-hidden{pointer-events:none;transform:translateY(-112%)}.nav-pill{display:none}.nav-container{justify-content:space-between;padding:.8rem 12px;padding:var(--nav-padding-y) 12px}.nav-center{background:#0000;box-shadow:none;gap:.5rem;justify-content:flex-start;margin:0;min-width:0;padding:0;width:auto}.brand-circle{margin-right:.5rem}.nav-links{background:#fffffffa;border-radius:10px;box-shadow:0 10px 30px #1018281f;flex-direction:column;opacity:0;padding:.5rem;pointer-events:none;position:absolute;right:0;top:100%;transform:translateY(-6px);transition:opacity .16s ease,transform .16s ease;width:220px}.nav-links.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-links li{padding:.5rem .8rem}.mobile-only{display:block}}.hero{padding:120px 0}.hero--entering{opacity:1;transform:translateY(8px) scale(.995)}.hero--entered{opacity:1;transform:none;transition:transform .52s cubic-bezier(.2,.9,.3,1)}.hero--reveal{filter:drop-shadow(0 18px 60px rgba(16,24,40,.06));transform:scale(1.01);transition:transform .42s ease,filter .42s ease}.hero--entering .fade-up{opacity:1;transform:translateY(12px) scale(.96)}.hero--entered .fade-up{opacity:1;transform:none;transition:transform .52s cubic-bezier(.2,.9,.3,1)}.hero--entered .hero-content>:first-child{transition-delay:.1s}.hero--entered .hero-content>:nth-child(2){transition-delay:.18s}.hero--entered .hero-content>:nth-child(3){transition-delay:.26s}.hero--entered .hero-content>:nth-child(4){transition-delay:.34s}.hero--entered .hero-content>:nth-child(5){transition-delay:.42s}.hero--entered .hero-content>:nth-child(6){transition-delay:.5s}.hero--entered .hero-content>:nth-child(7){transition-delay:.58s}.hero--entering .hero-visual.fade-up{opacity:0;transform:translateY(12px) scale(.996)}.hero--entered .hero-visual.fade-up{opacity:1;transform:none;transition:opacity .62s ease,transform .62s cubic-bezier(.2,.9,.3,1);transition-delay:.22s}.hero-inner{align-items:center;display:flex;gap:48px}.hero-content{flex:1 1;max-width:640px}.typewriter{align-items:center;color:var(--muted);display:flex;font-size:18px;gap:8px;margin-top:8px}.role-text{color:var(--text);font-weight:600}.type-cursor{animation:blink 1s steps(2,start) infinite;color:var(--accent);display:inline-block}@keyframes blink{to{visibility:hidden}}.hero-socials{display:flex;gap:12px;margin-top:12px}.hero-socials a{align-items:center;background:#1018280f;border-radius:8px;color:var(--text);display:inline-flex;font-weight:700;height:36px;justify-content:center;text-decoration:none;width:36px}.hero-stats{display:flex;gap:20px;margin-bottom:18px}.hero-stats .stat{align-items:flex-start;display:flex;flex-direction:column}.hero-stats .num{font-size:20px;font-weight:700}.hero-stats .label{color:var(--muted);font-size:13px}.hero-title{font-size:96px;line-height:1.02;margin-bottom:12px}.hero--entering .hero-title{letter-spacing:.02em;opacity:0;transform:translateY(14px) scale(.992)}.hero--entered .hero-title{letter-spacing:0;opacity:1;transform:none;transition:transform .52s cubic-bezier(.2,.9,.3,1),letter-spacing .42s ease,opacity .42s ease}.hero-sub{color:var(--text);font-size:34px;font-weight:800;margin-bottom:12px}.hero-name{display:inline}.hero-sub-desc{color:var(--muted);display:inline;font-weight:600}.hero-desc{color:var(--muted);margin-top:8px}.hero-visual{animation-delay:.16s}.avatar,.hero-visual{align-items:center;display:flex;justify-content:center;width:520px}.avatar{background:#0000;border-radius:0;box-shadow:none;height:520px;overflow:hidden;padding:0}.hero--entering .avatar{opacity:0;transform:translateY(28px) scale(.96) rotate(-3deg)}.hero--entered .avatar{opacity:1;transform:none;transition:transform .62s cubic-bezier(.2,.9,.3,1),opacity .52s ease;transition-delay:.28s}@keyframes avatar-float{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}.hero--entered .avatar-img,.hero--entered .avatar-inner{animation:avatar-float 6s ease-in-out 1.2s infinite;will-change:transform}.avatar-inner{align-items:center;background:#0000;border-radius:0;color:var(--text);display:flex;font-size:80px;font-weight:800;height:100%;justify-content:center;width:100%}.avatar-img{display:block;height:100%;-webkit-mask-image:radial-gradient(ellipse at center,#000 60%,#0000 100%);mask-image:radial-gradient(ellipse at center,#000 60%,#0000 100%);object-fit:cover;width:100%}.hero-actions{align-items:center;display:flex;gap:12px;margin-top:20px}.btn-outline{background:#0000;border:1px solid #10182814;border-radius:10px;color:var(--text);padding:10px 14px}.hero .hero-actions .btn,.hero .hero-actions a.btn-outline{box-shadow:0 8px 20px #10182814;transform-origin:center;transition:box-shadow .18s ease,transform .18s ease;will-change:transform}.hero .hero-actions .btn:focus,.hero .hero-actions .btn:hover,.hero .hero-actions a.btn-outline:focus,.hero .hero-actions a.btn-outline:hover{box-shadow:0 14px 30px #1018281f;transform:translateY(-4px) scale(1.04)}.hero .hero-actions .btn:active,.hero .hero-actions a.btn-outline:active{transform:translateY(-2px) scale(.995);transition-duration:.12s}.hero .hero-actions .btn:focus-visible,.hero .hero-actions a.btn-outline:focus-visible{box-shadow:0 14px 30px #1018281f;outline:none;transform:translateY(-4px) scale(1.04)}.hero-scroll{animation:bounce 2s infinite;color:var(--muted);font-size:13px;margin-top:32px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (max-width:1100px){.hero-inner{flex-direction:column-reverse;gap:20px;text-align:center}.avatar,.hero-visual{width:320px}.avatar{border-radius:0;height:320px}.hero-title{font-size:56px}.hero-sub{font-size:22px}.hero-actions{justify-content:center}}@media (max-width:640px){.hero-inner{gap:12px}.avatar,.hero-visual{width:220px}.avatar{border-radius:0;height:220px}.hero-title{font-size:36px}.hero-sub{font-size:16px}.hero{padding:5px 0}.hero-sub-desc{display:none}.typewriter{font-size:18px;justify-content:center;margin-top:6px}.role-text{color:var(--text);font-size:18px;font-weight:700}.hero-desc{margin-bottom:16px;margin-top:14px}.hero-socials{border:1px solid #000;border-radius:9999px;display:flex;gap:10px;margin:12px auto;padding:6px 14px;width:-webkit-fit-content;width:fit-content}.hero-socials,.hero-socials a{align-items:center;background:#0000;justify-content:center}.hero-socials a{border-radius:8px;color:var(--text);display:inline-flex;height:36px;text-decoration:none;width:36px}.hero .hero-actions .btn,.hero .hero-actions a,.hero .hero-actions a.btn-outline{background:#0000!important;border:1px solid #000!important;border-radius:6px;box-shadow:none!important;color:var(--muted);font-size:13px;padding:6px 8px;text-decoration:none!important;transform-origin:center;transition:transform .18s cubic-bezier(.2,.9,.2,1),box-shadow .18s cubic-bezier(.2,.9,.2,1);will-change:transform}.hero .hero-actions .btn:active,.hero .hero-actions .btn:focus-visible,.hero .hero-actions .btn:hover,.hero .hero-actions a.btn-outline:active,.hero .hero-actions a.btn-outline:focus-visible,.hero .hero-actions a.btn-outline:hover,.hero .hero-actions a:active,.hero .hero-actions a:focus-visible,.hero .hero-actions a:hover{box-shadow:0 14px 34px #10182824!important;transform:translateY(-4px) scale(1.06)!important}}@media (prefers-reduced-motion:reduce){.hero--entered,.hero--entering,.hero--reveal{transform:none!important;transition:none!important}.hero--entered .avatar-img,.hero--entered .avatar-inner,.hero--entered .hero-content>*{animation:none!important;transition:none!important}}:root{--bg:#f2f3f5;--text:#222;--accent:#3b82f6;--highlight:#ffd166;--muted:#6b6b6b}*{box-sizing:border-box}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f2f3f5;background:var(--bg);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;line-height:1.5;scroll-behavior:smooth}body,h1,h2,h3{color:#222;color:var(--text);margin:0}h1,h2,h3{font-family:Poppins,Montserrat,sans-serif}p{color:#6b6b6b;color:var(--muted);margin:0}.container{margin:0 auto;max-width:1100px;padding:0 1rem}.colors-section p{max-width:640px}.btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-weight:600;gap:.6rem}.btn,.btn:active,.btn:focus,.btn:hover{text-decoration:none}.btn-primary{background:#3b82f6;background:var(--accent);box-shadow:0 6px 20px #3b82f62e;color:#fff;padding:.65rem 1rem}.btn-ghost{background:#ffd166;background:var(--highlight);box-shadow:0 6px 18px #ffd16624;color:#111;padding:.6rem .9rem}.fade-up{opacity:0;transform:translateY(8px);transition:opacity .7s ease,transform .7s ease}.fade-up.in-view{opacity:1;transform:none}.card{background:#fff;border-radius:14px;box-shadow:0 8px 30px #1018280f;padding:1rem}.main-content{padding-top:32px}.section{margin-top:28px}@media (min-width:720px){.section,section[id]{scroll-margin-top:80px;scroll-margin-top:calc(var(--nav-min-height, 72px) + 8px)}}.section p{margin-top:8px}.section-bottom{margin-bottom:80px}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;white-space:nowrap;width:1px}.contact-grid{grid-gap:28px;align-items:start;display:grid;gap:28px;grid-template-columns:1fr 380px}.contact-form input,.contact-form textarea{border:1px solid #3b82f61f;border-radius:8px;font-size:15px;margin-top:12px;padding:12px 14px;width:100%}.contact-form textarea{resize:vertical}.contact-actions{display:flex;gap:12px;margin-top:16px}.contact-info .contact-list{list-style:none;margin-top:12px;padding-left:0}.contact-info .contact-list li{color:#6b6b6b;color:var(--muted);margin-top:8px}.socials{gap:10px;margin-top:16px}.social-link{color:#3b82f6;color:var(--accent);font-weight:600;text-decoration:none}@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}@media (max-width:640px){.fade-up{transition:opacity .32s ease,transform .32s ease}}.about-section{margin-top:-40px;padding:18px 0 36px}.about-grid{align-items:flex-start;background:#fffffffa;border:1px solid #1018280f;border-radius:14px;box-shadow:0 8px 30px #1018280a;display:flex;gap:28px;padding:22px}.about-left,.about-right{flex:1 1}.about-center{flex:0 0 360px}.about-left h2{font-size:36px;margin-bottom:12px}.about-section>h2{font-size:36px;margin-bottom:18px}.about-left p{max-width:460px}.about-center .stat-card{background:#ffecec;border:1px solid #ff64641f;padding:18px}.stat-top{align-items:center;display:flex;gap:18px}.stat-num{font-size:52px;font-weight:800;line-height:1}.stat-label{font-size:14px}.stat-desc,.stat-label{color:#6b6b6b;color:var(--muted)}.stat-desc{margin-top:12px}.stat-image img{border-radius:10px;height:220px;object-fit:cover;width:100%}.about-right{display:flex;flex-direction:column;gap:18px}.mini-avatar{height:120px;overflow:hidden;padding:0;width:120px}.about-bullets{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.about-bullets li{align-items:flex-start;color:#6b6b6b;color:var(--muted);display:flex;gap:12px}@media (max-width:900px){.about-grid{align-items:center;flex-direction:column;text-align:center}.about-section{margin-top:-20px}.about-right{align-items:center}.mini-avatar{display:none;height:160px;width:160px}.stat-image img{height:160px}.about-center{flex:none;max-width:420px;width:100%}.about-left,.about-right{width:100%}}:root{--cursor-size:10px;--cursor-hover-size:18px;--cursor-color:var(--accent,#3b82f6)}.custom-cursor{background:#3b82f6;background:var(--cursor-color);border-radius:50%;box-shadow:0 6px 18px #3b82f624;height:10px;height:var(--cursor-size);left:0;margin-left:-5px;margin-left:calc(var(--cursor-size)/-2);margin-top:-5px;margin-top:calc(var(--cursor-size)/-2);pointer-events:none;position:fixed;top:0;transform:translateZ(0);transition:width .22s ease,height .22s ease,background .22s ease,box-shadow .22s ease;width:10px;width:var(--cursor-size);z-index:9999}.custom-cursor.cursor--hover{background:#3b82f624;border:1px solid #3b82f6;border:1px solid var(--cursor-color);height:18px;height:var(--cursor-hover-size);margin-left:-9px;margin-left:calc(var(--cursor-hover-size)/-2);margin-top:-9px;margin-top:calc(var(--cursor-hover-size)/-2);width:18px;width:var(--cursor-hover-size)}.cursor-ripple{border:1px solid #3b82f647;border-radius:50%;height:12px;left:0;margin-left:-6px;margin-top:-6px;opacity:0;pointer-events:none;position:fixed;top:0;transform:translateZ(0) scale(.4);transform-origin:center;width:12px;z-index:9998}.cursor-ripple.ripple-animate{animation:ripple .6s ease-out}@keyframes ripple{0%{opacity:.6;transform:scale(.4)}to{opacity:0;transform:scale(3.2)}}@media (pointer:coarse),(prefers-reduced-motion:reduce){.cursor-ripple,.custom-cursor{display:none!important}}.skills-section{background:var(--bg);color:var(--text);padding:64px 0}.skills-header h2{font-size:48px;margin-bottom:8px}.skills-header .muted{color:#222222b3;margin-top:8px}.skills-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(3,1fr);margin-top:28px}.logo-loop{display:none}.card-loop{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;margin:12px 0 20px;overflow-x:auto;padding:0 72px;position:relative;scrollbar-width:none;width:100%}.card-loop::-webkit-scrollbar{display:none}.card-track{align-items:stretch;display:flex;gap:18px}.card-item{flex:0 0 220px;max-width:220px}.card-loop:after,.card-loop:before{bottom:0;content:"";pointer-events:none;position:absolute;top:0;width:72px;z-index:2}.card-loop:before{background:linear-gradient(to right,var(--bg),#0000);left:0}.card-loop:after{background:linear-gradient(to left,var(--bg),#0000);right:0}.skill-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 8px 24px #1018280f;color:var(--text);display:flex;height:140px;padding:14px}.skill-icon{align-items:center;background:#0000;border-radius:10px;color:inherit;display:inline-flex;font-size:22px;height:56px;justify-content:center;width:56px}.skill-logo{display:block;filter:none;height:40px;object-fit:contain;width:40px}.skill-icon-fallback{align-items:center;background:#f3f4f6;border-radius:8px;box-shadow:inset 0 1px 0 #fff9;color:var(--text);display:inline-flex;font-size:12px;font-weight:700;height:40px;justify-content:center;line-height:1;text-transform:uppercase;width:40px}.skill-title{color:var(--text);font-size:16px;margin:0 0 6px}.skill-desc{color:var(--muted);font-size:13px;margin:0}.skill-info{display:flex;flex-direction:column;justify-content:center;margin-left:12px}@media (max-width:1000px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.skills-grid{grid-template-columns:1fr}.card-loop{-ms-overflow-style:auto;scrollbar-width:auto}.card-loop::-webkit-scrollbar{display:block;height:8px}.card-loop::-webkit-scrollbar-thumb{background:#2223;border-radius:4px}}.contact-section{padding:48px 0 80px}.contact-inner{align-items:flex-start;background:#fffffff2;border:1px solid #000;border-radius:14px;box-shadow:none;display:flex;gap:28px;padding:22px}.contact-left{flex:1 1 50%}.contact-heading{font-size:44px;line-height:1.05;margin:0 0 4px}.contact-block{margin-bottom:6px}.contact-label{color:var(--muted);font-size:13px;font-weight:600}.contact-value{color:var(--text);font-size:14px;margin-top:6px}.contact-follow{margin-top:18px}.socials{display:flex;gap:12px;margin-top:8px}.socials a{align-items:center;background:#111;border-radius:999px;color:#fff;display:inline-flex;height:36px;justify-content:center;text-decoration:none;width:36px}.contact-right{flex:0 0 480px}.top-row{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}@media (min-width:901px){.top-row{align-items:flex-start;flex-direction:row;gap:10px;margin-bottom:4px}.top-row .field{flex:1 1;min-width:0}.contact-left{padding-bottom:6px}}.field-label{margin-top:6px}@media (min-width:901px){.field-label{font-size:15px}.message-label{font-size:15px;margin-top:12px}}.field{display:flex;flex-direction:column}.field-label{color:var(--muted);font-size:12.5px;margin-bottom:6px}.contact-section .contact-right .contact-form input,.contact-section .contact-right .contact-form textarea{background:#0000!important;border:none!important;border-bottom:2px solid #1018281f!important;border-radius:0!important;font-size:14px!important;padding:8px 6px!important;width:100%!important}.contact-section .contact-right .contact-form input:focus,.contact-section .contact-right .contact-form textarea:focus{border-bottom-color:var(--accent)!important;outline:none!important}.contact-section .contact-right .contact-form textarea{min-height:100px!important;resize:vertical!important}.contact-form .btn{margin-top:8px}.contact-form .btn-primary{background:#000;border-radius:8px;box-shadow:none;color:#fff;padding:12px 18px;width:220px}.contact-form .btn-primary:hover{background:#111}.form-actions{display:flex;justify-content:flex-end;margin-top:12px}.contact-form input::placeholder,.contact-form textarea::placeholder{color:#10182873;font-size:13px}@media (max-width:900px){.contact-inner{flex-direction:column}.contact-right{flex:1 1 auto}}@media (min-width:901px){.contact-left{border-right:1px solid #1018280f;padding-right:22px}}@media (max-width:640px){.contact-inner{background:#fffffffa;border-radius:10px;padding:12px;width:100%}.contact-left{border-right:none;padding-right:0}}.contact-status{border-radius:8px;font-size:14px;margin-top:12px;padding:10px 12px}.contact-success{background:#10b98114;border:1px solid #10b9812e;color:#059669}.contact-error{background:#ef44440f;border:1px solid #ef44441f;color:#dc2626}.contact-form .btn[disabled]{cursor:default;opacity:.65}.projects-section{padding:40px 0 64px}.projects-section .section-title{font-size:2.4rem;font-weight:700;letter-spacing:-.5px;margin-bottom:22px}.projects-grid{grid-gap:28px;align-items:stretch;display:grid;gap:28px;grid-template-columns:repeat(3,1fr)}.project-card{background:#0000;flex-direction:column;overflow:visible;transition:transform .26s cubic-bezier(.2,.9,.2,1),box-shadow .22s}.project-card,.project-visual{display:flex;position:relative}.project-visual{align-items:center;border-radius:20px;box-shadow:0 12px 40px #0c141e14;height:320px;justify-content:center;overflow:hidden;transition:transform .32s cubic-bezier(.2,.9,.2,1),box-shadow .22s}.project-card:focus-within,.project-card:hover{transform:translateY(-8px)}.project-card:active{transform:translateY(-4px)}.project-card:focus-within .visual-1,.project-card:hover .visual-1{box-shadow:0 22px 60px #0c141e1f;transform:rotate(-2deg) translateY(-12px) scale(1.03)}.project-card:focus-within .visual-2,.project-card:hover .visual-2{box-shadow:0 22px 60px #0c141e1f;transform:rotate(1deg) translateY(-6px) scale(1.03)}.project-card:focus-within .visual-3,.project-card:hover .visual-3{box-shadow:0 22px 60px #0c141e1f;transform:rotate(-1deg) translateY(-8px) scale(1.03)}.project-card:focus-within{outline:none}.project-poster{display:block;height:100%;object-fit:cover;width:100%}.visual-1{background:linear-gradient(135deg,#f7c6c7,#ffd6a5);transform:rotate(-6deg) translateY(-6px)}.visual-2{background:linear-gradient(135deg,#ffd6a5,#c2e9fb);transform:rotate(4deg) translateY(0)}.visual-3{background:linear-gradient(135deg,#c2e9fb,#d4c1ec);transform:rotate(-3deg) translateY(4px)}.project-number{bottom:10px;color:#08080814;font-size:140px;font-weight:700;line-height:.9;pointer-events:none;position:absolute;right:18px}.visual-1 .project-number{transform:rotate(6deg)}.visual-2 .project-number{transform:rotate(-4deg)}.visual-3 .project-number{transform:rotate(3deg)}.project-body{display:flex;flex:1 1 auto;flex-direction:column;padding:18px 6px}.project-title{font-size:1.05rem;margin:6px 0}.project-desc{color:#444;font-size:.95rem;line-height:1.45}.project-cta{align-self:flex-start;background:#0000000f;border-radius:8px;color:var(--text);display:inline-block;font-weight:600;margin-top:auto;padding:8px 12px;text-decoration:none;white-space:nowrap}.project-cta:hover{background:#00000014}@media (max-width:980px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.projects-grid{grid-template-columns:1fr}.project-visual{height:260px}.project-number{bottom:6px;font-size:110px;right:12px}}.site-footer{background:#1018280f;border-top:1px solid #1018280f;color:var(--muted);padding:28px 0}.footer-inner{align-items:center;display:flex;gap:12px;justify-content:space-between}.footer-left{font-size:14px}.footer-small{color:var(--muted);font-size:13px;margin-top:6px}.footer-small a{color:var(--muted);font-weight:600;text-decoration:none}.footer-small .sep{color:var(--muted);margin:0 8px}.footer-right{align-items:center;display:flex;gap:12px}.footer-right .icon-link{align-items:center;background:#0000;border-radius:8px;color:var(--muted);display:inline-flex;font-size:18px;height:36px;justify-content:center;text-decoration:none;transition:color .16s ease,transform .14s ease;width:36px}.footer-right .icon-link:hover{color:var(--text);transform:translateY(-2px)}@media (max-width:640px){.footer-inner{flex-direction:column;gap:8px;text-align:center}.footer-right{flex-wrap:wrap;justify-content:center}}@media (min-width:900px){.site-footer{background:#10182814;border-top:2px solid #0000001f}}.splash-overlay{align-items:center;background:linear-gradient(180deg,#fff,#f1eeee);display:flex;inset:0;justify-content:center;position:fixed;transition:opacity .42s ease,visibility .42s ease;z-index:10000}.splash-content{align-items:center;background:#fffffffa;border-radius:14px;box-shadow:0 18px 60px #1018281f;display:flex;gap:18px;padding:28px 34px;transform:translateY(0)}.splash-brand-circle{align-items:center;background:#0b0b0b;border-radius:50%;box-shadow:0 10px 28px #1018282e;color:#fff;display:flex;font-weight:700;height:68px;justify-content:center;width:68px}.splash-initials{font-size:1.1rem;letter-spacing:.6px}.splash-title{color:#222;font-size:1.25rem;font-weight:700}@media (prefers-reduced-motion:no-preference){.splash-overlay{opacity:1}.splash-content{animation:splashPop .82s cubic-bezier(.2,.9,.3,1)}@keyframes splashPop{0%{opacity:0;transform:translateY(6px) scale(.98)}60%{opacity:1;transform:translateY(-4px) scale(1.02)}to{transform:translateY(0) scale(1)}}}@media (max-width:720px){.splash-content{gap:12px;padding:16px 18px}.splash-brand-circle{height:52px;width:52px}.splash-title{font-size:1rem}}.splash-overlay.splash-hidden{opacity:0;pointer-events:none;visibility:hidden}
/*# sourceMappingURL=main.762e0bc0.css.map*/