/* =====================================================================
   TUSHAR SANTRA — CREATIVE PRODUCER PORTFOLIO
   HUD / techy-futuristic system · magenta neon + cyan secondary
   ===================================================================== */

/* ----------  TOKENS  ---------- */
:root{
  /* base — warm near-black (wibify) */
  --bg:        #0b0a09;
  --bg-2:      #100d0c;
  --panel:     #16130f;
  --panel-2:   #1c1813;
  --line:      rgba(224,206,190,.10);
  --line-2:    rgba(224,206,190,.18);

  /* text */
  --ink:       #f4efe9;
  --ink-2:     #a8a099;
  --ink-3:     #6e655e;

  /* accent — warm orange-red primary, deep ember secondary */
  --neon:      #ff4d2e;
  --neon-soft: #ff7a5c;
  --neon-deep: #e23a1c;
  --neon-2:    #ff7a2f;
  --neon-2-soft:#ffa166;

  --neon-rgb:  255,77,46;
  --neon2-rgb: 255,122,47;

  --glow:      0 0 24px rgba(var(--neon-rgb),.34);
  --glow-2:    0 0 24px rgba(var(--neon2-rgb),.26);

  --maxw: 1280px;
  --gut: clamp(20px, 5vw, 64px);

  /* Mattis-style radius scale */
  --r-lg: 28px;
  --r-md: 20px;
  --r-sm: 12px;

  --font-d: "Space Grotesk", system-ui, sans-serif;
  --font-display: "Archivo", "Space Grotesk", system-ui, sans-serif;
  --font-serif: "Archivo", system-ui, sans-serif;
  --font-m: "JetBrains Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-fuel: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-d);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  letter-spacing:-.003em;
}

