*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #06080f;--bg2: #090c19;--surface: #0f1528;--surface2: #141d36;--card: #0d1224;--blue: #3a6eff;--blue-light: #7aa0ff;--blue-glow: rgba(58,110,255,.22);--blue-subtle: rgba(58,110,255,.09);--peony: #c44dff;--peony-dim: rgba(196,77,255,.12);--text: #dce8ff;--text-2: #8fa4cc;--text-3: #4a5a7a;--white: #ffffff;--border: rgba(58,110,255,.16);--border2: rgba(58,110,255,.08);--nav-h: 80px;--rp: 56px;--rt: 28px;--rm: 18px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}html{scroll-behavior:smooth}body{font-family:Figtree,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out)}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease-out),transform .55s var(--ease-out)}.reveal-stagger.revealed>*:nth-child(1){opacity:1;transform:translateY(0);transition-delay:0s}.reveal-stagger.revealed>*:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.08s}.reveal-stagger.revealed>*:nth-child(3){opacity:1;transform:translateY(0);transition-delay:.16s}.reveal-stagger.revealed>*:nth-child(4){opacity:1;transform:translateY(0);transition-delay:.24s}.hero-label{opacity:0;transform:translateY(10px);animation:heroLabel .5s .05s var(--ease-out) forwards}.hero-inline{opacity:0;animation:heroFadeIn .6s .3s var(--ease-out) forwards}.hero-sub{opacity:0;transform:translateY(16px);animation:heroSub .6s .2s var(--ease-out) forwards}.band{opacity:0;transform:translateY(24px);animation:heroSub .7s .35s var(--ease-out) forwards}@keyframes heroLabel{to{opacity:1;transform:translateY(0)}}@keyframes heroFadeIn{to{opacity:1}}@keyframes heroSub{to{opacity:1;transform:translateY(0)}}@media(max-width:900px){.hero-label,.hero-inline,.hero-sub,.band{opacity:1;transform:none;animation:none}}@keyframes spin-anim{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #22c55e33}50%{box-shadow:0 0 0 7px #22c55e0f}}@media(prefers-reduced-motion:reduce){.reveal,.reveal-stagger>*{opacity:1!important;transform:none!important;transition:none!important}.hero-label,.hero-inline,.hero-sub,.band{opacity:1!important;transform:none!important;animation:none!important}.spin-ring{animation:none!important}}.overlay{display:none;position:fixed;inset:0;z-index:900;background:#04050eb8;opacity:0;transition:opacity .32s}.overlay.vis{opacity:1}.drawer{position:fixed;inset:0;z-index:950;display:flex;flex-direction:column;background:var(--bg2);transform:translateY(-100%);transition:transform .5s cubic-bezier(.77,0,.175,1);pointer-events:none}.drawer.open{transform:translateY(0);pointer-events:all}.d-bar{display:flex;justify-content:space-between;align-items:center;padding:0 var(--rp);height:var(--nav-h);border-bottom:1px solid var(--border2);flex-shrink:0}.d-logo{display:inline-flex;align-items:center;text-decoration:none;color:var(--white)}.site-logo{display:block;height:42px;width:auto;max-width:210px;object-fit:contain;object-position:left center}.site-logo--drawer{height:50px;max-width:250px}.site-logo--footer{height:32px;max-width:165px;opacity:.94}.site-logo--demo{height:48px;max-width:200px}.d-close{width:38px;height:38px;background:var(--surface);border:1px solid var(--border2);border-radius:10px;display:grid;place-items:center;cursor:pointer;color:var(--text-2);font-size:1.3rem;transition:background .18s,color .18s}.d-close:hover{background:var(--surface2);color:var(--white)}.d-nav{flex:1;display:flex;flex-direction:column;justify-content:center;padding:24px var(--rp);overflow:hidden}.d-nav a{display:flex;align-items:center;gap:20px;text-decoration:none;color:var(--text-3);font-family:Outfit,sans-serif;font-size:clamp(2.4rem,8vw,4.5rem);font-weight:300;letter-spacing:-.04em;line-height:1;padding:18px 0;border-bottom:1px solid var(--border2);transition:color .2s,padding-left .3s var(--ease-spring)}.d-nav a:last-child{border-bottom:none}.d-nav a:hover{color:var(--white);padding-left:18px}.d-num{font-size:.7rem;font-weight:500;letter-spacing:1px;color:var(--text-3);font-family:Figtree,sans-serif;flex-shrink:0;margin-top:6px;transition:color .2s}.d-nav a:hover .d-num{color:var(--blue-light)}.d-foot{padding:22px var(--rp);border-top:1px solid var(--border2);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-shrink:0}.d-socials{display:flex;gap:9px}.d-socials a{width:40px;height:40px;background:var(--surface);border:1px solid var(--border2);border-radius:10px;display:grid;place-items:center;color:var(--text-3);text-decoration:none;font-size:1.1rem;transition:background .18s,color .18s,border-color .18s}.d-socials a:hover{background:var(--blue-subtle);border-color:var(--border);color:var(--blue-light)}.nav-wrap{position:sticky;top:0;z-index:800;background:linear-gradient(180deg,#0a0e1af7,#06080ff0);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 10px 40px #00000059,inset 0 1px #ffffff0a}.nav-wrap nav{max-width:1320px;margin:0 auto;height:var(--nav-h);padding:0 var(--rp);display:grid;grid-template-columns:1fr auto 1fr;align-items:center}.nav-left{display:flex;align-items:center;min-width:0}.nav-logo{display:inline-flex;align-items:center;text-decoration:none;transition:opacity .2s,filter .2s}.nav-logo:hover{opacity:.92}.nav-logo:hover .site-logo{filter:brightness(1.08)}.nav-center{justify-self:center}.nav-pill{display:inline-flex;align-items:center;flex-wrap:nowrap;gap:0;padding:4px 6px;background:#0f1528f5;border-radius:9999px;border:1px solid rgba(58,110,255,.32);box-shadow:0 3px 18px #00000059,0 0 0 1px #0003}.nav-pill a{text-decoration:none;color:#ebf0ffeb;font-size:.88rem;font-weight:600;padding:8px 14px;border-radius:9999px;transition:background .18s,color .18s;white-space:nowrap}.nav-pill a:hover{background:var(--blue-subtle);color:var(--text)}.nav-pill a.nav-active{background:#3a6eff24;color:var(--white)}.nav-pill__sep{flex-shrink:0;width:1px;height:14px;background:#3a6eff47;border-radius:1px}.nav-right{display:flex;align-items:center;justify-content:flex-end;gap:10px}.nav-cta{--nav-cta-bg: #234fcd;--nav-cta-icon-size: 44px;display:inline-flex;align-items:center;gap:0px;padding:0;border:none;cursor:pointer;background:transparent;font-family:Figtree,sans-serif;font-size:.88rem;font-weight:600;white-space:nowrap;isolation:isolate;filter:drop-shadow(0 4px 16px rgba(0,0,0,.32));transition:transform .15s,filter .18s ease}.nav-cta:hover{--nav-cta-bg: #1f45b5;transform:translateY(-1px);filter:drop-shadow(0 5px 18px rgba(0,0,0,.22)) drop-shadow(0 10px 32px var(--blue-glow))}.nav-cta:active{transform:translateY(0)}.nav-cta:focus-visible{outline:2px solid var(--blue-light);outline-offset:3px;border-radius:9999px}.nav-cta__label{display:inline-flex;align-items:center;padding:0 18px;min-height:44px;border-radius:9999px;background-color:var(--nav-cta-bg);color:#f5f8ff!important;transition:background-color .18s ease}.nav-cta__icon{display:inline-flex;margin-left:-4px;align-items:center;justify-content:center;flex-shrink:0;width:var(--nav-cta-icon-size);height:var(--nav-cta-icon-size);border-radius:50%;background-color:var(--nav-cta-bg);font-size:1rem;color:#f5f8ff;transition:background-color .18s ease}.nav-cta__icon i{display:block;line-height:1}.btn{display:inline-flex;align-items:center;gap:7px;background:#234fcd;color:#f5f8ff!important;text-decoration:none;border:none;border-radius:50px;padding:10px 20px;font-family:Figtree,sans-serif;font-size:.86rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .18s,transform .15s,box-shadow .18s}.btn:hover{background:#1f45b5;transform:translateY(-1px);box-shadow:0 6px 28px var(--blue-glow)}.btn i{font-size:1rem}.btn-ghost{display:inline-flex;align-items:center;gap:7px;background:transparent;color:var(--text-2)!important;border:1px solid var(--border);border-radius:50px;padding:10px 20px;font-family:Figtree,sans-serif;font-size:.86rem;font-weight:500;text-decoration:none;white-space:nowrap;transition:background .18s,color .18s,border-color .18s}.btn-ghost:hover{background:var(--surface);color:var(--white)!important;border-color:var(--border)}.btn-ghost i{font-size:1rem}.hamburger{display:none;width:38px;height:38px;background:var(--surface);border:1px solid var(--border);border-radius:10px;cursor:pointer;position:relative;overflow:hidden;flex-shrink:0}.hamburger i{position:absolute;inset:0;display:grid;place-items:center;font-size:1.15rem;color:var(--text);transition:opacity .18s,transform .26s var(--ease-spring)}.hamburger .ic-x{opacity:0;transform:rotate(-40deg) scale(.6)}.hamburger.open .ic-menu{opacity:0;transform:rotate(40deg) scale(.6)}.hamburger.open .ic-x{opacity:1;transform:rotate(0) scale(1)}.hero-wrap{max-width:1320px;margin:0 auto;padding:64px var(--rp) 56px}.hero-label{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--blue-light);font-weight:600;margin-bottom:28px}.hero-head{max-width:100%}.hero-h1{font-family:Outfit,sans-serif;font-size:clamp(2.75rem,7vw,7.35rem);font-weight:200;line-height:1.04;letter-spacing:-.04em;color:var(--white);word-break:break-word;overflow-wrap:break-word}.hero-h1 em{font-style:normal;font-weight:300;color:var(--blue-light);text-shadow:0 0 48px rgba(58,110,255,.18)}.hero-desc__tail{display:block;margin-top:.5em}.hero-inline{display:inline-flex;align-items:center;gap:8px;margin:0;max-width:min(100%,300px);background:linear-gradient(135deg,rgba(58,110,255,.08) 0%,var(--surface) 45%);border:1px solid rgba(58,110,255,.2);border-radius:100px;padding:5px 14px 5px 5px;font-size:clamp(.52rem,1vw,.74rem);font-family:Figtree,sans-serif;font-weight:400;color:#c8d6f5eb;letter-spacing:0;line-height:1.45;white-space:normal;box-shadow:0 2px 14px #0003}.hero-inline-icon{width:26px;height:26px;background:#3a6eff1f;border:1px solid rgba(58,110,255,.28);border-radius:50%;display:grid;place-items:center;color:var(--blue-light);flex-shrink:0}.hero-inline-icon i{font-size:.82rem}.hero-inline strong{color:var(--text);font-weight:600}.hero-sub{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,360px);gap:28px 48px;align-items:start;margin-top:28px;max-width:100%}.hero-sub__copy{min-width:0}.hero-sub__side{display:flex;flex-direction:column;align-items:flex-end;gap:20px;min-width:0}.hero-desc{max-width:42ch;font-size:1.07rem;line-height:1.68;color:#dce8ffe6;font-weight:400;text-wrap:pretty}.hero-desc strong{color:var(--white);font-weight:600}.hero-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}.band-wrap{padding:0 var(--rp) 80px;max-width:1320px;margin:0 auto}.band{background:linear-gradient(130deg,#0c1530,#112050 40%,#0d1a45,#080f2a);border-radius:28px;padding:64px 68px;position:relative;overflow:hidden;border:1px solid rgba(58,110,255,.14)}.band:before{content:"";position:absolute;top:-80px;right:-60px;width:440px;height:440px;background:radial-gradient(circle,rgba(58,110,255,.22) 0%,transparent 70%);pointer-events:none}.band:after{content:"";position:absolute;bottom:-60px;left:30%;width:320px;height:320px;background:radial-gradient(circle,rgba(196,77,255,.1) 0%,transparent 70%);pointer-events:none}.band-text{font-family:Outfit,sans-serif;font-size:clamp(1.15rem,2.8vw,2.1rem);font-weight:300;color:#dce8ff8c;line-height:1.55;max-width:680px;letter-spacing:-.02em}.band-text strong{color:var(--white);font-weight:400}.spin-btn{position:absolute;right:60px;bottom:40px;width:96px;height:96px;cursor:pointer;text-decoration:none}.spin-ring{width:100%;height:100%;display:block;animation:spin-anim 13s linear infinite;will-change:transform}.spin-ring text{font-family:Figtree,sans-serif;font-size:10px;fill:#7aa0ffa6;letter-spacing:3.5px}.spin-arrow-c{position:absolute;inset:0;display:grid;place-items:center}.spin-arrow-c i{font-size:1.5rem;color:var(--blue-light)}.spin-btn:hover .spin-arrow-c i{transform:translate(3px,-3px);transition:transform .22s var(--ease-spring)}.section{max-width:1320px;margin:0 auto;padding:96px var(--rp)}@supports (content-visibility: auto){.home-content .band-wrap,.home-content .fit-section,.home-content #o-mne,.home-content .process-section,.home-content .code-showcase,.home-content .projects-section,.home-content .cta-wrap,.home-content footer{content-visibility:auto;contain-intrinsic-size:720px}}.fit-section,.process-section{padding-top:24px}.fit-grid,.process-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.fit-card,.process-step{background:var(--card);border:1px solid var(--border2);border-radius:18px;padding:22px 18px}.fit-card h3,.process-step h3{font-family:Outfit,sans-serif;font-size:1rem;font-weight:500;color:var(--white);margin-bottom:8px;letter-spacing:-.02em}.fit-card p,.process-step p{color:var(--text-2);font-size:.86rem;line-height:1.65}.process-steps{grid-template-columns:repeat(4,minmax(0,1fr))}.process-step__n{width:30px;height:30px;border-radius:9px;border:1px solid var(--border);background:var(--blue-subtle);color:var(--blue-light);display:grid;place-items:center;font-size:.82rem;font-weight:700;margin-bottom:12px}.section-tag{display:inline-flex;align-items:center;gap:7px;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;font-weight:600;color:var(--blue);margin-bottom:40px}.section-tag:after{content:"";display:block;width:40px;height:1px;background:var(--blue);opacity:.3;margin-left:4px}.section-tag i{font-size:.88rem}.s-heading{font-family:Outfit,sans-serif;font-weight:300;letter-spacing:-.03em;line-height:1.05;color:var(--white)}.s-heading em{font-style:normal;color:var(--blue)}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.about-grid .s-heading{font-size:clamp(2rem,4vw,3.6rem)}.about-body p{font-size:.97rem;line-height:1.8;color:var(--text-2);font-weight:300;margin-bottom:16px}.about-body p:last-child{margin-bottom:0}.about-body p strong{color:var(--text);font-weight:500}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}.tag{display:inline-flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--border2);border-radius:50px;padding:5px 13px;font-size:.78rem;color:var(--text-2);transition:border-color .18s,color .18s}.tag:hover{border-color:var(--border);color:var(--text)}.tag i{font-size:.88rem;color:var(--blue)}.skills-section{margin-top:80px;padding-top:72px;border-top:1px solid var(--border2)}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.skill-card{background:var(--card);border:1px solid var(--border2);border-radius:20px;padding:28px 24px;transition:transform .22s var(--ease-out),border-color .22s}.skill-card:hover{transform:translateY(-6px);border-color:var(--border)}.skill-card:after{content:"";position:absolute;inset:0;border-radius:20px;box-shadow:0 16px 48px #3a6eff24;opacity:0;transition:opacity .22s;pointer-events:none}.skill-card{position:relative}.skill-card:hover:after{opacity:1}.sk-icon{width:44px;height:44px;background:var(--blue-subtle);border:1px solid var(--border2);border-radius:12px;display:grid;place-items:center;margin-bottom:18px}.sk-icon i{font-size:1.35rem;color:var(--blue)}.skill-card h3{font-family:Outfit,sans-serif;font-size:1rem;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:-.2px}.skill-card p{font-size:.83rem;color:var(--text-2);line-height:1.6;font-weight:300}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border2);border-radius:20px;overflow:hidden;margin-top:72px;border:1px solid var(--border2)}.stats.stats--triple{grid-template-columns:repeat(3,1fr)}.stat{background:var(--card);padding:36px 24px;text-align:center}.stat-n{font-family:Outfit,sans-serif;font-size:2.8rem;font-weight:200;color:var(--blue-light);letter-spacing:-.04em;display:block;line-height:1}.stat-l{font-size:.78rem;color:var(--text-3);margin-top:8px}.code-showcase{padding-top:20px}.code-showcase__head{margin-bottom:20px}.code-showcase__lead{margin-top:16px;max-width:72ch;color:var(--text-2);line-height:1.7;font-size:.98rem}.code-editor{border:1px solid rgba(58,110,255,.2);border-radius:18px;background:linear-gradient(180deg,#0a1021,#080d1d);box-shadow:0 20px 56px #00000061;overflow:hidden}.code-editor--full{width:100%}.code-editor__bar{height:42px;border-bottom:1px solid rgba(58,110,255,.14);display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 14px;background:#090e1deb}.code-editor__workspace{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:360px}.code-editor__sidebar{border-right:1px solid rgba(58,110,255,.12);background:#080d1ce6;padding:12px 10px}.code-editor__sidebar-title{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin:0 0 10px 4px}.code-editor__tree{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.code-editor__tree li{display:flex;align-items:center;gap:8px;min-height:30px;border-radius:8px;padding:5px 8px;color:var(--text-2);font:500 .76rem/1.3 Figtree,sans-serif}.code-editor__tree li.lvl-0{padding-left:8px}.code-editor__tree li.lvl-1{padding-left:18px}.code-editor__tree li.lvl-2{padding-left:28px}.code-editor__tree li.lvl-3{padding-left:38px}.code-editor__tree li.lvl-4{padding-left:48px}.code-editor__tree li.lvl-5{padding-left:58px}.code-editor__tree li i{color:#7aa0ffe0;font-size:.9rem}.code-editor__tree li.is-folder{color:#b9ccf0}.code-editor__tree li.is-open{color:#d5e4ff}.code-editor__tree li.is-active{background:#3a6eff2e;color:var(--white);border:1px solid rgba(58,110,255,.26)}.code-editor__tree li.is-file[data-snippet-id]{cursor:pointer}.code-editor__live-dot{margin-left:auto;width:7px;height:7px;border-radius:50%;background:#4f8cff;box-shadow:0 0 #4f8cff6b;animation:codeLiveDotPulse 1.9s ease-out infinite;flex-shrink:0}.code-editor__tree li.is-active .code-editor__live-dot{background:#7db3ff;box-shadow:0 0 #7db3ff80}@keyframes codeLiveDotPulse{0%{box-shadow:0 0 #4f8cff6b}70%{box-shadow:0 0 0 8px #4f8cff00}to{box-shadow:0 0 #4f8cff00}}.code-editor__main{min-width:0}.code-editor__file{height:34px;display:none;align-items:center;padding:0 14px;border-bottom:1px solid rgba(58,110,255,.12);color:#c5d4f2bd;font-size:.72rem;letter-spacing:.04em;background:#090e1d80}.code-editor__file.is-active{display:flex}.code-editor__dots{display:inline-flex;align-items:center;gap:7px}.code-editor__dots span{width:10px;height:10px;border-radius:50%;display:block}.code-editor__dots span:nth-child(1){background:#ff5f56}.code-editor__dots span:nth-child(2){background:#ffbd2e}.code-editor__dots span:nth-child(3){background:#27c93f}.code-editor__path{color:#c5d4f2b8;font-size:.72rem;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.code-editor__body{margin:0;display:none;padding:18px 16px 20px;overflow-x:auto;min-height:320px;font:500 .78rem/1.72 JetBrains Mono,Fira Code,SFMono-Regular,Menlo,monospace;color:#d9e6ff}.code-editor__body.is-active{display:block}.projects-section{background:var(--bg2);border-top:1px solid var(--border2);border-bottom:1px solid var(--border2)}.projects-inner{max-width:1320px;margin:0 auto;padding:96px var(--rp)}.projects-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:44px;gap:24px}.projects-head .s-heading{font-size:clamp(1.8rem,3.5vw,3rem)}.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.projects-note{margin-top:22px;font-size:.9rem;line-height:1.7;color:var(--text-2);text-align:center}.proj-card{background:var(--card);border:1px solid var(--border2);border-radius:22px;padding:32px;position:relative;transition:transform .22s var(--ease-out),border-color .22s}.proj-card__link{position:absolute;inset:0;z-index:3;border-radius:inherit}.proj-card__link:focus-visible{outline:2px solid var(--blue-light);outline-offset:2px}.proj-card:hover{transform:translateY(-6px);border-color:var(--border)}.proj-card:after{content:"";position:absolute;inset:0;border-radius:22px;box-shadow:0 18px 56px #3a6eff24;opacity:0;transition:opacity .22s;pointer-events:none}.proj-card:hover:after{opacity:1}.proj-card.feat{grid-column:1 / -1;background:linear-gradient(130deg,#0c1a42,#0f2058,#0c1a42);border-color:#3a6eff38;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}.proj-chip{display:inline-flex;align-items:center;gap:5px;font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;color:var(--blue-light);background:var(--blue-subtle);border:1px solid rgba(58,110,255,.2);border-radius:50px;padding:4px 11px 4px 8px;margin-bottom:14px}.proj-chip i{font-size:.82rem}.proj-card.feat .proj-chip{color:var(--peony);background:var(--peony-dim);border-color:#c44dff40}.proj-card h3{font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:500;color:var(--text);margin-bottom:10px;letter-spacing:-.3px}.proj-card.feat h3{font-size:1.8rem;font-weight:300;color:var(--white);letter-spacing:-.04em}.proj-card p{font-size:.85rem;color:var(--text-2);line-height:1.65;font-weight:300}.proj-card.feat>div>p{color:#dce8ff8c;font-size:.92rem}.proj-visual{width:200px;height:160px;background:#3a6eff12;border:1px solid rgba(58,110,255,.18);border-radius:16px;display:grid;place-items:center;flex-shrink:0;overflow:hidden}.proj-visual--cover{padding:0;background:#0003}.proj-visual__img{width:100%;height:100%;object-fit:cover;display:block}.proj-visual i{font-size:3.4rem;color:var(--blue);opacity:.5}.proj-card__thumb{margin:-32px -32px 18px;height:148px;border-radius:22px 22px 0 0;overflow:hidden;border-bottom:1px solid var(--border2)}.proj-card__thumb img{width:100%;height:100%;object-fit:cover;display:block}.arrow-link{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;font-weight:500;color:var(--blue-light);text-decoration:none;margin-top:18px;transition:gap .18s,color .18s}.arrow-link i{font-size:.95rem;transition:transform .22s var(--ease-spring)}.proj-card:hover .arrow-link,.proj-card:focus-within .arrow-link{gap:9px;color:var(--white)}.proj-card:hover .arrow-link i,.proj-card:focus-within .arrow-link i{transform:translate(3px,-3px)}.cta-wrap{max-width:1320px;margin:0 auto;padding:80px var(--rp)}.cta-box{background:linear-gradient(130deg,#0c1530,#0f1f58 45%,#0c1a45);border:1px solid rgba(58,110,255,.18);border-radius:28px;padding:88px 72px;text-align:center;position:relative;overflow:hidden}.cta-box:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(58,110,255,.18) 0%,transparent 70%);pointer-events:none}.cta-box:after{content:"";position:absolute;bottom:-80px;right:8%;width:300px;height:300px;background:radial-gradient(circle,rgba(196,77,255,.1) 0%,transparent 70%);pointer-events:none}.cta-box h2,.cta-box h3{font-family:Outfit,sans-serif;font-size:clamp(2.2rem,5.5vw,4.2rem);font-weight:200;color:var(--white);letter-spacing:-.04em;line-height:1;margin-bottom:16px;position:relative}.cta-box h2 em,.cta-box h3 em{font-style:normal;color:var(--blue-light)}.cta-box>p{color:var(--text-3);font-size:.97rem;margin-bottom:36px;position:relative;font-weight:300}.cta-row{display:flex;justify-content:center;align-items:center;gap:12px;position:relative;flex-wrap:wrap}.cta-mail{display:inline-flex;align-items:center;gap:8px;color:#fffffff2;font-size:.95rem;font-weight:500;letter-spacing:.01em;text-decoration:none;border:1px solid rgba(255,255,255,.35);border-radius:50px;padding:12px 22px;background:#ffffff14;box-shadow:0 0 0 1px #3a6eff1f;transition:color .18s,border-color .18s,background .18s,box-shadow .18s}.cta-mail i{font-size:1.05rem;opacity:.95}.cta-mail:hover{color:#fff;border-color:#93baffa6;background:#ffffff24;box-shadow:0 0 24px #3a6eff40}footer{border-top:1px solid var(--border2);background:linear-gradient(180deg,#06080f33,#04050ea6)}.footer-inner{max-width:1320px;margin:0 auto;padding:36px var(--rp) 40px;display:grid;grid-template-columns:minmax(200px,1.35fr) minmax(160px,1fr) minmax(200px,1fr);gap:28px 48px;align-items:start}.footer-col{display:flex;flex-direction:column;gap:0;min-width:0}.footer-col--brand{gap:12px}.footer-brand{display:inline-flex;align-items:center;text-decoration:none;color:inherit;transition:opacity .2s}.footer-brand:hover{opacity:.88}.footer-heading{font-family:Outfit,sans-serif;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--text-3);margin:0 0 12px}.footer-company{display:flex;flex-direction:column;gap:2px;margin:0 0 4px;font-size:.76rem;color:var(--text-2);line-height:1.45}.footer-ids{font-size:.74rem;color:var(--text-3);font-weight:300;margin:0;line-height:1.5}.footer-ids__sep{margin:0 7px;opacity:.55}.footer-legal-nav{display:flex;flex-direction:column;align-items:flex-start;gap:9px;font-size:.8rem;font-weight:400}.footer-legal-nav a{color:var(--text-2);text-decoration:none;transition:color .15s}.footer-legal-nav a:hover{color:var(--blue-light);text-decoration:underline}.footer-col--social{align-items:flex-end;text-align:right}.footer-col--social .footer-heading{align-self:flex-end;text-align:right}.footer-socials{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;margin-bottom:14px}.footer-socials a{width:36px;height:36px;background:#3a6eff0a;border:1px solid var(--border2);border-radius:10px;display:grid;place-items:center;color:var(--text-3);text-decoration:none;font-size:1.05rem;transition:background .18s,color .18s,border-color .18s}.footer-socials a:hover{background:var(--blue-subtle);color:var(--blue-light);border-color:var(--border)}.footer-copy{font-size:.74rem;color:var(--text-3);font-weight:300;margin:0;line-height:1.55;max-width:26ch;text-align:right}@media(max-width:900px){.footer-inner{grid-template-columns:1fr 1fr;gap:28px 32px;padding:32px var(--rt) 36px}.footer-col--brand{grid-column:1 / -1;padding-bottom:24px;border-bottom:1px solid var(--border2);align-items:center;text-align:center}.footer-col--legal{align-items:flex-start}.footer-col--social{align-items:flex-end}}@media(max-width:600px){.footer-inner{grid-template-columns:1fr;gap:26px;padding:28px var(--rm) 32px;text-align:center}.footer-col--brand{border-bottom:none;padding-bottom:0}.footer-col--legal,.footer-col--social{align-items:center;text-align:center}.footer-col--social .footer-heading{align-self:center;text-align:center}.footer-legal-nav{align-items:center;width:100%}.footer-socials{justify-content:center}.footer-copy{text-align:center;max-width:none;align-self:center}}.cookie-consent{position:fixed;bottom:0;left:0;right:0;z-index:1002;padding:10px 14px;padding-bottom:max(10px,env(safe-area-inset-bottom));pointer-events:none}.cookie-consent__panel{pointer-events:auto;max-width:920px;margin:0 auto;background:linear-gradient(165deg,#0f1528f7,#090c19fa);border:1px solid var(--border2);border-radius:14px;padding:16px 18px 14px;box-shadow:0 -12px 48px #00000073;backdrop-filter:blur(14px)}.cookie-consent__title{font-family:Outfit,sans-serif;font-weight:600;font-size:.92rem;color:var(--text);margin:0 0 6px;letter-spacing:-.02em}.cookie-consent__lead{font-size:.8rem;line-height:1.55;color:var(--text-2);font-weight:300;margin:0 0 8px}.cookie-consent__more{margin:0 0 12px;font-size:.74rem;color:var(--text-3)}.cookie-consent__link{color:var(--blue-light);text-decoration:none}.cookie-consent__link:hover{text-decoration:underline}.cookie-consent__dot{margin:0 6px;opacity:.5}.cookie-consent__actions--row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:12px}.cookie-consent__actions--row .cookie-consent__btn{flex:1 1 140px;min-width:0}.cookie-consent__accordion{display:flex;flex-direction:column;gap:0}.cookie-consent__accordion-btn{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;margin:0;padding:11px 14px;font-family:Figtree,sans-serif;font-size:.8rem;font-weight:500;color:var(--text-2);background:#3a6eff0f;border:1px solid var(--border2);border-radius:10px;cursor:pointer;text-align:left;transition:background .18s,border-color .18s,color .18s}.cookie-consent__accordion-btn:hover{background:#3a6eff1a;border-color:var(--border);color:var(--text)}.cookie-consent__accordion-ic{font-size:1.05rem;color:var(--blue-light);transition:transform .22s var(--ease-out);flex-shrink:0}.cookie-consent__accordion.is-open .cookie-consent__accordion-ic{transform:rotate(180deg)}.cookie-consent__prefs-panel{margin-top:10px;padding-top:2px;animation:cookieAccordionIn .22s var(--ease-out)}@keyframes cookieAccordionIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.cookie-consent__prefs{margin:0 0 12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border2);border-radius:10px;display:flex;flex-direction:column;gap:10px}.cookie-consent__row{display:flex;align-items:flex-start;gap:10px;font-size:.8rem;color:var(--text-2);cursor:pointer;line-height:1.4}.cookie-consent__row input{margin-top:3px;accent-color:var(--blue)}.cookie-consent__row--disabled{opacity:.75;cursor:default}.cookie-consent__btn{font-size:.78rem!important;padding:9px 14px!important}.cookie-consent__btn--primary{border-color:transparent!important;background:linear-gradient(135deg,var(--blue),#5b7cff)!important;color:var(--white)!important}.cookie-consent__btn--primary:hover{filter:brightness(1.06)}.cookie-consent__btn--save{display:flex;width:100%;justify-content:center;border-color:var(--border)!important;background:var(--surface2)!important;color:var(--text)!important}.cookie-consent__btn--save:hover{background:var(--surface)!important;border-color:var(--blue)!important}@media(max-width:600px){.cookie-consent{padding:8px 10px}.cookie-consent__panel{padding:14px 14px 12px}.cookie-consent__actions--row{flex-direction:column;align-items:stretch}.cookie-consent__actions--row .cookie-consent__btn{width:100%;flex:none}}.legal-page__body{margin-top:28px}.legal-page__section{margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid var(--border2)}.legal-page__section:last-of-type{border-bottom:none}.legal-page__h2{font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:600;color:var(--white);margin:0 0 12px;letter-spacing:-.02em}.legal-page__body p,.legal-page__body li{font-size:.9rem;line-height:1.75;color:var(--text-2);font-weight:300;margin:0 0 12px}.legal-page__body a{color:var(--blue-light);text-decoration:none}.legal-page__body a:hover{text-decoration:underline}.legal-page__body code{font-size:.82em;background:var(--surface);padding:2px 6px;border-radius:4px;border:1px solid var(--border2)}.legal-page__list{margin:8px 0 0;padding-left:1.2em}.legal-page__back{margin-top:32px}.green-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;box-shadow:0 0 0 3px #22c55e33;animation:pulse 2.5s infinite;flex-shrink:0}.d-availability{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--text-3)}@media(max-width:1080px){.nav-wrap nav{grid-template-columns:1fr 1fr}.nav-center{display:none}.hamburger{display:grid;place-items:center}.hero-wrap{padding-top:52px}.hero-h1{font-size:clamp(2.5rem,6.5vw,5.5rem);line-height:1.05}.hero-inline{font-size:clamp(.52rem,1.15vw,.72rem)}.hero-sub{grid-template-columns:1fr;gap:24px}.hero-sub__side{align-items:flex-start;flex-direction:column;gap:18px}.hero-desc{max-width:100%}.hero-actions{justify-content:flex-start}.code-editor__workspace{grid-template-columns:1fr}.code-editor__sidebar{border-right:none;border-bottom:1px solid rgba(58,110,255,.12)}.band-wrap{padding:0 var(--rt) 56px}.band{padding:48px 44px 120px;border-radius:22px}.spin-btn{right:36px;bottom:28px}.section{padding:72px var(--rt)}.fit-grid,.process-steps{grid-template-columns:1fr 1fr}.about-grid{grid-template-columns:1fr;gap:40px}.skills-grid,.stats,.stats.stats--triple{grid-template-columns:repeat(2,1fr)}.projects-inner{padding:72px var(--rt)}.proj-grid,.proj-card.feat{grid-template-columns:1fr}.proj-visual{width:100%;height:140px}.cta-wrap{padding:56px var(--rt)}.cta-box{padding:60px 40px}.footer-inner{padding:24px var(--rt)}.d-bar,.d-nav,.d-foot{padding-left:var(--rt);padding-right:var(--rt)}}@media(max-width:600px){:root{--nav-h: 64px}.nav-wrap nav{grid-template-columns:1fr auto;padding:0 var(--rm)}.site-logo{height:34px;max-width:175px}.nav-cta{--nav-cta-icon-size: 38px;gap:10px;font-size:.82rem}.nav-cta__label{min-height:40px;padding:0 16px}.nav-cta__icon{font-size:.92rem}.hero-wrap{padding:36px var(--rm) 36px}.hero-label{font-size:.66rem;margin-bottom:20px}.hero-h1{font-size:clamp(2.2rem,11.5vw,3.2rem);letter-spacing:-.03em;line-height:1}.hero-inline{display:none}.hero-inline-mob{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:7px 14px 7px 8px;font-size:.76rem;font-family:Figtree,sans-serif;color:var(--text-2);margin-top:18px}.hero-inline-mob .hero-inline-icon{width:28px;height:28px}.hero-sub{margin-top:24px;gap:18px}.hero-sub__side{flex-direction:column;align-items:stretch}.hero-desc{font-size:.96rem;line-height:1.7}.hero-actions{flex-wrap:wrap;justify-content:flex-start}.hero-actions .btn,.hero-actions .btn-ghost{font-size:.82rem;padding:9px 16px}.code-editor__body{font-size:.71rem;line-height:1.62;padding:14px 12px 16px}.code-editor__bar{padding:0 10px;gap:10px}.code-editor__path{font-size:.66rem}.code-editor__sidebar{padding:10px 8px}.code-editor__tree li{min-height:28px;font-size:.72rem;padding:4px 6px}.band-wrap{padding:0 var(--rm) 52px}.band{padding:32px 24px 100px;border-radius:18px}.band-text{font-size:clamp(1rem,4.5vw,1.25rem)}.spin-btn{right:18px;bottom:18px;width:78px;height:78px}.section{padding:60px var(--rm)}.fit-grid,.process-steps{grid-template-columns:1fr}.about-grid .s-heading{font-size:clamp(1.8rem,8.5vw,2.4rem)}.about-body p{font-size:.9rem}.skills-section{margin-top:52px;padding-top:52px}.skills-grid{grid-template-columns:1fr;gap:12px}.skill-card{padding:22px 18px}.stats{grid-template-columns:1fr 1fr;margin-top:52px}.stats.stats--triple{grid-template-columns:1fr}.stat{padding:24px 14px}.stat-n{font-size:2.2rem}.projects-inner{padding:60px var(--rm)}.projects-head{flex-direction:column;align-items:flex-start;gap:16px}.projects-head .s-heading{font-size:clamp(1.8rem,8vw,2.4rem)}.proj-grid{gap:14px}.projects-note{margin-top:18px;font-size:.84rem;text-align:left}.proj-card{padding:20px 18px;border-radius:18px}.proj-card__thumb{margin:-20px -18px 14px;height:120px;border-radius:18px 18px 0 0}.proj-card.feat{padding:22px 18px}.proj-card.feat h3{font-size:1.4rem}.proj-card h3{font-size:1.05rem}.proj-visual{height:110px}.proj-visual i{font-size:2.4rem}.cta-wrap{padding:0 var(--rm) 60px}.cta-box{padding:44px 22px;border-radius:20px}.cta-box h2,.cta-box h3{font-size:clamp(1.9rem,9vw,2.6rem)}.cta-row{flex-direction:column;align-items:stretch}.cta-row .btn,.cta-mail{justify-content:center}.footer-inner{padding:22px var(--rm) 28px}.d-bar{padding:0 var(--rm)}.d-nav{padding:20px var(--rm)}.d-nav a{font-size:clamp(2rem,10vw,3rem);padding:14px 0}.d-foot{padding:18px var(--rm);flex-wrap:wrap}}.sub-hero{max-width:1320px;margin:0 auto;padding:48px var(--rp) 28px}.sub-hero .hero-label{margin-bottom:22px}.sub-hero h1.sub-hero-title{font-family:Outfit,sans-serif;font-weight:200;font-size:clamp(2.4rem,6vw,4.8rem);letter-spacing:-.04em;line-height:1.05;color:var(--white)}.sub-hero h1.sub-hero-title em{font-style:normal;color:var(--blue)}.sub-hero .sub-hero-lead{margin-top:22px;max-width:560px;font-size:1rem;line-height:1.72;color:var(--text-2);font-weight:300}@media(max-width:1080px){.sub-hero{padding:40px var(--rt) 24px}}@media(max-width:600px){.sub-hero{padding:32px var(--rm) 20px}}.contact-sheet{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:0;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .28s var(--ease-out),visibility .28s}.contact-sheet.is-open{pointer-events:auto;opacity:1;visibility:visible}.contact-sheet__backdrop{position:absolute;inset:0;background:#04050ee0;cursor:pointer}.contact-sheet__panel{position:relative;z-index:1;width:100%;max-width:640px;max-height:min(92dvh,920px);display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border2);border-bottom:none;border-radius:22px 22px 0 0;box-shadow:0 -12px 60px #0006;transform:translateY(100%);transition:transform .34s var(--ease-out);padding-bottom:env(safe-area-inset-bottom,0px)}.contact-sheet.is-open .contact-sheet__panel{transform:translateY(0)}.contact-sheet__handle{flex-shrink:0;width:44px;height:5px;margin:10px auto 4px;border-radius:999px;background:var(--border2);opacity:.85}.contact-sheet__inner{flex:1;min-height:0;overflow-y:auto;padding:12px 26px 24px;-webkit-overflow-scrolling:touch}.contact-sheet__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:10px}.contact-sheet__title{font-family:Outfit,sans-serif;font-weight:600;font-size:1.35rem;color:var(--white);letter-spacing:-.03em;margin:0}.contact-sheet__close{width:40px;height:40px;flex-shrink:0;border-radius:11px;border:1px solid var(--border2);background:var(--surface);color:var(--text-2);cursor:pointer;display:grid;place-items:center;font-size:1.2rem;transition:background .18s,color .18s}.contact-sheet__close:hover{background:var(--surface2);color:var(--white)}.contact-sheet__lead{font-size:.88rem;color:var(--text-2);line-height:1.55;margin:0 0 20px;font-weight:300}.about-tech-wrap{margin-top:56px;padding:32px 28px 36px;border-radius:22px;border:1px solid var(--border2);background:var(--surface);max-width:100%}.about-tech-head{margin-bottom:28px}.about-tech-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--blue);margin:0 0 10px}.about-tech-eyebrow i{font-size:.95rem}.about-tech-h2{font-family:Outfit,sans-serif;font-size:clamp(1.25rem,2.5vw,1.65rem);font-weight:600;color:var(--text);letter-spacing:-.03em;margin:0 0 10px}.about-tech-lead{font-size:.88rem;color:var(--text-2);line-height:1.55;margin:0;font-weight:300;max-width:56ch}.about-tech-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px 40px}.about-tech-cat__head{margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border2)}.about-tech-cat__title{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--blue-light);margin:0}.about-tech-tags{display:flex;flex-wrap:wrap;gap:8px}.about-tech-tag{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:8px 12px;border-radius:10px;border:1px solid var(--border2);background:var(--card);color:var(--text-2);font-weight:500;transition:border-color .18s,color .18s,background .18s}.about-tech-tag:hover{border-color:#3a6eff66;color:var(--blue-light);background:#3a6eff0f}@media(max-width:720px){.about-tech-wrap{padding:24px 18px 28px;margin-top:40px}.about-tech-grid{grid-template-columns:1fr;gap:24px}}.contact-form{display:flex;flex-direction:column;gap:16px;text-align:left}.contact-form--modal{gap:14px}.contact-form__label{display:block;margin:0 0 6px;font-size:.78rem;font-weight:500;color:var(--text-2);letter-spacing:.02em}.contact-form__field input,.contact-form__field select,.contact-form__field textarea{width:100%;font-family:Figtree,sans-serif;font-size:.92rem;color:var(--text);background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:11px 14px;transition:border-color .18s,box-shadow .18s}.contact-form__field input::placeholder,.contact-form__field select::placeholder,.contact-form__field textarea::placeholder{color:var(--text-3)}.contact-form__field input:focus,.contact-form__field select:focus,.contact-form__field textarea:focus{outline:none;border-color:var(--border);box-shadow:0 0 0 3px var(--blue-subtle)}.contact-form__field textarea{resize:vertical;min-height:120px;line-height:1.55}.contact-form__select-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 14px}.contact-form__field--full{grid-column:1 / -1}.contact-form__field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-2) 50%),linear-gradient(135deg,var(--text-2) 50%,transparent 50%);background-position:calc(100% - 20px) calc(50% - 2px),calc(100% - 14px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:34px}.contact-form__submit{margin-top:4px;align-self:flex-start;border:none;cursor:pointer}.contact-form__submit:disabled{cursor:not-allowed;opacity:.7}.contact-form__status{margin:0;font-size:.82rem;line-height:1.45;font-weight:400}.contact-form__status.is-pending{color:var(--text-2)}.contact-form__status.is-success{color:#74f2bd}.contact-form__status.is-error{color:#ff8c93}.contact-form__note{font-size:.76rem;color:var(--text-3);line-height:1.5;margin:12px 0 0;font-weight:300}.contact-form__note a{color:var(--blue-light);text-decoration:none}.contact-form__note a:hover{text-decoration:underline}.contact-form__note--compact{margin-top:8px;margin-bottom:0}.cta-row--stack{flex-wrap:wrap;justify-content:center}@media(max-width:600px){.contact-form__select-grid{grid-template-columns:1fr;gap:12px}.contact-sheet__inner{padding:10px 18px 20px}}@media(prefers-reduced-motion:reduce){.contact-sheet,.contact-sheet__panel{transition:none}.contact-sheet.is-open .contact-sheet__panel{transform:translateY(0)}}
