/* ============================================================
   VIDHAATH CREATION STUDIO — 2026 REDESIGN
   "The studio for future visualisation"
   Visual-first · minimal copy · scroll-driven
   Palette unchanged from brand: #04080F / #00D4FF → #6366F1
   ============================================================ */

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;text-size-adjust:100%;}
img,video,canvas{display:block;max-width:100%;}
button{font:inherit;background:none;border:none;cursor:pointer;color:inherit;}
a{color:inherit;}

/* ── TOKENS ── */
:root{
  --bg:#04080F;--bg1:#07101E;--bg2:#0C1828;
  --cyan:#00D4FF;--indigo:#6366F1;
  --grad:linear-gradient(90deg,#00D4FF 0%,#6366F1 100%);
  --text:#E8EDF5;--muted:#8A9BB0;--dim:rgba(232,237,245,0.5);
  --border:rgba(255,255,255,0.08);--bc:rgba(0,212,255,0.22);
  --fd:'Bebas Neue',sans-serif;--fb:'Inter','DM Sans',sans-serif;--fm:'Share Tech Mono','JetBrains Mono',monospace;
  --nav-h:76px;--pad:clamp(20px,4vw,56px);--max:1500px;
  --ease:cubic-bezier(0.16,1,0.3,1);
}

body{background:var(--bg);color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.5;overflow-x:hidden;}
::selection{background:rgba(0,212,255,0.3);color:#fff;}
html{scrollbar-width:thin;scrollbar-color:rgba(0,212,255,0.3) var(--bg);}

/* Film grain — brand carry-over */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9990;opacity:0.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ── UTILITIES ── */
.w{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
.lbl{font-family:var(--fm);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:10px;}
.lbl::before{content:'';width:24px;height:1px;background:var(--cyan);}
.lbl.plain::before{display:none;}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.outline-text{color:transparent;-webkit-text-stroke:1px rgba(232,237,245,0.25);}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;border-radius:100px;font-size:14px;font-weight:600;text-decoration:none;letter-spacing:0.01em;transition:transform 0.35s var(--ease),background 0.3s,color 0.3s,border-color 0.3s;white-space:nowrap;}
.btn-fill{background:var(--grad);color:#fff;}
.btn-fill:hover{transform:translateY(-3px) scale(1.02);}
.btn-line{border:1px solid var(--border);color:var(--text);}
.btn-line:hover{border-color:var(--bc);color:var(--cyan);transform:translateY(-3px);}
.btn .arr{transition:transform 0.35s var(--ease);}
.btn:hover .arr{transform:translateX(4px);}

/* ── LOADER ── */
.loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:transform 0.9s var(--ease);}
.loader.done{transform:translateY(-101%);}
.loader-word{font-family:var(--fd);font-size:clamp(32px,6vw,72px);letter-spacing:0.14em;overflow:hidden;}
.loader-word span{display:inline-block;animation:loadUp 0.9s var(--ease) both;}
.loader-word img{display:block;width:clamp(300px,72vw,1000px);height:auto;max-width:90vw;filter:brightness(0) invert(1);}
.loader-pct{position:absolute;bottom:32px;right:var(--pad);font-family:var(--fd);font-size:clamp(60px,12vw,140px);line-height:0.85;color:transparent;-webkit-text-stroke:1px rgba(0,212,255,0.4);}
.loader-bar{position:absolute;bottom:0;left:0;height:2px;background:var(--grad);width:0%;}
@keyframes loadUp{from{transform:translateY(110%);}to{transform:translateY(0);}}

/* ── CURSOR (fine pointers only) ── */
.cur,.cur-ring{display:none;}
@media (pointer:fine){
  .cur{display:block;position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;background:var(--cyan);z-index:9999;pointer-events:none;transform:translate(-50%,-50%);}
  .cur-ring{display:flex;align-items:center;justify-content:center;position:fixed;top:0;left:0;width:40px;height:40px;border-radius:50%;border:1px solid rgba(0,212,255,0.4);z-index:9998;pointer-events:none;transform:translate(-50%,-50%);transition:width 0.3s var(--ease),height 0.3s var(--ease),background 0.3s,border-color 0.3s;font-family:var(--fm);font-size:0;letter-spacing:0.1em;color:#04080F;}
  .cur-ring.grow{width:84px;height:84px;background:rgba(0,212,255,0.92);border-color:transparent;font-size:10px;}
  .cur-ring.grow::after{content:'VIEW';}
  body.has-cursor,body.has-cursor a,body.has-cursor button{cursor:none;}
}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1002;height:var(--nav-h);display:flex;align-items:center;transition:background 0.4s,border-color 0.4s,transform 0.4s var(--ease);border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(4,8,15,0.7);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);border-color:var(--border);}
.nav.hide{transform:translateY(-100%);}
.nav-in{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav-logo{display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0;}
.logo-mark{width:36px;height:36px;border-radius:9px;background:var(--grad);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;}
.logo-mark img{width:62%;height:62%;object-fit:contain;filter:brightness(0) invert(1);}
.nav-logo .logo-word{height:46px;width:auto;filter:brightness(0) invert(1);}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-family:var(--fm);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);text-decoration:none;position:relative;padding:6px 0;transition:color 0.25s;}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--grad);transform:scaleX(0);transform-origin:right;transition:transform 0.35s var(--ease);}
.nav-links a:hover,.nav-links a.active{color:var(--text);}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left;}
.nav-cta{font-family:var(--fm);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;padding:11px 22px;border-radius:100px;background:var(--grad);color:#fff;text-decoration:none;transition:transform 0.3s var(--ease);flex-shrink:0;}
.nav-cta:hover{transform:translateY(-2px);}
.nav-burger{display:none;flex-direction:column;gap:6px;width:40px;height:40px;align-items:center;justify-content:center;z-index:1002;}
.nav-burger span{display:block;width:24px;height:1.5px;background:var(--text);transition:transform 0.35s var(--ease),opacity 0.3s;}
.nav-burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* Mobile overlay menu — mega type */
.menu{position:fixed;inset:0;z-index:1001;background:rgba(4,8,15,0.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;flex-direction:column;justify-content:center;padding:calc(var(--nav-h) + 20px) var(--pad) 36px;overflow-y:auto;visibility:hidden;opacity:0;transition:opacity 0.45s var(--ease),visibility 0.45s;}
.menu-list{width:100%;max-width:var(--max);margin:0 auto;}
.menu.open{visibility:visible;opacity:1;}
.menu a.mega{display:flex;align-items:center;gap:clamp(16px,4vw,30px);padding:clamp(12px,1.8vh,20px) 0;border-bottom:1px solid var(--border);font-family:var(--fd);font-size:clamp(40px,11vw,78px);line-height:1;text-decoration:none;color:var(--text);text-transform:uppercase;transform:translateY(26px);opacity:0;transition:transform 0.6s var(--ease),opacity 0.6s,color 0.3s,padding-left 0.35s var(--ease);}
.menu a.mega:first-of-type{border-top:1px solid var(--border);}
.menu.open a.mega{transform:translateY(0);opacity:1;}
.menu.open a.mega:nth-of-type(2){transition-delay:0.05s;}
.menu.open a.mega:nth-of-type(3){transition-delay:0.10s;}
.menu.open a.mega:nth-of-type(4){transition-delay:0.15s;}
.menu.open a.mega:nth-of-type(5){transition-delay:0.20s;}
.menu a.mega:hover,.menu a.mega:focus-visible{color:var(--cyan);padding-left:12px;}
.menu a.mega .idx{flex:0 0 auto;width:clamp(30px,8vw,46px);font-family:var(--fm);font-size:clamp(11px,1.4vw,13px);-webkit-text-stroke:0;color:var(--cyan);letter-spacing:0.1em;vertical-align:baseline;margin:0;align-self:center;}
.menu-meta{margin-top:clamp(30px,5vh,52px);display:flex;gap:14px 28px;flex-wrap:wrap;font-family:var(--fm);font-size:11px;letter-spacing:0.08em;color:var(--muted);}
.menu-meta a{color:var(--muted);text-decoration:none;}
.menu-meta a:hover{color:var(--cyan);}

/* ── HERO (home) ── */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease;pointer-events:none;}
.hero-slide.active{opacity:1;pointer-events:auto;}
.hero-slide img,.hero-slide video{width:100%;height:100%;object-fit:cover;}
.hero-slide canvas{display:block;width:100%!important;height:100%!important;}
#hero-3d-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;pointer-events:none;z-index:2;background:var(--bg1);}
#hero-3d-loading svg{animation:hero3dSpin 1s linear infinite;}
#hero-3d-loading span{font-family:var(--fm);font-size:9px;letter-spacing:0.14em;color:var(--muted);text-transform:uppercase;}
#hero-3d-hint{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-family:var(--fm);font-size:9px;letter-spacing:0.1em;color:rgba(232,237,245,0.28);text-transform:uppercase;pointer-events:none;z-index:3;display:none;white-space:nowrap;transition:opacity 1.5s ease;}
@keyframes hero3dSpin{to{transform:rotate(360deg);}}
.hero-media-nav{position:absolute;top:calc(var(--nav-h) + 64px);right:var(--pad);display:flex;flex-direction:column;align-items:flex-end;gap:8px;z-index:4;}
.hmn-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 17px;border-radius:100px;border:1px solid var(--border);background:rgba(4,8,15,0.55);color:var(--muted);font-family:var(--fm);font-size:10px;letter-spacing:0.08em;cursor:pointer;transition:all 0.3s;text-transform:uppercase;backdrop-filter:blur(8px);}
.hmn-btn:hover{border-color:var(--bc);color:var(--text);}
.hmn-btn.active{border-color:var(--bc);color:var(--cyan);background:rgba(0,212,255,0.1);}
.hmn-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;}
.hero-slide-label{margin-top:6px;font-family:var(--fm);font-size:9px;letter-spacing:0.12em;color:rgba(232,237,245,0.3);text-transform:uppercase;}
.hero-progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:rgba(255,255,255,0.06);z-index:5;}
.hero-pb{height:100%;background:var(--grad);width:0;transition:none;}
.hero-pb.anim{width:100%;transition:width 6s linear;}
.hero-veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top,rgba(4,8,15,0.92) 0%,rgba(4,8,15,0.25) 38%,rgba(4,8,15,0.1) 60%,rgba(4,8,15,0.55) 100%);}
.hero-grid-dots{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0.5;
  background-image:radial-gradient(circle,rgba(255,255,255,0.05) 1px,transparent 1px);background-size:40px 40px;
  mask-image:linear-gradient(to bottom,black,transparent 70%);-webkit-mask-image:linear-gradient(to bottom,black,transparent 70%);}
