:root{--s-hero:#eeeef4;--s-proj:#f8f8fa;--s-skills:#13131f;--s-about:#f2f2f0;--s-contact:#1e2248;--ink:#0d0d14;--ink2:#2a2a3d;--ink3:#6b6b80;--ink4:#a0a0b8;--rule:#d0d0de;--rule2:#e4e4ee;--ind:#2d3561;--ind2:#4a5090;--ind3:#8b92c9;--ind4:#c8cbea;--ind5:#eaeaf8;--fe:#3b82f6;--be:#10b981;--tl:#f59e0b;--head:"Outfit",sans-serif;--body:"Inter",sans-serif;--mono:"IBM Plex Mono",monospace;--nav-bg:rgba(238,238,244,.94);--hero-bg:#eeeef4;--dm-transition:background .3s,color .3s,border-color .3s}body.dark{--s-hero:#0e0e18;--s-proj:#11111e;--s-skills:#080812;--s-about:#0d0d1a;--s-contact:#0a0a14;--ink:#e8e8f4;--ink2:#c8c8e0;--ink3:#8888aa;--ink4:#5a5a7a;--rule:#2a2a42;--rule2:#1e1e32;--ind:#7b84d4;--ind2:#9098e0;--ind3:#5a62b0;--ind4:#2d3168;--ind5:#12142a;--nav-bg:rgba(14,14,24,.94)}body.dark #hero:before{opacity:.15}body.dark .ab-img{background:#1a1a2e}body.dark .ab-letter{color:#1e1e38}body.dark .pc{background:var(--s-proj)}body.dark .pc:hover{background:#18182c}body.dark .arch,body.dark .arch:before,body.dark .process,body.dark .ps{background:var(--ind5)}body.dark .proc-grid{background:var(--ind4)}body.dark nav{background:var(--nav-bg)}body.dark .h-sys,body.dark .h-sys:before{background:var(--ind5)}body.dark .now-b{background:var(--s-hero)}body.dark .chip{background:var(--ind5);color:var(--ind2)}body.dark .chip:hover{background:var(--ind);color:#fff}body.dark .ab-facts,body.dark .fact{border-color:var(--rule)}body.dark .ab-box{background:var(--ind5);border-color:var(--ind4)}body.dark .pf-vn{-webkit-text-stroke:1px rgba(139,146,201,.18)}body.dark .exp-item{border-color:var(--rule);background:var(--ind5)}body.dark .exp-company{color:var(--ink)}body.dark .exp-role{color:var(--ink2)}body.dark .exp-meta{color:var(--ink3)}body.dark .exp-badge{background:var(--ind4);color:var(--ind2)}body.dark .h-role{background:linear-gradient(135deg,var(--ink) 0,var(--ind2) 50%,#a0a8d8 100%);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;animation:roleGrad 6s ease infinite}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--s-hero);color:var(--ink);font-family:var(--body);overflow-x:hidden;cursor:none;font-size:15px;line-height:1.6;transition:var(--dm-transition)}#prog{position:fixed;top:0;left:0;z-index:999;height:2px;width:0;background:linear-gradient(90deg,var(--ind),var(--ind3));pointer-events:none}#cur{width:10px;height:10px;border-radius:50%;background:var(--ind);z-index:9999;transition:width .15s,height .15s,background .2s}#cur,#curR{position:fixed;pointer-events:none;transform:translate(-50%,-50%)}#curR{width:36px;height:36px;border:1.5px solid var(--ind3);border-radius:50%;z-index:9998;transition:width .2s,height .2s,border-color .2s;opacity:.6}.hov #cur{transform:translate(-50%,-50%) scale(1.7);background:var(--ind2)}.hov #curR{width:56px;height:56px;border-color:rgba(45,53,97,.18)}nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 28px;height:44px;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--rule2);font-family:var(--mono);font-size:11px;gap:24px;transition:var(--dm-transition)}.nb,nav{display:flex;align-items:center}.nb{gap:6px;text-decoration:none;color:var(--ink)}.nb-name{font-weight:600;font-family:var(--head);font-size:13px}.nb-ver{color:var(--ink4);font-size:10px}.nl{display:flex;gap:2px;margin-left:4px}.nl a{color:var(--ink3);text-decoration:none;padding:4px 10px;border-radius:4px;font-size:11px;transition:color .2s,background .2s}.nl a:hover{color:var(--ink);background:var(--rule2)}.nr{margin-left:auto;display:flex;align-items:center;gap:16px}.nr-hash{color:var(--ink4)}.nr-hash b{color:var(--ind)}.nr-avail{display:flex;align-items:center;gap:5px;color:var(--ink3)}.adot{width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}#dm-toggle{background:none;border:1px solid var(--rule);color:var(--ink3);cursor:none;padding:3px 8px;border-radius:4px;font-size:13px;transition:all .2s}#dm-toggle:hover{border-color:var(--ind3);color:var(--ink)}#hero{position:relative;min-height:100vh;background:var(--s-hero);overflow:hidden;padding-top:44px;display:flex;flex-direction:column}#hero canvas,#hero:before{position:absolute;inset:0;pointer-events:none}#hero:before{content:"";background:radial-gradient(ellipse 80% 60% at 60% 40%,rgba(45,53,97,.07) 0,transparent 70%)}.h-wm{bottom:-40px;left:-20px;font-family:var(--head);font-size:clamp(120px,18vw,220px);font-weight:900;color:var(--ind);opacity:.04;line-height:1;letter-spacing:-.04em;white-space:nowrap}.h-orb,.h-wm{position:absolute;pointer-events:none}.h-orb{border-radius:50%;filter:blur(60px);z-index:1}.h-orb1{width:420px;height:420px;background:radial-gradient(circle,rgba(74,80,144,.1) 0,transparent 70%);top:-80px;left:-100px;animation:orbFloat1 18s ease-in-out infinite}.h-orb2{width:320px;height:320px;background:radial-gradient(circle,rgba(59,130,246,.07) 0,transparent 70%);top:30%;right:8%;animation:orbFloat2 22s ease-in-out infinite}.h-orb3{width:240px;height:240px;background:radial-gradient(circle,rgba(139,146,201,.09) 0,transparent 70%);bottom:15%;left:35%;animation:orbFloat3 16s ease-in-out infinite}@keyframes orbFloat1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,30px) scale(1.08)}66%{transform:translate(-20px,50px) scale(.95)}}@keyframes orbFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-30px,40px) scale(1.12)}}@keyframes orbFloat3{0%,to{transform:translate(0)}40%{transform:translate(25px,-20px)}70%{transform:translate(-15px,15px)}}.h-body{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;flex:1 1}.h-left{padding:72px 56px 60px 60px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid var(--rule2)}.h-kicker{font-family:var(--mono);font-size:11px;color:var(--ink3);letter-spacing:.12em;text-transform:lowercase;margin-bottom:28px}.acc{color:var(--ind)}.h-name{font-family:var(--head);font-weight:900;line-height:.9;letter-spacing:-.04em}.h-name .n1{color:var(--ink)}.h-name .n1,.h-name .n2{display:block;font-size:clamp(74px,13vw,196px)}.h-name .n2{color:transparent;-webkit-text-stroke:2.5px var(--ind);margin-left:.06em;transition:color .3s,-webkit-text-stroke .3s;min-height:1.1em}.h-name .n2:hover{color:var(--ind);-webkit-text-stroke:none}.h-cursor{display:inline-block;color:var(--ind);font-weight:300;animation:none;margin-left:1px}.h-right{padding:72px 60px 60px 56px;display:flex;flex-direction:column;justify-content:center;gap:20px}.h-role{background:linear-gradient(135deg,var(--ink) 0,var(--ind2) 50%,var(--ind3) 100%);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:roleGrad 6s ease infinite;font-family:var(--head);font-weight:700;font-size:clamp(18px,2.4vw,32px);line-height:1.2;margin-bottom:16px;letter-spacing:-.02em}@keyframes roleGrad{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.h-bio{color:var(--ink3);font-size:14px;line-height:1.7;max-width:480px}.h-bio strong{color:var(--ink2);font-weight:500}.h-sys{background:var(--ind5);border:1px solid var(--ind4);border-radius:8px;padding:14px 18px;font-family:var(--mono);font-size:11.5px;display:flex;flex-direction:column;gap:6px;transition:border-color .3s,box-shadow .3s}.h-sys:hover{border-color:var(--ind3);box-shadow:0 0 0 1px var(--ind4),0 4px 24px rgba(45,53,97,.08)}.h-sys .sl{opacity:0;animation:sysLineIn .4s ease forwards}.h-sys .sl:first-child{animation-delay:.7s}.h-sys .sl:nth-child(2){animation-delay:1.02s}.h-sys .sl:nth-child(3){animation-delay:1.34s}.h-sys .sl:nth-child(4){animation-delay:1.66s}@keyframes sysLineIn{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}.h-sys-uptime{opacity:1!important;animation:none!important;border-top:1px solid var(--ind4);margin-top:6px;padding-top:6px}.sl{display:flex;gap:12px}.sk{color:var(--ink4)}.sv{color:var(--ink2)}.sv.ok{color:#22c55e}.sv.act{color:var(--ind2)}.h-rule{height:1px;background:var(--rule2)}.h-cta{display:flex;gap:12px}.btn-p,.h-cta{align-items:center}.btn-p{font-family:var(--head);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--ind);padding:14px 32px;text-decoration:none;position:relative;overflow:hidden;display:inline-flex;gap:8px;transition:transform .2s,box-shadow .2s;border:1px solid transparent;isolation:isolate}.btn-p:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--ind2),var(--ind));opacity:0;transition:opacity .25s;z-index:0}.btn-p:after{content:"→";font-size:13px;transform:translateX(-4px);opacity:0;transition:transform .22s,opacity .22s}.btn-p:after,.btn-p>*{position:relative;z-index:1}.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(45,53,97,.28),0 2px 8px rgba(45,53,97,.15)}.btn-p:hover:before{opacity:1}.btn-p:hover:after{transform:translateX(0);opacity:1}.btn-g{color:var(--ink3);text-decoration:none;font-size:13px;transition:color .2s}.btn-g:hover{color:var(--ink)}.h-bar{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--rule2)}.hb{padding:16px 24px;border-right:1px solid var(--rule2);opacity:0;animation:fadeup .5s ease forwards}.hb:first-child{animation-delay:.55s}.hb:nth-child(2){animation-delay:.65s}.hb:nth-child(3){animation-delay:.75s}.hb:nth-child(4){animation-delay:.85s}.hb:nth-child(5){animation-delay:.95s}.hb:last-child{border-right:none}.hb-k{font-family:var(--mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink4);margin-bottom:4px}.hb-v{font-family:var(--head);font-size:16px;font-weight:700;color:var(--ink)}.hb-v.ind{color:var(--ind)}@keyframes fadeup{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}#now{background:var(--ind5);border-bottom:1px solid var(--ind4);display:grid;grid-template-columns:180px 1fr;position:relative;overflow:hidden}#now:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(45,53,97,.04) 30%,rgba(74,80,144,.07) 60%,transparent);pointer-events:none}#now:after{content:"";right:0;height:1px;background:linear-gradient(90deg,var(--ind3),var(--ind4),transparent)}#now:after,.now-beam{position:absolute;bottom:0;left:0}.now-beam{top:0;width:60px;background:linear-gradient(90deg,transparent,rgba(74,80,144,.12),transparent);pointer-events:none;animation:nowscan 4s ease-in-out infinite}@keyframes nowscan{0%{transform:translateX(-100%);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateX(200%);opacity:0}}.now-s{padding:22px 24px;border-right:1px solid var(--ind4);display:flex;flex-direction:column;justify-content:center;gap:5px;background:rgba(45,53,97,.03)}.now-ey{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ind2);display:flex;align-items:center;gap:7px}.pdot{width:7px;height:7px;background:#4ade80;border-radius:50%;animation:blink 2s infinite;box-shadow:0 0 6px #4ade80}@keyframes blink{0%,to{opacity:1}50%{opacity:.25}}.now-sub{font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--ind3)}.now-b{padding:22px 40px;display:flex;align-items:center;justify-content:space-between;gap:32px;position:relative}.now-main{flex:1 1;min-width:0}.now-t{font-family:var(--head);font-weight:700;font-size:clamp(15px,1.6vw,22px);color:var(--ink);letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-d{font-family:var(--mono);font-size:10px;color:var(--ind3);margin-top:3px;letter-spacing:.05em}.now-cs{display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0}.chip{font-family:var(--mono);font-size:9px;letter-spacing:.06em;color:var(--ind2);border:1px solid var(--ind4);padding:4px 10px;background:#fff;transition:background .2s,color .2s,border-color .2s,transform .15s;cursor:default}.chip:hover{background:var(--ind);color:#fff;border-color:var(--ind);transform:translateY(-1px)}.sec{padding:100px 60px}.sec-hd{display:flex;align-items:baseline;gap:20px;margin-bottom:56px}.sec-n{font-family:var(--mono);font-size:11px;color:var(--ink4)}.sec-t{font-family:var(--head);font-size:clamp(32px,4vw,52px);font-weight:800;color:var(--ink);letter-spacing:-.02em}.sec-t em{color:var(--ind);font-style:normal}.sec-a{font-family:var(--mono);font-size:11px;color:var(--ink4);margin-left:auto}.rev{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}.rev.visible{opacity:1;transform:none}.pf{display:grid;grid-template-columns:1fr 1fr;min-height:480px;border:1px solid var(--rule2);border-radius:12px;overflow:hidden;margin-bottom:32px}.pf-info{padding:52px 56px;display:flex;flex-direction:column;gap:20px;background:var(--s-proj)}.pf-top{display:flex;align-items:center;gap:16px}.pf-badge{color:var(--ind);letter-spacing:.12em;background:var(--ind5);padding:3px 10px;border-radius:20px}.pf-badge,.pf-id{font-family:var(--mono);font-size:10px}.pf-id{color:var(--ink4)}.pf-title{font-family:var(--head);font-size:clamp(24px,2.5vw,36px);font-weight:800;line-height:1.15;color:var(--ink);letter-spacing:-.02em}.pf-title em{color:var(--ind);font-style:normal}.pf-sub{font-size:13px;color:var(--ink3)}.pf-desc{font-size:13.5px;color:var(--ink2);line-height:1.7}.arch{background:var(--ind5);border-radius:8px;padding:14px 16px;flex-direction:column}.ar,.arch{display:flex;gap:8px}.ar{align-items:center;flex-wrap:wrap}.ab-box{font-family:var(--mono);font-size:10.5px;background:rgba(255,255,255,.7);border:1px solid var(--rule);padding:3px 9px;border-radius:4px;color:var(--ink2)}.ab-box.hi{background:var(--ind);color:#fff;border-color:var(--ind)}.aa{font-size:10px}.aa,.al{color:var(--ink4);font-family:var(--mono)}.al{font-size:9px;letter-spacing:.12em;margin-left:auto}.pf-tags{display:flex;gap:6px;flex-wrap:wrap}.ptag{font-family:var(--mono);font-size:10px;color:var(--ink3);background:var(--rule2);padding:3px 8px;border-radius:4px}.pf-panel{display:flex;flex-direction:column;border-left:1px solid var(--rule2)}.pf-vis{flex:1 1;position:relative;overflow:hidden}.pf-img-slide,.pf-img-track{position:absolute;inset:0}.pf-img-slide{opacity:0;transition:opacity .5s;display:flex;align-items:center;justify-content:center}.pf-img-slide.active{opacity:1}.pf-img-slide.exit{opacity:0}.proj-visual{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pf-vc{position:absolute;bottom:12px;right:14px;font-family:var(--mono);font-size:9px;color:rgba(0,0,0,.3);letter-spacing:.12em}.pf-dots{display:flex;gap:6px;justify-content:center;padding:12px;background:var(--s-proj);border-top:1px solid var(--rule2)}.pf-dot{width:6px;height:6px;border-radius:50%;background:var(--ind4);cursor:none;transition:background .2s,transform .2s}.pf-dot.active{background:var(--ind);transform:scale(1.3)}@keyframes featuredIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pf.animating-in{animation:featuredIn .45s ease forwards}.pg{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px}.pc{display:block;opacity:1;visibility:visible;border:1px solid var(--rule2);border-radius:10px;padding:28px;cursor:none;transition:border-color .25s,background .25s,transform .25s;background:var(--s-proj)}.pc:hover{border-color:var(--ind3);transform:translateY(-3px)}.pc.active{border-color:var(--ind);background:var(--ind5)}.pc-selected{outline:2px solid var(--ind)}.pc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.pc-vis{width:52px;height:52px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:900;font-size:22px}.pc-n{font-family:var(--mono);font-size:9px;color:var(--ink4)}.pc-title{font-family:var(--head);font-size:17px;font-weight:700;color:var(--ink);margin-bottom:6px}.pc-title em{color:var(--ind);font-style:normal}.pc-sub{font-size:12px;color:var(--ink3);line-height:1.5}.pc-foot{margin-top:16px;display:flex;gap:6px;flex-wrap:wrap}.ptag-s{font-family:var(--mono);font-size:9.5px;color:var(--ink4);background:var(--rule2);padding:2px 7px;border-radius:3px}#skills{background:var(--s-skills)}#skills .sec-t{color:#e8e8f4}#skills .sec-a,#skills .sec-n{color:#5a5a7a}.sk-layout{display:grid;grid-template-columns:240px 1fr;grid-gap:60px;gap:60px;align-items:start}.sk-lede{font-family:var(--head);font-size:22px;font-weight:700;color:#e8e8f4;line-height:1.3}.sk-sublede{font-family:var(--mono);font-size:11px;color:#5a5a7a;line-height:1.8}.sk-cats{display:flex;flex-direction:column;gap:28px}.scat-hd{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#8888aa;margin-bottom:12px}.scat-bar{width:20px;height:2px}.cat-fe .scat-bar{background:var(--fe)}.cat-be .scat-bar{background:var(--be)}.cat-tl .scat-bar{background:var(--tl)}.spills{flex-wrap:wrap;gap:8px}.sp,.spills{display:flex}.sp{align-items:center;gap:7px;background:#1a1a2e;border:1px solid #2a2a42;border-radius:6px;padding:7px 12px;font-size:12px;color:#c8c8e0;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease;cursor:default}.sp:hover{border-color:#4a4a70;background:#20203a;transform:translateY(-3px) scale(1.04);box-shadow:0 6px 20px rgba(0,0,0,.12)}.sp.hot{border-color:#2d3561}.sp.hot:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 8px 24px rgba(0,0,0,.15)}.cat-fe .sp:hover{border-color:var(--fe);background:rgba(59,130,246,.07)}.cat-be .sp:hover{border-color:var(--be);background:rgba(16,185,129,.07)}.cat-tl .sp:hover{border-color:var(--tl);background:rgba(245,158,11,.07)}.si{display:flex;align-items:center;justify-content:center}.si,.si svg{width:16px;height:16px}#about{background:var(--s-about)}.ab-grid{display:grid;grid-template-columns:1fr 1.4fr;grid-gap:80px;gap:80px;align-items:start}.ab-img{background:#e8e8f0;border-radius:12px;aspect-ratio:3/4;position:relative;overflow:hidden}.ab-img canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.ab-letter{position:absolute;bottom:20px;left:24px;font-family:var(--head);font-size:clamp(80px,12vw,130px);font-weight:900;color:rgba(45,53,97,.08);line-height:1;pointer-events:none;letter-spacing:-.04em}.ab-foot{position:absolute;bottom:16px;right:20px;font-family:var(--mono);font-size:10px;color:var(--ink4);text-align:right;display:flex;flex-direction:column;gap:2px}.ab-intro{font-family:var(--head);font-size:clamp(22px,2.5vw,30px);font-weight:700;line-height:1.25;color:var(--ink);margin-bottom:16px}.ab-intro span{color:var(--ind)}.ab-body{font-size:14px;color:var(--ink3);line-height:1.8;margin-bottom:28px}.ab-body em{color:var(--ind2);font-style:italic}.ab-facts{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--rule2);border-radius:8px;overflow:hidden;margin-bottom:28px}.fact{padding:14px 18px;border-right:1px solid var(--rule2);border-bottom:1px solid var(--rule2)}.fact:nth-child(2n){border-right:none}.fact:nth-last-child(-n+2){border-bottom:none}.fk{font-family:var(--mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink4);margin-bottom:4px}.fv{font-size:13px;font-weight:500;color:var(--ink)}.exp-section{margin-top:36px}.exp-section-label{font-family:var(--mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink4);margin-bottom:14px}.exp-list{display:flex;flex-direction:column;gap:10px}.exp-item{display:grid;grid-template-columns:auto 1fr auto;align-items:start;grid-gap:14px;gap:14px;padding:14px 16px;border:1px solid var(--rule2);border-radius:8px;background:var(--s-about);transition:border-color .2s}.exp-item:hover{border-color:var(--ind3)}.exp-logo{width:36px;height:36px;border-radius:6px;background:var(--rule2);display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:13px;color:var(--ind);overflow:hidden;flex-shrink:0}.exp-logo img{width:100%;height:100%;object-fit:contain}.exp-body{display:flex;flex-direction:column;gap:2px}.exp-company{font-family:var(--head);font-size:14px;font-weight:700;color:var(--ink)}.exp-role{font-size:12.5px;color:var(--ink2)}.exp-meta{font-family:var(--mono);font-size:10px;color:var(--ink4);margin-top:2px}.exp-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.exp-dates{font-size:10px;color:var(--ink4);white-space:nowrap}.exp-badge,.exp-dates{font-family:var(--mono)}.exp-badge{font-size:9px;padding:2px 8px;border-radius:20px;background:rgba(45,53,97,.1);color:var(--ind)}.process{background:var(--ind5);border-radius:10px;padding:24px;margin-top:32px}.proc-title{font-family:var(--mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink4);margin-bottom:16px}.proc-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:2px;gap:2px;background:var(--rule2);border-radius:6px;overflow:hidden}.ps{padding:16px;background:var(--s-about)}.ps-n{font-family:var(--mono);font-size:10px;color:var(--ind);margin-bottom:6px}.ps-t{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px}.ps-d{font-size:12px;color:var(--ink3);line-height:1.5}#contact{display:grid;grid-template-columns:1fr 1fr;background:var(--s-contact)}.ct-l{border-right:1px solid rgba(255,255,255,.09);justify-content:space-between}.ct-l,.ct-r{padding:100px 60px;display:flex;flex-direction:column}.ct-r{justify-content:center;gap:24px}.ct-ey{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.35);margin-bottom:24px}.ct-hd{font-family:var(--head);font-size:clamp(40px,5vw,72px);font-weight:900;color:#fff;line-height:1;letter-spacing:-.03em}.ct-hd em{color:var(--ind3);font-style:normal}.ct-sub{font-size:14px;color:rgba(255,255,255,.5)}.ct-socs{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.soc{font-family:var(--mono);font-size:11px;padding:5px 12px;border-radius:4px;transition:all .2s}.soc:hover{border-color:rgba(255,255,255,.35);color:rgba(255,255,255,.8)}.ct-elbl{font-family:var(--mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.3)}.ct-eml{font-family:var(--head);font-size:clamp(16px,2vw,22px);font-weight:700;color:#fff;text-decoration:none}.ct-eml:hover{color:var(--ind3)}.btn-ct{background:var(--ind);color:#fff;text-decoration:none;padding:13px 28px;border-radius:6px;font-size:13px;font-weight:600;transition:background .2s;display:inline-block}.btn-ct:hover{background:var(--ind2)}.ct-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:16px 18px;font-family:var(--mono);font-size:11px;display:flex;flex-direction:column;gap:7px}.ct-stat .sl{display:flex;gap:12px}.ct-stat .k{color:rgba(255,255,255,.3)}.ct-stat .v{color:rgba(255,255,255,.7)}.ct-stat .v.ok{color:#22c55e}.foot{background:var(--s-contact);border-top:1px solid rgba(255,255,255,.06);overflow:hidden;padding:0;margin:0}.foot-marquee{overflow:hidden;padding:14px 0;mask-image:linear-gradient(90deg,transparent,black 5%,black 95%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,black 5%,black 95%,transparent)}.foot-marquee-track{display:flex;animation:marqueeScroll 28s linear infinite;width:max-content}.foot-marquee:hover .foot-marquee-track{animation-play-state:paused}.foot-marquee-item{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.1);padding:0 28px;flex-shrink:0}.foot-marquee-item:after{content:"·";margin-left:28px;opacity:.3}@keyframes marqueeScroll{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.ct-hd .word{display:inline-block;opacity:0;transform:translateY(50px) rotate(2deg);animation:wordRise .65s cubic-bezier(.16,1,.3,1) forwards}.ct-hd .word:first-child{animation-delay:.05s}.ct-hd .word:nth-child(2){animation-delay:.14s}.ct-hd .word:nth-child(3){animation-delay:.23s}.ct-hd .word:nth-child(4){animation-delay:.32s}.ct-hd .word:nth-child(5){animation-delay:.41s}@keyframes wordRise{to{opacity:1;transform:translateY(0) rotate(0deg)}}@media(max-width:960px){.nr{display:none}.h-body{grid-template-columns:1fr;padding:56px 28px 0}.h-right{border-left:none;border-top:1px solid var(--rule);padding:36px 0 40px}.h-bar{grid-template-columns:1fr 1fr}.hb:nth-child(2n){border-right:none}.hb:nth-child(n+3){border-top:1px solid var(--rule)}#now{grid-template-columns:1fr}.now-s{border-right:none;border-bottom:1px solid var(--ind4)}.now-b{flex-direction:column;align-items:flex-start;padding:20px 28px}.sec{padding:72px 28px}#projects .sec-hd{padding:48px 28px 20px}.pf{grid-template-columns:1fr}.pf-info{padding:40px 28px}.pf-vis{min-height:260px}.pg,.sk-layout{grid-template-columns:1fr}.sk-layout{gap:40px}#contact,.ab-grid{grid-template-columns:1fr}.ct-l{border-right:none;border-bottom:1px solid rgba(255,255,255,.09)}.ct-l,.ct-r{padding:60px 28px}.proc-grid{grid-template-columns:1fr}}@media(max-width:768px){.foot-marquee{padding:10px 0}}@media(max-width:600px){.h-bar{grid-template-columns:1fr}.hb{border-right:none!important;border-bottom:1px solid var(--rule)}.hb:last-child{border-bottom:none}}.soc{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;border-radius:8px;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.4);text-decoration:none;transition:border-color .2s,color .2s,transform .2s,box-shadow .2s}.soc svg{width:16px;height:16px;fill:currentColor;transition:transform .2s}.soc:hover{border-color:rgba(139,146,201,.5);color:rgba(255,255,255,.9);transform:translateY(-3px);box-shadow:0 6px 18px rgba(0,0,0,.25)}.soc:hover svg{transform:scale(1.12)}