/* Hito Madin · Monaco-style
   ──────────────────────────────────────────────────────────────
   Layered hero (bg video → proof quotes → headline), serif h2's,
   centered floating pill nav, animated column visuals.
*/

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300;0,6..72,400;0,6..72,500;1,6..72,400&family=Geist:wght@300;400;500;600&family=Geist+Mono:wght@400;500&display=swap');

:root{
  --ink:#0A0A0A;
  --ink-2:#0E0E0E;
  --surface:#131313;
  --hairline:rgba(240,237,230,.08);
  --hairline-strong:rgba(240,237,230,.16);
  --ivory:#F0EDE6;
  --ivory-2:#E8E4DA;
  --ivory-dim:rgba(240,237,230,.62);
  --grey:rgba(240,237,230,.42);
  --grey-dim:rgba(240,237,230,.28);

  --serif:'Newsreader', Georgia, serif;
  --sans:'Geist', ui-sans-serif, -apple-system, system-ui, sans-serif;
  --mono:'Geist Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --container:1200px;
  --gutter:clamp(20px, 4vw, 56px);
  --section-y:clamp(96px, 13vw, 176px);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--ink);color:var(--ivory);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
html{overflow-x:hidden}
body{font-size:16px;line-height:1.5;font-weight:400;letter-spacing:-.01em;overflow-x:hidden}

::selection{background:var(--ivory);color:var(--ink)}

a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
img,svg{display:block;max-width:100%}

.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}

/* ─── Type ───────────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;color:var(--ivory);letter-spacing:-.015em;line-height:1.04}
h1{font-size:clamp(48px, 7.4vw, 96px)}
h2{font-size:clamp(40px, 5.4vw, 72px)}
h3{font-family:var(--sans);font-size:17px;font-weight:500;letter-spacing:-.012em;line-height:1.3}

/* italic emphasis — Newsreader has a true italic */
h1 i,h2 i,h3 i,.hero-h1 i{font-style:italic;color:var(--ivory)}

p{color:var(--ivory-dim);max-width:62ch;text-wrap:pretty;font-size:16px;line-height:1.55}

/* ─── Buttons ────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  height:44px;padding:0 22px;
  border-radius:999px;
  font-size:14px;font-weight:500;letter-spacing:-.005em;
  white-space:nowrap;
  transition:background .2s ease, color .2s ease, transform .15s ease;
}
.btn-primary{background:var(--ivory);color:#000;font-weight:600}
.btn-primary:hover{background:#fff;transform:translateY(-1px)}
.btn-lg{height:52px;padding:0 28px;font-size:15px}

/* ─── Hero stack: bg video + nav + proof + hero ──────────────── */
.hero-stack{
  position:relative;
  min-height:clamp(720px, 100svh, 980px);
  display:grid;
  grid-template-rows:auto auto 1fr;
  padding-bottom:clamp(72px, 9vw, 128px);
  overflow:hidden;
  isolation:isolate;
}

/* background video placeholder — animated gradient blobs that live INSIDE
   .hero-video (the button frame), now using .hero-bg as the absolute layer. */