.hero-top{position:absolute;top:calc(var(--nav-h) + 22px);left:0;right:0;z-index:3;display:flex;justify-content:space-between;align-items:flex-start;padding:0 var(--pad);font-family:var(--fm);font-size:10px;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;}
.hero-bottom{position:relative;z-index:3;padding:0 var(--pad) clamp(28px,5vh,56px);}
.hero-h1{font-family:var(--fd);font-size:clamp(58px,12.5vw,200px);line-height:0.84;text-transform:uppercase;letter-spacing:0.005em;}
.hero-h1 .row{display:block;overflow:hidden;}
.hero-h1 .row>span{display:inline-block;}
.hero-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-top:clamp(20px,3.5vh,40px);flex-wrap:wrap;}
.hero-sub{max-width:430px;font-size:15px;font-weight:300;color:var(--muted);line-height:1.7;}
.hero-sub strong{color:var(--text);font-weight:500;}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;font-family:var(--fm);font-size:9px;letter-spacing:0.2em;color:var(--dim);text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;}
.hero-scroll::after{content:'';width:1px;height:34px;background:linear-gradient(to bottom,var(--cyan),transparent);animation:drip 2s var(--ease) infinite;}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top;}45%{transform:scaleY(1);transform-origin:top;}55%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* ── HERO — static key image ── */
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}