/* page-wide grid + vignette backdrop */
/* home-screen photo — very back layer, behind the gradient + grid */
.hero-photo{
  position:absolute; top:0; left:0; right:0; height:100svh; z-index:1; pointer-events:none;
  background:url("../assets/hero-bg.jpg") center 22%/cover no-repeat;
  opacity:.7; filter:brightness(1.18) contrast(1.04);
  -webkit-mask-image:linear-gradient(180deg, #000 60%, transparent 100%);
  mask-image:linear-gradient(180deg, #000 60%, transparent 100%);
}

.backdrop{
  position:fixed; inset:0; z-index:0; pointer-events:none;
}
.backdrop::before{
  /* grid overlay — site-wide, stronger */
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(196,188,216,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(196,188,216,.05) 1px, transparent 1px);
  background-size: 88px 88px, 88px 88px;
  mask-image: linear-gradient(180deg, #000 0%, #000 88%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 88%, transparent 100%);
}
.backdrop::after{
  /* site-wide film noise + faint base bloom */
  content:""; position:absolute; inset:0;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"),
    radial-gradient(70% 60% at 50% 120%, rgba(var(--neon-rgb),.05), transparent 60%);
  background-size:200px 200px, cover;
  opacity:.07;
}

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }

/* ----------  TYPE HELPERS  ---------- */
.mono{ font-family:var(--font-m); }
.eyebrow{
  font-family:var(--font-m);
  font-size:12px; letter-spacing:.26em; text-transform:uppercase; font-weight:500;
  color:var(--ink-2); display:inline-flex; align-items:center; gap:11px;
}
.eyebrow::before{
  content:""; width:9px; height:9px; background:var(--neon);
  box-shadow:var(--glow); display:inline-block; border-radius:1px;
}
.eyebrow.c2{ color:var(--ink-2); }
.eyebrow.c2::before{ background:var(--neon-2); box-shadow:var(--glow-2); }

h1,h2,h3{ margin:0; font-family:var(--font-display); font-weight:800; line-height:.98; letter-spacing:-.025em; text-transform:uppercase; }
h1 em, h2 em, h3 em, .serif-em{
  font-family:var(--font-display); font-style:normal; font-weight:800;
  color:var(--neon); letter-spacing:-.025em;
}

/* animated heading — word-by-word mask rise (Fuel-style), gated on .in */
.anim-head{ display:inline-block; }
.anim-head .w{
  display:inline-block; overflow:hidden; vertical-align:top;
  padding-bottom:.14em; margin-bottom:-.14em;
}
.anim-head .w > span{
  display:inline-block; transform:translateY(112%); opacity:0;
  filter:blur(6px);
  transition:transform 1.05s var(--ease-fuel), opacity .8s var(--ease-fuel), filter .8s var(--ease-fuel);
}
.reveal.in .anim-head .w > span,
.anim-head.in .w > span{ transform:translateY(0) !important; opacity:1 !important; filter:blur(0) !important; }
.anim-head .w:nth-child(1) > span{ transition-delay:.03s; }
.anim-head .w:nth-child(2) > span{ transition-delay:.09s; }
.anim-head .w:nth-child(3) > span{ transition-delay:.15s; }
.anim-head .w:nth-child(4) > span{ transition-delay:.21s; }
.anim-head .w:nth-child(5) > span{ transition-delay:.27s; }
.anim-head .w:nth-child(6) > span{ transition-delay:.33s; }
.anim-head .w:nth-child(7) > span{ transition-delay:.39s; }
.anim-head .w:nth-child(8) > span{ transition-delay:.45s; }
.anim-head .w:nth-child(9) > span{ transition-delay:.51s; }
.anim-head .w:nth-child(n+10) > span{ transition-delay:.57s; }
@media (prefers-reduced-motion: reduce){
  .anim-head .w > span{ transform:none; opacity:1; filter:none; transition:none; }
}

.section-index{
  font-family:var(--font-m); font-size:12px; color:var(--ink-3);
  letter-spacing:.2em;
}

/* ----------  LAYOUT  ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
section{ position:relative; z-index:1; }
.sec-pad{ padding-block: clamp(90px, 14vh, 180px); }

.sec-head{ display:flex; flex-direction:column; gap:18px; margin-bottom:56px; }
.sec-head h2{
  font-size:clamp(38px, 6.2vw, 82px);
  text-wrap:balance;
}
.sec-head .lead{
  color:var(--ink-2); max-width:54ch; font-size:clamp(16px,1.5vw,20px);
}

/* HUD corner-bracket frame */
.hud{ position:relative; }
.hud::before,.hud::after{
  content:""; position:absolute; width:14px; height:14px; pointer-events:none;
  border-color:var(--neon); opacity:.7;
}
.hud::before{ top:-1px; left:-1px; border-top:1.5px solid; border-left:1.5px solid; }
.hud::after{ bottom:-1px; right:-1px; border-bottom:1.5px solid; border-right:1.5px solid; }

/* ----------  BUTTONS  ---------- */
.btn{
  font-family:var(--font-m); font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:12px;
  padding:15px 24px; border-radius:999px; cursor:pointer; white-space:nowrap;
  border:1px solid var(--line-2); color:var(--ink);
  background:rgba(255,255,255,.015);
  transition:.35s var(--ease);
  position:relative; overflow:hidden;
}
.btn .dot{ width:7px; height:7px; border-radius:50%; background:var(--neon); box-shadow:var(--glow); }
.btn:hover{ border-color:var(--neon); color:#fff; box-shadow:var(--glow); transform:translateY(-2px); }
.btn.solid{
  background:var(--neon); color:#0a0a0f; border-color:var(--neon);
  box-shadow:var(--glow);
}
.btn.solid .dot{ background:#0a0a0f; box-shadow:none; }
.btn.solid:hover{ background:var(--neon-soft); color:#000; }
.btn .arr{ transition:transform .35s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }

/* wibify-style primary pill — sliding label + fill sweep */
.btn-w{
  --h:58px;
  position:relative; display:inline-flex; align-items:center; gap:0;
  height:var(--h); padding:0; border-radius:999px; cursor:pointer; overflow:hidden;
  border:1px solid var(--neon); background:transparent; color:var(--ink);
  font-family:var(--font-m); font-size:13px; letter-spacing:.16em; text-transform:uppercase; font-weight:500;
  transition:color .4s var(--ease), box-shadow .4s var(--ease);
  isolation:isolate;
}
.btn-w .label{ padding:0 8px 0 26px; position:relative; z-index:2; transition:transform .5s var(--ease); }
.btn-w .ico{
  position:relative; z-index:2; width:var(--h); height:var(--h); flex:none;
  display:grid; place-items:center; border-radius:50%;
  background:var(--neon); color:#0a0a0b; margin-left:6px;
  transition:transform .5s var(--ease), background .4s var(--ease);
}
.btn-w .ico svg{ width:17px; height:17px; transition:transform .5s var(--ease); }
.btn-w::before{
  content:""; position:absolute; inset:0; z-index:1; border-radius:999px;
  background:var(--neon); transform:translateX(-101%); transition:transform .5s var(--ease);
}
.btn-w:hover{ color:#0a0a0b; box-shadow:var(--glow); }
.btn-w:hover::before{ transform:translateX(0); }
.btn-w:hover .ico{ background:#0a0a0b; color:var(--neon); transform:translateX(-4px); }
.btn-w:hover .ico svg{ transform:translateX(3px); }
.btn-w:hover .label{ transform:translateX(4px); }
@media (prefers-reduced-motion: reduce){
  .btn-w::before, .btn-w .label, .btn-w .ico, .btn-w .ico svg{ transition:none; }
}

/* ----------  NAV (Mattis floating pill)  ---------- */
.nav{
  position:fixed; top:18px; left:50%; transform:translateX(-50%); z-index:50;
  width:calc(100% - var(--gut) * 2); max-width:1180px;
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 10px 10px 20px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(12,12,16,.55);
  backdrop-filter:blur(16px) saturate(150%);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  transition:background .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.nav.scrolled{
  background:rgba(10,10,13,.78);
  border-color:var(--line-2);
  box-shadow:0 10px 40px rgba(0,0,0,.5);
}
.brand{ display:flex; align-items:center; gap:12px; font-family:var(--font-m); font-size:14px; letter-spacing:.06em; }
.brand .mark{
  width:32px; height:32px; display:grid; place-items:center;
  border:1px solid var(--neon); color:var(--neon); font-weight:700;
  box-shadow:var(--glow); border-radius:50%; font-size:13px;
}
.brand b{ font-family:var(--font-d); font-weight:600; letter-spacing:-.01em; white-space:nowrap; }
.brand > span{ display:flex; flex-direction:column; line-height:1.25; white-space:nowrap; }
.brand span span{ color:var(--ink-3); font-size:11px; }
.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  font-family:var(--font-m); font-size:12.5px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-2); padding:9px 16px; border-radius:999px; transition:.25s var(--ease);
  position:relative;
}
.nav-links a .ix{ color:var(--neon); margin-right:7px; opacity:.7; font-size:11px; }
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.05); }
.nav-links a.active{ color:#0a0a0b; background:var(--neon); }
.nav-links a.active .ix{ color:#0a0a0b; opacity:.6; }
.nav-links a.active::after{ display:none; }
.nav-cta{ margin-left:8px; }
.burger{ display:none; }

/* ----------  HERO  ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; z-index:1; padding-block:clamp(120px,17vh,170px) clamp(50px,8vh,90px); }
.hero-inner{ position:relative; z-index:2; width:100%; }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:40px; }
.hero-copy{ position:relative; z-index:2; max-width:760px; }

/* global aurora — dynamic moving orange gradient, spans whole site, cursor-reactive */
.aurora-bg{ position:fixed; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.aurora-inner{
  position:absolute; inset:-16%;
  transform:translate3d(calc(var(--px,0) * -28px), calc(var(--py,0) * -28px), 0);
  transition:transform .5s cubic-bezier(.22,.61,.36,1); will-change:transform;
}
.aurora-bg .blob{
  position:absolute; border-radius:50%; filter:blur(70px); mix-blend-mode:screen;
  opacity:.42; will-change:transform;
}
.aurora-bg .b1{
  width:46vw; height:46vw; right:-2vw; top:-6vw;
  background:radial-gradient(circle at 50% 50%, rgba(255,90,46,.85), rgba(255,77,46,.22) 55%, transparent 72%);
  animation:auroraA 18s ease-in-out infinite;
}
.aurora-bg .b2{
  width:40vw; height:40vw; left:-8vw; top:34%;
  background:radial-gradient(circle at 50% 50%, rgba(255,140,60,.6), rgba(255,122,47,.16) 55%, transparent 72%);
  animation:auroraB 23s ease-in-out infinite;
}
.aurora-bg .b3{
  width:34vw; height:34vw; right:18vw; top:52%;
  background:radial-gradient(circle at 50% 50%, rgba(226,58,28,.6), rgba(226,58,28,.14) 55%, transparent 72%);
  animation:auroraC 28s ease-in-out infinite;
}
.aurora-bg .b4{
  width:38vw; height:38vw; left:24vw; bottom:-10vw;
  background:radial-gradient(circle at 50% 50%, rgba(255,100,50,.5), rgba(255,90,46,.12) 55%, transparent 72%);
  animation:auroraA 25s ease-in-out infinite reverse;
}
/* glow that tracks the cursor */
.aurora-cursor{
  position:absolute; left:0; top:0; width:620px; height:620px; border-radius:50%;
  transform:translate3d(calc(var(--cx,50vw) - 310px), calc(var(--cy,50vh) - 310px), 0);
  background:radial-gradient(circle at 50% 50%, rgba(255,110,60,.28), rgba(255,90,46,.08) 45%, transparent 66%);
  filter:blur(40px); mix-blend-mode:screen; will-change:transform;
  transition:transform .2s ease-out;
}
@keyframes auroraA{
  0%,100%{ transform:translate3d(0,0,0) scale(1); }
  33%{ transform:translate3d(-7vw,6vw,0) scale(1.15); }
  66%{ transform:translate3d(-2vw,-5vw,0) scale(.9); }
}
@keyframes auroraB{
  0%,100%{ transform:translate3d(0,0,0) scale(1); }
  40%{ transform:translate3d(7vw,-6vw,0) scale(1.2); }
  70%{ transform:translate3d(-5vw,4vw,0) scale(.95); }
}
@keyframes auroraC{
  0%,100%{ transform:translate3d(0,0,0) scale(1); }
  50%{ transform:translate3d(8vw,7vw,0) scale(1.25); }
}
@media (prefers-reduced-motion: reduce){
  .aurora-bg .blob{ animation:none; }
  .aurora-inner, .aurora-cursor{ transition:none; }
}
.hero-tag{ display:flex; flex-wrap:wrap; gap:10px 18px; align-items:center; margin-bottom:30px; }
.hero-loc{ font-family:var(--font-m); font-size:12px; color:var(--ink-3); letter-spacing:.18em; text-transform:uppercase; }
.hero h1{
  font-size:clamp(46px, 8.4vw, 132px);
  line-height:.9; letter-spacing:-.03em; font-weight:900;
}
.hero h1 .out{
  -webkit-text-stroke:1.4px var(--neon); color:transparent;
  text-shadow:0 0 30px rgba(var(--neon-rgb),.35);
}
.hero .role{
  margin-top:26px; font-family:var(--font-m);
  font-size:clamp(12px,1.4vw,15px); letter-spacing:.22em; text-transform:uppercase;
  color:var(--neon-2); display:flex; align-items:center; gap:14px; flex-wrap:wrap;
}
.hero .role .bar{ height:1px; width:54px; background:var(--neon-2); box-shadow:var(--glow-2); }
.hero .desc{ margin-top:28px; max-width:44ch; color:var(--ink-2); font-size:clamp(15px,1.5vw,18px); }
.hero .cta-row{ margin-top:38px; display:flex; flex-wrap:wrap; gap:14px; }

.hero-stats{
  margin-top:clamp(48px,7vh,80px); display:grid; grid-template-columns:repeat(3,1fr);
  border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  background:rgba(22,19,15,.4);
  backdrop-filter:blur(4px);
}
.stat{ padding:24px clamp(16px,2.4vw,34px); border-left:1px solid var(--line); }
.stat:first-child{ border-left:0; }
.stat .num{ font-size:clamp(34px,4.6vw,60px); font-weight:700; letter-spacing:-.04em; line-height:1; }
.stat .num em{ color:var(--neon); font-style:normal; }
.stat .lbl{ font-family:var(--font-m); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-top:12px; }

.scroll-hint{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3;
  font-family:var(--font-m); font-size:11px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--ink-3); display:flex; flex-direction:column; align-items:center; gap:10px;
}
.scroll-hint .ln{ width:1px; height:42px; background:linear-gradient(var(--neon),transparent); }

/* ----------  ABOUT  ---------- */
.about-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(36px,5vw,80px); align-items:start; }
.portrait-wrap{ position:relative; }
.portrait-frame{
  position:relative; aspect-ratio:4/5; border:1px solid var(--line-2); border-radius:var(--r-lg);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.02) 0 12px, transparent 12px 24px),
    var(--panel);
  overflow:hidden;
}
.portrait-frame image-slot{ width:100%; height:100%; }
.portrait-meta{
  position:absolute; left:14px; bottom:14px; right:14px; z-index:3;
  display:flex; justify-content:space-between; align-items:flex-end;
  font-family:var(--font-m); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2);
  pointer-events:none;
}
.portrait-meta .tag{ color:var(--neon); }
.about-copy p{ color:var(--ink-2); font-size:clamp(16px,1.5vw,20px); margin:0 0 22px; }
.about-copy p strong{ color:var(--ink); font-weight:600; }
.about-copy .big{ color:var(--ink); font-size:clamp(20px,2.4vw,30px); line-height:1.35; letter-spacing:-.01em; margin-bottom:30px; }

.skills{ margin-top:40px; display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; }
.skill-row{ background:var(--bg); padding:18px 20px; display:grid; grid-template-columns:140px 1fr; gap:18px; align-items:baseline; }
.skill-row .k{ font-family:var(--font-m); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--neon-2); }
.skill-row .v{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  font-family:var(--font-m); font-size:12.5px; color:var(--ink-2);
  border:1px solid var(--line-2); padding:6px 11px; border-radius:2px; transition:.25s var(--ease);
}
.chip:hover{ border-color:var(--neon); color:#fff; }

/* ----------  WORK  ---------- */
.work-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.work-card{
  position:relative; border:1px solid var(--line); background:var(--panel); border-radius:var(--r-md);
  overflow:hidden; cursor:pointer; transition:.4s var(--ease);
}
.work-card.big{ grid-column:span 2; }
.work-media{
  position:relative; aspect-ratio:16/9; overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.022) 0 14px, transparent 14px 28px),
    linear-gradient(135deg, var(--panel-2), var(--bg));
  display:grid; place-items:center;
}
.work-card.big .work-media{ aspect-ratio:21/9; }
.work-media .ph{
  font-family:var(--font-m); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3);
  display:flex; flex-direction:column; align-items:center; gap:12px; text-align:center; padding:20px;
}
.work-media .ph .play{
  width:58px; height:58px; border-radius:50%; border:1.5px solid var(--neon);
  display:grid; place-items:center; color:var(--neon); box-shadow:var(--glow); transition:.4s var(--ease);
}
.work-card:hover .play{ transform:scale(1.08); background:var(--neon); color:#000; }
.work-meta{ padding:20px 22px 22px; display:flex; flex-direction:column; gap:10px; }
.work-meta .top{ display:flex; justify-content:space-between; align-items:center; gap:14px; }
.work-meta h3{ font-size:clamp(19px,2vw,26px); letter-spacing:-.01em; }
.work-meta .cat{ font-family:var(--font-m); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--neon); white-space:nowrap; }
.work-meta .sub{ color:var(--ink-2); font-size:15px; }
.work-tags{ display:flex; flex-wrap:wrap; gap:7px; margin-top:6px; }
.work-tags span{ font-family:var(--font-m); font-size:11px; color:var(--ink-3); border:1px solid var(--line); padding:4px 9px; }
.work-card:hover{ border-color:var(--line-2); transform:translateY(-3px); }
.work-card::after{
  content:""; position:absolute; left:0; top:0; height:2px; width:0; background:var(--neon);
  box-shadow:var(--glow); transition:width .5s var(--ease);
}
.work-card:hover::after{ width:100%; }