.hero-bg{
  position:absolute;inset:0;
  z-index:0;
  background:#050505;
  overflow:hidden;
}
.hv-layer{
  position:absolute;border-radius:50%;
  filter:blur(80px);
  mix-blend-mode:screen;
  opacity:.55;
}
.hv-1{
  width:60vw;height:60vw;left:-10%;top:-20%;
  background:radial-gradient(circle, rgba(240,237,230,.18) 0%, transparent 60%);
  animation:hv-1 22s ease-in-out infinite;
}
.hv-2{
  width:55vw;height:55vw;right:-10%;top:30%;
  background:radial-gradient(circle, rgba(180,200,220,.14) 0%, transparent 60%);
  animation:hv-2 28s ease-in-out infinite;
}
.hv-3{
  width:70vw;height:70vw;left:20%;bottom:-30%;
  background:radial-gradient(circle, rgba(220,200,180,.10) 0%, transparent 60%);
  animation:hv-3 32s ease-in-out infinite;
}
@keyframes hv-1{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(15%,8%) scale(1.15)}
}
@keyframes hv-2{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-12%,-10%) scale(1.2)}
}
@keyframes hv-3{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-8%,-12%) scale(1.1)}
}
.hv-grain{
  position:absolute;inset:0;
  opacity:.08;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.hv-vignette{
  position:absolute;inset:0;
  background:radial-gradient(80% 80% at 50% 40%, transparent 30%, rgba(0,0,0,.55) 100%);
}
.hv-tag{
  position:absolute;bottom:14px;right:18px;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(240,237,230,.18);
  pointer-events:none;
}
@media (prefers-reduced-motion: reduce){
  .hv-layer{animation:none}
}

/* ─── Hero video player (front-and-center inside hero stack) ── */
.hero-video-wrap{
  position:relative;z-index:2;
  padding:clamp(28px, 5vw, 64px) 0 0;
}
.hero-video{
  display:block;width:100%;
  position:relative;
  aspect-ratio:16/9;
  border-radius:16px;
  overflow:hidden;
  padding:0;
  background:#0A0A0A;
  border:.5px solid var(--hairline-strong);
  box-shadow:
    0 0 0 1px rgba(240,237,230,.04),
    0 30px 80px rgba(0,0,0,.6),
    0 60px 160px rgba(0,0,0,.5);
  cursor:default;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.hero-video:hover{
  transform:translateY(-3px);
  box-shadow:
    0 0 0 1px rgba(240,237,230,.08),
    0 40px 100px rgba(0,0,0,.65),
    0 80px 220px rgba(0,0,0,.55);
}
/* override the global .hv-* sizes (which used vw) when nested in the frame */
.hero-video .hv-layer{filter:blur(50px);opacity:.85;mix-blend-mode:normal}
.hero-video .hv-1{
  width:50%;height:auto;aspect-ratio:1;left:8%;top:10%;
  background:radial-gradient(circle, rgba(140,170,210,.45) 0%, rgba(140,170,210,.15) 40%, transparent 70%);
}
.hero-video .hv-2{
  width:55%;height:auto;aspect-ratio:1;right:5%;top:25%;
  background:radial-gradient(circle, rgba(220,180,140,.40) 0%, rgba(220,180,140,.12) 40%, transparent 70%);
}
.hero-video .hv-3{
  width:60%;height:auto;aspect-ratio:1;left:25%;bottom:-10%;
  background:radial-gradient(circle, rgba(230,210,180,.32) 0%, rgba(230,210,180,.10) 40%, transparent 70%);
}
.hero-video .hv-tag{top:16px;right:18px;bottom:auto;color:rgba(240,237,230,.30)}
.hero-video .hv-vignette{
  background:radial-gradient(70% 70% at 50% 50%, transparent 30%, rgba(0,0,0,.55) 100%);
}
.hv-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:88px;height:88px;border-radius:50%;
  background:#FFFFFF;color:#0A0A0A;
  display:grid;place-items:center;
  box-shadow:0 10px 36px rgba(0,0,0,.4), 0 0 0 14px rgba(255,255,255,.08);
  transition:transform .25s ease, box-shadow .25s ease;
  z-index:2;
}
.hero-video:hover .hv-play{
  transform:translate(-50%,-50%) scale(1.05);
  box-shadow:0 10px 44px rgba(0,0,0,.5), 0 0 0 18px rgba(255,255,255,.12);
}
.hv-play svg{margin-left:4px}
.hv-time{
  position:absolute;left:22px;bottom:20px;z-index:2;
  font-family:var(--mono);font-size:12px;color:var(--ivory);
  padding:5px 10px;border:.5px solid var(--hairline-strong);
  border-radius:6px;background:rgba(20,20,20,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
@media (max-width:760px){
  .hv-play{width:64px;height:64px}
  .hv-play svg{width:18px;height:18px}
  .hv-time{font-size:11px;left:14px;bottom:14px}
  .hero-video .hv-tag{font-size:9px;top:12px;right:14px}
}

/* ─── Nav (Monaco-style: pill follows scroll, blurs & condenses) ─ */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:50;
  display:flex;justify-content:center;
  padding:18px var(--gutter) 0;
  pointer-events:none;
  transition:padding .35s cubic-bezier(.2,.7,.2,1);
}
.nav-inner{
  pointer-events:auto;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
  width:100%;max-width:1180px;
  height:64px;
  padding:0 10px 0 28px;
  background:rgba(10,10,10,.18);
  border:.5px solid rgba(240,237,230,.06);
  border-radius:999px;
  backdrop-filter:blur(8px) saturate(140%);
  -webkit-backdrop-filter:blur(8px) saturate(140%);
  box-shadow:0 1px 0 rgba(255,255,255,.02) inset;
  transition:
    background .35s cubic-bezier(.2,.7,.2,1),
    border-color .35s cubic-bezier(.2,.7,.2,1),
    backdrop-filter .35s cubic-bezier(.2,.7,.2,1),
    max-width .4s cubic-bezier(.2,.7,.2,1),
    height .35s cubic-bezier(.2,.7,.2,1),
    padding .35s cubic-bezier(.2,.7,.2,1),
    box-shadow .35s ease;
}
.nav.is-scrolled{padding-top:12px}
.nav.is-scrolled .nav-inner{
  background:rgba(14,14,14,.72);
  border-color:rgba(240,237,230,.14);
  backdrop-filter:blur(22px) saturate(170%);
  -webkit-backdrop-filter:blur(22px) saturate(170%);
  max-width:960px;
  height:54px;
  padding:0 8px 0 24px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.04) inset,
    0 8px 28px rgba(0,0,0,.35);
}
.nav.is-scrolled .brand{font-size:18px;letter-spacing:.04em}
.nav.is-scrolled .nav-cta{height:38px}
.nav.is-scrolled .nav-cta-arrow{width:26px;height:26px}
.nav-side{display:flex;align-items:center;gap:24px;font-size:14px;letter-spacing:-.005em}
.nav-side a:not(.nav-cta){color:var(--ivory-dim);transition:color .15s ease}
.nav-side a:not(.nav-cta):hover{color:var(--ivory)}
.nav-side-l{justify-self:start}
.nav-side-r{justify-self:end;gap:14px}
.brand{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--serif);
  font-size:22px;
  line-height:1;
  font-weight:500;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--ivory);
  transition:font-size .35s cubic-bezier(.2,.7,.2,1), letter-spacing .35s cubic-bezier(.2,.7,.2,1);
}
.brand > span:last-child{
  display:inline-block;
  /* Newsreader uppercase caps sit above the line-box optical center;
     nudge down so the wordmark visually centers with the brand-mark dot. */
  transform:translateY(.14em);
  line-height:1;
}
/* Brand mark: 4-way facet gem (SVG). Sized inline by class. */
.brand-mark{
  width:24px;height:24px;
  display:block;flex:0 0 24px;
  /* subtle glow on hover (nav) — disabled for now to keep it clean */
}
.brand-mark.final-mark{width:48px;height:48px;flex:0 0 48px;margin:0 auto 32px}
.nav-cta{
  height:38px;padding:0 6px 0 18px;border-radius:999px;
  background:#FFFFFF;color:#0A0A0A;
  font-family:var(--sans);font-size:13px;font-weight:600;
  letter-spacing:-.005em;
  display:inline-flex;align-items:center;gap:10px;
  transition:background .2s ease, transform .15s ease;
}
.nav-cta:hover{background:#fff;transform:translateY(-1px)}
.nav-cta-arrow{
  width:26px;height:26px;border-radius:50%;
  background:#0A0A0A;color:#FFFFFF;
  display:grid;place-items:center;
  font-size:13px;line-height:1;font-weight:500;
  transition:transform .25s ease;
}
.nav-cta:hover .nav-cta-arrow{transform:translateX(2px)}
@media (max-width:900px){
  .nav-side-l{display:none}
  .nav-inner{grid-template-columns:auto 1fr;padding:7px 7px 7px 16px;gap:8px}
  .nav-side-r{justify-self:end}
}

/* ─── Proof carousel (sits below taller nav, blurred backdrop) ── */
.proof-bar{
  position:relative;z-index:2;
  padding:clamp(104px, 9vw, 132px) var(--gutter) 0;
  display:flex;justify-content:center;
}
.proof-carousel{
  position:relative;
  width:100%;max-width:540px;
  padding:44px 28px;
  background:rgba(20,20,20,.40);
  border:.5px solid var(--hairline-strong);
  border-radius:16px;
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
}
/* slides stack in place: each absolute-positioned and fades in/out.
   the carousel sizes to the tallest slide via an invisible spacer slide. */
.proof-slide{
  position:absolute;top:0;left:0;right:0;bottom:0;
  padding:44px 28px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:18px;
  text-align:center;
  opacity:0;transform:translateY(6px);
  transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1);
  pointer-events:none;
}
/* spacer: invisible duplicate of the longest content reserves height so
   the absolute-positioned slides have a consistent box to live in. */