/* ── HERO — LIVE 3D CENTERPIECE (explode + hotspots) — legacy, now used by #gear-demo ── */
.hero-stage{position:absolute;inset:0;}
.hero-stage canvas{display:block;width:100%!important;height:100%!important;cursor:grab;touch-action:none;}
.hero-stage canvas:active{cursor:grabbing;}
.hero-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;pointer-events:none;transition:opacity 1s ease;}
.hero.hero-static .hero-fallback{opacity:1;}
.hero.hero-static #hero-3d-loading,.hero.hero-static .hot,.hero.hero-static .hero-drag-hint{display:none!important;}
.hero-eyebrow{font-family:var(--fm);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:11px;margin-bottom:clamp(14px,2.4vh,24px);}
.hero-eyebrow::before{content:'';width:30px;height:1px;background:var(--cyan);}
/* explode toggle active state */
#explode-btn.active{border-color:var(--bc);color:var(--cyan);background:rgba(0,212,255,0.1);}
/* hotspots projected from 3D */
.hot{position:absolute;top:0;left:0;z-index:4;pointer-events:auto;opacity:0;transition:opacity 0.4s ease;will-change:transform,opacity;}
.hot i{display:block;width:11px;height:11px;border-radius:50%;background:var(--cyan);transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(0,212,255,0.16);}
.hot i::after{content:'';position:absolute;left:50%;top:50%;width:11px;height:11px;margin:-5.5px 0 0 -5.5px;border-radius:50%;border:1px solid rgba(0,212,255,0.55);animation:hotPulse 2.6s var(--ease) infinite;}
.hot b{position:absolute;left:13px;top:-10px;white-space:nowrap;font-family:var(--fm);font-size:9.5px;letter-spacing:0.13em;text-transform:uppercase;color:var(--text);background:rgba(4,8,15,0.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);padding:5px 10px;border-radius:6px;opacity:0;transform:translateX(-4px);transition:opacity 0.3s,transform 0.3s;pointer-events:none;font-weight:400;}
.hot:hover b{opacity:1;transform:translateX(0);}
@keyframes hotPulse{0%{transform:scale(1);opacity:1;}70%{transform:scale(2.6);opacity:0;}100%{opacity:0;}}
.hero-drag-hint{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:9px;letter-spacing:0.1em;color:rgba(232,237,245,0.34);text-transform:uppercase;pointer-events:none;z-index:3;white-space:nowrap;transition:opacity 1.2s ease;}
@media (max-width:700px){.hot{display:none!important;}.hero-scroll{display:none;}.hero-eyebrow{font-size:9.5px;letter-spacing:0.12em;}.hero-eyebrow::before{width:18px;}}

/* ── MARQUEE (kinetic type band) ── */
.kin{padding:clamp(24px,4vh,48px) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;background:var(--bg1);}
.kin-track{display:flex;width:max-content;animation:kin 38s linear infinite;}
.kin-item{font-family:var(--fd);font-size:clamp(28px,4.4vw,62px);line-height:0.9;text-transform:uppercase;white-space:nowrap;padding-right:48px;display:flex;align-items:center;gap:48px;}
.kin-item em{font-style:normal;color:transparent;-webkit-text-stroke:1px rgba(0,212,255,0.45);}
.kin-dot{width:9px;height:9px;border-radius:50%;background:var(--grad);flex-shrink:0;}
@keyframes kin{to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.kin-track{animation:none;}.hero-scroll::after{animation:none;}}

/* ── SHOWREEL ── */
.reel{position:relative;padding:clamp(60px,10vh,120px) 0;}
.reel-frame{position:relative;border-radius:clamp(12px,2vw,24px);overflow:hidden;margin:0 var(--pad);aspect-ratio:16/8.2;background:var(--bg1);}
.reel-frame video{width:100%;height:100%;object-fit:cover;}
.reel-frame::after{content:'';position:absolute;inset:0;box-shadow:inset 0 0 0 1px var(--border);border-radius:inherit;pointer-events:none;}
.reel-lbl{position:absolute;top:26px;left:30px;z-index:2;display:inline-flex;align-items:center;gap:9px;font-family:var(--fm);font-size:10px;letter-spacing:0.16em;color:#fff;text-transform:uppercase;background:rgba(4,8,15,0.55);padding:8px 16px;border-radius:100px;backdrop-filter:blur(8px);}
.reel-lbl i{width:7px;height:7px;border-radius:50%;background:var(--cyan);animation:pulse 2s infinite;font-style:normal;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.25;}}