/* ----------  WORK SEGMENTS + CAROUSELS  ---------- */
.work-segment{ margin-top:8px; }
.work-segment + .work-segment{ margin-top:clamp(54px,8vh,92px); }
.seg-head{ display:flex; align-items:center; gap:18px; margin-bottom:26px; flex-wrap:wrap; }
.seg-head h3{ font-size:clamp(22px,3vw,36px); font-weight:600; letter-spacing:-.02em; }
.seg-head h3 em{ color:var(--neon); font-style:normal; }
.seg-head .meta{ font-family:var(--font-m); font-size:11.5px; color:var(--ink-3); letter-spacing:.1em; text-transform:uppercase; }
.seg-head .rule{ flex:1; height:1px; background:var(--line); min-width:30px; }
.seg-nav{ display:flex; gap:8px; }
.seg-nav button{
  width:42px; height:42px; border-radius:50%; border:1px solid var(--line-2); background:rgba(255,255,255,.02);
  color:var(--ink); cursor:pointer; display:grid; place-items:center; font-size:15px; transition:.25s var(--ease);
}
.seg-nav button:hover{ border-color:var(--neon); color:#fff; box-shadow:var(--glow); }
.seg-nav button:disabled{ opacity:.3; cursor:default; box-shadow:none; border-color:var(--line); }

.carousel{ position:relative; }
.carousel-track{
  display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding:4px 2px 18px; scroll-behavior:smooth; scrollbar-width:thin;
  scrollbar-color:var(--neon) transparent;
}
.carousel-track::-webkit-scrollbar{ height:6px; }
.carousel-track::-webkit-scrollbar-track{ background:var(--line); border-radius:3px; }
.carousel-track::-webkit-scrollbar-thumb{ background:var(--neon); border-radius:3px; }
.carousel-track > .work-card{ flex:0 0 auto; scroll-snap-align:start; }
.carousel-track.long > .work-card{ width:clamp(300px, 34vw, 440px); }
.carousel-track.short > .work-card{ width:clamp(190px, 21vw, 250px); }

/* vertical (short form) cards */
.work-card.vert .work-media{ aspect-ratio:9/16; }
.work-card.vert .work-meta{ padding:15px 16px 18px; gap:6px; }
.work-card.vert .work-meta h3{ font-size:clamp(15px,1.4vw,18px); }
.work-card.vert .work-meta .sub{ font-size:13px; line-height:1.5; }
.platform{
  position:absolute; top:12px; left:12px; z-index:2; font-family:var(--font-m); font-size:10px;
  letter-spacing:.1em; text-transform:uppercase; color:var(--ink); background:rgba(7,7,12,.6);
  border:1px solid var(--line-2); padding:5px 9px; border-radius:2px; backdrop-filter:blur(6px);
}

/* AI Gen sub-block */
.ai-block{ margin-top:clamp(38px,6vh,60px); }
.ai-head{ display:flex; align-items:center; gap:14px; margin-bottom:22px; flex-wrap:wrap; }
.ai-badge{
  font-family:var(--font-m); font-size:11px; letter-spacing:.16em; text-transform:uppercase; font-weight:600;
  color:var(--neon); border:1px solid var(--neon); padding:7px 13px; border-radius:2px;
  display:inline-flex; align-items:center; gap:9px; background:rgba(var(--neon-rgb),.08); box-shadow:var(--glow);
}
.ai-badge .spark{ width:7px; height:7px; border-radius:50%; background:var(--neon); box-shadow:var(--glow); }
.ai-head .desc{ color:var(--ink-3); font-size:13px; font-family:var(--font-m); letter-spacing:.04em; }
.ai-block .work-card.vert{ border-style:dashed; }
.ai-block .platform{ color:var(--neon); border-color:rgba(var(--neon-rgb),.45); }

/* ----------  VIDEO CARDS + LIGHTBOX  ---------- */
.video-card{ cursor:pointer; }
.video-card .work-media{ aspect-ratio:16/9; padding:0; }
/* Fuel-style hover overlay: dark wash slides up on hover */
.video-card .work-media::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(0deg, rgba(7,7,12,.72) 0%, rgba(7,7,12,.12) 45%, transparent 70%);
  opacity:0; transition:opacity .5s var(--ease-fuel);
}
.video-card:hover .work-media::before{ opacity:1; }
.video-card.vert .work-media{ aspect-ratio:9/16; }
.video-card .vthumb{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform .55s var(--ease), filter .4s var(--ease);
  filter:saturate(.92) brightness(.86);
}
.video-card:hover .vthumb{ transform:scale(1.05); filter:saturate(1.05) brightness(1); }
.video-card .work-media::after{ z-index:1; }
.video-card .vtag{
  position:absolute; top:12px; left:12px; z-index:3; font-family:var(--font-m); font-size:10px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink); background:rgba(7,7,12,.66);
  border:1px solid var(--line-2); padding:5px 9px; border-radius:2px; backdrop-filter:blur(6px);
}
.video-card .vtag.live{ color:#0a0a0b; background:var(--neon); border-color:var(--neon); font-weight:600; }
.video-card .vplay{
  position:absolute; z-index:3; inset:0; margin:auto; width:62px; height:62px; border-radius:50%;
  display:grid; place-items:center; color:#0a0a0b; background:var(--neon);
  box-shadow:var(--glow); transition:transform .4s var(--ease), background .3s var(--ease);
}
.video-card .vplay svg{ width:26px; height:26px; margin-left:3px; }
.video-card:hover .vplay{ transform:scale(1.12); background:var(--neon-soft); }
.video-card .work-meta{ padding:15px 18px 17px; }
.video-card .work-meta .top{ align-items:center; }
.video-card .work-meta h3{ font-size:17px; }
.video-card .work-meta .cat{ color:var(--neon); }

.lightbox{
  position:fixed; inset:0; z-index:100; display:none; place-items:center;
  background:rgba(5,5,7,.9); backdrop-filter:blur(10px); padding:clamp(16px,5vw,60px);
}
.lightbox.open{ display:grid; }
.lb-frame{
  position:relative; width:min(1100px,100%); aspect-ratio:16/9;
  border:1px solid var(--line-2); border-radius:var(--r-md); overflow:hidden; box-shadow:0 30px 90px rgba(0,0,0,.6);
  background:#000; animation:lbpop .4s var(--ease);
}
.lightbox.short .lb-frame{ width:auto; height:min(84vh,820px); aspect-ratio:9/16; max-width:100%; }
@keyframes lbpop{ from{ opacity:0; transform:scale(.96) translateY(10px); } to{ opacity:1; transform:none; } }
.lb-embed, .lb-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.lb-close{
  position:absolute; top:clamp(16px,3vw,30px); right:clamp(16px,3vw,30px); z-index:2;
  width:46px; height:46px; border-radius:50%; border:1px solid var(--line-2); background:rgba(7,7,12,.7);
  color:var(--ink); font-size:16px; cursor:pointer; transition:.25s var(--ease);
}
.lb-close:hover{ border-color:var(--neon); color:#fff; box-shadow:var(--glow); transform:rotate(90deg); }

/* ----------  TIMELINE (3D path)  ---------- */
.timeline-section{ overflow:hidden; }
.tl-stage{ position:relative; perspective:1400px; }
.tl-track{ position:relative; transform-style:preserve-3d; }
.tl-spine{
  position:absolute; left:50%; top:0; bottom:0; width:2px; transform:translateX(-50%);
  background:linear-gradient(var(--line) 0%, var(--line) 100%);
}
.tl-spine .fill{
  position:absolute; left:0; top:0; width:100%; height:var(--tl-progress,0%);
  background:linear-gradient(var(--neon), var(--neon-2));
  box-shadow:0 0 16px rgba(var(--neon-rgb),.6);
}
.tl-item{
  position:relative; width:50%; padding:26px 46px; margin-bottom:28px;
  transform-style:preserve-3d;
}
.tl-item.left{ left:0; text-align:right; }
.tl-item.right{ left:50%; }
.tl-node{
  position:absolute; top:34px; width:15px; height:15px; border-radius:50%;
  background:var(--bg); border:2px solid var(--neon); box-shadow:var(--glow); z-index:3;
}
.tl-item.left .tl-node{ right:-7.5px; }
.tl-item.right .tl-node{ left:-7.5px; }
.tl-card{
  display:inline-block; text-align:left; border:1px solid var(--line); border-radius:var(--r-md);
  background:var(--panel); padding:22px 24px; min-width:min(420px,100%);
  transition:.45s var(--ease); position:relative;
}
.tl-item.left .tl-card{ text-align:right; }
.tl-card:hover{ border-color:var(--neon); transform:translateZ(34px); box-shadow:0 24px 60px rgba(0,0,0,.5), var(--glow); }
.tl-date{ font-family:var(--font-m); font-size:12px; letter-spacing:.1em; color:var(--neon-2); text-transform:uppercase; }
.tl-role{ font-size:clamp(18px,1.8vw,23px); margin:8px 0 4px; letter-spacing:-.01em; }
.tl-co{ font-family:var(--font-m); font-size:13px; color:var(--ink-2); }
.tl-co em{ color:var(--neon); font-style:normal; }
.tl-desc{ color:var(--ink-2); font-size:14.5px; margin-top:12px; line-height:1.55; }

/* ----------  CLIENTS / LOGO WALL  ---------- */
.marquee{ overflow:hidden; border-block:1px solid var(--line); padding:0; position:relative; border-radius:var(--r-lg); margin-inline:var(--gut); width:auto; }
.marquee::before,.marquee::after{
  content:""; position:absolute; top:0; bottom:0; width:14vw; z-index:2; pointer-events:none;
}
.marquee::before{ left:0; background:linear-gradient(90deg,var(--bg),transparent); }
.marquee::after{ right:0; background:linear-gradient(270deg,var(--bg),transparent); }
.marquee-row{ display:flex; gap:0; width:max-content; animation:scrollx 38s linear infinite; }
.marquee-row.rev{ animation-direction:reverse; animation-duration:46s; }
.marquee:hover .marquee-row{ animation-play-state:paused; }
.logo-cell{
  display:flex; align-items:center; gap:14px; padding:30px 46px; white-space:nowrap;
  border-right:1px solid var(--line);
}
.logo-cell .wm{
  font-family:var(--font-d); font-weight:600; font-size:clamp(20px,2.4vw,30px);
  letter-spacing:-.01em; color:var(--ink-2); transition:.3s var(--ease);
}
.logo-cell .wm.mono{ font-family:var(--font-m); font-weight:500; letter-spacing:.02em; }
.logo-cell:hover .wm{ color:#fff; text-shadow:0 0 18px rgba(var(--neon-rgb),.6); }
.logo-cell .reg{ font-family:var(--font-m); font-size:11px; color:var(--neon); align-self:flex-start; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }

.clients-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:30px; }

/* ----------  TESTIMONIALS  ---------- */
.tst-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tst{
  border:1px solid var(--line); background:var(--panel); padding:30px 28px; border-radius:var(--r-md);
  display:flex; flex-direction:column; gap:22px; transition:.4s var(--ease); position:relative;
}
.tst:hover{ border-color:var(--line-2); transform:translateY(-4px); }
.tst .quote-mark{ font-family:var(--font-m); color:var(--neon); font-size:34px; line-height:.6; }
.tst p{ margin:0; color:var(--ink); font-size:16.5px; line-height:1.6; flex:1; }
.tst .who{ display:flex; align-items:center; gap:14px; }
.tst .av{
  width:42px; height:42px; border-radius:50%; border:1px solid var(--neon-2);
  display:grid; place-items:center; font-family:var(--font-m); font-size:13px; color:var(--neon-2);
  flex:none;
}
.tst .who .n{ font-size:15px; font-weight:600; line-height:1.2; }
.tst .who .r{ font-family:var(--font-m); font-size:11.5px; color:var(--ink-3); letter-spacing:.04em; }
.placeholder-note{ font-family:var(--font-m); font-size:11px; color:var(--ink-3); margin-top:22px; letter-spacing:.06em; }

/* ----------  CONTACT  ---------- */
.contact{ position:relative; }
.contact-card{
  border:1px solid var(--line-2); background:linear-gradient(160deg, var(--panel-2), var(--bg)); border-radius:var(--r-lg);
  padding:clamp(34px,5vw,72px); position:relative; overflow:hidden;
}
.contact-card::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(60% 80% at 90% 10%, rgba(var(--neon-rgb),.14), transparent 60%);
}
.contact-grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(30px,5vw,70px); align-items:center; position:relative; }
.contact h2{ font-size:clamp(36px,6vw,82px); letter-spacing:-.03em; line-height:.98; }
.contact h2 em{ color:transparent; -webkit-text-stroke:1.4px var(--neon); font-style:normal; }
.contact .sub{ color:var(--ink-2); margin-top:24px; max-width:42ch; font-size:18px; }
.avail{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-m); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--neon-2); margin-bottom:26px; }
.avail .pulse{ width:9px; height:9px; border-radius:50%; background:var(--neon-2); box-shadow:var(--glow-2); animation:pulse 2s infinite; }
@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