.proof-carousel::before{
  content:"\201C The clearest thinking I\2019ve seen on how AI should actually be deployed inside a company. \201D";
  display:block;visibility:hidden;
  font-family:var(--serif);font-style:italic;
  font-size:clamp(16px, 1.45vw, 19px);
  line-height:1.35;letter-spacing:-.005em;
  max-width:38ch;margin:0 auto 18px;
  text-wrap:balance;
}
.proof-carousel::after{
  content:"VP Marketing | Shape Properties";
  display:block;visibility:hidden;
  font-size:12.5px;line-height:1;letter-spacing:-.005em;
}
.proof-slide.is-active{opacity:1;transform:none;pointer-events:auto}
.proof-slide blockquote{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(16px, 1.45vw, 19px);
  color:var(--ivory);
  line-height:1.35;
  letter-spacing:-.005em;
  max-width:38ch;
  text-wrap:balance;
}
.proof-name{
  display:flex;align-items:center;gap:10px;
  font-family:var(--sans);
}
.proof-meta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;
  letter-spacing:-.005em;
}
.proof-meta .name{color:var(--ivory);font-weight:500}
.proof-meta .role{
  color:var(--grey);
  padding-left:8px;
  border-left:.5px solid var(--hairline-strong);
}
.proof-avatar{width:28px;height:28px;flex:0 0 28px;font-size:13px}
.proof-avatar.has-logo{padding:5px}
.proof-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg, rgba(240,237,230,.18), rgba(240,237,230,.06));
  border:.5px solid var(--hairline-strong);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:18px;color:var(--ivory);
  font-style:italic;
  flex:0 0 44px;
  overflow:hidden;
}
.proof-avatar.has-logo{padding:9px;background:rgba(240,237,230,.04)}
.proof-avatar.has-logo img{
  display:block;width:100%;height:100%;
  object-fit:contain;
  opacity:.92;
  filter:grayscale(100%) brightness(1.2);
}
.proof-meta{
  display:inline-flex;align-items:baseline;gap:10px;
  font-size:12.5px;letter-spacing:-.005em;line-height:1;
}
.proof-meta .name{color:var(--ivory);font-weight:500;line-height:1}
.proof-meta .role{
  color:var(--grey);
  padding-left:10px;
  border-left:.5px solid var(--hairline-strong);
  line-height:1;
  /* baseline-align uses the text baseline; the border sits relative to the
     line-box, which is taller. align it to the text by setting equal height
     via padding-block. */
  align-self:stretch;
  display:inline-flex;align-items:center;
}
@media (max-width:600px){
  .proof-carousel{padding:36px 20px;border-radius:14px}
  .proof-slide{padding:36px 20px;gap:14px}
  .proof-slide blockquote{font-size:15px;line-height:1.4}
  .proof-meta{font-size:11.5px;flex-wrap:wrap;justify-content:center;gap:6px}
}

/* ─── Hero headline ──────────────────────────────────────────── */
.hero{
  position:relative;z-index:2;
  padding:clamp(56px, 8vw, 112px) 0 clamp(24px, 4vw, 56px);
  display:flex;align-items:center;justify-content:center;
}
.hero-inner{
  display:flex;flex-direction:column;align-items:center;gap:28px;
  text-align:center;
}
.hero-h1{
  font-family:var(--serif);
  font-size:clamp(40px, 6.4vw, 84px);
  font-weight:400;
  letter-spacing:-.022em;
  line-height:1;
  max-width:none;
  white-space:nowrap;
  color:var(--ivory);
}
.hero-h1 i{font-style:italic;color:var(--ivory)}
.hero-sub{
  font-family:var(--sans);
  font-size:clamp(16px, 1.4vw, 19px);
  color:var(--ivory-dim);
  max-width:52ch;
  line-height:1.5;
  text-wrap:pretty;
}
.hero-ctas{display:flex;gap:12px;align-items:center;margin-top:8px}