/* ── STACKED CAPABILITY PANELS (CSS sticky stack) ── */
.stack-head{padding:clamp(50px,9vh,110px) var(--pad) clamp(30px,5vh,60px);display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;max-width:var(--max);margin:0 auto;width:100%;}
.sec-h{font-family:var(--fd);font-size:clamp(46px,7.5vw,110px);line-height:0.88;text-transform:uppercase;}
.stack{position:relative;}
/* dwell gap — keeps each panel pinned longer so it's readable before the next slides over */
.stk-gap{height:48svh;pointer-events:none;}
@media (max-width:700px){.stk-gap{height:30svh;}}
.stk{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:flex-end;}
.stk-media{position:absolute;inset:0;}
.stk-media img,.stk-media video{width:100%;height:100%;object-fit:cover;}
.stk::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(4,8,15,0.94) 0%,rgba(4,8,15,0.35) 45%,rgba(4,8,15,0.18) 100%);}
.stk-in{position:relative;z-index:2;width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--pad) clamp(34px,6vh,70px);display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.stk-num{font-family:var(--fd);font-size:clamp(15px,1.6vw,22px);color:var(--cyan);letter-spacing:0.18em;margin-bottom:14px;display:block;}
.stk-title{font-family:var(--fd);font-size:clamp(54px,9vw,150px);line-height:0.85;text-transform:uppercase;margin-bottom:16px;}
.stk-line{max-width:420px;font-size:15px;font-weight:300;color:rgba(232,237,245,0.78);line-height:1.65;}
.stk-side{display:flex;flex-direction:column;align-items:flex-start;gap:18px;padding-bottom:6px;}
.stk-tags{display:flex;flex-wrap:wrap;gap:8px;max-width:340px;}
.stk-tag{font-family:var(--fm);font-size:9.5px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(232,237,245,0.75);border:1px solid rgba(255,255,255,0.22);padding:7px 14px;border-radius:100px;backdrop-filter:blur(6px);background:rgba(4,8,15,0.25);}
.stk-link{font-family:var(--fm);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--cyan);text-decoration:none;display:inline-flex;align-items:center;gap:10px;}
.stk-link:hover{gap:16px;}
.stk-link{transition:gap 0.3s var(--ease);}

/* ── HORIZONTAL WORK STRIP ── */
.hwork{padding:clamp(60px,10vh,130px) 0 clamp(50px,8vh,100px);background:var(--bg);}
.hwork-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:clamp(28px,4vh,48px);}
.hw-track{display:flex;gap:clamp(12px,1.5vw,20px);overflow-x:auto;scroll-snap-type:x mandatory;padding:8px var(--pad) 26px;scrollbar-width:none;cursor:grab;}
.hw-track::-webkit-scrollbar{display:none;}
.hw-track.drag{cursor:grabbing;scroll-snap-type:none;}
.hw-card{flex:0 0 auto;width:clamp(300px,42vw,620px);scroll-snap-align:start;text-decoration:none;color:inherit;}
.hw-media{position:relative;aspect-ratio:16/10.5;border-radius:14px;overflow:hidden;background:var(--bg1);border:1px solid var(--border);transition:border-color 0.3s;}
.hw-media img,.hw-media video{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.hw-card:hover .hw-media img,.hw-card:hover .hw-media video{transform:scale(1.05);}
.hw-card:hover .hw-media{border-color:var(--bc);}
.hw-meta{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:14px 4px 0;}
.hw-title{font-size:15px;font-weight:600;}
.hw-cat{font-family:var(--fm);font-size:9.5px;letter-spacing:0.12em;color:var(--cyan);text-transform:uppercase;white-space:nowrap;}
.hw-bar{height:2px;background:rgba(255,255,255,0.06);margin:18px var(--pad) 0;border-radius:2px;overflow:hidden;}
.hw-bar i{display:block;height:100%;width:20%;background:var(--grad);border-radius:2px;transition:width 0.2s linear;}

/* ── PROOF STRIP (segments — wireframe C) ── */
.proof{border-bottom:1px solid var(--border);background:var(--bg);}
.proof-in{max-width:var(--max);margin:0 auto;padding:18px var(--pad);display:flex;align-items:center;gap:clamp(14px,3vw,36px);flex-wrap:wrap;justify-content:center;}
.proof-lbl{font-family:var(--fm);font-size:9px;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;flex-shrink:0;}
.proof-item{font-family:var(--fm);font-size:10px;letter-spacing:0.1em;color:var(--dim);text-transform:uppercase;display:flex;align-items:center;gap:10px;}
.proof-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--cyan);opacity:0.6;}

/* ── WHY CAD-NATIVE (wireframe F) ── */
.why3{padding:0 0 clamp(60px,10vh,120px);}
.why3-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);}
.why3-item{border-top:2px solid var(--bc);padding-top:18px;}
.why3-item i{font-family:var(--fm);font-style:normal;font-size:10px;color:var(--cyan);letter-spacing:0.14em;text-transform:uppercase;display:block;margin-bottom:10px;}
.why3-item h3{font-family:var(--fd);font-size:clamp(20px,2.2vw,30px);font-weight:400;text-transform:uppercase;letter-spacing:0.02em;margin-bottom:8px;}
.why3-item p{font-size:13.5px;font-weight:300;color:var(--muted);line-height:1.7;}
@media (max-width:820px){.why3-grid{grid-template-columns:1fr;}}