.contact-list{ display:flex; flex-direction:column; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; }
.cl-row{ background:var(--bg); padding:18px 20px; display:flex; align-items:center; justify-content:space-between; gap:16px; transition:.3s var(--ease); }
.cl-row:hover{ background:var(--panel); }
.cl-row .k{ font-family:var(--font-m); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.cl-row .v{ font-size:15.5px; display:flex; align-items:center; gap:10px; }
.cl-row:hover .v{ color:#fff; }
.cl-row .arr{ color:var(--neon); opacity:0; transform:translateX(-6px); transition:.3s var(--ease); }
.cl-row:hover .arr{ opacity:1; transform:translateX(0); }

/* ----------  FOOTER  ---------- */
.footer{ border-top:1px solid var(--line); padding:40px var(--gut); position:relative; z-index:1; }
.footer-in{ max-width:var(--maxw); margin:0 auto; display:flex; flex-wrap:wrap; gap:18px; justify-content:space-between; align-items:center; }
.footer .mono{ font-size:12px; color:var(--ink-3); letter-spacing:.08em; }
.footer a:hover{ color:var(--neon); }

/* ----------  SCROLL REVEAL (Fuel appear effect)  ---------- */
.reveal{ opacity:0; transform:translateY(40px); filter:blur(8px); transition:opacity 1s var(--ease-fuel), transform 1.1s var(--ease-fuel), filter 1s var(--ease-fuel); }
.reveal.in{ opacity:1; transform:none; filter:blur(0); }
.reveal.d1{ transition-delay:.09s; }
.reveal.d2{ transition-delay:.18s; }
.reveal.d3{ transition-delay:.27s; }

/* staggered children — set via [data-stagger]; each child rises in sequence */
[data-stagger] > *{ opacity:0; transform:translateY(42px); filter:blur(8px); transition:opacity .9s var(--ease-fuel), transform 1s var(--ease-fuel), filter .9s var(--ease-fuel); transition-delay:calc(var(--i,0) * .08s); }
[data-stagger].in > *{ opacity:1; transform:none; filter:blur(0); }

/* scroll-scale media (Fuel) — driven by JS var --p (0..1) */
[data-scale]{ will-change:transform; transform:scale(var(--scale,.9)); border-radius:var(--r-scale,26px); overflow:hidden; transition:none; }

/* scroll progress bar */
.scroll-prog{ position:fixed; top:0; left:0; height:2px; width:100%; transform:scaleX(var(--sp,0)); transform-origin:0 50%; background:linear-gradient(90deg, var(--neon), var(--neon-2)); box-shadow:var(--glow); z-index:60; pointer-events:none; }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; filter:none; transition:none; }
  [data-stagger] > *{ opacity:1; transform:none; filter:none; transition:none; }
  [data-scale]{ transform:none; }
  .marquee-row{ animation:none; }
}