/* ─── Trusted by ─────────────────────────────────────────────── */
.trusted{
  padding:64px 0 88px;
  position:relative;
}
.trusted-cap{
  text-align:left;
  font-size:13px;
  color:var(--grey);
  margin-bottom:24px;
  font-weight:400;
  letter-spacing:-.005em;
}
.marquee{
  position:relative;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.marquee-track{
  display:flex;width:max-content;gap:80px;align-items:center;
  animation:marquee 56s linear infinite;
}
.trusted:hover .marquee-track{animation-play-state:paused}
.marquee-item{
  flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;
  height:72px;position:relative;
}
.marquee-item img{
  display:block;width:auto;max-height:64px;
  opacity:.55;filter:grayscale(100%) brightness(1.1);
  transition:opacity .25s ease, filter .25s ease;
}
.marquee-item:hover img{opacity:1;filter:grayscale(0%) brightness(1)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.marquee-track{animation:none}}

/* ─── Block (3-col benefit sections) ─────────────────────────── */
.block{
  padding:var(--section-y) 0;
  border-top:.5px solid var(--hairline);
}
.block.alt{background:var(--ink-2)}
.block-head{
  margin:0 auto clamp(64px, 8vw, 112px);
  max-width:820px;
  text-align:center;
}
.block-head h2{
  letter-spacing:-.022em;
  max-width:20ch;
  margin:0 auto 20px;
  text-wrap:balance;
}
.block-sub{
  font-family:var(--sans);
  font-size:17px;
  color:var(--ivory-dim);
  max-width:54ch;
  margin:0 auto;
  line-height:1.55;
}
.cols{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:clamp(28px, 3vw, 48px);
  row-gap:64px;
}
.col{
  display:flex;flex-direction:column;gap:18px;
}
.col h3{color:var(--ivory)}
.col p{font-family:var(--sans);font-size:15px;line-height:1.55;color:var(--ivory-dim)}
@media (max-width:900px){.cols{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.cols{grid-template-columns:1fr;row-gap:48px}}

/* ─── Column visuals ─────────────────────────────────────────── */
.col-vis{
  position:relative;
  width:100%;
  aspect-ratio:16/10;
  background:linear-gradient(180deg, rgba(240,237,230,.025) 0%, rgba(240,237,230,.005) 100%);
  border:.5px solid var(--hairline);
  border-radius:12px;
  overflow:hidden;
  margin-bottom:6px;
}

/* ── (1) STACK · cards merge into one ───── */
.card-stack-card{
  position:absolute;
  width:42%;height:24%;
  border:.5px solid var(--hairline-strong);
  background:rgba(240,237,230,.04);
  border-radius:6px;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
}
[data-anim="stack"] .c1{animation:stack-1 6s cubic-bezier(.5,0,.3,1) infinite}
[data-anim="stack"] .c2{animation:stack-2 6s cubic-bezier(.5,0,.3,1) infinite}
[data-anim="stack"] .c3{animation:stack-3 6s cubic-bezier(.5,0,.3,1) infinite}
[data-anim="stack"] .c4.is-target{
  background:rgba(240,237,230,.10);
  border-color:var(--ivory-dim);
}
@keyframes stack-1{
  0%,90%,100%{transform:translate(-122%,-90%) rotate(-8deg);opacity:.7}
  45%,75%{transform:translate(-50%,-50%) rotate(0);opacity:.95}
}
@keyframes stack-2{
  0%,90%,100%{transform:translate(22%,-90%) rotate(7deg);opacity:.7}
  45%,75%{transform:translate(-50%,-50%) rotate(0);opacity:.95}
}
@keyframes stack-3{
  0%,90%,100%{transform:translate(-50%,40%) rotate(-3deg);opacity:.7}
  45%,75%{transform:translate(-50%,-50%) rotate(0);opacity:.95}
}

/* ── (2) LOG · streaming lines ───── */
.vis-log{
  position:absolute;inset:14% 12%;
  display:flex;flex-direction:column;gap:8px;justify-content:flex-end;
}
.log-line{
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;gap:10px;
  padding:8px 12px;
  background:rgba(240,237,230,.04);
  border:.5px solid var(--hairline);
  border-radius:6px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:0;color:var(--ivory);
  opacity:0;
}
.log-line .dot{width:5px;height:5px;border-radius:50%;background:var(--ivory)}
.log-line .s{font-size:10px;color:var(--ivory-dim)}
[data-anim="log"] .l1{animation:log-in 6s linear infinite}
[data-anim="log"] .l2{animation:log-in 6s linear .8s infinite}
[data-anim="log"] .l3{animation:log-in 6s linear 1.6s infinite}
[data-anim="log"] .l4{animation:log-in 6s linear 2.4s infinite}
@keyframes log-in{
  0%{opacity:0;transform:translateY(8px)}
  10%,80%{opacity:1;transform:none}
  100%{opacity:0;transform:translateY(-4px)}
}

/* ── (3) ORBIT · core + ring + dots ───── */
.orbit-core{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:32px;height:32px;border-radius:50%;
  background:var(--ivory);
  box-shadow:0 0 30px rgba(240,237,230,.4);
  animation:pulse-soft 3s ease-in-out infinite;
}
.orbit-ring{
  position:absolute;left:50%;top:50%;
  border-radius:50%;
  border:.5px solid var(--hairline-strong);
}
.orbit-ring.r1{width:42%;aspect-ratio:1;transform:translate(-50%,-50%);animation:rotate 14s linear infinite}
.orbit-ring.r2{width:64%;aspect-ratio:1;transform:translate(-50%,-50%);animation:rotate 22s linear reverse infinite}
.orbit-dot{
  position:absolute;
  width:7px;height:7px;border-radius:50%;
  background:var(--ivory);
  left:50%;top:50%;
  transform-origin:0 0;
}
.orbit-dot.d1{animation:orbit-1 14s linear infinite}
.orbit-dot.d2{animation:orbit-2 22s linear reverse infinite}
.orbit-dot.d3{animation:orbit-3 18s linear infinite}
@keyframes rotate{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes orbit-1{
  from{transform:translate(-50%,-50%) rotate(0) translateX(21%) rotate(0)}
  to  {transform:translate(-50%,-50%) rotate(360deg) translateX(21%) rotate(-360deg)}
}
@keyframes orbit-2{
  from{transform:translate(-50%,-50%) rotate(120deg) translateX(32%) rotate(-120deg)}
  to  {transform:translate(-50%,-50%) rotate(480deg) translateX(32%) rotate(-480deg)}
}
@keyframes orbit-3{
  from{transform:translate(-50%,-50%) rotate(240deg) translateX(32%) rotate(-240deg)}
  to  {transform:translate(-50%,-50%) rotate(600deg) translateX(32%) rotate(-600deg)}
}
@keyframes pulse-soft{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.95}
  50%{transform:translate(-50%,-50%) scale(1.15);opacity:1}
}

/* ── (3b) ZAP · operator consumes floating tasks ───── */
/* each unit is a zero-size anchor at center, rotated to its angle.
   the beam + task live inside it, so the beam always aims at its task. */
.orbit-zap .zap-unit{
  position:absolute;left:50%;top:50%;
  width:0;height:0;
  transform:rotate(var(--a));
}
.orbit-zap .u1{--a:20deg; --r:94px}
.orbit-zap .u2{--a:71deg; --r:60px}
.orbit-zap .u3{--a:122deg;--r:94px}
.orbit-zap .u4{--a:173deg;--r:60px}
.orbit-zap .u5{--a:224deg;--r:94px}
.orbit-zap .u6{--a:275deg;--r:62px}
.orbit-zap .u7{--a:326deg;--r:94px}

/* beam: grows from the core out to the task, then fades */
.orbit-zap .zap-beam{
  position:absolute;left:0;top:0;
  width:var(--r);height:2px;border-radius:2px;
  transform-origin:0 50%;
  transform:translateY(-50%) scaleX(.15);
  background:linear-gradient(90deg, rgba(240,237,230,0) 0%, rgba(240,237,230,.12) 55%, rgba(240,237,230,.95) 100%);
  filter:drop-shadow(0 0 6px rgba(240,237,230,.5));
  opacity:0;
  animation:zap-beam 8s ease-out infinite;
}
/* task chip floating at the end of the beam (counter-rotated to stay upright) */
.orbit-zap .zap-task{
  position:absolute;left:0;top:0;
  width:24px;height:11px;border-radius:3px;
  background:rgba(240,237,230,.06);
  border:.5px solid var(--hairline-strong);
  transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a)));
  animation:zap-task 8s ease-in-out infinite;
}
.orbit-zap .zap-task::before{
  content:"";position:absolute;left:4px;top:50%;
  width:3px;height:3px;border-radius:50%;
  background:var(--ivory-dim);transform:translateY(-50%);
}
.orbit-zap .zap-task::after{
  content:"";position:absolute;left:11px;right:4px;top:50%;
  height:1px;background:var(--hairline-strong);transform:translateY(-50%);
}