/* ── SIGNALS — "does this sound like you?" wayfinding ── */
.signals{padding:clamp(58px,9vh,116px) 0;border-top:1px solid var(--border);}
.signals .w{max-width:var(--max);margin:0 auto;}
.sig-head{margin-bottom:clamp(28px,5vh,52px);}
.sig-head h2{font-family:var(--fd);font-size:clamp(38px,5.6vw,82px);line-height:0.9;text-transform:uppercase;margin-top:14px;}
.sig-head h2 .grad-text{display:inline;}
.sig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,28px);}
.sig-item{border-top:2px solid var(--bc);padding-top:18px;}
.sig-item .n{font-family:var(--fm);font-size:10px;color:var(--cyan);letter-spacing:0.16em;display:block;margin-bottom:12px;}
.sig-item h3{font-family:var(--fd);font-size:clamp(19px,1.7vw,24px);font-weight:400;text-transform:uppercase;letter-spacing:0.02em;line-height:1.05;margin-bottom:10px;}
.sig-item p{font-size:13px;font-weight:300;color:var(--muted);line-height:1.65;}
@media (max-width:1000px){.sig-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.sig-grid{grid-template-columns:1fr;}}

/* ── WHO — audience wayfinding band ── */
.who{padding:clamp(54px,9vh,108px) 0;border-top:1px solid var(--border);background:var(--bg1);}
.who-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(30px,5vw,72px);align-items:center;max-width:var(--max);margin:0 auto;}
.who-h{font-family:var(--fd);font-size:clamp(32px,4.2vw,62px);line-height:0.92;text-transform:uppercase;margin:14px 0 18px;}
.who-h em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.who-p{font-size:14.5px;font-weight:300;color:var(--muted);line-height:1.75;max-width:520px;}
.who-tags{display:flex;flex-wrap:wrap;gap:9px;align-content:flex-start;}
.who-tags span{font-family:var(--fm);font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:rgba(232,237,245,0.82);border:1px solid var(--border);padding:9px 16px;border-radius:100px;transition:border-color 0.25s,color 0.25s;}
.who-tags span:hover{border-color:var(--bc);color:var(--cyan);}
@media (max-width:820px){.who-grid{grid-template-columns:1fr;}}

/* ── CTA helper line ── */
.cta-sub{max-width:560px;margin:clamp(18px,3vh,28px) auto 0;font-size:15px;font-weight:300;color:var(--muted);line-height:1.7;position:relative;z-index:1;}

/* ── LIVE 3D DEMO (wireframe G) ── */
.demo3d{padding:0 0 clamp(70px,12vh,140px);}
.demo3d-stage{position:relative;margin:0 var(--pad);border:1.5px dashed rgba(0,212,255,0.35);border-radius:clamp(12px,2vw,24px);aspect-ratio:16/8;background:radial-gradient(ellipse at 50% 100%,rgba(0,212,255,0.05),var(--bg1) 70%);overflow:hidden;}
.demo3d-stage canvas{width:100%!important;height:100%!important;display:block;touch-action:none;}
.demo3d-badge{position:absolute;top:14px;right:16px;z-index:3;font-family:var(--fm);font-size:9px;letter-spacing:0.14em;color:#fff;background:var(--grad);padding:5px 12px;border-radius:4px;text-transform:uppercase;}
.demo3d-hint{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:3;font-family:var(--fm);font-size:9px;letter-spacing:0.12em;color:rgba(232,237,245,0.4);text-transform:uppercase;pointer-events:none;white-space:nowrap;transition:opacity 1.5s ease;}
.demo3d-load{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;pointer-events:none;}
.demo3d-load svg{animation:hero3dSpin 1s linear infinite;}
.demo3d-load span{font-family:var(--fm);font-size:9px;letter-spacing:0.14em;color:var(--muted);text-transform:uppercase;}
.demo3d-foot{display:flex;justify-content:center;margin-top:18px;}
.demo3d-wind{position:absolute;top:14px;left:16px;z-index:3;display:none;align-items:center;gap:8px;font-family:var(--fm);font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--cyan);background:rgba(4,8,15,0.6);border:1px solid var(--bc);padding:8px 15px;border-radius:100px;cursor:pointer;transition:all 0.25s;backdrop-filter:blur(8px);}
.demo3d-wind:hover{background:rgba(0,212,255,0.12);}
.demo3d-wind.on{background:var(--grad);color:#fff;border-color:transparent;}
.demo3d-note{position:absolute;bottom:14px;right:16px;z-index:3;font-family:var(--fm);font-size:8.5px;letter-spacing:0.1em;color:rgba(232,237,245,0.4);text-transform:uppercase;opacity:0;transition:opacity 0.4s;pointer-events:none;}
.demo3d-note.show{opacity:1;}
@media (max-width:640px){.demo3d-stage{aspect-ratio:16/12;}}

/* ── MANIFESTO ── */
.mani{padding:clamp(90px,16vh,200px) 0;text-align:center;position:relative;overflow:hidden;}
.mani::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:760px;height:760px;background:radial-gradient(circle,rgba(0,212,255,0.06) 0%,rgba(99,102,241,0.04) 40%,transparent 70%);pointer-events:none;}
.mani-line{font-family:var(--fd);font-size:clamp(40px,7.5vw,108px);line-height:1.02;text-transform:uppercase;display:block;position:relative;z-index:1;}
.mani-line.ghost{color:transparent;-webkit-text-stroke:1px rgba(232,237,245,0.22);}
.mani-stats{display:flex;justify-content:center;gap:clamp(28px,6vw,90px);margin-top:clamp(44px,8vh,90px);flex-wrap:wrap;position:relative;z-index:1;}
.ms{display:flex;flex-direction:column;gap:6px;align-items:center;}
.ms b{font-family:var(--fd);font-size:clamp(34px,4vw,58px);line-height:1;font-weight:400;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.ms span{font-family:var(--fm);font-size:9.5px;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;}

/* ── PROCESS RAIL (micro) ── */
.rail{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg1);}
.rail-in{display:grid;grid-template-columns:repeat(4,1fr);max-width:var(--max);margin:0 auto;}
.rail-step{padding:clamp(26px,4vh,44px) var(--pad);border-right:1px solid var(--border);position:relative;transition:background 0.3s;}
.rail-step:last-child{border-right:none;}
.rail-step:hover{background:var(--bg2);}
.rail-step i{font-family:var(--fm);font-style:normal;font-size:10px;color:var(--cyan);letter-spacing:0.16em;display:block;margin-bottom:10px;}
.rail-step b{font-family:var(--fd);font-size:clamp(20px,2.2vw,30px);font-weight:400;text-transform:uppercase;letter-spacing:0.03em;}
.rail-step span{display:block;font-size:12px;color:var(--muted);font-weight:300;margin-top:6px;}