/* failsafe: when the page renders while hidden (transitions freeze at 0),
   snap reveal content to its final visible state */
html.reveal-off .reveal,
html.reveal-off [data-stagger] > *,
html.reveal-off .anim-head .w > span{
  opacity:1 !important; transform:none !important; filter:none !important; transition:none !important;
}

/* ----------  RESULTS / LIVE GRAPH  ---------- */
.results-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,4vw,60px); margin-bottom:8px; }
.rstat .num{ font-size:clamp(48px,7vw,104px); font-weight:700; letter-spacing:-.04em; line-height:.9; }
.rstat .num em{ font-style:normal; color:var(--ink); }
.rstat .lbl{ font-family:var(--font-m); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); margin-top:16px; display:inline-flex; align-items:center; gap:10px; }
.rstat .lbl::before{ content:""; width:11px; height:11px; border-radius:2px; background:var(--neon); box-shadow:var(--glow); }
.rstat.s2 .lbl::before{ background:var(--neon-2); box-shadow:var(--glow-2); }
.rstat.s3 .lbl::before{ background:var(--neon-2-soft); box-shadow:none; opacity:.7; }
.rstat .sub{ font-family:var(--font-m); font-size:12px; color:var(--ink-3); margin-top:8px; letter-spacing:.02em; }