/* burst pattern over the 8s loop: 1 beam, then 2, then 1, then 3 at once.
   units sharing a delay fire simultaneously (parallel multitasking). */
.orbit-zap .u1 .zap-beam,.orbit-zap .u1 .zap-task{animation-delay:-4s}  /* solo  (t≈1.3s) */
.orbit-zap .u2 .zap-beam,.orbit-zap .u2 .zap-task{animation-delay:-2s}  /* pair  (t≈3.3s) */
.orbit-zap .u3 .zap-beam,.orbit-zap .u3 .zap-task{animation-delay:-2s}  /* pair  (t≈3.3s) */
.orbit-zap .u4 .zap-beam,.orbit-zap .u4 .zap-task{animation-delay:-8s}  /* solo  (t≈5.3s) */
.orbit-zap .u5 .zap-beam,.orbit-zap .u5 .zap-task{animation-delay:-6s}  /* trio  (t≈7.3s) */
.orbit-zap .u6 .zap-beam,.orbit-zap .u6 .zap-task{animation-delay:-6s}  /* trio  (t≈7.3s) */
.orbit-zap .u7 .zap-beam,.orbit-zap .u7 .zap-task{animation-delay:-6s}  /* trio  (t≈7.3s) */

/* core flares with each burst */
.orbit-zap .orbit-core{animation:core-flare 2s ease-in-out infinite}

@keyframes zap-beam{
  0%,58%{opacity:0;transform:translateY(-50%) scaleX(.15)}
  64%   {opacity:1;transform:translateY(-50%) scaleX(1)}
  70%   {opacity:0;transform:translateY(-50%) scaleX(1)}
  100%  {opacity:0;transform:translateY(-50%) scaleX(1)}
}
@keyframes zap-task{
  0%  {opacity:0;background:rgba(240,237,230,.06);border-color:var(--hairline-strong);box-shadow:none;
       transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a))) scale(.5)}
  12% {opacity:1;
       transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a))) scale(1)}
  58% {opacity:1;background:rgba(240,237,230,.06);border-color:var(--hairline-strong);box-shadow:none;
       transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a))) scale(1)}
  66% {opacity:1;background:var(--ivory);border-color:var(--ivory);box-shadow:0 0 14px rgba(240,237,230,.75);
       transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a))) scale(1.35)}
  73% {opacity:0;background:var(--ivory);border-color:var(--ivory);box-shadow:0 0 18px rgba(240,237,230,0);
       transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a))) scale(0)}
  92% {opacity:0;
       transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a))) scale(0)}
  100%{opacity:0;
       transform:translateX(var(--r)) translate(-50%,-50%) rotate(calc(-1 * var(--a))) scale(.5)}
}
@keyframes core-flare{
  0%,100%{transform:translate(-50%,-50%) scale(1);box-shadow:0 0 24px rgba(240,237,230,.4)}
  50%    {transform:translate(-50%,-50%) scale(1.12);box-shadow:0 0 40px rgba(240,237,230,.7)}
}

/* ── (4) CONNECT · 4 sources → 1 hub ───── */
[data-anim="connect"] .cn-src{
  position:absolute;
  width:36px;height:36px;border-radius:8px;
  border:.5px solid var(--hairline-strong);
  background:rgba(240,237,230,.04);
}
[data-anim="connect"] .s1{left:14%;top:18%}
[data-anim="connect"] .s2{right:14%;top:18%}
[data-anim="connect"] .s3{left:14%;bottom:18%}
[data-anim="connect"] .s4{right:14%;bottom:18%}
[data-anim="connect"] .cn-hub{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:50%;
  background:var(--ivory);
  box-shadow:0 0 36px rgba(240,237,230,.35);
  animation:pulse-soft 3s ease-in-out infinite;
}
.cn-lines{position:absolute;inset:0;width:100%;height:100%}
.cn-lines path{
  fill:none;stroke:rgba(240,237,230,.35);stroke-width:.7;
  stroke-dasharray:3 5;
  animation:dash-flow 8s linear infinite;
}
@keyframes dash-flow{from{stroke-dashoffset:0}to{stroke-dashoffset:-100}}

/* ── (5) GLOVE · senior operator portrait placeholder ───── */
[data-anim="glove"]{display:flex;align-items:center;justify-content:center;position:relative}
.gv-portrait{
  width:38%;aspect-ratio:1;border-radius:50%;
  background:
    radial-gradient(circle at 50% 40%, rgba(240,237,230,.20) 0%, rgba(240,237,230,.06) 50%, transparent 70%);
  border:.5px solid var(--hairline-strong);
  position:relative;
  animation:pulse-soft 4s ease-in-out infinite;
}
.gv-portrait::after{
  content:"";position:absolute;
  left:50%;top:38%;transform:translate(-50%,-50%);
  width:30%;aspect-ratio:1;border-radius:50%;
  background:var(--ivory);opacity:.85;
}
.gv-portrait::before{
  content:"";position:absolute;
  left:50%;top:84%;transform:translateX(-50%);
  width:60%;height:40%;border-radius:50% 50% 0 0;
  background:var(--ivory);opacity:.85;
}
.gv-aura{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:60%;aspect-ratio:1;border-radius:50%;
  border:.5px solid var(--hairline-strong);
  animation:rotate 20s linear infinite;
}
.gv-aura::before,.gv-aura::after{
  content:"";position:absolute;left:50%;top:0;
  transform:translate(-50%,-50%);
  width:7px;height:7px;border-radius:50%;
  background:var(--ivory);
}
.gv-aura::after{top:auto;bottom:0;transform:translate(-50%,50%)}
.gv-sig{
  position:absolute;left:50%;bottom:14%;transform:translateX(-50%);
  width:48px;height:1px;background:var(--ivory-dim);
  box-shadow:0 -16px 0 0 rgba(240,237,230,.3), 0 -32px 0 0 rgba(240,237,230,.15);
}