/* ── PAGE HERO (inner pages) ── */
.phero{padding:calc(var(--nav-h) + clamp(44px,8vh,96px)) 0 clamp(22px,3.5vh,44px);position:relative;overflow:hidden;}
.phero::before{content:'';position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:700px;height:380px;background:radial-gradient(ellipse,rgba(0,212,255,0.09) 0%,transparent 70%);pointer-events:none;}
.phero-h{font-family:var(--fd);font-size:clamp(54px,9vw,128px);line-height:0.86;text-transform:uppercase;}
.phero-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;margin-top:24px;flex-wrap:wrap;}
.phero-sub{max-width:440px;font-size:15px;font-weight:300;color:var(--muted);line-height:1.7;}
/* page-intro — the intro text fills the viewport; the page's content reveals on scroll (Work/Solutions/Studio) */
.page-intro{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:calc(var(--nav-h) + clamp(16px,3vh,40px)) 0 clamp(28px,5vh,64px);background:var(--bg) url("../images/work/rendering/cad-wireframe-car-render.webp") no-repeat right center / cover;}
/* readability scrim — dark on the left where the copy sits, clears to reveal the render on the right */
.page-intro::before{content:'';position:absolute;inset:0;pointer-events:none;z-index:0;background:linear-gradient(90deg,rgba(4,8,15,0.95) 0%,rgba(4,8,15,0.62) 42%,rgba(4,8,15,0.12) 78%,rgba(4,8,15,0) 100%),linear-gradient(to top,rgba(4,8,15,0.78),transparent 52%);}
.page-intro > *{position:relative;z-index:1;}
.page-intro .phero{min-height:0;padding:0;}
.page-intro .phero::before{display:none;}
.page-intro .statement{padding:clamp(18px,3.5vh,44px) 0 0;}
/* per-page intro backgrounds: Work = side wireframe (default) · Solutions = top wireframe · Studio = solid front */
.page-intro--solution{background-image:url("../images/work/rendering/cad-wireframe-car-top-render.webp");background-position:center;}
.page-intro--studio{background-image:url("../images/work/rendering/cad-car-front-solid-render.webp");background-position:center;}
@media (max-width:760px){.page-intro{background-position:center;}.page-intro::before{background:linear-gradient(to top,rgba(4,8,15,0.92) 0%,rgba(4,8,15,0.55) 58%,rgba(4,8,15,0.45) 100%);}}

/* ── WORK GRID ── */
.filters{display:flex;gap:clamp(10px,1.4vw,20px);flex-wrap:wrap;justify-content:center;padding:18px var(--pad);border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg1);position:sticky;top:0;z-index:50;}
.fbtn{font-family:var(--fm);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;padding:9px 20px;border-radius:100px;border:1px solid var(--border);color:var(--muted);transition:all 0.25s;}
.fbtn:hover{border-color:var(--bc);color:var(--text);}
.fbtn.active{background:var(--grad);border-color:transparent;color:#fff;}
.wgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(10px,1.4vw,18px);padding:clamp(28px,5vh,56px) var(--pad);max-width:var(--max);margin:0 auto;}
.wcard{position:relative;border-radius:14px;overflow:hidden;background:var(--bg1);border:1px solid var(--border);text-decoration:none;color:inherit;transition:border-color 0.3s,transform 0.5s var(--ease);grid-column:span 4;}
.wcard.wide{grid-column:span 8;}
.wcard.half{grid-column:span 6;}
.wcard:hover{border-color:var(--bc);transform:translateY(-4px);}
.wcard.hidden{display:none;}
.wc-media{position:relative;aspect-ratio:16/10;overflow:hidden;}
.wcard.wide .wc-media{aspect-ratio:16/8.4;}
.wcard.half .wc-media{aspect-ratio:16/9.4;}
.wc-media img,.wc-media video{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.wcard:hover .wc-media img,.wcard:hover .wc-media video{transform:scale(1.06);}
.wc-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(4,8,15,0.75),transparent 45%);}
.wc-meta{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;display:flex;align-items:baseline;justify-content:space-between;gap:14px;z-index:2;}
.wc-title{font-size:14.5px;font-weight:600;line-height:1.3;}
.wc-cat{font-family:var(--fm);font-size:9px;letter-spacing:0.12em;color:var(--cyan);text-transform:uppercase;white-space:nowrap;}
.wc-live{position:absolute;top:14px;left:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;font-family:var(--fm);font-size:9px;letter-spacing:0.12em;color:var(--cyan);text-transform:uppercase;background:rgba(4,8,15,0.6);border:1px solid var(--bc);padding:6px 13px;border-radius:100px;backdrop-filter:blur(8px);}
.wc-live i{width:6px;height:6px;border-radius:50%;background:var(--cyan);animation:pulse 2s infinite;font-style:normal;}
/* ── WORK — segregated by discipline (uniform grids, no masonry gaps) ── */
.worklist{max-width:var(--max);margin:0 auto;padding:clamp(30px,5vh,60px) var(--pad) clamp(50px,8vh,100px);}
.wcat{margin-top:clamp(44px,7vh,84px);}
.wcat:first-child{margin-top:0;}
.wcat.hidden{display:none;}
.wcat-head{display:flex;align-items:baseline;gap:16px;padding-bottom:14px;margin-bottom:clamp(18px,3vh,30px);border-bottom:1px solid var(--border);}
.wcat-num{font-family:var(--fm);font-size:11px;color:var(--cyan);letter-spacing:0.16em;flex-shrink:0;}
.wcat-h{font-family:var(--fd);font-size:clamp(26px,3.4vw,46px);line-height:1;text-transform:uppercase;letter-spacing:0.01em;}
.wcat-meta{font-family:var(--fm);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-left:auto;flex-shrink:0;}
.wcat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.5vw,22px);}
.wcat-grid .wcard{grid-column:auto;}
@media (max-width:900px){.wcat-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.wcat-grid{grid-template-columns:1fr;}.wcat-meta{display:none;}}