.graph-wrap{
  position:relative; margin-top:clamp(30px,6vh,70px); border:1px solid var(--line);
  border-radius:var(--r-lg); overflow:hidden; background:linear-gradient(180deg, var(--panel) 0%, var(--bg) 100%);
}
.graph-wrap svg{ display:block; width:100%; height:auto; }
.graph-grid line{ stroke:var(--line); stroke-width:1; }
.graph-area{ fill:url(#areaGrad); opacity:0; transition:opacity 1.2s ease .6s; }
.graph-line{
  fill:none; stroke:var(--neon); stroke-width:3; stroke-linecap:round; stroke-linejoin:round;
  filter:drop-shadow(0 0 8px rgba(var(--neon-rgb),.55));
  stroke-dasharray:var(--len); stroke-dashoffset:var(--len);
}
.in .graph-line{ animation:draw 2.4s var(--ease) forwards; }
.in .graph-area{ opacity:1; }
@keyframes draw{ to{ stroke-dashoffset:0; } }
.graph-end{ opacity:0; }
.in .graph-end{ animation:fadeIn .5s ease 2.1s forwards; }
@keyframes fadeIn{ to{ opacity:1; } }
.graph-dot-core{ fill:#fff; }
.graph-dot-ring{ fill:none; stroke:var(--neon); stroke-width:2; transform-box:fill-box; transform-origin:center; }
.in .graph-dot-ring{ animation:blink 1.6s ease-in-out 2.1s infinite; }
@keyframes blink{ 0%,100%{ opacity:1; r:7px; } 50%{ opacity:.25; r:11px; } }
.graph-badge rect{ fill:rgba(10,10,11,.7); stroke:var(--neon); stroke-width:1; }
.graph-badge text{ fill:var(--neon); font-family:var(--font-m); font-size:15px; font-weight:600; letter-spacing:.04em; }
.graph-vline{ stroke:var(--neon); stroke-width:1; stroke-dasharray:3 4; opacity:.4; }
.graph-eyebrow{ position:absolute; top:22px; left:24px; z-index:2; }
.graph-pulse{ fill:var(--neon); }
.in .graph-pulse{ animation:pulseDot 1.6s ease-in-out 2.1s infinite; }
@keyframes pulseDot{ 0%,100%{ opacity:.9; } 50%{ opacity:.2; } }

/* ----------  PROCESS / A→Z  ---------- */
.process-head{ display:grid; grid-template-columns:1.3fr .7fr; gap:30px 60px; align-items:end; margin-bottom:34px; }
.process-head .lead{ color:var(--ink-2); font-size:clamp(16px,1.6vw,20px); max-width:46ch; }
.process-sub{ display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-bottom:22px; }
.handoffs-badge{ font-family:var(--font-m); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--neon); border:1px solid var(--neon); border-radius:6px; padding:10px 16px; box-shadow:var(--glow); }
.proc-board{
  position:relative; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  background:
    linear-gradient(rgba(210,214,180,.04) 1px, transparent 1px) 0 0/100% 56px,
    linear-gradient(90deg, rgba(210,214,180,.04) 1px, transparent 1px) 0 0/56px 100%,
    linear-gradient(160deg, var(--panel) 0%, var(--bg) 100%);
  padding:clamp(34px,6vw,72px) clamp(24px,4vw,54px);
}
.proc-ghost{ position:absolute; left:2%; top:50%; transform:translateY(-50%); font-family:var(--font-serif); font-style:italic; font-size:clamp(140px,26vw,360px); color:rgba(210,214,180,.035); line-height:1; pointer-events:none; user-select:none; z-index:0; }
.proc-flow{ position:relative; z-index:1; display:flex; align-items:flex-start; justify-content:space-between; gap:14px; }
.proc-flow::before{ content:""; position:absolute; top:34px; left:34px; right:34px; height:1px; background:var(--line); z-index:0; }
.proc-prog{ position:absolute; top:34px; left:34px; height:1px; background:var(--neon); box-shadow:var(--glow); width:0; transition:width 1.4s var(--ease) .3s; z-index:1; }
.in .proc-prog{ width:var(--pw, 80%); }
.proc-step{ position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; gap:14px; text-align:center; flex:1; min-width:0; }
.proc-node{
  width:68px; height:68px; border-radius:var(--r-sm); border:1px solid var(--line-2); background:var(--bg);
  display:grid; place-items:center; position:relative; transition:.4s var(--ease); color:var(--ink);
}
.proc-node svg{ width:26px; height:26px; }
.proc-node .corner{ position:absolute; bottom:6px; right:8px; font-family:var(--font-m); font-size:9px; color:var(--ink-3); letter-spacing:.05em; }
.proc-step:hover .proc-node{ border-color:var(--neon); transform:translateY(-4px); box-shadow:var(--glow); }
.proc-step.live .proc-node{ background:var(--neon); color:#0a0a0b; border-color:var(--neon); box-shadow:var(--glow); }
.proc-step.live .proc-node .corner{ color:rgba(10,10,11,.6); }
.proc-name{ font-family:var(--font-m); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); }
.proc-tag{ font-family:var(--font-m); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }

/* ----------  RESPONSIVE  ---------- */
@media (max-width: 1000px){
  .about-grid{ grid-template-columns:1fr; }
  .portrait-wrap{ max-width:440px; }
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero-media{ order:-1; }
  .hero-media-frame{ aspect-ratio:16/10; max-height:46vh; }
  .contact-grid{ grid-template-columns:1fr; }
  .tst-grid{ grid-template-columns:1fr; }
  .work-grid{ grid-template-columns:1fr; }
  .work-card.big{ grid-column:span 1; }
  .work-card.big .work-media{ aspect-ratio:16/9; }
}
@media (max-width: 860px){
  /* nav → brand + burger only */
  .nav-links{ display:none; }
  .nav-cta{ display:none; }
  .burger{ display:grid; }
  .nav{ padding:9px 9px 9px 16px; top:12px; }
}

@media (max-width: 760px){
  body{ font-size:16px; }
  .sec-pad{ padding-block:clamp(64px,10vh,96px); }
  .sec-head{ margin-bottom:38px; }
  /* CRITICAL: stop vertical-centering the hero — tall content was clipping
     off the top of the screen with no way to scroll up. Anchor to the top. */
  .hero{ align-items:flex-start; min-height:auto; padding-block:clamp(96px,16vh,128px) clamp(40px,7vh,70px); }
  /* hero copy must stay readable over the photo */
  .hero-copy{ max-width:100%; }
  .hero .desc{ max-width:100%; }
  .hero-photo{ height:100svh; opacity:.42; background-position:center 18%; }
  /* lighter compositing for smoother mobile scroll */
  .aurora-bg .blob{ filter:blur(52px); }
  .hero-stats{ grid-template-columns:1fr; margin-top:40px; }
  .stat{ border-left:0; border-top:1px solid var(--line); display:flex; align-items:baseline; justify-content:space-between; gap:16px; padding:18px 20px; }
  .stat:first-child{ border-top:0; }
  .stat .lbl{ margin-top:0; text-align:right; }
  .skill-row{ grid-template-columns:1fr; gap:10px; }
  /* full-width, comfortable CTAs */
  .cta-row{ width:100%; }
  .cta-row .btn, .cta-row .btn-w{ flex:1 1 auto; justify-content:center; min-height:54px; }
  /* timeline collapses to single column */
  .tl-spine{ left:7px; }
  .tl-item{ width:100%; left:0 !important; text-align:left !important; padding:0 0 0 38px; margin-bottom:24px; }
  .tl-item .tl-card{ text-align:left !important; min-width:0; width:100%; }
  .tl-item .tl-node{ left:0 !important; right:auto !important; }
  /* results + process */
  .results-stats{ grid-template-columns:1fr; gap:30px; }
  .process-head{ grid-template-columns:1fr; }
  .proc-flow{ overflow-x:auto; justify-content:flex-start; gap:26px; padding-bottom:10px; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; }
  .proc-flow::before, .proc-prog{ display:none; }
  .proc-step{ flex:0 0 auto; width:96px; scroll-snap-align:start; }
  /* carousels: peek next card so swipe is discoverable */
  .carousel-track.long > .work-card{ width:clamp(260px, 82vw, 360px); }
  .carousel-track.short > .work-card{ width:clamp(150px, 46vw, 210px); }
  /* contact list rows stack label/value */
  .contact h2{ font-size:clamp(34px,11vw,56px); }
}

@media (max-width: 480px){
  :root{ --gut:18px; }
  .brand b{ font-size:13px; }
  .brand span span{ font-size:9px; }
  .brand .mark{ width:30px; height:30px; }
  .hero h1{ font-size:clamp(42px,13vw,72px); }
  .hero .role{ letter-spacing:.16em; }
  .cta-row{ flex-direction:column; }
  .cta-row .btn, .cta-row .btn-w{ width:100%; }
  .sec-head .eyebrow{ font-size:11px; }
  /* graph keeps a usable height */
  .graph-wrap svg{ min-height:260px; }
  .graph-eyebrow{ font-size:10px; top:14px; left:16px; }
  /* testimonial + cards a touch tighter */
  .tst{ padding:26px 22px; }
  .contact-card{ padding:30px 22px; }
  .cl-row{ flex-wrap:wrap; gap:4px 16px; }
  /* marquee text not too huge */
  .logo-cell .wm{ font-size:clamp(20px,7vw,26px); }
  .mobile-menu a{ font-size:26px; }
}

/* mobile menu overlay */
.mobile-menu{
  position:fixed; inset:0; z-index:60; background:rgba(11,10,9,.97);
  backdrop-filter:blur(14px); display:none; flex-direction:column; padding:104px var(--gut) 40px; gap:6px;
}
.mobile-menu.open{ display:flex; }
.mobile-menu a{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; font-size:clamp(30px,9vw,44px); padding:18px 0; border-bottom:1px solid var(--line); display:flex; gap:16px; align-items:baseline; color:var(--ink); transition:color .25s var(--ease), padding-left .25s var(--ease); }
.mobile-menu a:hover, .mobile-menu a:active{ color:var(--neon); padding-left:8px; }
.mobile-menu a .ix{ font-family:var(--font-m); font-weight:500; font-size:13px; color:var(--neon); }
.burger{
  width:46px; height:46px; place-items:center; border:1px solid var(--line-2); background:rgba(255,255,255,.02); cursor:pointer; border-radius:50%;
}
.burger span{ display:block; width:18px; height:1.6px; background:var(--ink); margin:3px 0; transition:.3s; }
.close-x{ position:absolute; top:18px; right:var(--gut); width:46px; height:46px; border:1px solid var(--line-2); background:rgba(255,255,255,.02); color:var(--ink); cursor:pointer; font-family:var(--font-m); font-size:12px; border-radius:50%; }