/* ── (6) TIMELINE · D1 → D7 → D14 ───── */
[data-anim="timeline"]{display:flex;align-items:center;justify-content:center}
.tl-line{
  position:absolute;left:14%;right:14%;top:50%;height:1px;
  background:var(--hairline-strong);
}
.tl-fill{
  position:absolute;left:14%;top:50%;height:1px;
  background:var(--ivory);
  width:0;
  animation:tl-fill 5s cubic-bezier(.4,0,.4,1) infinite;
}
@keyframes tl-fill{
  0%{width:0}
  90%,100%{width:72%}
}
.tl-step{
  position:absolute;top:50%;transform:translate(-50%,-50%);
  width:32px;height:32px;border-radius:50%;
  background:var(--ink);
  border:.5px solid var(--hairline-strong);
  display:grid;place-items:center;
  font-family:var(--mono);font-size:10px;color:var(--ivory-dim);
  letter-spacing:.04em;
}
.tl-step span{position:relative;z-index:1}
.tl-step.s1{left:14%;background:var(--ivory);color:var(--ink);border-color:var(--ivory)}
.tl-step.s2{left:50%;animation:tl-step 5s ease-in-out infinite}
.tl-step.s3{left:86%;animation:tl-step 5s ease-in-out 1s infinite}
@keyframes tl-step{
  0%,30%{background:var(--ink);color:var(--ivory-dim);border-color:var(--hairline-strong)}
  60%,100%{background:var(--ivory);color:var(--ink);border-color:var(--ivory)}
}

/* ── (7) FILES · documents organizing into folder ───── */
[data-anim="files"]{position:relative}
.fs-doc{
  position:absolute;width:22%;height:30%;
  background:rgba(240,237,230,.05);
  border:.5px solid var(--hairline-strong);
  border-radius:3px;
}
.fs-doc::before,.fs-doc::after{
  content:"";position:absolute;left:14%;right:14%;
  height:1px;background:var(--hairline-strong);
}
.fs-doc::before{top:30%}
.fs-doc::after{top:55%;right:40%}
.fs-doc.d1{top:10%;left:16%;animation:doc-in 5s ease-in-out infinite}
.fs-doc.d2{top:6%;right:18%;animation:doc-in 5s ease-in-out .3s infinite}
.fs-doc.d3{top:36%;left:8%;animation:doc-in 5s ease-in-out .6s infinite}
.fs-doc.d4{top:42%;right:10%;animation:doc-in 5s ease-in-out .9s infinite}
.fs-doc.d5{bottom:24%;left:42%;animation:doc-in 5s ease-in-out 1.2s infinite}
.fs-folder{
  position:absolute;left:50%;bottom:14%;transform:translateX(-50%);
  width:30%;height:18%;
  background:rgba(240,237,230,.12);
  border:.5px solid var(--ivory-dim);
  border-radius:0 6px 6px 6px;
}
.fs-folder::before{
  content:"";position:absolute;left:0;top:-6px;
  width:36%;height:8px;background:var(--ivory);opacity:.7;
  border-radius:6px 6px 0 0;
}
@keyframes doc-in{
  0%{opacity:1;transform:translate(0,0) scale(1)}
  80%{opacity:.6;transform:translate(calc((50% - 50%) * 1), 80%) scale(.5)}
  90%,100%{opacity:0;transform:translate(0,80%) scale(.4)}
}

/* ── (8) FLOW · nodes + traveling pulses ───── */
[data-anim="flow"]{position:relative}
.fw-node{
  position:absolute;
  width:24px;height:24px;border-radius:50%;
  background:rgba(240,237,230,.06);
  border:.5px solid var(--hairline-strong);
}
.fw-node.n1{left:13%;top:50%;transform:translateY(-50%)}
.fw-node.n2{left:50%;top:21%;transform:translate(-50%,-50%);background:var(--ivory);border-color:var(--ivory)}
.fw-node.n3{left:50%;bottom:21%;transform:translate(-50%,50%);background:var(--ivory);border-color:var(--ivory)}
.fw-node.n4{right:13%;top:50%;transform:translateY(-50%)}
.fw-lines{position:absolute;inset:0;width:100%;height:100%}
.fw-lines path{
  fill:none;stroke:rgba(240,237,230,.35);stroke-width:.7;
  stroke-dasharray:3 5;
  animation:dash-flow 6s linear infinite;
}
.fw-pulse{
  position:absolute;
  width:8px;height:8px;border-radius:50%;
  background:var(--ivory);
  box-shadow:0 0 12px rgba(240,237,230,.6);
  left:13%;top:50%;
  opacity:0;
}
.fw-pulse.p1{animation:flow-pulse-up 4s linear infinite}
.fw-pulse.p2{animation:flow-pulse-down 4s linear 2s infinite}
@keyframes flow-pulse-up{
  0%{opacity:1;left:13%;top:50%}
  50%{opacity:1;left:50%;top:21%}
  100%{opacity:0;left:87%;top:50%}
}
@keyframes flow-pulse-down{
  0%{opacity:1;left:13%;top:50%}
  50%{opacity:1;left:50%;top:79%}
  100%{opacity:0;left:87%;top:50%}
}