/* ── SOLUTION FULL-BLEED PANELS ── */
.sol{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;border-bottom:1px solid var(--border);}
.sol-media{position:absolute;inset:0;}
.sol-media img,.sol-media video{width:100%;height:100%;object-fit:cover;}
.sol::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(4,8,15,0.95) 8%,rgba(4,8,15,0.4) 50%,rgba(4,8,15,0.25) 100%);}
.sol-in{position:relative;z-index:2;width:100%;max-width:var(--max);margin:0 auto;padding:calc(var(--nav-h) + 30px) var(--pad) clamp(36px,7vh,76px);display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:end;}
.sol-num{font-family:var(--fm);font-size:11px;color:var(--cyan);letter-spacing:0.2em;display:block;margin-bottom:16px;}
.sol-title{font-family:var(--fd);font-size:clamp(52px,8.5vw,140px);line-height:0.85;text-transform:uppercase;margin-bottom:18px;}
.sol-line{max-width:480px;font-size:15.5px;font-weight:300;color:rgba(232,237,245,0.8);line-height:1.7;}
.sol-aside{display:flex;flex-direction:column;gap:20px;align-items:flex-start;}
.sol-feat{list-style:none;width:100%;}
.sol-feat li{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,0.12);font-family:var(--fm);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(232,237,245,0.8);}
.sol-feat li::before{content:'→';color:var(--cyan);font-size:11px;}

/* ── STUDIO PAGE ── */
.statement{padding:clamp(20px,3.5vh,44px) 0 clamp(56px,9vh,104px);}
.statement-h{font-family:var(--fd);font-size:clamp(32px,4.4vw,64px);line-height:1.04;text-transform:uppercase;max-width:1150px;}
.statement-h em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.statement-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;margin-top:clamp(28px,5vh,52px);flex-wrap:wrap;}
.statement-foot .mani-stats{justify-content:flex-end;margin-top:0;gap:clamp(22px,4vw,56px);}
@media (max-width:760px){.statement-foot .mani-stats{justify-content:flex-start;}}
.statement-p{max-width:460px;font-size:15px;font-weight:300;color:var(--muted);line-height:1.8;}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:2px;border:1px solid var(--border);border-radius:18px;overflow:hidden;background:var(--border);}
.duo-cell{background:var(--bg1);padding:clamp(30px,4vw,56px);}
.duo-cell h3{font-family:var(--fd);font-size:clamp(24px,2.6vw,38px);text-transform:uppercase;line-height:1;margin-bottom:14px;}
.duo-cell p{font-size:14px;font-weight:300;color:var(--muted);line-height:1.8;}
.quoteband{padding:clamp(70px,12vh,150px) 0;text-align:center;position:relative;overflow:hidden;}
.quoteband::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:680px;height:480px;background:radial-gradient(ellipse,rgba(99,102,241,0.07),transparent 70%);pointer-events:none;}
.quoteband blockquote{font-family:var(--fd);font-size:clamp(30px,4.6vw,64px);line-height:1.05;text-transform:uppercase;max-width:1000px;margin:0 auto;position:relative;z-index:1;}
.quoteband cite{display:block;margin-top:22px;font-family:var(--fm);font-style:normal;font-size:10px;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;}

