*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --gold:#c9a55a;--gold2:#e8c878;--gold-glow:rgba(201,165,90,.15);
  --bg:#07070c;--bg2:#0d0d16;--bg3:#121219;
  --fg:#f0ece2;--fg2:rgba(240,236,226,.55);--fg3:rgba(240,236,226,.18);
  --border:rgba(240,236,226,.07);--border-gold:rgba(201,165,90,.2);
}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{background:var(--bg);color:var(--fg);font-family:'Outfit',sans-serif;font-weight:300;cursor:none;overflow-x:hidden;}
/* ── CURTAIN INTRO ── */
#curtain{position:fixed;inset:0;background:#000;z-index:10000;display:flex;align-items:center;justify-content:center;transition:transform 1.1s cubic-bezier(.76,0,.24,1);pointer-events:none;}
#curtain.away{transform:translateY(-100%);}
#curtain-rk{font-family:'Cormorant',serif;font-size:10rem;font-weight:300;font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(201,165,90,.5);letter-spacing:-.02em;animation:ig 2s ease-in-out infinite;}
/* ── SCROLL PROGRESS BAR ── */
#prog{position:fixed;top:0;left:0;width:0%;height:2px;background:linear-gradient(to right,#D4AF37,#fff8dc);z-index:9999;transition:width .08s linear;pointer-events:none;}
#cur,#cur2{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;top:0;left:0;transform:translate(-50%,-50%);}
#cur{width:8px;height:8px;background:var(--gold);box-shadow:0 0 10px rgba(201,165,90,.9),0 0 22px rgba(201,165,90,.4);transition:transform .1s;}
#cur2{width:36px;height:36px;border:1px solid rgba(201,165,90,.4);transition:width .3s,height .3s,border-color .3s;}
#cur2.h{width:54px;height:54px;border-color:var(--gold);}
#trail-canvas{position:fixed;inset:0;pointer-events:none;z-index:9997;}
.particle{position:fixed;border-radius:50%;pointer-events:none;z-index:9998;animation:pb .65s ease-out forwards;}
@keyframes pb{to{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0);}}
.exp-line{transform-origin:top center;transform:scaleY(0);transition:transform 1.8s cubic-bezier(.22,1,.36,1);}
.exp-line.drawn{transform:scaleY(1);}
#stars{position:fixed;inset:0;pointer-events:none;z-index:0;}
nav{position:fixed;top:0;inset-inline:0;z-index:500;height:68px;padding:0 4rem;display:flex;align-items:center;justify-content:space-between;transition:background .4s,border-color .4s;border-bottom:1px solid transparent;}
nav.s{background:rgba(7,7,12,.88);backdrop-filter:blur(20px);border-bottom-color:var(--border);}
.nav-logo{font-family:'Cormorant',serif;font-size:1.55rem;font-weight:400;color:var(--fg);text-decoration:none;letter-spacing:.06em;}
.nav-logo em{color:var(--gold);font-style:italic;}
.nav-links{display:flex;gap:2.4rem;list-style:none;}
.nav-links a{font-size:.67rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg2);text-decoration:none;transition:color .3s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--gold);transition:width .35s;}
.nav-links a:hover{color:var(--gold);}
.nav-links a:hover::after{width:100%;}
.nav-btn{padding:.5rem 1.4rem;border:1px solid var(--border-gold);font-size:.67rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);text-decoration:none;transition:all .35s;display:flex;align-items:center;gap:.5rem;}
.nav-btn:hover{background:var(--gold);color:var(--bg);}
.nav-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 7px #4ade80;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.25;}}
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:0 4rem;padding-top:88px;position:relative;z-index:1;overflow:hidden;}
.hero-tag{display:flex;align-items:center;gap:.8rem;font-family:'DM Mono',monospace;font-size:.63rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:2.5rem;opacity:0;animation:su .7s ease .9s forwards;}
.hero-tag span{width:28px;height:1px;background:var(--gold);}
#tw{min-width:1px;}
.hero-h{font-family:'Cormorant',serif;font-size:clamp(4.5rem,10.5vw,12.5rem);font-weight:300;line-height:.9;letter-spacing:-.02em;margin-bottom:2rem;}
.hr1,.hr2,.hr3{display:block;overflow:hidden;}
.hr1 span,.hr2 span,.hr3 span{display:block;opacity:0;animation:rr .85s cubic-bezier(.77,0,.18,1) forwards;}
.hr1 span{animation-delay:1s;}
.hr2 span{animation-delay:1.15s;font-style:italic;color:transparent;-webkit-text-stroke:1.5px rgba(240,236,226,.2);}
.hr3 span{animation-delay:1.3s;color:var(--gold);font-style:italic;font-size:.6em;}
@keyframes rr{from{opacity:0;transform:translateY(105%);}to{opacity:1;transform:translateY(0);}}
.hero-p{max-width:460px;font-size:1rem;line-height:1.9;color:var(--fg2);margin-bottom:3rem;opacity:0;animation:su .7s ease 1.55s forwards;}
.hero-p strong{color:var(--fg);font-weight:400;}
.hero-ctas{display:flex;align-items:center;gap:2rem;opacity:0;animation:su .7s ease 1.7s forwards;}
.btn-g{padding:.95rem 2.8rem;background:var(--gold);color:var(--bg);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;text-decoration:none;transition:all .35s;position:relative;overflow:hidden;}
.btn-g::before{content:'';position:absolute;inset:0;background:var(--gold2);transform:translateX(-101%);transition:transform .4s;}
.btn-g:hover::before{transform:translateX(0);}
.btn-g:hover{box-shadow:0 14px 40px rgba(201,165,90,.35);transform:translateY(-2px);}
.btn-g span{position:relative;z-index:1;}
.btn-t{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg2);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:.25rem;transition:all .3s;display:flex;align-items:center;gap:.4rem;}
.btn-t:hover{color:var(--fg);border-color:var(--gold);gap:.8rem;}
.hero-float{position:absolute;right:4rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.9rem;opacity:0;animation:sl .8s ease 1.9s forwards;}
@keyframes sl{from{opacity:0;transform:translateY(-50%) translateX(25px);}to{opacity:1;transform:translateY(-50%) translateX(0);}}
.hf-tag{padding:.45rem 1.1rem;border:1px solid var(--border);font-family:'DM Mono',monospace;font-size:.57rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3);background:rgba(7,7,12,.5);backdrop-filter:blur(6px);transition:all .3s;}
.hf-tag::before{content:'';display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--gold);margin-right:.5rem;opacity:.5;}
.hf-tag:hover{color:var(--gold);border-color:var(--border-gold);}
.hero-scroll{position:absolute;bottom:2.5rem;left:4rem;display:flex;align-items:center;gap:.9rem;font-family:'DM Mono',monospace;font-size:.57rem;letter-spacing:.28em;text-transform:uppercase;color:var(--fg3);opacity:0;animation:su .7s ease 2.1s forwards;}
.sw{width:20px;height:32px;border:1px solid var(--fg3);border-radius:10px;display:flex;justify-content:center;padding-top:5px;}
.sw::after{content:'';width:2px;height:6px;background:var(--gold);border-radius:2px;animation:sa 2s ease-in-out infinite;}
@keyframes sa{0%{opacity:1;transform:translateY(0);}80%{opacity:0;transform:translateY(12px);}100%{opacity:0;}}
.hero-bg-num{position:absolute;right:-1rem;bottom:-5rem;font-family:'Cormorant',serif;font-size:32vw;font-weight:300;color:transparent;-webkit-text-stroke:1px rgba(240,236,226,.02);pointer-events:none;line-height:1;}
@keyframes su{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}
.ticker{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.3rem 0;overflow:hidden;position:relative;z-index:1;background:rgba(201,165,90,.015);}
.ticker-track{display:flex;gap:4rem;white-space:nowrap;animation:tk 30s linear infinite;}
.ticker-track span{font-family:'DM Mono',monospace;font-size:.63rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(201,165,90,.28);flex-shrink:0;}
.ticker-track .d{color:var(--gold);font-size:.3rem;}
@keyframes tk{to{transform:translateX(-50%);}}
/* ── TECH STACK MARQUEE ── */
.ts-strip{overflow:hidden;background:#040408;border-top:1px solid rgba(201,165,90,.08);border-bottom:1px solid rgba(201,165,90,.08);padding:.85rem 0;position:relative;z-index:1;}
.ts-strip:hover .ts-track{animation-play-state:paused;}
.ts-track{display:flex;gap:2.8rem;white-space:nowrap;animation:tss 24s linear infinite;}
.ts-track span{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(201,165,90,.32);flex-shrink:0;}
.ts-track .ts-dot{color:var(--gold);opacity:.5;letter-spacing:0;}
@keyframes tss{to{transform:translateX(-50%);}}
.sec{padding:9rem 4rem;position:relative;z-index:1;}
.sec.alt{background:var(--bg2);}
.sec-tag{display:flex;align-items:center;gap:.7rem;font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem;}
.sec-tag::before{content:'';width:22px;height:1px;background:var(--gold);}
.sec-h{font-family:'Cormorant',serif;font-size:clamp(2.8rem,5vw,6rem);font-weight:300;line-height:1.02;}
.sec-h em{font-style:italic;color:var(--gold);}
.sec-h .ghost{color:transparent;-webkit-text-stroke:1px rgba(240,236,226,.15);}
.rv{opacity:0;transform:translateY(40px);transition:opacity .85s ease,transform .85s ease;}
.rv.on{opacity:1;transform:none;}
.rv-l{opacity:0;transform:translateX(-40px);transition:opacity .85s ease,transform .85s ease;}
.rv-l.on{opacity:1;transform:none;}
.rv-r{opacity:0;transform:translateX(40px);transition:opacity .85s ease,transform .85s ease;}
.rv-r.on{opacity:1;transform:none;}
.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:7rem;align-items:center;margin-top:5rem;}
.about-frame{position:relative;}
.af-box{aspect-ratio:4/5;background:var(--bg3);border:1px solid var(--border);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.af-box::before{content:'';position:absolute;inset:12px;border:1px solid rgba(201,165,90,.06);pointer-events:none;z-index:1;}
.af-corner{position:absolute;top:-.8rem;left:-.8rem;width:36px;height:36px;border-top:1px solid var(--gold);border-left:1px solid var(--gold);opacity:.6;z-index:2;}
.af-code{position:absolute;inset:0;padding:2rem;font-family:'DM Mono',monospace;font-size:.58rem;line-height:1.75;color:rgba(201,165,90,.1);white-space:pre;overflow:hidden;animation:cs 22s linear infinite;}
@keyframes cs{to{transform:translateY(-50%);}}
.af-overlay{position:absolute;inset:0;background:radial-gradient(circle,rgba(7,7,12,.2),rgba(7,7,12,.65));}
.af-init{position:relative;z-index:2;font-family:'Cormorant',serif;font-size:9rem;font-weight:300;font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(201,165,90,.3);animation:ig 5s ease-in-out infinite;}
@keyframes ig{0%,100%{filter:drop-shadow(0 0 30px rgba(201,165,90,.1));}50%{filter:drop-shadow(0 0 60px rgba(201,165,90,.22));}}
.af-badge{position:absolute;bottom:-1.3rem;right:-1.3rem;background:var(--bg2);border:1px solid var(--border-gold);padding:1.2rem 1.8rem;}
.af-n{font-family:'Cormorant',serif;font-size:2.4rem;font-weight:300;color:var(--gold);display:block;line-height:1;}
.af-l{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg3);}
.about-text .sec-h{margin-bottom:2.5rem;}
.about-p{font-size:.96rem;line-height:1.95;color:var(--fg2);margin-bottom:1.1rem;}
.about-p strong{color:var(--fg);font-weight:400;}
.pills{display:flex;flex-wrap:wrap;gap:.6rem;margin:2rem 0;}
.pill{padding:.35rem 1rem;border:1px solid var(--border);font-family:'DM Mono',monospace;font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fg3);transition:all .3s;cursor:default;}
.pill:hover{border-color:var(--border-gold);color:var(--gold);background:var(--gold-glow);}
.stats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);margin-top:2.5rem;}
.stat{padding:1.5rem 1.1rem;border-right:1px solid var(--border);transition:background .3s;}
.stat:last-child{border-right:none;}
.stat:hover{background:var(--gold-glow);}
.stat-n{font-family:'Cormorant',serif;font-size:2.6rem;font-weight:300;color:var(--gold);display:block;line-height:1;margin-bottom:.25rem;}
.stat-l{font-family:'DM Mono',monospace;font-size:.53rem;letter-spacing:.16em;text-transform:uppercase;color:var(--fg3);}
.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:4.5rem;}
.sk-list{display:flex;flex-direction:column;gap:2rem;}
.sk-item{opacity:0;transform:translateX(-20px);transition:opacity .7s,transform .7s;}
.sk-item.on{opacity:1;transform:none;}
.sk-head{display:flex;justify-content:space-between;margin-bottom:.4rem;}
.sk-name{font-family:'Cormorant',serif;font-size:1.25rem;font-weight:400;}
.sk-val{font-family:'DM Mono',monospace;font-size:.63rem;color:var(--gold);}
.sk-desc{font-size:.75rem;color:var(--fg3);margin-bottom:.6rem;line-height:1.6;}
.sk-bar{height:1px;background:rgba(240,236,226,.06);position:relative;}
.sk-bar-fill{height:100%;background:linear-gradient(to right,var(--gold),var(--gold2));position:absolute;left:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform 1.3s cubic-bezier(.77,0,.18,1);box-shadow:0 0 10px rgba(201,165,90,.35);}
.sk-item.on .sk-bar-fill{transform:scaleX(1);}
.sk-dots{display:flex;gap:.3rem;margin-top:.5rem;}
.dot{width:4px;height:4px;border-radius:50%;background:rgba(240,236,226,.08);}
.dot.on{background:var(--gold);}
.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.ti{background:var(--bg2);padding:1.4rem .9rem;display:flex;flex-direction:column;align-items:center;gap:.6rem;transition:background .3s,transform .3s;text-align:center;position:relative;overflow:hidden;}
.ti::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transition:transform .4s;}
.ti:hover{background:rgba(201,165,90,.04);transform:translateY(-2px);}
.ti:hover::after{transform:scaleX(1);}
.ti-ico{font-size:1.5rem;}
.ti-n{font-size:.7rem;font-weight:400;color:var(--fg);}
.ti-lv{font-family:'DM Mono',monospace;font-size:.53rem;letter-spacing:.14em;color:var(--gold);opacity:.5;text-transform:uppercase;}
.proj-sec{padding:9rem 0 9rem 4rem;position:relative;z-index:1;overflow:hidden;}
.proj-head{display:flex;justify-content:space-between;align-items:flex-end;padding-right:4rem;margin-bottom:4.5rem;}
.proj-bignum{font-family:'Cormorant',serif;font-size:5rem;font-weight:300;font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(240,236,226,.12);line-height:1;}
.proj-scroll{display:flex;gap:1.5rem;overflow-x:auto;padding-bottom:1.5rem;padding-right:4rem;scrollbar-width:none;cursor:grab;}
.proj-scroll:active{cursor:grabbing;}
.proj-scroll::-webkit-scrollbar{display:none;}
.pcard{flex:0 0 400px;background:var(--bg3);border:1px solid var(--border);display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:border-color .4s,box-shadow .4s,transform .4s;position:relative;overflow:hidden;cursor:none;}
.pcard:hover{border-color:var(--border-gold);box-shadow:0 18px 55px rgba(201,165,90,.1);}
.cv{height:230px;position:relative;overflow:hidden;flex-shrink:0;}
.cv-num{position:absolute;top:1rem;left:1.2rem;font-family:'DM Mono',monospace;font-size:.56rem;letter-spacing:.22em;color:var(--gold);opacity:.6;z-index:10;}
.cv-ext{position:absolute;top:.8rem;right:.9rem;width:30px;height:30px;border:1px solid rgba(201,165,90,.25);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--fg2);text-decoration:none;background:rgba(7,7,12,.55);backdrop-filter:blur(6px);transition:all .3s;z-index:10;}
.cv-ext:hover{background:var(--gold);color:var(--bg);border-color:var(--gold);}
.cv-gradient{position:absolute;inset:0;bottom:0;}
.cv-fade{position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(to top,var(--bg3),transparent);z-index:5;}
.cb{padding:1.6rem;}
.cb-cat{font-family:'DM Mono',monospace;font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:.6;margin-bottom:.4rem;}
.cb-name{font-family:'Cormorant',serif;font-size:1.8rem;font-weight:400;margin-bottom:.6rem;line-height:1.1;}
.cb-desc{font-size:.8rem;line-height:1.72;color:var(--fg2);font-style:italic;margin-bottom:1.3rem;}
.cb-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.3rem;}
.ctag{padding:.2rem .75rem;border:1px solid var(--border);font-family:'DM Mono',monospace;font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg3);}
.pcard:hover .ctag{border-color:rgba(201,165,90,.16);color:rgba(201,165,90,.5);}
.cb-links{display:flex;gap:1.2rem;align-items:center;}
.clink-a{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(201,165,90,.22);padding-bottom:.18rem;display:flex;align-items:center;gap:.3rem;transition:all .3s;}
.clink-a:hover{gap:.7rem;border-bottom-color:var(--gold);}
.clink-b{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--fg3);text-decoration:none;transition:color .3s;}
.clink-b:hover{color:var(--fg);}
.scroll-nav{display:flex;align-items:center;gap:1.2rem;padding-right:4rem;margin-top:1.5rem;}
.sn-btn{width:28px;height:28px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--fg3);cursor:none;transition:all .3s;}
.sn-btn:hover{border-color:var(--border-gold);color:var(--gold);}
.sn-txt{font-family:'DM Mono',monospace;font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg3);}
/* Aurora */
.cv-aurora{background:#08060a;}
.aurora-nav{position:absolute;top:0;left:0;right:0;padding:.55rem 1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(200,164,90,.08);z-index:6;}
.au-logo{font-family:'Cormorant',serif;font-size:.7rem;letter-spacing:.3em;color:#c9a55a;font-weight:400;}
.au-links{display:flex;gap:.45rem;}
.au-links span{width:18px;height:1.5px;background:rgba(240,236,226,.18);border-radius:1px;}
.aurora-hero{position:absolute;top:1.8rem;left:1rem;z-index:6;}
.au-ey{width:55px;height:1px;background:rgba(201,165,90,.5);margin-bottom:.55rem;}
.au-t{font-family:'Cormorant',serif;font-size:2.5rem;font-weight:300;line-height:.88;color:#f0ece2;letter-spacing:-.02em;}
.au-t.it{color:transparent;-webkit-text-stroke:1px rgba(240,236,226,.25);font-style:italic;}
.au-t.gd{color:#c9a55a;font-style:italic;}
.au-sub{margin-top:.6rem;}
.au-sub span{display:block;width:70px;height:1.5px;background:rgba(240,236,226,.1);border-radius:1px;margin-bottom:.25rem;}
.au-sub span.s{width:45px;}
.au-btns{display:flex;gap:.5rem;margin-top:.6rem;}
.au-b1{width:45px;height:9px;background:#c9a55a;border-radius:1px;}
.au-b2{width:32px;height:9px;border:1px solid rgba(240,236,226,.15);border-radius:1px;}
.au-grd{position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 49px,rgba(201,165,90,.03) 50px);pointer-events:none;z-index:3;}
.au-orb{position:absolute;right:2rem;top:50%;transform:translateY(-50%);width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(201,165,90,.12),transparent);border:1px solid rgba(201,165,90,.1);z-index:4;}
.au-orb::before{content:'';position:absolute;inset:10px;border-radius:50%;border:1px solid rgba(201,165,90,.07);}
.au-bignum{position:absolute;right:-.5rem;bottom:-1.5rem;font-family:'Cormorant',serif;font-size:5.5rem;font-weight:300;color:transparent;-webkit-text-stroke:1px rgba(201,165,90,.04);line-height:1;pointer-events:none;z-index:2;}
/* Pulse */
.cv-pulse{background:#020308;}
.pu-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,255,.02) 1px,transparent 1px);background-size:22px 22px;z-index:1;}
.pu-scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.07) 4px);z-index:2;pointer-events:none;}
.pu-nav{position:absolute;top:0;left:0;right:0;padding:.55rem 1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,255,255,.06);background:rgba(2,3,8,.7);backdrop-filter:blur(4px);z-index:7;}
.pu-logo{font-size:.7rem;letter-spacing:.4em;color:#00ffff;font-weight:700;text-shadow:0 0 8px rgba(0,255,255,.4);}
.pu-live{display:flex;align-items:center;gap:.3rem;font-size:.48rem;letter-spacing:.2em;color:#4ade80;}
.pu-live::before{content:'';width:5px;height:5px;border-radius:50%;background:#4ade80;box-shadow:0 0 5px #4ade80;animation:pulse 1.5s infinite;}
.pu-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-58%);text-align:center;z-index:6;}
.pu-t1{font-size:2.4rem;font-weight:900;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.2);line-height:.88;letter-spacing:.05em;}
.pu-t2{font-size:2.4rem;font-weight:900;color:#00ffff;text-shadow:0 0 12px rgba(0,255,255,.45);line-height:.88;}
.pu-t3{font-size:2.4rem;font-weight:900;color:#ff00ff;text-shadow:0 0 12px rgba(255,0,255,.45);line-height:.88;}
.pu-bars{position:absolute;bottom:0;left:0;right:0;height:50px;display:flex;align-items:flex-end;gap:2px;padding:0 .5rem;z-index:6;}
.pu-bars span{flex:1;border-radius:1px 1px 0 0;min-height:3px;animation:ba 1.1s ease-in-out infinite alternate;}
.pu-bars span:nth-child(odd){background:linear-gradient(to top,#00ffff88,#00ffff22);}
.pu-bars span:nth-child(even){background:linear-gradient(to top,#ff00ff88,#ff00ff22);}
.pu-bars span:nth-child(1){height:55%;animation-delay:.05s;}
.pu-bars span:nth-child(2){height:85%;animation-delay:.1s;}
.pu-bars span:nth-child(3){height:40%;animation-delay:.15s;}
.pu-bars span:nth-child(4){height:70%;animation-delay:.2s;}
.pu-bars span:nth-child(5){height:90%;animation-delay:.25s;}
.pu-bars span:nth-child(6){height:50%;animation-delay:.3s;}
.pu-bars span:nth-child(7){height:75%;animation-delay:.35s;}
.pu-bars span:nth-child(8){height:60%;animation-delay:.4s;}
.pu-bars span:nth-child(9){height:95%;animation-delay:.45s;}
.pu-bars span:nth-child(10){height:45%;animation-delay:.5s;}
.pu-bars span:nth-child(11){height:80%;animation-delay:.55s;}
.pu-bars span:nth-child(12){height:65%;animation-delay:.6s;}
@keyframes ba{from{transform:scaleY(.35);}to{transform:scaleY(1);}}
/* Verdure */
.cv-verdure{background:#faf6ef;}
.vd-left{position:absolute;inset:0 50% 0 0;background:#f2e8d8;padding:1.8rem .8rem .8rem;display:flex;flex-direction:column;justify-content:center;gap:.3rem;z-index:5;}
.vd-tag{width:48px;height:4px;background:rgba(100,75,50,.25);border-radius:2px;margin-bottom:.4rem;}
.vd-h1{font-family:'Cormorant',serif;font-size:.95rem;font-weight:400;color:#1e2a18;line-height:1.1;}
.vd-h1 em{font-style:italic;color:#2d5a2d;}
.vd-h2{font-family:'Cormorant',serif;font-size:.95rem;font-weight:400;color:#1e2a18;line-height:1.1;}
.vd-subs{display:flex;flex-direction:column;gap:.2rem;margin-top:.4rem;}
.vd-subs span{height:2px;background:rgba(30,42,24,.1);border-radius:1px;}
.vd-subs span:first-child{width:65px;}
.vd-subs span:last-child{width:42px;}
.vd-btn{width:52px;height:10px;background:#2d5a2d;border-radius:8px;margin-top:.5rem;}
.vd-right{position:absolute;inset:0 0 0 50%;background:linear-gradient(145deg,#3a6b3a,#4f8a4f,#6aaa6a);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;z-index:5;}
.vd-plate{width:76px;height:76px;border-radius:50%;background:radial-gradient(circle at 30% 28%,#5a9a5a,#2d5a2d);box-shadow:0 8px 22px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;animation:fl 4s ease-in-out infinite;}
@keyframes fl{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
.vd-inner{width:62px;height:62px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:1.3rem;}
.vd-badge{background:rgba(250,246,239,.88);border-radius:20px;padding:.2rem .6rem;font-size:.42rem;letter-spacing:.1em;color:#2d5a2d;font-weight:500;}
.vd-bottom{position:absolute;bottom:0;left:0;right:0;display:flex;z-index:6;background:rgba(22,35,22,.92);}
.vd-tab{flex:1;padding:.42rem .2rem;text-align:center;font-size:.44rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(250,246,239,.35);border-right:1px solid rgba(255,255,255,.05);}
.vd-tab.a{color:#8aab7e;border-top:1px solid #8aab7e;}
.vd-tab:last-child{border-right:none;}
/* Axiom */
.cv-axiom{background:#040611;}
.ax-parts{position:absolute;inset:0;background-image:radial-gradient(rgba(60,120,255,.05) 1px,transparent 1px);background-size:18px 18px;z-index:1;}
.ax-nav{position:absolute;top:0;left:0;right:0;height:20px;padding:0 .8rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.04);background:rgba(4,6,17,.8);z-index:7;}
.ax-logo{font-size:.52rem;font-weight:700;letter-spacing:-.01em;color:#8fa8ff;}
.ax-nls{display:flex;gap:.35rem;}
.ax-nls span{width:16px;height:1.5px;background:rgba(255,255,255,.08);border-radius:1px;}
.ax-cta{width:24px;height:7px;background:#2255ff;border-radius:2px;margin-left:auto;}
.ax-body{position:absolute;top:20px;left:0;right:0;bottom:0;display:grid;grid-template-columns:42px 1fr;z-index:6;}
.ax-side{background:rgba(255,255,255,.015);border-right:1px solid rgba(255,255,255,.035);padding:.4rem .35rem;display:flex;flex-direction:column;gap:.28rem;}
.ax-si{height:5px;background:rgba(255,255,255,.05);border-radius:2px;}
.ax-si.a{background:rgba(40,100,255,.22);border-left:2px solid #2255ff;}
.ax-main{padding:.5rem;}
.ax-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:.28rem;margin-bottom:.45rem;}
.ax-card{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.04);border-radius:2px;padding:.3rem;}
.ax-cn{font-size:.42rem;font-weight:700;color:#c8d0f0;letter-spacing:-.01em;}
.ax-cl{width:100%;height:2px;background:rgba(255,255,255,.05);margin-top:.2rem;border-radius:1px;}
.ax-chart{background:rgba(255,255,255,.018);border:1px solid rgba(255,255,255,.04);height:68px;position:relative;overflow:hidden;padding:.35rem .3rem 0;}
.ax-cl2{position:absolute;left:0;right:0;top:32%;height:1px;background:rgba(80,130,255,.18);}
.ax-bars{position:absolute;bottom:0;left:.3rem;right:.3rem;display:flex;align-items:flex-end;gap:2px;height:52px;}
.ax-bars span{flex:1;border-radius:1px 1px 0 0;min-height:2px;animation:ab 2.2s ease-in-out infinite alternate;}
.ax-bars span:nth-child(odd){background:rgba(55,110,255,.5);}
.ax-bars span:nth-child(even){background:rgba(130,90,255,.4);}
.ax-bars span:nth-child(1){height:52%;}
.ax-bars span:nth-child(2){height:70%;animation-delay:.15s;}
.ax-bars span:nth-child(3){height:42%;animation-delay:.3s;}
.ax-bars span:nth-child(4){height:82%;animation-delay:.45s;}
.ax-bars span:nth-child(5){height:58%;animation-delay:.6s;}
.ax-bars span:nth-child(6){height:88%;animation-delay:.75s;}
.ax-bars span:nth-child(7){height:48%;animation-delay:.9s;}
.ax-bars span:nth-child(8){height:72%;animation-delay:1.05s;}
.ax-bars span:nth-child(9){height:62%;animation-delay:1.2s;}
.ax-bars span:nth-child(10){height:78%;animation-delay:1.35s;}
@keyframes ab{from{transform:scaleY(.4);}to{transform:scaleY(1);}}
.ax-pts{position:absolute;inset:0;pointer-events:none;z-index:2;}
.ax-pts span{position:absolute;width:2px;height:2px;border-radius:50%;background:rgba(100,150,255,.45);animation:pf 3.5s ease-in-out infinite;}
.ax-pts span:nth-child(1){top:18%;left:25%;animation-delay:.4s;}
.ax-pts span:nth-child(2){top:35%;left:72%;animation-delay:1s;}
.ax-pts span:nth-child(3){top:60%;left:42%;animation-delay:1.6s;}
.ax-pts span:nth-child(4){top:75%;left:82%;animation-delay:.7s;}
.ax-pts span:nth-child(5){top:22%;left:88%;animation-delay:2s;}
@keyframes pf{0%,100%{opacity:.4;transform:translateY(0);}50%{opacity:.9;transform:translateY(-7px);}}
/* Solstice */
.cv-solstice{background:#07070b;}
.sl-nav{position:absolute;top:0;left:0;right:0;height:20px;padding:0 .8rem;display:flex;align-items:center;border-bottom:1px solid rgba(240,236,226,.04);z-index:7;}
.sl-logo{font-family:'Cormorant',serif;font-size:.62rem;letter-spacing:.28em;color:#f0ece2;font-weight:300;}
.sl-nls{display:flex;gap:.45rem;margin-left:auto;}
.sl-nls span{width:17px;height:1px;background:rgba(240,236,226,.18);}
.sl-body{position:absolute;top:20px;left:0;right:0;bottom:0;display:grid;grid-template-columns:1fr 1fr;z-index:6;}
.sl-left{padding:.8rem .7rem;display:flex;flex-direction:column;justify-content:center;gap:.28rem;}
.sl-ey{width:26px;height:1px;background:#c9a55a;margin-bottom:.2rem;}
.sl-h1{font-family:'Cormorant',serif;font-size:1rem;font-weight:300;color:#f0ece2;line-height:1.1;}
.sl-h2{font-family:'Cormorant',serif;font-size:1.3rem;font-weight:300;color:#c9a55a;font-style:italic;line-height:1.1;}
.sl-sub{width:55px;height:1.5px;background:rgba(240,236,226,.07);border-radius:1px;}
.sl-btns{display:flex;gap:.4rem;margin-top:.3rem;}
.sl-b1{width:38px;height:9px;background:#c9a55a;border-radius:1px;}
.sl-b2{width:38px;height:9px;border:1px solid rgba(240,236,226,.18);border-radius:1px;}
.sl-right{display:flex;align-items:center;justify-content:center;}
.watch{width:88px;height:88px;border-radius:50%;background:radial-gradient(circle at 30% 28%,#2a2520,#181818);box-shadow:0 0 0 5px rgba(200,164,90,.14),0 0 0 6px rgba(200,164,90,.07),0 8px 28px rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;animation:fl 5s ease-in-out infinite;position:relative;}
.watch-bezel{position:absolute;inset:-4px;border-radius:50%;border:3.5px solid transparent;background:linear-gradient(135deg,#b8893a,#7a5814,#c9a84c,#7a5814) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;}
.watch-dial{width:70px;height:70px;border-radius:50%;background:radial-gradient(circle at 30% 28%,#2d2d2d,#161616);position:relative;display:flex;align-items:center;justify-content:center;}
.wh{position:absolute;left:50%;bottom:50%;transform-origin:bottom;border-radius:2px;}
.wh-h{width:2px;height:20px;background:#c9a55a;transform:translateX(-50%) rotate(120deg);box-shadow:0 0 4px rgba(200,164,90,.5);}
.wh-m{width:1.5px;height:26px;background:#ddd;transform:translateX(-50%) rotate(245deg);opacity:.8;}
.wh-s{width:1px;height:30px;background:#e04040;transform:translateX(-50%) rotate(0deg);}
.watch-center{position:absolute;width:5px;height:5px;border-radius:50%;background:#c9a55a;z-index:5;box-shadow:0 0 5px rgba(200,164,90,.6);}
.sl-grain{position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");z-index:1;}
/* Appointly — blue SaaS booking */
.cv-appointly{background:#040d1e;}
.ap-grad{position:absolute;inset:0;background:linear-gradient(-45deg,#1d4ed8,#2563eb,#4f46e5,#0ea5e9);background-size:400% 400%;animation:gradAp 6s ease infinite;z-index:1;}
@keyframes gradAp{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.ap-nav{position:absolute;top:0;left:0;right:0;padding:.5rem .9rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1);background:rgba(4,13,30,.5);backdrop-filter:blur(6px);z-index:7;}
.ap-logo{font-size:.62rem;font-weight:800;letter-spacing:.06em;color:#fff;}
.ap-dot{display:flex;align-items:center;gap:.3rem;font-size:.47rem;color:#4ade80;}
.ap-dot::before{content:'';width:5px;height:5px;border-radius:50%;background:#4ade80;box-shadow:0 0 6px #4ade80;animation:pulse 2s infinite;}
.ap-hero{position:absolute;top:1.8rem;left:1rem;right:1rem;z-index:6;text-align:center;}
.ap-badge{display:inline-flex;align-items:center;gap:.3rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:.2rem .7rem;font-size:.45rem;color:#fff;letter-spacing:.08em;margin-bottom:.5rem;}
.ap-h1{font-size:1.15rem;font-weight:900;color:#fff;line-height:1.15;letter-spacing:-.02em;}
.ap-h1 span{color:#93c5fd;}
.ap-sub{font-size:.48rem;color:rgba(255,255,255,.55);margin:.35rem 0 .55rem;letter-spacing:.05em;}
.ap-btns{display:flex;gap:.4rem;justify-content:center;}
.ap-b1{width:50px;height:9px;background:#fff;border-radius:5px;}
.ap-b2{width:36px;height:9px;border:1px solid rgba(255,255,255,.35);border-radius:5px;}
.ap-cards{position:absolute;bottom:.5rem;left:.8rem;right:.8rem;display:grid;grid-template-columns:repeat(4,1fr);gap:.3rem;z-index:6;}
.ap-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:3px;padding:.28rem .3rem;backdrop-filter:blur(4px);}
.ap-cn{font-size:.42rem;font-weight:700;color:#fff;letter-spacing:-.01em;}
.ap-cl{font-size:.38rem;color:rgba(255,255,255,.4);margin-top:.1rem;}
/* Code section */
.code-sec{padding:9rem 4rem;background:var(--bg2);position:relative;z-index:1;}
.code-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-top:4.5rem;}
.code-claim{font-family:'Cormorant',serif;font-size:clamp(1.7rem,2.6vw,3rem);font-weight:300;font-style:italic;line-height:1.32;margin-bottom:2rem;}
.code-claim span{color:var(--gold);}
.code-pts{display:flex;flex-direction:column;gap:1.1rem;}
.cp{display:flex;gap:1rem;padding:1.1rem;border:1px solid var(--border);transition:all .3s;}
.cp:hover{border-color:var(--border-gold);background:var(--gold-glow);}
.cp-ico{font-size:1.2rem;flex-shrink:0;}
.cp-t{font-size:.86rem;font-weight:500;color:var(--fg);margin-bottom:.2rem;}
.cp-d{font-size:.77rem;line-height:1.65;color:var(--fg2);}
.code-block{background:#080810;border:1px solid var(--border);}
.cb-bar{padding:.65rem 1rem;background:rgba(255,255,255,.02);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.45rem;}
.cb-d{width:9px;height:9px;border-radius:50%;}
.cbd1{background:#ff5f57;}.cbd2{background:#ffbd2e;}.cbd3{background:#28c941;}
.cb-fn{margin:0 auto;font-family:'DM Mono',monospace;font-size:.62rem;color:var(--fg3);}
.cb-body{padding:1.6rem;font-family:'DM Mono',monospace;font-size:.7rem;line-height:1.85;}
.cl{display:block;opacity:0;animation:cf .35s ease forwards;}
@keyframes cf{to{opacity:1;}}
.ln{color:rgba(201,165,90,.22);margin-right:1.4rem;user-select:none;}
.kw{color:#c792ea;}.fn{color:#82aaff;}.st{color:#c3e88d;}.cm{color:rgba(201,165,90,.32);}.vr{color:#f78c6c;}
/* Experience */
.exp-grid{display:grid;grid-template-columns:360px 1fr;gap:6rem;margin-top:5rem;}
.exp-line{position:absolute;left:0;top:0;width:1px;height:100%;background:linear-gradient(to bottom,var(--gold),rgba(201,165,90,.03));}
.exp-items{position:relative;}
.ei{padding:0 0 3.2rem 2.2rem;position:relative;opacity:0;transform:translateX(-18px);transition:opacity .65s,transform .65s;}
.ei.on{opacity:1;transform:none;}
.ei-dot{position:absolute;left:-4px;top:.3rem;width:8px;height:8px;border-radius:50%;background:var(--bg);border:1px solid var(--gold);transition:background .3s;}
.ei:hover .ei-dot{background:var(--gold);}
.ei-yr{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.22em;color:var(--gold);opacity:.5;margin-bottom:.4rem;}
.ei-role{font-family:'Cormorant',serif;font-size:1.35rem;font-weight:400;margin-bottom:.18rem;}
.ei-co{font-size:.76rem;color:var(--fg3);margin-bottom:.7rem;}
.ei-desc{font-size:.8rem;line-height:1.75;color:rgba(240,236,226,.35);font-style:italic;}
.exp-right{display:flex;flex-direction:column;gap:2rem;}
.quote-box{font-family:'Cormorant',serif;font-size:clamp(1.5rem,2.4vw,2.6rem);font-weight:300;font-style:italic;line-height:1.35;color:var(--fg);padding:2.2rem;border:1px solid var(--border);background:var(--bg3);position:relative;}
.qm{position:absolute;top:.8rem;left:1.3rem;font-family:'Cormorant',serif;font-size:5.5rem;font-weight:300;font-style:italic;color:var(--gold);opacity:.1;line-height:1;}
.qa{display:flex;align-items:center;gap:.7rem;margin-top:1.3rem;font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:.55;}
.qa::before{content:'';width:18px;height:1px;background:var(--gold);}
.vals{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;}
.val{padding:1.5rem;border:1px solid var(--border);transition:all .3s;position:relative;overflow:hidden;}
.val::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transition:transform .4s;}
.val:hover{border-color:var(--border-gold);background:var(--gold-glow);}
.val:hover::after{transform:scaleX(1);}
.val-ico{font-size:1.3rem;margin-bottom:.9rem;}
.val-t{font-family:'Cormorant',serif;font-size:1.15rem;font-weight:400;margin-bottom:.3rem;}
.val-d{font-size:.77rem;line-height:1.65;color:var(--fg2);}
/* Contact */
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:start;position:relative;z-index:1;}
.contact-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(circle,rgba(201,165,90,.035),transparent 65%);pointer-events:none;}
.contact-h{font-family:'Cormorant',serif;font-size:clamp(3rem,5.5vw,6.5rem);font-weight:300;line-height:.92;margin:1.5rem 0 2rem;}
.contact-h em{font-style:italic;color:var(--gold);}
.contact-sub{font-size:.95rem;line-height:1.88;color:var(--fg2);font-style:italic;margin-bottom:3rem;}
.contact-links{display:flex;flex-direction:column;}
.cl-item{display:flex;align-items:center;gap:1.1rem;padding:1.3rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--fg2);transition:all .3s;position:relative;overflow:hidden;}
.cl-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--gold-glow);transition:width .4s;}
.cl-item:hover{color:var(--fg);padding-left:.7rem;}
.cl-item:hover::before{width:100%;}
.cl-ico{width:40px;height:40px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--fg3);transition:all .3s;flex-shrink:0;position:relative;z-index:1;}
.cl-item:hover .cl-ico{border-color:var(--border-gold);color:var(--gold);}
.cl-info{position:relative;z-index:1;}
.cl-lbl{font-family:'DM Mono',monospace;font-size:.53rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.12rem;}
.cl-val{font-size:.86rem;}
.form{display:flex;flex-direction:column;gap:1.2rem;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.fg{display:flex;flex-direction:column;gap:.45rem;}
.fg label{font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg3);}
.fg input,.fg textarea,.fg select{background:rgba(240,236,226,.025);border:1px solid var(--border);padding:.82rem 1rem;color:var(--fg);font-family:'Outfit',sans-serif;font-size:.86rem;font-weight:300;outline:none;transition:border-color .3s,background .3s;width:100%;}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--border-gold);background:rgba(201,165,90,.025);}
.fg textarea{height:115px;resize:none;}
.fg select option{background:var(--bg);}
.form-btn{align-self:flex-start;padding:.95rem 2.8rem;background:transparent;border:1px solid var(--gold);color:var(--gold);font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;cursor:none;display:flex;align-items:center;gap:.5rem;transition:color .4s;position:relative;overflow:hidden;}
.form-btn::before{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s;z-index:0;}
.form-btn:hover{color:var(--bg);}
.form-btn:hover::before{transform:scaleX(1);}
.form-btn span,.form-btn svg{position:relative;z-index:1;}
.form-ok{display:none;padding:.9rem 1.2rem;border:1px solid rgba(74,222,128,.3);color:#4ade80;font-family:'DM Mono',monospace;font-size:.65rem;letter-spacing:.14em;}
footer{padding:4rem 4rem 2.5rem;border-top:1px solid var(--border);position:relative;z-index:1;}
.ft-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:4rem;margin-bottom:4rem;}
.ft-brand{font-family:'Cormorant',serif;font-size:2rem;font-weight:300;font-style:italic;color:var(--gold);display:block;margin-bottom:1rem;}
.ft-bio{font-size:.8rem;line-height:1.8;color:var(--fg3);}
.ft-col h4{font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);opacity:.55;margin-bottom:1.4rem;font-weight:400;}
.ft-col ul{list-style:none;}
.ft-col li{margin-bottom:.75rem;}
.ft-col a{font-size:.8rem;color:var(--fg3);text-decoration:none;transition:color .3s;}
.ft-col a:hover{color:var(--gold);}
.ft-bottom{border-top:1px solid var(--border);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;}
.ft-copy{font-family:'DM Mono',monospace;font-size:.56rem;letter-spacing:.1em;color:rgba(240,236,226,.16);}
@media(max-width:768px){
  #cur,#cur2{display:none!important;}*{cursor:auto!important;}
  nav{padding:0 1.4rem;height:60px;}
  .nav-links{display:none!important;}
  .nav-btn{font-size:.58rem;padding:.4rem 1rem;}
  .hero{padding:0 1.4rem;padding-top:80px;min-height:100svh;}
  .hero-h{font-size:clamp(3.2rem,14vw,5rem)!important;}
  .hero-float{display:none!important;}
  .hero-bg-num{font-size:50vw;right:-2rem;bottom:-2rem;}
  .hero-ctas{flex-direction:column;align-items:flex-start;gap:1rem;}
  .hero-scroll{left:1.4rem;}
  .sec,.code-sec{padding:5rem 1.4rem;}
  .proj-sec{padding:5rem 0 5rem 1.4rem;}
  .about-grid{grid-template-columns:1fr!important;gap:4rem!important;}
  .af-box{aspect-ratio:3/2!important;}
  .af-badge{bottom:-1rem;right:0;}
  .stats{grid-template-columns:1fr 1fr!important;}
  .stat{border-bottom:1px solid var(--border);}
  .skills-grid{grid-template-columns:1fr!important;gap:3rem!important;}
  .pcard{flex:0 0 300px!important;}
  .cv{height:180px!important;}
  .proj-head{padding-right:1.4rem;flex-direction:column;align-items:flex-start;gap:1rem;}
  .proj-scroll{padding-right:1.4rem;}
  .scroll-nav{padding-right:1.4rem;}
  .code-inner{grid-template-columns:1fr!important;gap:2.5rem!important;}
  .exp-grid{grid-template-columns:1fr!important;gap:3rem!important;}
  .vals{grid-template-columns:1fr!important;}
  .contact-inner{grid-template-columns:1fr!important;gap:3rem!important;}
  .frow{grid-template-columns:1fr!important;}
  .contact-h{font-size:clamp(2.5rem,10vw,4rem)!important;}
  footer{padding:3rem 1.4rem 2rem;}
  .ft-grid{grid-template-columns:1fr!important;gap:2.5rem!important;}
  .ft-bottom{flex-direction:column;gap:.5rem;text-align:center;}
}
@media(max-width:480px){
  .hero-h{font-size:clamp(2.8rem,13vw,4rem)!important;}
  .sec-h{font-size:clamp(2rem,9vw,3rem)!important;}
  .pcard{flex:0 0 270px!important;}
  .stats{grid-template-columns:1fr 1fr!important;}
  .btn-g{padding:.8rem 2rem;font-size:.65rem;}
}
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;z-index:600;position:relative;}
.ham span{display:block;width:22px;height:1.5px;background:var(--fg);transition:all .3s;}
.ham.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px);}
.ham.open span:nth-child(2){opacity:0;}
.ham.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px);}
.mob-menu{position:fixed;inset:0;background:rgba(7,7,12,.97);backdrop-filter:blur(20px);z-index:499;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;opacity:0;pointer-events:none;transition:opacity .4s;}
.mob-menu.open{opacity:1;pointer-events:all;}
.mob-menu a{font-family:'Cormorant',serif;font-size:2.8rem;font-weight:300;color:var(--fg);text-decoration:none;letter-spacing:.04em;transition:color .3s;}
.mob-menu a:hover{color:var(--gold);}
@media(max-width:768px){.ham{display:flex!important;}.nav-btn{display:none!important;}}