/* ── (9) BRIEF · animated chart ───── */
[data-anim="brief"]{position:relative;display:flex;align-items:flex-end;justify-content:center;gap:7%;padding:18% 10% 18%}
.br-bar{
  width:8%;
  background:rgba(240,237,230,.10);
  border-radius:2px;
  height:0;
  animation:br-grow 6s ease-in-out infinite;
}
.br-bar.b1{height:32%;animation-delay:0s}
.br-bar.b2{height:54%;animation-delay:.15s}
.br-bar.b3{height:38%;animation-delay:.30s}
.br-bar.b4{height:72%;animation-delay:.45s;background:var(--ivory)}
.br-bar.b5{height:50%;animation-delay:.60s}
.br-bar.b6{height:64%;animation-delay:.75s;background:var(--ivory)}
.br-marker{
  position:absolute;left:50%;top:24%;transform:translateX(-50%);
  width:10px;height:10px;border-radius:50%;
  background:var(--ivory);
  box-shadow:0 0 0 4px rgba(240,237,230,.18), 0 0 24px rgba(240,237,230,.4);
  animation:pulse-soft 2.4s ease-in-out infinite;
}
@keyframes br-grow{
  0%{transform:scaleY(0);transform-origin:bottom}
  20%,80%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

@media (prefers-reduced-motion: reduce){
  [data-anim] *{animation:none !important}
}

/* ─── Company section ────────────────────────────────────────── */
.company{
  padding:var(--section-y) 0;
  border-top:.5px solid var(--hairline);
}
.company-wrap{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  gap:clamp(20px, 3vw, 56px);
  align-items:center;
}
.company-head{display:flex;flex-direction:column;gap:20px;max-width:480px;justify-self:end}
.company-tag{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ivory-dim);
}
.company-head h2{letter-spacing:-.022em;max-width:14ch;text-wrap:balance;margin:0}
.company-head .block-sub{font-size:16px;color:var(--ivory-dim);max-width:50ch;line-height:1.55}
.company-creds{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.cred-pill{
  font-family:var(--sans);font-size:12.5px;font-weight:500;
  color:var(--ivory);letter-spacing:-.005em;
  padding:6px 14px;
  border:.5px solid var(--hairline-strong);
  border-radius:999px;
  background:rgba(240,237,230,.03);
}

/* team visual — concentric rings + orbiting role pills */
.company-vis{
  position:relative;
  width:100%;
  aspect-ratio:1;
  max-width:480px;
  margin:0;
  justify-self:start;
}
.team-core{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:13%;aspect-ratio:1;border-radius:50%;
  background:var(--ivory);
  box-shadow:0 0 36px rgba(240,237,230,.4);
  z-index:3;
}
.team-core-pulse{
  position:absolute;left:50%;top:50%;
  width:13%;aspect-ratio:1;border-radius:50%;
  background:rgba(240,237,230,.30);
  animation:core-pulse 3.2s ease-out infinite;
  z-index:2;
}
@keyframes core-pulse{
  0%{transform:translate(-50%,-50%) scale(1);opacity:.7}
  100%{transform:translate(-50%,-50%) scale(3.4);opacity:0}
}
.team-ring{
  position:absolute;left:50%;top:50%;
  border-radius:50%;
  border:.5px solid var(--hairline-strong);
}
.team-ring.r1{width:42%;aspect-ratio:1;transform:translate(-50%,-50%);animation:ring-spin 32s linear infinite}
.team-ring.r2{width:66%;aspect-ratio:1;transform:translate(-50%,-50%);animation:ring-spin 44s linear reverse infinite}
.team-ring.r3{width:92%;aspect-ratio:1;transform:translate(-50%,-50%);animation:ring-spin 60s linear infinite}
@keyframes ring-spin{
  from{transform:translate(-50%,-50%) rotate(0)}
  to  {transform:translate(-50%,-50%) rotate(360deg)}
}

.team-node{
  position:absolute;left:50%;top:50%;
  transform-origin:0 0;
  z-index:4;
}
.tn-label{
  display:inline-block;
  font-family:var(--sans);font-size:12px;font-weight:500;
  color:var(--ivory);letter-spacing:-.005em;
  padding:6px 12px;
  border:.5px solid var(--hairline-strong);
  border-radius:999px;
  background:rgba(20,20,20,.85);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  white-space:nowrap;
  transform:translate(-50%,-50%);
}
.team-node.n1{animation:tn-orbit-1 32s linear infinite}
.team-node.n2{animation:tn-orbit-2 44s linear reverse infinite}
.team-node.n3{animation:tn-orbit-3 60s linear infinite}
.team-node.n4{animation:tn-orbit-4 44s linear reverse infinite}
.team-node.n5{animation:tn-orbit-5 60s linear infinite}
@keyframes tn-orbit-1{
  from{transform:rotate(0)        translateX(21%) rotate(0)}
  to  {transform:rotate(360deg)   translateX(21%) rotate(-360deg)}
}
@keyframes tn-orbit-2{
  from{transform:rotate(140deg)   translateX(33%) rotate(-140deg)}
  to  {transform:rotate(500deg)   translateX(33%) rotate(-500deg)}
}
@keyframes tn-orbit-3{
  from{transform:rotate(40deg)    translateX(46%) rotate(-40deg)}
  to  {transform:rotate(400deg)   translateX(46%) rotate(-400deg)}
}
@keyframes tn-orbit-4{
  from{transform:rotate(260deg)   translateX(33%) rotate(-260deg)}
  to  {transform:rotate(620deg)   translateX(33%) rotate(-620deg)}
}
@keyframes tn-orbit-5{
  from{transform:rotate(200deg)   translateX(46%) rotate(-200deg)}
  to  {transform:rotate(560deg)   translateX(46%) rotate(-560deg)}
}
@media (prefers-reduced-motion: reduce){
  .team-ring,.team-node,.team-core-pulse{animation:none}
}
@media (max-width:820px){
  .company-wrap{grid-template-columns:1fr;gap:40px}
  .company-head{justify-self:stretch;max-width:none}
  .company-vis{max-width:360px;justify-self:center;order:-1}
}

/* ─── Final CTA ──────────────────────────────────────────────── */
.final{
  padding:clamp(120px, 14vw, 200px) 0 clamp(96px, 12vw, 160px);
  text-align:center;
  position:relative;
  /* no overflow:hidden — let the glow spill into the section above */
}
/* aurora glow stack — anchored at the section's top edge so it bleeds
   upward into the previous section as one continuous space. */
.final::before{
  content:"";position:absolute;
  left:50%;top:46%;transform:translate(-50%,-50%);
  width:min(1100px, 110vw);
  height:min(900px, 90vw);
  pointer-events:none;z-index:0;
  background:
    radial-gradient(closest-side, rgba(140,170,210,.22) 0%, transparent 70%),
    radial-gradient(closest-side at 35% 55%, rgba(220,180,140,.18) 0%, transparent 65%),
    radial-gradient(closest-side at 65% 60%, rgba(230,210,180,.16) 0%, transparent 65%);
  filter:blur(20px);
  animation:final-glow 5s ease-in-out infinite;
}
.final::after{
  content:"";position:absolute;
  left:50%;top:46%;transform:translate(-50%,-50%);
  width:min(640px, 78vw);
  height:min(640px, 78vw);
  pointer-events:none;z-index:0;
  border-radius:50%;
  background:radial-gradient(closest-side, rgba(255,245,225,.10) 0%, transparent 75%);
  animation:final-pulse 2.6s ease-in-out infinite;
}
/* drastic breathing — clear fade-out → bright peak */
@keyframes final-glow{
  0%,100%{transform:translate(-50%,-50%) scale(.92);opacity:.25}
  50%   {transform:translate(-48%,-54%) scale(1.14);opacity:1}
}
@keyframes final-pulse{
  0%,100%{transform:translate(-50%,-50%) scale(.88);opacity:.2}
  50%   {transform:translate(-50%,-50%) scale(1.14);opacity:1}
}
@media (prefers-reduced-motion: reduce){
  .final::before,.final::after{animation:none}
}
.final-tagline{
  font-family:var(--serif);
  font-size:clamp(14px, 1.2vw, 17px);
  color:var(--ivory-dim);
  max-width:46ch;
  margin:0 auto 36px;
  line-height:1.5;
  letter-spacing:.005em;
  text-wrap:balance;
}
.final-tagline i{font-style:italic;color:var(--ivory)}
.final > .wrap{position:relative;z-index:1}
.final-mark{
  width:48px;height:48px;margin:0 auto 32px;display:block;
}
/* When .final-mark is the SVG itself (not a span wrapper), enforce size. */
svg.brand-mark.final-mark{width:48px;height:48px}
.final h2{
  letter-spacing:-.022em;
  max-width:18ch;
  margin:0 auto 24px;
  text-wrap:balance;
}
.final p{
  margin:0 auto 40px;font-size:17px;
  color:var(--ivory-dim);max-width:50ch;line-height:1.55;
}

/* ─── Footer ─────────────────────────────────────────────────── */
.footer{
  border-top:.5px solid var(--hairline);
  padding:48px 0 32px;
  background:var(--ink);
}
.footer-inner{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  margin-bottom:36px;
}
.footer-nav{display:flex;gap:28px;align-items:center;font-size:14px}
.footer-nav a{color:var(--ivory-dim);transition:color .15s ease}
.footer-nav a:hover{color:var(--ivory)}
.footer-base{
  font-size:12.5px;color:var(--grey);
  padding-top:24px;border-top:.5px solid var(--hairline);
}
@media (max-width:600px){
  .footer-inner{flex-direction:column;align-items:flex-start;gap:20px}
  .footer-nav{flex-wrap:wrap;gap:18px}
}

/* ─── Video modal (kept for future use; unused right now) ───── */
.vmodal{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(6px)}
.vmodal.is-open{opacity:1;pointer-events:auto}
.vmodal-x{position:absolute;top:20px;right:24px;width:44px;height:44px;border-radius:50%;background:rgba(240,237,230,.06);color:var(--ivory);font-size:24px;line-height:1;display:grid;place-items:center;cursor:default}
.vmodal-x:hover{background:rgba(240,237,230,.12)}
.vmodal-frame{width:100%;max-width:980px;aspect-ratio:16/9;background:var(--ink-2);border:.5px solid var(--hairline-strong);border-radius:8px;overflow:hidden}
.vmodal-inner{width:100%;height:100%;display:grid;place-items:center;background-image:repeating-linear-gradient(135deg, transparent 0, transparent 22px, rgba(240,237,230,.025) 22px, rgba(240,237,230,.025) 23px)}
.vmodal-placeholder{text-align:center;font-size:15px;color:var(--ivory);line-height:1.7}
.vmodal-placeholder span{font-size:12.5px;color:var(--grey);font-family:var(--mono)}

/* ─── Reveal on scroll ───────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity 1s ease, transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ─── Mobile pass ────────────────────────────────────────────── */
@media (max-width:760px){
  :root{--section-y:clamp(72px, 13vw, 112px);--gutter:20px}

  .nav{padding-top:10px}
  .nav.is-scrolled{padding-top:8px}
  .nav-inner{height:54px;padding:0 8px 0 18px}
  .nav.is-scrolled .nav-inner{height:48px}
  .brand{font-size:18px;letter-spacing:.04em}
  .nav.is-scrolled .brand{font-size:16px}
  .brand-mark{width:20px;height:20px;flex:0 0 20px}
  .nav-cta{height:34px;padding:0 6px 0 12px;font-size:12.5px}
  .nav-cta-arrow{width:24px;height:24px;font-size:12px}
  .proof-bar{padding-top:104px}

  .hero-stack{min-height:auto;padding-bottom:64px}
  .hero{padding-top:32px}
  .hero-h1{font-size:36px;line-height:1.04;letter-spacing:-.02em;white-space:nowrap}
  .hero-sub{font-size:15.5px}
  .hero-ctas .btn{height:48px;padding:0 26px}

  .trusted{padding:32px 0 48px}
  .trusted-cap{font-size:12px;margin-bottom:24px}
  .marquee-track{gap:56px}
  .marquee-item{height:60px}
  .marquee-item img{max-height:44px}

  .block-head{margin-bottom:48px}
  .block-head h2{font-size:38px;letter-spacing:-.02em}
  .block-sub{font-size:15.5px}

  .col-vis{aspect-ratio:5/3}

  .company-head h2{font-size:38px}

  .final{padding:88px 0 96px}
  .final-mark{width:40px;height:40px;margin-bottom:24px}
  .final h2{font-size:48px;letter-spacing:-.02em}
  .final p{font-size:15.5px;margin-bottom:32px}
  .final .btn{width:100%;max-width:320px;justify-content:center;height:52px}
}

@media (max-width:380px){
  .brand span:last-child{display:none}
  .hero-h1{font-size:30px}
  .final h2{font-size:40px}
}