/* ── CONTACT ── */
.contact-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,5vw,80px);padding-top:clamp(36px,6vh,72px);padding-bottom:clamp(60px,10vh,110px);align-items:start;}
.c-left{position:sticky;top:calc(var(--nav-h) + 32px);}
.c-mega{font-family:var(--fd);font-size:clamp(70px,11vw,170px);line-height:0.84;text-transform:uppercase;margin-bottom:30px;}
.c-rows{display:flex;flex-direction:column;border-top:1px solid var(--border);}
.c-row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:16px 0;border-bottom:1px solid var(--border);font-size:14px;}
.c-row .k{font-family:var(--fm);font-size:9.5px;letter-spacing:0.16em;color:var(--cyan);text-transform:uppercase;}
.c-row a{color:var(--text);text-decoration:none;transition:color 0.2s;}
.c-row a:hover{color:var(--cyan);}
.form{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border);}
.fgroup{display:grid;grid-template-columns:200px 1fr;gap:20px;align-items:center;padding:20px 0;border-bottom:1px solid var(--border);}
.fgroup label{font-family:var(--fm);font-size:10px;letter-spacing:0.14em;color:var(--muted);text-transform:uppercase;}
.fgroup input,.fgroup textarea{background:transparent;border:none;outline:none;font-family:var(--fb);font-size:16px;color:var(--text);width:100%;padding:4px 0;}
.fgroup input::placeholder,.fgroup textarea::placeholder{color:rgba(138,155,176,0.4);}
.fgroup textarea{resize:vertical;min-height:110px;line-height:1.6;}
.fgroup:focus-within label{color:var(--cyan);}
.form-send{margin-top:28px;align-self:flex-start;display:inline-flex;align-items:center;gap:12px;padding:18px 40px;border-radius:100px;background:var(--grad);color:#fff;font-size:15px;font-weight:600;transition:transform 0.35s var(--ease);}
.form-send:hover{transform:translateY(-3px) scale(1.02);}

/* ── BIG CTA + FOOTER ── */
.cta{position:relative;padding:clamp(90px,16vh,200px) 0;text-align:center;overflow:hidden;border-top:1px solid var(--border);}
.cta::before{content:'';position:absolute;bottom:-300px;left:50%;transform:translateX(-50%);width:900px;height:600px;background:radial-gradient(ellipse,rgba(0,212,255,0.1) 0%,rgba(99,102,241,0.06) 45%,transparent 70%);pointer-events:none;}
.cta-h{font-family:var(--fd);font-size:clamp(58px,11.5vw,190px);line-height:0.85;text-transform:uppercase;position:relative;z-index:1;}
.cta-h em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.cta-btns{display:flex;justify-content:center;gap:14px;margin-top:clamp(30px,5vh,52px);flex-wrap:wrap;position:relative;z-index:1;}
.cta-mail{margin-top:26px;position:relative;z-index:1;}
.cta-mail a{font-family:var(--fm);font-size:12px;letter-spacing:0.1em;color:var(--muted);text-decoration:none;transition:color 0.2s;}
.cta-mail a:hover{color:var(--cyan);}

.footer{border-top:1px solid var(--border);padding:clamp(40px,6vh,64px) 0 32px;background:var(--bg1);}
.footer-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:clamp(32px,5vh,52px);}
.footer-brand{display:block;}
.footer-brand .logo-mark{display:inline-flex;vertical-align:middle;margin:0 12px 16px 0;}
.footer-brand .logo-word{display:inline-block;vertical-align:middle;height:40px;width:auto;filter:brightness(0) invert(1);margin:0 0 16px 0;}
.footer-brand p{font-size:12.5px;color:var(--muted);font-weight:300;max-width:240px;line-height:1.7;}
.footer-cols{display:flex;gap:clamp(32px,5vw,80px);flex-wrap:wrap;}
.fcol h4{font-family:var(--fm);font-size:9.5px;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;margin-bottom:16px;}
.fcol a{display:block;font-size:13px;color:var(--dim);text-decoration:none;margin-bottom:9px;transition:color 0.2s;}
.fcol a:hover{color:var(--cyan);}
.fcol span.txt{display:block;font-size:13px;color:var(--dim);margin-bottom:9px;}
.footer-social{display:flex;gap:8px;margin-top:18px;}
.soc{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;transition:all 0.25s;}
.soc:hover{border-color:var(--bc);color:var(--cyan);background:rgba(0,212,255,0.06);}
.soc svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5;}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:24px;border-top:1px solid var(--border);flex-wrap:wrap;font-size:12px;color:var(--muted);}
.footer-bottom a{color:var(--muted);text-decoration:none;transition:color 0.2s;}
.footer-bottom a:hover{color:var(--cyan);}
.footer-legal{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}

/* ── REVEAL (JS adds .in) ── */
.rv{opacity:0;transform:translateY(36px);transition:opacity 0.9s var(--ease),transform 0.9s var(--ease);}
.rv.in{opacity:1;transform:none;}
.dl1{transition-delay:0.08s;}.dl2{transition-delay:0.16s;}.dl3{transition-delay:0.24s;}.dl4{transition-delay:0.32s;}
html.no-js .rv{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none;}}

/* ── RESPONSIVE ── */
@media (max-width:1100px){
  .wcard,.wcard.wide,.wcard.half{grid-column:span 6;}
  .sol-in{grid-template-columns:1fr;gap:30px;}
  .rail-in{grid-template-columns:1fr 1fr;}
  .rail-step:nth-child(2){border-right:none;}
  .rail-step:nth-child(-n+2){border-bottom:1px solid var(--border);}
}
@media (max-width:900px){
  .nav-links,.nav-cta{display:none;}
  .nav-burger{display:flex;}
  .duo{grid-template-columns:1fr;}
  .contact-wrap{grid-template-columns:1fr;}
  .c-left{position:static;}
  .stk-in{flex-direction:column;align-items:flex-start;gap:22px;}
}
@media (max-width:640px){
  :root{--nav-h:64px;}
  .wcard,.wcard.wide,.wcard.half{grid-column:span 12;}
  .rail-in{grid-template-columns:1fr;}
  .rail-step{border-right:none;border-bottom:1px solid var(--border);}
  .rail-step:last-child{border-bottom:none;}
  .fgroup{grid-template-columns:1fr;gap:8px;}
  .hero-top{display:none;}
  .hw-card{width:82vw;}
  .footer-bottom{justify-content:center;text-align:center;}
}
