  :root{
    --gunmetal:#232628;
    --gunmetal-2:#2e3133;
    --cream:#FDF6E2;
    --cream-2:#f4ecd5;
    --ink-60:rgba(35,38,40,.62);
    --ink-40:rgba(35,38,40,.42);
    --ink-15:rgba(35,38,40,.15);
    --ink-08:rgba(35,38,40,.08);
    --cream-60:rgba(253,246,226,.62);
    --cream-40:rgba(253,246,226,.40);
    --cream-15:rgba(253,246,226,.15);
    --display:"Funnel Display","Futura PT",ui-sans-serif,system-ui,sans-serif;
    --sans:"Funnel Sans","Futura PT","Futura CYR Book",ui-sans-serif,system-ui,sans-serif;
    --radius:0;
    --radius-lg:0;
  }
  *,*::before,*::after{box-sizing:border-box}
  html,body{margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--cream);
    color:var(--gunmetal);
    font-family:var(--sans);
    font-weight:400;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    font-feature-settings:"ss01","cv11";
    overflow-x:hidden;
  }
  ::selection{background:var(--gunmetal);color:var(--cream)}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

  /* ---------- Layout ---------- */
  .wrap{max-width:1320px;margin:0 auto;padding:0 32px}
  @media (max-width:720px){ .wrap{padding:0 20px} }

  h1,h2,h3,h4{font-family:var(--display);font-weight:400;letter-spacing:-0.02em;margin:0;color:var(--gunmetal)}
  h1{font-size:clamp(48px,8.2vw,128px);line-height:.94;letter-spacing:-0.035em}
  h2{font-size:clamp(36px,5.4vw,80px);line-height:1.02;letter-spacing:-0.028em}
  h3{font-size:clamp(26px,2.6vw,40px);line-height:1.08;letter-spacing:-0.02em}
  h4{font-size:20px;line-height:1.2}
  p{margin:0;line-height:1.5}
  .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.02em}

  .eyebrow{
    font-family:var(--sans);
    text-transform:uppercase;
    letter-spacing:.18em;
    font-size:12px;
    font-weight:500;
    color:var(--ink-60);
    display:inline-flex;align-items:center;gap:10px;
  }
  .eyebrow::before{
    content:"";width:6px;height:6px;border-radius:50%;background:var(--gunmetal);
  }

  /* ---------- Nav ---------- */
  .nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    padding:18px 0;
    transition:background .35s ease, border-color .35s ease, padding .35s ease;
    border-bottom:1px solid transparent;
  }
  .nav.scrolled{
    background:rgba(253,246,226,.78);
    backdrop-filter:saturate(160%) blur(14px);
    -webkit-backdrop-filter:saturate(160%) blur(14px);
    border-bottom-color:var(--ink-08);
    padding:12px 0;
  }
  .nav-row{display:flex;align-items:center;justify-content:space-between;gap:24px}
  .brand{display:flex;align-items:center;gap:10px}
  /* --- Logo lockup: icon + wordmark, optically balanced --- */
  /* Icon is square so its mass reads heavier; size it SHORTER than the wordmark height. */
  .brand img.icon{height:22px;width:auto;display:block}
  .brand img.wordmark{height:26px;width:auto;display:block}
  .nav.scrolled .brand img.icon{height:19px}
  .nav.scrolled .brand img.wordmark{height:22px}
  .nav-links{display:flex;align-items:center;gap:6px}
  .nav-links a{
    padding:8px 14px;border-radius:0;color:var(--gunmetal);font-size:14.5px;
    transition:background .2s ease, color .2s ease;
  }
  .nav-links a:hover{background:var(--ink-08)}
  .nav-cta{display:flex;align-items:center;gap:10px}
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:12px 20px;border-radius:0;
    font-size:14.5px;font-weight:500;
    transition:transform .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
    border:1px solid transparent;line-height:1;
    white-space:nowrap;
  }
  .btn-ghost{color:var(--gunmetal);border-color:var(--ink-15)}
  .btn-ghost:hover{background:var(--ink-08)}
  .btn-primary{background:var(--gunmetal);color:var(--cream)}
  .btn-primary:hover{transform:translateY(-1px);box-shadow:0 18px 40px -18px rgba(35,38,40,.55)}
  .btn-cream{background:var(--cream);color:var(--gunmetal)}
  .btn-cream:hover{transform:translateY(-1px)}
  .btn .arr{display:inline-block;transition:transform .25s ease}
  .btn:hover .arr{transform:translate(2px,-2px)}
  @media (max-width:880px){ .nav-links{display:none} .nav-cta .btn-ghost{display:none} }

  /* ---------- Hero ---------- */
  .hero{position:relative;padding:148px 0 96px;overflow:hidden}
  .hero-grain{
    position:absolute;inset:-10% -5% auto -5%;height:120%;z-index:0;pointer-events:none;
    background:
      radial-gradient(60% 50% at 78% 20%, rgba(202,170,118,.55), transparent 60%),
      radial-gradient(50% 50% at 18% 12%, rgba(178,194,196,.50), transparent 65%),
      radial-gradient(70% 60% at 50% 110%, rgba(35,38,40,.18), transparent 70%);
    filter:blur(40px) saturate(110%);
    opacity:.95;
  }
  .hero-grid{
    position:relative;z-index:1;
    display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;
  }
  @media (max-width:1024px){ .hero-grid{grid-template-columns:1fr;gap:40px} }
  .hero h1{max-width:14ch;font-size:clamp(44px,5.8vw,88px)}
  .hero h1 em{font-style:normal;font-family:var(--display);font-weight:300;color:var(--ink-60)}
  .hero-sub{
    margin-top:24px;max-width:46ch;font-size:clamp(16px,1.2vw,19px);color:var(--ink-60);line-height:1.5;
  }
  .hero-meta{
    margin-top:32px;display:flex;flex-wrap:wrap;gap:12px;align-items:center;
  }
  .hero-strip{
    margin-top:96px;display:flex;align-items:center;gap:48px;flex-wrap:wrap;
    color:var(--ink-40);
    grid-column:1 / -1;
    min-width:0;
    width:100%;
  }
  .hero-strip .lbl{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-60)}
  .logos{display:flex;align-items:center;gap:44px;flex-wrap:wrap;opacity:.78}
  .logos span{font-family:var(--display);font-size:22px;letter-spacing:-.01em;color:var(--gunmetal);opacity:.55}
  .logos .l-sans{font-family:var(--sans);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:14px}

  /* ---------- Showcase panel ---------- */
  .showcase{
    position:relative;
    border-radius:0;
    overflow:hidden;
    width:100%;
    aspect-ratio: 4/3.2;
    max-height:560px;
    background:#15171a;
    box-shadow:0 40px 80px -40px rgba(35,38,40,.45), 0 6px 20px -10px rgba(35,38,40,.2);
  }
  @media (max-width:1024px){ .showcase{max-width:640px;margin:0 auto;aspect-ratio:4/3} }
  .showcase-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-image:url("assets/gradient-hero.webp");transform:scale(1.05)}
  .showcase-veil{position:absolute;inset:0;background:linear-gradient(180deg, rgba(35,38,40,0) 0%, rgba(35,38,40,.35) 70%, rgba(35,38,40,.7) 100%)}
  .showcase-ui{
    position:absolute;inset:0;display:grid;grid-template-rows:1fr auto;padding:28px 32px;color:var(--cream);
  }
  .chip{
    display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:0;
    background:rgba(253,246,226,.14);border:1px solid rgba(253,246,226,.22);
    font-size:12px;letter-spacing:.04em;
    backdrop-filter:blur(8px);
  }
  .chip .dot{width:7px;height:7px;border-radius:50%;background:#9be3a2;box-shadow:0 0 0 4px rgba(155,227,162,.18)}
  .showcase-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
  .showcase-title{font-family:var(--display);font-size:clamp(22px,2.4vw,36px);line-height:1.05;letter-spacing:-.02em;max-width:24ch}
  .showcase-stats{display:flex;gap:36px;flex-wrap:wrap}
  .showcase-stat .n{font-family:var(--display);font-size:clamp(28px,3vw,44px);line-height:1}
  .showcase-stat .l{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-60);margin-top:6px}

  /* ---------- Section spacing ---------- */
  section{padding:120px 0;position:relative}
  @media (max-width:720px){ section{padding:80px 0} }
  .section-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:64px}
  .section-head .lead{max-width:48ch;color:var(--ink-60);font-size:18px;line-height:1.5}
  @media (max-width:880px){ .section-head{grid-template-columns:1fr} }

  /* ---------- Agents ---------- */
  .agents{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
  @media (max-width:1024px){ .agents{grid-template-columns:repeat(2,1fr)} }
  @media (max-width:560px){ .agents{grid-template-columns:1fr} }
  .agent{
    position:relative;border-radius:0;
    background:#fffbe9;border:1px solid var(--ink-08);
    padding:28px 26px 22px;min-height:360px;
    display:flex;flex-direction:column;justify-content:space-between;
    overflow:hidden;
    transition:transform .35s ease, box-shadow .35s ease;
  }
  .agent:hover{transform:translateY(-4px);box-shadow:0 30px 60px -40px rgba(35,38,40,.4)}
  .agent .num{font-family:var(--display);font-size:14px;color:var(--ink-40);letter-spacing:.04em}
  .agent h3{margin-top:auto;font-size:30px}
  .agent p{color:var(--ink-60);margin-top:10px;font-size:14.5px}
  .agent .glow{
    position:absolute;inset:auto -30% -50% -30%;height:70%;
    background-size:cover;background-position:center;
    opacity:.55;filter:blur(10px) saturate(120%);
    pointer-events:none;
    transition:opacity .35s ease, transform .35s ease;
  }
  .agent:hover .glow{opacity:.85;transform:translateY(-4px)}
  .agent.a1 .glow{background-image:url("assets/gradient-mountain.webp")}
  .agent.a2 .glow{background-image:url("assets/gradient-desert.webp")}
  .agent.a3 .glow{background-image:url("assets/gradient-field.webp")}
  .agent.a4 .glow{background-image:url("assets/gradient-lake.webp")}
  .agent .head-row{display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative;z-index:2}
  .agent .icon{
    width:34px;height:34px;border-radius:0;background:var(--gunmetal);color:var(--cream);
    display:grid;place-items:center;font-family:var(--display);font-size:14px;
  }
  .agent-body{position:relative;z-index:2}

  /* ---------- Industries selector ---------- */
  .industries-head{display:flex;justify-content:space-between;align-items:end;gap:48px;margin-bottom:48px;flex-wrap:wrap}
  .industries-head h2{max-width:18ch}
  .industries-head p{max-width:42ch;color:var(--ink-60);font-size:18px}
  .ind-tabs{
    display:flex;gap:6px;flex-wrap:wrap;
    border-top:1px solid var(--ink-15);
    padding-top:18px;margin-bottom:24px;
  }
  .ind-tab{
    padding:10px 16px;border-radius:0;font-size:14.5px;color:var(--ink-60);
    transition:background .2s ease, color .2s ease, border-color .2s ease;
    border:1px solid transparent;
  }
  .ind-tab:hover{color:var(--gunmetal);background:var(--ink-08)}
  .ind-tab.active{background:var(--gunmetal);color:var(--cream)}
  .ind-tab .n{font-family:var(--display);font-size:12px;margin-right:8px;opacity:.6}

  .ind-panel{
    display:grid;grid-template-columns:1.05fr .95fr;gap:24px;
    border-radius:0;overflow:hidden;
    background:#fffbe9;border:1px solid var(--ink-08);
    min-height:580px;
    transition:opacity .35s ease;
  }
  @media (max-width:980px){ .ind-panel{grid-template-columns:1fr} }
  .ind-panel.is-hidden{display:none}
  .ind-visual{
    position:relative;min-height:300px;background:#222;
  }
  .ind-visual::after{
    content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(35,38,40,0) 30%,rgba(35,38,40,.55) 100%);
  }
  .ind-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .ind-visual .badge-row{
    position:absolute;inset:auto 24px 24px 24px;display:flex;justify-content:space-between;align-items:flex-end;gap:12px;z-index:2;color:var(--cream);
  }
  .ind-visual .crumb{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-60);position:absolute;top:24px;left:24px;z-index:2}
  .ind-visual h3{color:var(--cream);font-size:clamp(28px,3.4vw,52px);line-height:1.02;max-width:14ch}

  .ind-content{padding:36px 36px 32px;display:flex;flex-direction:column;gap:24px}
  @media (max-width:560px){ .ind-content{padding:28px 24px} }
  .ind-narrative{font-size:17.5px;line-height:1.55;color:var(--gunmetal);max-width:54ch}
  .ind-narrative strong{font-weight:500}
  .ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  @media (max-width:560px){ .ind-grid{grid-template-columns:repeat(2,1fr)} }
  .kpi{
    border:1px solid var(--ink-08);border-radius:0;padding:14px 14px 12px;background:var(--cream);
  }
  .kpi .n{font-family:var(--display);font-size:32px;line-height:1;letter-spacing:-.02em}
  .kpi .l{font-size:12px;color:var(--ink-60);margin-top:8px;line-height:1.35}
  .ind-stack{display:flex;flex-direction:column;gap:10px}
  .ind-stack h5{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--ink-60);font-weight:500;margin:0}
  .agent-pills{display:flex;flex-wrap:wrap;gap:8px}
  .agent-pill{
    display:inline-flex;align-items:center;gap:8px;padding:7px 12px 7px 8px;border-radius:0;
    background:var(--cream);border:1px solid var(--ink-15);font-size:13px;
  }
  .agent-pill .icon{width:20px;height:20px;border-radius:0;background:var(--gunmetal);color:var(--cream);display:grid;place-items:center;font-family:var(--display);font-size:11px}
  .ind-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:14px;border-top:1px solid var(--ink-08)}
  .ind-foot .quote{font-size:14px;color:var(--ink-60);max-width:42ch;font-style:italic}

  /* ---------- How it works ---------- */
  .how{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  @media (max-width:880px){ .how{grid-template-columns:1fr} }
  .step{
    border-radius:0;border:1px solid var(--ink-08);background:#fffbe9;padding:30px;min-height:280px;
    display:flex;flex-direction:column;gap:14px;
  }
  .step .num{font-family:var(--display);font-size:14px;color:var(--ink-40);letter-spacing:.04em}
  .step h3{font-size:28px}
  .step p{color:var(--ink-60);font-size:15px}
  .step .diag{
    margin-top:auto;height:140px;border-radius:0;background:var(--cream);border:1px solid var(--ink-08);
    position:relative;overflow:hidden;
  }

  /* tiny diagrams */
  .d1::before{content:"";position:absolute;inset:auto 12px 24px 12px;height:6px;border-radius:0;background:linear-gradient(90deg,var(--gunmetal) 0 30%, var(--ink-15) 30% 100%)}
  .d1::after{
    content:"website · forms · CRM";position:absolute;left:14px;top:14px;font-family:ui-monospace,monospace;font-size:11px;color:var(--ink-60);letter-spacing:.04em;
  }
  .d2-dots{position:absolute;inset:0;display:grid;grid-template-columns:repeat(8,1fr);grid-auto-rows:14px;gap:6px;padding:14px}
  .d2-dots i{display:block;background:var(--ink-15);border-radius:0}
  .d2-dots i.on{background:var(--gunmetal)}
  .d3-line{position:absolute;left:14px;right:14px;top:50%;height:2px;background:var(--ink-15);transform:translateY(-50%)}
  .d3-pt{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--gunmetal);top:50%;transform:translate(-50%,-50%)}
  .d3-lbl{position:absolute;top:14px;left:14px;font-family:ui-monospace,monospace;font-size:11px;color:var(--ink-60)}

  /* ---------- Numbers ---------- */
  .numbers{
    background:var(--gunmetal);color:var(--cream);border-radius:0;
    padding:64px;position:relative;overflow:hidden;
  }
  .numbers .veil{
    position:absolute;inset:-10%;background-image:url("assets/gradient-mountain-2.webp");background-size:cover;background-position:center;opacity:.35;mix-blend-mode:screen;filter:blur(4px);pointer-events:none;
  }
  .numbers-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:48px}
  @media (max-width:880px){ .numbers-grid{grid-template-columns:repeat(2,1fr)} .numbers{padding:40px 28px} }
  .nstat .n{font-family:var(--display);font-size:clamp(48px,5.6vw,84px);line-height:.95;letter-spacing:-.03em}
  .nstat .l{margin-top:14px;color:var(--cream-60);font-size:14px;letter-spacing:.04em;max-width:24ch}
  .numbers-top{position:relative;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:56px;flex-wrap:wrap}
  .numbers-top h2{color:var(--cream);max-width:18ch}
  .numbers-top p{color:var(--cream-60);max-width:38ch;font-size:17px}

  /* ---------- CTA ---------- */
  .cta{
    position:relative;border-radius:0;overflow:hidden;min-height:520px;
    display:grid;place-items:center;text-align:center;color:var(--cream);
    padding:96px 32px;
  }
  .cta .bg{
    position:absolute;inset:0;
    background-image:
      radial-gradient(60% 80% at 80% 20%, rgba(220,180,120,.55), transparent 70%),
      radial-gradient(70% 90% at 10% 100%, rgba(120,150,160,.55), transparent 70%),
      url("assets/gradient-mountain.webp");
    background-size:cover, cover, cover;
    background-position:center;
    transform:scale(1.05);
  }
  .cta .veil{
    position:absolute;inset:0;
    background:linear-gradient(135deg, rgba(35,38,40,.1) 0%, rgba(35,38,40,.45) 60%, rgba(35,38,40,.62) 100%);
  }
  .cta-content{position:relative;z-index:2;max-width:780px}
  .cta h2{color:var(--cream);font-size:clamp(44px,6.2vw,96px);letter-spacing:-.03em}
  .cta p{color:var(--cream-60);max-width:48ch;margin:24px auto 36px;font-size:18px;line-height:1.5}

  /* ---------- Footer ---------- */
  footer{padding:80px 0 48px}
  .foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-bottom:56px;border-bottom:1px solid var(--ink-08)}
  @media (max-width:880px){ .foot-top{grid-template-columns:1fr 1fr} }
  .foot-top h5{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--ink-60);font-weight:500;margin:0 0 16px}
  .foot-top ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14.5px}
  .foot-top ul a{color:var(--gunmetal);opacity:.8}
  .foot-top ul a:hover{opacity:1}
  .foot-bot{display:flex;justify-content:space-between;align-items:center;gap:24px;padding-top:32px;font-size:13px;color:var(--ink-60);flex-wrap:wrap}
  .foot-mark{margin-top:64px;line-height:0}

  /* ---------- Reveal ---------- */
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
  .reveal.in{opacity:1;transform:none}
  @keyframes reveal-fallback{to{opacity:1;transform:none}}
  .reveal{animation:reveal-fallback 0s 4s forwards}

  /* ---------- Gradient decorations ---------- */
  .gradient-band{
    position:relative;border-radius:0;overflow:hidden;
    background:#222;color:var(--cream);
    padding:80px 64px;
  }
  .gradient-band > .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
  .gradient-band > .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(35,38,40,.15),rgba(35,38,40,.55))}
  .gradient-band > .inner{position:relative;z-index:2}
  @media (max-width:720px){ .gradient-band{padding:48px 28px} }

  /* Stat counter row on a gradient band */
  .gradient-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:36px;margin-top:48px}
  @media (max-width:880px){ .gradient-stats{grid-template-columns:repeat(2,1fr);gap:24px} }
  .gradient-stats .s{display:flex;flex-direction:column;gap:6px}
  .gradient-stats .n{font-family:var(--display);font-size:clamp(36px,4.4vw,64px);line-height:1;letter-spacing:-.025em}
  .gradient-stats .l{color:var(--cream-60);font-size:13px;letter-spacing:.04em;max-width:24ch}

  /* Agent card refresh — keep but make gradients more visible */
  .agent .glow{opacity:.7}
  .agent:hover .glow{opacity:.95}

  /* Decorative gradient orbs (absolute) */
  .orb{
    position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;pointer-events:none;z-index:0;
  }
  .orb.amber{background:radial-gradient(circle,#caaa76,transparent 65%);}
  .orb.sage{background:radial-gradient(circle,#b2c2c4,transparent 65%);}
  .orb.rose{background:radial-gradient(circle,#d8a0a4,transparent 65%);}
  .orb.olive{background:radial-gradient(circle,#9fa67a,transparent 65%);}

  /* Pill labels on gradient backgrounds */
  .pill-on-dark{
    display:inline-flex;align-items:center;gap:8px;
    padding:7px 14px;border-radius:0;
    background:rgba(253,246,226,.10);border:1px solid rgba(253,246,226,.22);
    color:var(--cream);font-size:12px;letter-spacing:.04em;
    backdrop-filter:blur(8px);
  }
  .pill-on-dark .d{width:7px;height:7px;border-radius:50%;background:#9be3a2;box-shadow:0 0 0 4px rgba(155,227,162,.18)}

  /* Governance / deployment cards */
  .gov-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  @media (max-width:980px){ .gov-grid{grid-template-columns:1fr} }
  .gov-card{
    position:relative;overflow:hidden;
    border-radius:0;border:1px solid var(--ink-08);
    background:#fffbe9;
    padding:30px 28px;min-height:280px;
    display:flex;flex-direction:column;gap:14px;
  }
  .gov-card .num{font-family:var(--display);font-size:13px;color:var(--ink-40);letter-spacing:.06em}
  .gov-card h3{font-size:24px}
  .gov-card p{color:var(--ink-60);font-size:14.5px;line-height:1.5}
  .gov-card .gd{
    position:absolute;inset:auto -20% -40% -20%;height:60%;
    background-size:cover;background-position:center;opacity:.45;filter:blur(8px) saturate(120%);
    pointer-events:none;
  }

  /* Rollout phase strip */
  .phases{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-radius:0;overflow:hidden;border:1px solid var(--ink-08)}
  @media (max-width:880px){ .phases{grid-template-columns:1fr} }
  .phase{padding:30px 24px;background:#fffbe9;border-right:1px solid var(--ink-08);min-height:240px;display:flex;flex-direction:column;gap:10px;position:relative}
  .phase:last-child{border-right:0}
  @media (max-width:880px){ .phase{border-right:0;border-bottom:1px solid var(--ink-08)} .phase:last-child{border-bottom:0} }
  .phase .wks{font-family:var(--display);font-size:12px;color:var(--ink-40);letter-spacing:.08em}
  .phase h4{font-family:var(--display);font-size:22px;letter-spacing:-.02em;margin:0}
  .phase ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:13.5px;color:var(--ink-60)}
  .phase ul li{display:flex;gap:10px;align-items:flex-start}
  .phase ul li::before{content:"—";color:var(--ink-40)}

  /* Legal page */
  .legal-shell{padding:140px 0 96px;position:relative;overflow:hidden}
  .legal-shell .grain{position:absolute;inset:-10% -10% auto -10%;height:60%;z-index:0;pointer-events:none;
    background:radial-gradient(40% 60% at 80% 20%, rgba(202,170,118,.4), transparent 60%),radial-gradient(40% 60% at 10% 30%, rgba(178,194,196,.4), transparent 60%);
    filter:blur(40px) saturate(110%);opacity:.9}
  .legal-grid{position:relative;z-index:1;display:grid;grid-template-columns:240px 1fr;gap:64px;align-items:flex-start}
  @media (max-width:880px){ .legal-grid{grid-template-columns:1fr;gap:32px} }
  .legal-toc{position:sticky;top:120px;display:flex;flex-direction:column;gap:8px}
  @media (max-width:880px){ .legal-toc{position:static} }
  .legal-toc h5{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--ink-60);font-weight:500;margin:0 0 12px}
  .legal-toc a{font-size:13.5px;color:var(--ink-60);padding:6px 0;border-left:1px solid transparent;padding-left:12px;margin-left:-12px;transition:color .2s,border-color .2s}
  .legal-toc a:hover{color:var(--gunmetal);border-left-color:var(--ink-15)}
  .legal-body{max-width:72ch;font-size:16px;line-height:1.65;color:var(--gunmetal)}
  .legal-body h1{font-size:clamp(40px,5.5vw,72px);letter-spacing:-.03em;line-height:.96;margin-bottom:16px}
  .legal-body .meta{font-size:12.5px;letter-spacing:.06em;color:var(--ink-60);margin-bottom:40px}
  .legal-body h2{font-size:clamp(24px,2.4vw,32px);letter-spacing:-.02em;margin:48px 0 16px;scroll-margin-top:120px}
  .legal-body h3{font-size:18px;font-family:var(--sans);font-weight:500;color:var(--gunmetal);margin:24px 0 8px}
  .legal-body p, .legal-body li{color:var(--ink-60);font-size:15.5px}
  .legal-body p{margin:0 0 14px}
  .legal-body ul{margin:0 0 16px;padding-left:18px}
  .legal-body strong{color:var(--gunmetal);font-weight:500}
  .legal-body a{text-decoration:underline;text-decoration-color:var(--ink-15);text-underline-offset:3px}
  .legal-body a:hover{text-decoration-color:var(--gunmetal)}

  /* ---------- Marquee logo strip ---------- */
  .marq{
    overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  }
  .marq-track{display:flex;gap:64px;animation:marq 38s linear infinite;width:max-content}
  .marq-track span{font-family:var(--display);font-size:24px;letter-spacing:-.01em;color:var(--ink-40)}
  @keyframes marq{from{transform:translateX(0)} to{transform:translateX(-50%)}}


  /* ---------- Hero stacked layout (text on top, video below) ---------- */
  .hero-stacked .hero-grid{
    grid-template-columns:minmax(0, 1fr) !important;
    gap:56px;
    text-align:center;
    justify-items:center;
  }
  .hero-stacked .hero-copy{max-width:1100px}
  .hero-stacked .hero-copy h1{max-width:none;margin-left:auto;margin-right:auto;white-space:nowrap;font-size:clamp(40px,7vw,104px)}
  @media (max-width:720px){
    .hero-stacked .hero-copy h1{white-space:normal;font-size:clamp(40px,9vw,72px)}
  }
  .hero-stacked .hero-copy .hero-sub{margin-left:auto;margin-right:auto;max-width:60ch}
  .hero-stacked .hero-copy .hero-meta{justify-content:center}
  .hero-stacked .eyebrow{justify-content:center}

  .hero-video{
    width:100%;
    max-width:1080px;
    aspect-ratio:16/9;
    border-radius:0;
    overflow:hidden;
    background:#15171a;
    box-shadow:0 40px 80px -40px rgba(35,38,40,.45), 0 6px 20px -10px rgba(35,38,40,.2);
    position:relative;
  }
  .hero-video video{
    width:100%;height:100%;display:block;object-fit:cover;
  }
  @media (max-width:720px){
    .hero-stacked .hero-grid{gap:36px}
    .hero-video{border-radius:0}
  }
  .preloader{
    position:fixed;inset:0;z-index:200;
    background:var(--cream);
    display:grid;place-items:center;
    transition:opacity .6s ease, visibility .6s ease;
  }
  .preloader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
  .preloader-inner{display:flex;flex-direction:column;align-items:center;gap:24px}
  .preloader-lockup{
    display:flex;align-items:center;gap:14px;
    opacity:0;animation:pl-rise .7s .15s ease-out forwards;
  }
  .preloader-icon{height:40px;width:auto;display:block}
  .preloader-logo{height:48px;width:auto;display:block}
  @keyframes pl-rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
  .preloader-progress{
    width:180px;height:2px;border-radius:0;background:rgba(35,38,40,.10);overflow:hidden;
    opacity:0;animation:fade-in .4s .45s ease-out forwards;
  }
  .preloader-progress::after{
    content:"";display:block;height:100%;width:30%;background:var(--gunmetal);
    animation:pl-slide 1.6s ease-in-out infinite;
  }
  @keyframes pl-slide{
    0%{transform:translateX(-110%)}
    50%{transform:translateX(220%)}
    100%{transform:translateX(220%)}
  }
  @keyframes fade-in{from{opacity:0}to{opacity:1}}

  /* ---------- Footer wordmark — giant solid mark, bottom cropped ---------- */
  footer{padding:80px 0 0;position:relative;overflow:hidden}
  .foot-mark{
    position:relative;
    margin:48px 0 0;
    line-height:0;
    height:clamp(120px, 18vw, 260px);
    overflow:hidden;
    background:none;
    padding:0;
    border-radius:0;
    aspect-ratio:auto;
  }
  .foot-mark img{
    position:absolute;
    left:50%;bottom:-22%;
    transform:translateX(-50%);
    width:104%;max-width:none;height:auto;
    opacity:1;
    /* Solid mark — no fade, just bottom-cropped */
    -webkit-mask-image:none;mask-image:none;
  }
  @media (max-width:720px){
    .foot-mark{margin-top:32px;height:clamp(80px, 22vw, 160px)}
    .foot-mark img{width:114%;bottom:-26%}
  }

  /* ---------- Industries showcase (image card carousel) ---------- */
  .ind-showcase{
    position:relative;
  }
  .ind-showcase-head{
    display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:end;
    margin-bottom:48px;
  }
  @media (max-width:880px){ .ind-showcase-head{grid-template-columns:1fr;gap:24px} }
  .ind-showcase-head h2{font-size:clamp(36px,5vw,72px);letter-spacing:-.028em;line-height:1;max-width:18ch}
  .ind-showcase-head p{color:var(--ink-60);font-size:18px;line-height:1.55;max-width:46ch}

  .ind-showcase-track{
    position:relative;
    display:flex;gap:18px;
    overflow-x:auto;overflow-y:visible;
    scroll-snap-type:x mandatory;
    scroll-behavior:smooth;
    scroll-padding:0 32px;
    padding:6px 32px 14px;
    margin:0 -32px;
    /* hide scrollbars but allow horizontal drag/scroll */
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .ind-showcase-track::-webkit-scrollbar{display:none}

  .ind-card{
    position:relative;flex:0 0 auto;
    width:clamp(280px, 36vw, 460px);
    aspect-ratio:4/5;
    border-radius:0;
    overflow:hidden;
    background:#222;color:var(--cream);
    text-decoration:none;
    scroll-snap-align:start;
    transition:transform .35s ease, box-shadow .35s ease;
  }
  .ind-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(35,38,40,.45)}
  .ind-card .bg{
    position:absolute;inset:0;background-size:cover;background-position:center;
    transition:transform .8s ease;
  }
  .ind-card:hover .bg{transform:scale(1.04)}
  .ind-card .veil{
    position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(35,38,40,0) 30%, rgba(35,38,40,.4) 60%, rgba(35,38,40,.78) 100%);
  }
  .ind-card .num{
    position:absolute;top:18px;left:20px;z-index:2;
    font-family:var(--display);font-size:13px;color:rgba(253,246,226,.7);letter-spacing:.16em;
  }
  .ind-card .arrow{
    position:absolute;top:18px;right:20px;z-index:2;
    width:32px;height:32px;border-radius:50%;
    background:rgba(253,246,226,.16);backdrop-filter:blur(8px);
    border:1px solid rgba(253,246,226,.22);
    display:grid;place-items:center;color:var(--cream);font-size:13px;
    transition:background .25s, transform .25s;
  }
  .ind-card:hover .arrow{background:var(--cream);color:var(--gunmetal);transform:translate(2px,-2px)}
  .ind-card .body{
    position:absolute;left:0;right:0;bottom:0;z-index:2;
    padding:24px 24px 22px;
    display:flex;flex-direction:column;gap:6px;
  }
  .ind-card h3{
    font-family:var(--display);font-size:clamp(24px,2.4vw,32px);letter-spacing:-.02em;line-height:1;
    color:var(--cream);margin:0;
  }
  .ind-card .tag{color:var(--cream-60);font-size:13.5px;letter-spacing:.04em}

  /* Carousel nav buttons */
  .ind-showcase-nav{
    position:absolute;top:14px;right:0;display:flex;gap:8px;z-index:3;
  }
  @media (max-width:880px){ .ind-showcase-nav{position:static;margin-bottom:24px;justify-content:flex-end} }
  .ind-nav-btn{
    width:42px;height:42px;border-radius:50%;
    background:var(--cream);border:1px solid var(--ink-15);color:var(--gunmetal);
    display:grid;place-items:center;cursor:pointer;font-size:14px;
    transition:background .2s, border-color .2s, transform .2s;
  }
  .ind-nav-btn:hover{background:var(--gunmetal);color:var(--cream);border-color:var(--gunmetal)}
  .ind-nav-btn:disabled{opacity:.35;cursor:default}
  .ind-nav-btn:disabled:hover{background:var(--cream);color:var(--gunmetal);border-color:var(--ink-15)}

  /* ---------- Bigger logo in nav ---------- */
  /* (sizes set above in the lockup block) */

  /* ---------- Inner-page hero (shared) ---------- */
  .page-hero{
    position:relative;
    padding:160px 0 80px;
    overflow:hidden;
  }
  .page-hero .hero-grain{position:absolute;inset:-10% -5% auto -5%;height:120%;z-index:0;pointer-events:none}
  .page-hero-inner{position:relative;z-index:1;max-width:880px}
  .page-hero .crumb{display:flex;align-items:center;gap:10px;color:var(--ink-60);font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:24px}
  .page-hero h1{font-size:clamp(48px,7vw,108px);letter-spacing:-.035em;line-height:.94;margin-bottom:24px}
  .page-hero h1 em{font-style:normal;font-family:var(--display);font-weight:300;color:var(--ink-60)}
  .page-hero .lede{font-size:clamp(17px,1.4vw,22px);color:var(--ink-60);max-width:60ch;line-height:1.5}
  .page-hero .meta-row{margin-top:32px;display:flex;flex-wrap:wrap;gap:12px}


  /* ---------- Nav active state ---------- */
  .nav-links a.is-active{background:var(--gunmetal);color:var(--cream)}
  .nav-links a.is-active:hover{background:var(--gunmetal)}
