/* ─────────────────────────────────────────────────────────────
   Intraprise — homepage
   Editorial blueprint: white paper, pale architect's-plan blue,
   deep navy ink as the action voice, teal as a quiet signature,
   pastel yellow held for dark-section emphasis.

   Type roles:
     Display / heading / italic emphasis — Fraunces (variable, opsz used)
     Body / lists / UI                    — DM Sans
     Eyebrows / captions / mono           — Inter (small, tracked)
     Wordmark                             — Syne
   ───────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,800;0,9..144,900;1,9..144,400;1,9..144,500;1,9..144,600;1,9..144,700&family=Space+Mono:wght@400;700&family=DM+Sans:wght@300;400;500;600&family=Syne:wght@600;700;800&display=swap');

:root{
  /* ── Surfaces ──────────────────────────────────────────────────
     Strict palette: white paper, deep navy, one mid-blue, neutral grays.
     No cyan, no azure. Legacy cyan and blue variable names are kept but
     now resolve to navy / mid-blue / neutral so downstream rules recolor. */
  --paper:#FFFFFF;
  --blue-mid:#1F6FD0;           /* secondary mid blue — accent blocks, markers, tiles */
  --blue-mid-ink:#1A5FB4;       /* same family, darkened for legible ink on white */
  --surface-2:#F1F3F5;          /* neutral light wash (replaces every blue wash) */
  --gray-band:#E8E7E2;          /* soft warm-neutral — quiet ribbon between sections */
  --cyan:var(--blue-mid);       /* legacy alias → mid-blue accent */
  --cyan-fill:var(--blue-mid);
  --cyan-soft:var(--surface-2);
  --cyan-line:#DEE2E6;          /* neutral hairline */
  --blue-soft:var(--surface-2);
  --blue-tint:#F5F6F8;          /* gentlest neutral wash */
  --blue-rule:#DEE2E6;
  --blue-rule-strong:#BCC2C8;
  --blue-gradient:var(--paper); /* flattened — no gradient */
  --dark:#07273C;               /* deep navy — primary dark surface */
  --dark-elev:#0C3550;
  --dark-tint:#114060;

  /* ── Text ── */
  --ink:#0C1B26;                /* primary text on light */
  --ink-2:#3F4A53;              /* neutral slate */
  --ink-3:#6B7680;              /* neutral gray */
  --ink-light:#EDF0F3;          /* primary text on dark — neutral near-white */
  --ink-light-2:#A6B1BB;        /* neutral light gray */
  --ink-light-3:#6F7C87;

  /* ── Accents ──
     Deep navy is the action voice. One mid-blue (#1F6FD0 family) is the
     signature accent. Yellow is rare punctuation. No azure, no cyan. */
  --blue-ink:#0B3A5B;            /* deep navy — primary CTA, action voice */
  --blue-ink-hover:#072B45;
  --teal:var(--blue-mid-ink);    /* legacy alias → legible mid-blue ink on white */
  --teal-tint:rgba(31,111,208,.08);
  --teal-glow:rgba(31,111,208,.20);
  --yellow:#F5E6A8;              /* single punch per dark section */
  --yellow-ink:#5A4E12;

  /* ── Functional ── */
  --shadow-quiet:0 1px 2px rgba(7,39,60,.05), 0 10px 30px -16px rgba(7,39,60,.16);
  --shadow-lift:0 2px 6px rgba(7,39,60,.07), 0 22px 50px -20px rgba(7,39,60,.24);

  /* ── Legacy aliases (existing rules reference these — keep mapped) ── */
  --bg-primary:var(--paper);
  --bg-soft:var(--blue-soft);
  --bg-tint:var(--blue-tint);
  --bg-gradient:var(--blue-gradient);
  --bg-dark:var(--dark);
  --bg-dark-elev:var(--dark-elev);
  --bg-dark-tint:var(--dark-tint);
  --text-primary:var(--ink);
  --text-secondary:var(--ink-2);
  --text-tertiary:var(--ink-3);
  --text-on-dark:var(--ink-light);
  --text-on-dark-secondary:var(--ink-light-2);
  --text-on-dark-tertiary:var(--ink-light-3);
  --border-subtle:var(--blue-rule);
  --border-strong:var(--blue-rule-strong);
  --border-on-dark:rgba(234,246,247,.10);
  --border-on-dark-strong:rgba(234,246,247,.22);
  --accent-primary:var(--blue-ink);
  --accent-hover:var(--blue-ink-hover);
  --accent-tint:rgba(11,58,91,.07);
  --accent-glow:rgba(31,111,208,.24);
  --accent-yellow:var(--yellow);
  --accent-yellow-ink:var(--yellow-ink);
  --shadow-card:var(--shadow-quiet);
  --shadow-card-hover:var(--shadow-lift);

  --bg:var(--paper); --bg-1:var(--blue-soft); --bg-2:#FFFFFF; --bg-3:var(--blue-tint);
  --surface:#FFFFFF;
  --ink-1:var(--ink);
  --ink-rule:var(--blue-rule);
  --ink-rule-strong:var(--blue-rule-strong);
  --pink-pastel:var(--teal);            /* signature accent on light */
  --pink-soft:var(--cyan);
  --cream:var(--ink);
  --cream-soft:var(--blue-soft);
  --blue-pastel:var(--cyan);
  --pink-cta:var(--blue-ink);
  --pink-cta-hov:var(--blue-ink-hover);
  --pink-ink:var(--blue-ink);
  --navy:var(--ink); --navy-2:var(--ink);
  --sky:var(--cyan);
  --turquoise:var(--cyan);
  --turquoise-soft:var(--cyan-soft);
  --turquoise-tint:var(--cyan-soft);
  --turquoise-ink:var(--teal);
  --turquoise-rule:var(--cyan-line);
  --paper-2:var(--cyan);
  --slate-1:var(--ink);
  --slate-2:var(--ink-2);
  --slate-3:var(--ink-3);
  --slate-rule:var(--blue-rule);
  --slate-rule-strong:var(--blue-rule-strong);

  /* Type families */
  --display:'Fraunces',ui-serif,Georgia,serif;
  --serif:'Fraunces',ui-serif,Georgia,serif;
  --body:'DM Sans',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  /* Spacing — 4/8 scale */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px;
  --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px;
  --s-9:88px; --s-10:120px;

  /* Layout */
  --gutter:clamp(20px,4vw,72px);
  --nav-h:62px;
  --maxw:1240px;
  --radius:5px;
  --radius-lg:9px;

  /* Motion — one shared cadence for hover/state changes.
     Staged motions (button ink-fill .32s, scroll reveals .7–.8s,
     filmstrip, the gentle portrait hover) intentionally opt out. */
  --dur:.25s;
  --ease:cubic-bezier(.2,.7,.2,1);

  /* Type scale — editorial contrast: small set tight, display oversized */
  --t-mono:11px;       /* eyebrow */
  --t-meta:13px;
  --t-body:16px;
  --t-sub:clamp(17px, 1.3vw, 19.5px);
  --t-h4:clamp(20px, 1.7vw, 24px);
  --t-h3:clamp(25px, 2.7vw, 38px);
  --t-h2:clamp(37px, 4.6vw, 66px);
  --t-display:clamp(56px, 7.9vw, 120px);  /* hero headline — nudged ~+7% */
  --t-stat:clamp(66px, 9.4vw, 140px);
}

/* Stat numerals — consistent site-wide */
.stat-num{
  font-family:var(--display);
  font-weight:800;
  font-variant-numeric:tabular-nums lining-nums;
  font-feature-settings:"tnum","lnum","ss01";
  letter-spacing:-.04em;
  line-height:.92;
  font-variation-settings:"opsz" 144;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip;background:var(--paper)}
/* Deep links / no-JS / reduced-motion jumps must clear the fixed nav,
   matching the JS smooth-scroll offset (nav height + a small gap). */
#top,#problem,#why,#solution,#demo,#proof,#team,#approach,#faq,#cta{
  scroll-margin-top:calc(var(--nav-h) + var(--s-3));
}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  font-size:var(--t-body);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  text-wrap:pretty;          /* fewer orphans/widows in body copy */
  overflow-x:clip;
}
::selection{background:var(--blue-ink);color:#fff}
img{max-width:100%;display:block}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}
a{color:inherit;text-decoration:none}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── Dark-section token re-scope ───────────────────────────── */
.section-dark,
.demo-section,
.approach,
.cta-section{
  background:var(--dark);
  color:var(--ink-light);
  position:relative;

  --ink-1:var(--ink-light);
  --ink-2:var(--ink-light-2);
  --ink-3:var(--ink-light-3);
  --ink-rule:var(--border-on-dark);
  --ink-rule-strong:var(--border-on-dark-strong);
  --bg:var(--dark); --bg-1:var(--dark); --bg-2:var(--dark-elev); --bg-3:var(--dark-elev);
  --surface:var(--dark-elev);
  --cream:var(--ink-light);
  --navy:var(--ink-light); --navy-2:var(--ink-light);
  /* on navy: accents read as quiet neutral light; the single per-section
     yellow punch stays via explicit rules. No cyan. */
  --sky:var(--ink-light-2);
  --pink-pastel:var(--ink-light-2);
  --turquoise:var(--ink-light-2);
  --turquoise-ink:var(--ink-light-2);
  --turquoise-soft:rgba(238,241,244,.08);
  --turquoise-tint:rgba(238,241,244,.05);
  --turquoise-rule:rgba(238,241,244,.20);
}
/* Flat navy — vignette gradient removed per the no-gradient brief. */
.section-dark > *,
.demo-section > *,
.approach > *,
.cta-section > *{position:relative;z-index:1}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .filmstrip-track{animation:none!important}
  .js .browser-window:not(.vis),.js .prob-col--us:not(.is-revealed){opacity:1!important;transform:none!important}
}

/* Grain texture removed — flat, confident surfaces only. */

/* ──────────────────────────────────────────────────────────────
   PRIMITIVES
   ───────────────────────────────────────────────────────────── */
.eyebrow{
  font-family:var(--mono);
  font-size:var(--t-mono);
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--teal);
  margin-bottom:var(--s-4);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:"";width:18px;height:1px;background:currentColor;display:inline-block;
}
.section-dark .eyebrow,
.demo-section .eyebrow,
.approach .eyebrow,
.cta-section .eyebrow{color:var(--ink-light-2)}

.section-inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(56px,7vw,96px) var(--gutter);
}
/* density variants — let some sections breathe more than others */
.section-inner--tight{padding-top:clamp(44px,5vw,72px);padding-bottom:clamp(44px,5vw,72px)}
.section-inner--air{padding-top:clamp(72px,9vw,120px);padding-bottom:clamp(72px,9vw,120px)}

.section-head{max-width:980px;margin-bottom:clamp(28px,3.6vw,52px)}
.section-title{
  font-family:var(--display);
  font-weight:600;
  font-variation-settings:"opsz" 72;
  font-size:var(--t-h2);
  line-height:1.04;
  letter-spacing:-.025em;
  color:var(--ink-1);
  text-wrap:balance;
}
.section-title em{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-variation-settings:"opsz" 72;
  color:var(--ink-1);
  letter-spacing:-.005em;
}
.section-title strong{font-weight:700;color:var(--ink-1)}
/* Problem headline — one notch smaller, wider line so more words fit */
#problem-h{font-size:clamp(33px,4.05vw,58px)}
.problem .section-head{max-width:1120px}
.section-sub{
  margin-top:var(--s-5);
  font-size:var(--t-sub);
  color:var(--ink-2);
  max-width:64ch;
  line-height:1.55;
}

/* ── Highlighter / marker ────────────────────────────────────
   Hand-drawn swipe behind selected words. Used in EXACTLY five
   places (3 on the landing page, 2 in the mega-menu) and nowhere
   else. The fill is translucent and the swipe edge is irregular
   (asymmetric border-radius + slight skew/rotate) so it reads as
   a marker stroke, not a solid rectangle. isolation:isolate keeps
   the ::before behind the text but above any section background. */
.mark{
  position:relative;
  isolation:isolate;
  white-space:nowrap;          /* keep the phrase (and its swipe) on one line */
  padding:0 .08em;
}
/* A marker swipe: a flat translucent stroke over the lower third of the
   text, soft uneven ends, a hair of skew/rotation — not an oval, not a
   solid rectangle, not a gradient blob. */
.mark::before{
  content:"";
  position:absolute;z-index:-1;
  left:-.08em;right:-.10em;
  top:62%;bottom:13%;
  background:linear-gradient(98deg,
    transparent 0%, var(--mark-c) 3.5%,
    var(--mark-c) 96.5%, transparent 100%);
  border-radius:.32em .24em .3em .22em / .55em .42em .5em .46em;
  transform:rotate(-1deg) skewX(-4deg);
}
/* yellow — warm hook / differentiating verb */
.mark--yellow{--mark-c:rgba(245,230,168,.85)}
/* mid-blue — credibility / what we sell (cooler, varies the rhythm) */
.mark--blue{--mark-c:rgba(31,111,208,.34)}

/* ── Buttons ─────────────────────────────────────────────────
   Mechanical hover: arrow shifts, surface ink-fills from the left. */
.btn{
  position:relative;
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-weight:500;font-size:14.5px;letter-spacing:.005em;
  padding:14px 22px;
  border-radius:2px;
  line-height:1;white-space:nowrap;
  transition:transform .18s ease, color .25s, border-color .25s, box-shadow .25s;
  overflow:hidden;
  isolation:isolate;
}
.btn > span[aria-hidden]{
  display:inline-flex;transition:transform var(--dur) var(--ease);
}
.btn:hover > span[aria-hidden]{transform:translateX(4px)}
.btn:active{transform:translateY(1px)}

.btn-primary{
  background:var(--blue-ink);color:#fff;
  box-shadow:inset 0 0 0 1px var(--blue-ink);
}
.btn-primary::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--blue-ink-hover);
  transform:translateX(-101%);
  transition:transform .32s cubic-bezier(.2,.7,.2,1);
}
.btn-primary:hover::before{transform:translateX(0)}
.btn-primary:hover{box-shadow:inset 0 0 0 1px var(--blue-ink-hover), 0 8px 24px -12px var(--accent-glow)}

.btn-outline{
  background:transparent;color:var(--ink);
  box-shadow:inset 0 0 0 1px rgba(11,26,44,.22);
}
.btn-outline::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--ink);
  transform:translateX(-101%);
  transition:transform .32s cubic-bezier(.2,.7,.2,1);
}
.btn-outline:hover{color:#fff;box-shadow:inset 0 0 0 1px var(--ink)}
.btn-outline:hover::before{transform:translateX(0)}

.btn-lg{font-size:15.5px;padding:18px 28px}

/* Dark surface variants */
.section-dark .btn-outline,
.demo-section .btn-outline,
.approach .btn-outline,
.cta-section .btn-outline{
  color:var(--ink-light);
  box-shadow:inset 0 0 0 1px var(--border-on-dark-strong);
}
.section-dark .btn-outline::before,
.demo-section .btn-outline::before,
.approach .btn-outline::before,
.cta-section .btn-outline::before{background:var(--ink-light)}
.section-dark .btn-outline:hover,
.demo-section .btn-outline:hover,
.approach .btn-outline:hover,
.cta-section .btn-outline:hover{color:var(--dark);box-shadow:inset 0 0 0 1px var(--ink-light)}

/* Focus */
a:focus-visible,button:focus-visible,summary:focus-visible{
  outline:2px solid var(--teal);outline-offset:3px;
  box-shadow:0 0 0 5px var(--teal-tint);
}
.btn:focus-visible{outline:2px solid var(--teal);outline-offset:3px;box-shadow:0 0 0 5px var(--teal-tint)}
.section-dark a:focus-visible,
.section-dark button:focus-visible,
.demo-section a:focus-visible,
.demo-section button:focus-visible,
.approach a:focus-visible,
.approach button:focus-visible,
.cta-section a:focus-visible,
.cta-section button:focus-visible{
  outline-color:var(--yellow);
  box-shadow:0 0 0 5px rgba(245,230,168,.18);
}

/* Quiet accent rule under section titles — one restrained signature detail */
.section-title{position:relative;padding-bottom:18px}
.section-title::after{
  content:"";position:absolute;left:0;bottom:0;
  width:42px;height:2px;background:var(--teal);
}
.section-dark .section-title::after,
.demo-section .section-title::after,
.approach .section-title::after,
.cta-section .section-title::after{background:var(--yellow)}
/* CTA section is centered — center its rule */
.cta-inner .cta-headline{padding-bottom:0}
.cta-inner .cta-headline::after{display:none}

/* ─────────────────────────────────────────────────────────────
   NAV
   ───────────────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:9999;
  display:flex;align-items:center;gap:24px;
  height:var(--nav-h);
  padding:0 var(--gutter);
  background:var(--paper);
  border-bottom:1px solid var(--blue-rule);
}
.nav-brand{
  font-family:'Syne','Fraunces',sans-serif;
  font-weight:800;font-size:15px;
  letter-spacing:.20em;color:var(--ink);
}
.nav-brand .accent{color:var(--blue-ink)}
.nav-links{
  display:flex;align-items:center;gap:28px;
  list-style:none;margin-left:24px;
  font-size:13px;color:var(--ink-2);
}
.nav-links a{transition:color var(--dur) var(--ease);position:relative;padding:6px 0}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:1px;background:var(--teal);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur) var(--ease);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1)}

.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}

/* Language switcher (DE / EN) */
.lang-switch{
  display:inline-flex;align-items:center;
  border:1px solid rgba(11,26,44,.18);
  border-radius:2px;overflow:hidden;
  background:var(--paper);
  font-family:var(--body);font-weight:500;font-size:12px;letter-spacing:.04em;
  line-height:1;
}
.lang-switch a,
.lang-switch span{
  display:inline-flex;align-items:center;justify-content:center;
  height:38px;min-width:38px;padding:0 10px;
  color:var(--ink);
  text-transform:uppercase;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.lang-switch a + a,
.lang-switch a + span,
.lang-switch span + a{
  border-left:1px solid rgba(11,26,44,.18);
}
.lang-switch a:hover{background:var(--blue-tint)}
.lang-switch .is-active{
  background:var(--blue-ink);color:#fff;cursor:default;
}

.nav-cta{
  position:relative;overflow:hidden;isolation:isolate;
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue-ink);color:#fff;
  font-weight:500;font-size:13px;letter-spacing:.01em;
  padding:9px 16px;border-radius:2px;
  transition:color var(--dur) var(--ease);
}
.nav-cta::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--blue-ink-hover);transform:translateX(-101%);
  transition:transform .32s cubic-bezier(.2,.7,.2,1);
}
.nav-cta:hover::before{transform:translateX(0)}
.nav-cta span{transition:transform var(--dur) var(--ease)}
.nav-cta:hover span{transform:translateX(4px)}

.menu-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  height:38px;padding:0 16px;border-radius:2px;
  border:1px solid rgba(11,26,44,.18);color:var(--ink);
  background:var(--paper);
  font-family:var(--body);font-weight:500;font-size:13px;letter-spacing:.01em;
  transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease),background var(--dur) var(--ease);
}
.menu-btn:hover{
  border-color:var(--ink);color:var(--ink);
  background:var(--blue-tint);
}
.menu-btn-lines{
  display:inline-flex;flex-direction:column;justify-content:center;gap:4px;
  width:16px;height:12px;
}
.menu-btn-lines span{
  display:block;width:100%;height:1.4px;background:currentColor;
  transition:width var(--dur) var(--ease);
}
.menu-btn-lines span:last-child{width:11px;align-self:flex-end}
.menu-btn:hover .menu-btn-lines span:last-child{width:100%}
.menu-btn-label{line-height:1}
@media(max-width:520px){
  .menu-btn-label{display:none}
  .menu-btn{padding:0;width:38px}
}
@media(max-width:860px){
  .nav-links{display:none}
}

/* ─────────────────────────────────────────────────────────────
   HERO — editorial cover. Flat navy. Text block on top, the pilot
   portrait sits below it (never overlaid), at its natural size.
   ───────────────────────────────────────────────────────────── */
.hero{
  position:relative;
  padding:calc(var(--nav-h) + clamp(48px,7vw,92px)) var(--gutter) clamp(56px,8vw,104px);
  background:var(--dark);          /* flat navy — no gradient, no grid */
  color:var(--ink-light);
}
.hero-inner{
  max-width:980px;margin:0 auto;
  display:flex;flex-direction:column;
}
.hero-text{
  min-width:0;
  display:flex;flex-direction:column;align-items:flex-start;
}
.hero-text .eyebrow{color:var(--ink-light-2);margin-bottom:var(--s-5)}
.hero-title{
  font-family:var(--display);font-weight:600;
  font-variation-settings:"opsz" 144;
  font-size:var(--t-display);
  line-height:.98;letter-spacing:-.038em;
  color:#fff;
  margin-bottom:var(--s-5);
  text-wrap:balance;
  max-width:15ch;
}
.hero-title em{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-variation-settings:"opsz" 144;
  color:#fff;
  letter-spacing:-.02em;
}
.hero-title strong{font-weight:700}
/* Second line drops below and is indented — an intentional
   editorial typeset, not a wrap accident. */
.hero-title-l2{display:block;padding-left:clamp(28px,4vw,64px)}
.hero-sub{
  font-size:var(--t-sub);
  color:var(--ink-light-2);
  max-width:56ch;
  margin-bottom:var(--s-4);
  line-height:1.62;
  text-wrap:pretty;
}
.hero .hero-kicker{color:var(--yellow)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:var(--s-3);margin-top:var(--s-7)}
/* On navy the primary CTA becomes the single yellow action. */
.hero .btn-primary{
  background:var(--yellow);color:#1A1A1A;
  box-shadow:inset 0 0 0 1px var(--yellow);
}
.hero .btn-primary::before{background:#EEDC8E}
.hero .btn-primary:hover{color:#1A1A1A;box-shadow:inset 0 0 0 1px #EEDC8E}

/* Portrait — below the text block, separated, centred, natural size. */
.hero-portrait{
  margin:clamp(48px,7vw,88px) auto 0;
  width:100%;max-width:360px;          /* brand mark, not a full illustration */
  display:flex;flex-direction:column;align-items:center;
}
/* Whole portrait is a quiet link to the "Why" section — implicit,
   no overlay or label, just a gentle hover and a palette focus ring. */
.portrait-link{
  display:block;width:100%;cursor:pointer;
  border-radius:1px;
}
.portrait-link .portrait-frame img{
  transition:opacity .3s ease, transform .3s ease;
}
.portrait-link:hover .portrait-frame img{
  opacity:.92;transform:scale(1.02);
}
.portrait-link:focus-visible{
  outline:2px solid var(--yellow);outline-offset:6px;
}
/* Brand mark — free-standing on the navy hero so the logo's orange
   goggle-glow reads (the old white photo-card has been retired with
   the pilot illustration). */
.portrait-frame{
  position:relative;
  aspect-ratio:1/1;
  width:100%;
  background:transparent;
  border:none;
  transition:transform .25s ease-out;
  will-change:transform;
}
.portrait-frame img{
  width:100%;height:100%;
  object-fit:contain;object-position:center;
  padding:clamp(4px,1vw,14px);
}
.hero-portrait figcaption{
  font-family:var(--mono);font-weight:700;
  font-size:11px;letter-spacing:.20em;text-transform:uppercase;
  color:var(--ink-light-2);
  margin-top:var(--s-5);
  display:flex;align-items:center;gap:10px;
}
.hero-portrait figcaption::before{
  content:"";width:22px;height:1px;background:var(--ink-light-2);display:inline-block;flex-shrink:0;
}
.hero-portrait figcaption em{font-style:normal;color:var(--ink-light)}

@media(max-width:620px){
  .hero-text{max-width:none}
  .hero-portrait{max-width:312px}
}

/* ─────────────────────────────────────────────────────────────
   2. PROBLEM — three-column with the "With Intraprise" column lifted
   ───────────────────────────────────────────────────────────── */
.problem{background:var(--paper)}
.problem-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(0px,0vw,0px) clamp(20px,2.6vw,40px);
  align-items:stretch;
}
/* Editorial comparison ledger — ruled columns, not cards. */
.prob-col{
  position:relative;
  padding:var(--s-6) clamp(18px,1.6vw,26px) var(--s-7);
  display:flex;flex-direction:column;gap:var(--s-4);
  background:var(--paper);
  border-top:1.5px solid var(--ink);
  min-height:0;
  transition:transform .25s ease;
}
.prob-col::before{
  content:"";position:absolute;top:-1.5px;left:0;width:52px;height:4px;
  background:var(--blue-mid);
}
.prob-col--cost{background:var(--paper)}
.prob-col--try{
  background:var(--cyan-soft);
  margin:0 calc(-1 * clamp(10px,1.3vw,20px));
  padding-left:clamp(28px,2.9vw,46px);padding-right:clamp(28px,2.9vw,46px);
}
.prob-col--try::before{background:var(--ink-3)}

.prob-col--us{
  background:var(--blue-ink);
  color:var(--ink-light);
  border-top-color:var(--blue-ink);
  padding-left:clamp(24px,2.2vw,34px);padding-right:clamp(24px,2.2vw,34px);
  position:relative;overflow:hidden;
  transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1);
}
.prob-col--us::before{background:var(--cyan)}
.prob-col--us::after{
  /* the single yellow punch for this section */
  content:"";position:absolute;top:var(--s-6);right:24px;width:34px;height:3px;background:var(--yellow);
}
.js .prob-col--us:not(.is-revealed){opacity:0;transform:translateY(24px)}
.prob-col--us.is-revealed{opacity:1;transform:translateY(0)}

.col-eyebrow{
  font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.20em;text-transform:uppercase;
  color:var(--ink-3);font-weight:600;
}
.col-eyebrow.on-dark{color:var(--ink-light-2)}
.prob-col--cost .col-eyebrow{color:var(--ink-3)}
.prob-col--try .col-eyebrow{color:var(--ink-3)}

.prob-stat{display:flex;flex-direction:column;gap:8px;margin-top:var(--s-2)}
.prob-stat + .prob-stat{margin-top:var(--s-5)}
.prob-num{
  font-size:clamp(66px,8.4vw,128px);
  line-height:.88;letter-spacing:-.045em;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.prob-num.pink{color:var(--ink)}
.prob-num .pct{font-size:.34em;font-weight:700;color:var(--ink);margin-left:5px;letter-spacing:0;font-variation-settings:"opsz" 40}
.prob-cap{color:var(--ink-2);font-size:14px;max-width:26ch;line-height:1.5}

.prob-list{list-style:none;display:flex;flex-direction:column;gap:8px;padding-left:0}
.prob-list li{
  position:relative;padding-left:18px;
  font-size:14.5px;color:var(--ink);line-height:1.5;
}
.prob-list li::before{
  content:"";position:absolute;left:0;top:.65em;width:9px;height:1.5px;
  background:var(--teal);
}
.prob-list.on-dark li{color:var(--ink-light)}
.prob-list.on-dark li strong{color:var(--yellow);font-weight:600}
.prob-list.on-dark li::before{background:var(--yellow)}

.prob-aside{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:14.5px;color:var(--teal);
  padding-top:var(--s-2);margin-top:var(--s-2);
  border-top:1px solid var(--blue-rule);
}
.prob-col--try .prob-aside{color:var(--ink-2);border-color:var(--blue-rule)}
.prob-aside.on-dark{color:var(--yellow);border-color:rgba(245,230,168,.25)}

@media(max-width:980px){
  .problem-grid{grid-template-columns:1fr 1fr}
  .prob-col--us{grid-column:1/-1}
}
@media(max-width:620px){
  .problem-grid{grid-template-columns:1fr}
  .prob-col--us{grid-column:auto}
}

/* ─────────────────────────────────────────────────────────────
   FILMSTRIP — quiet breath between sections
   ───────────────────────────────────────────────────────────── */
.filmstrip{
  /* Soft warm-neutral gray: a calm ribbon between sections — present
     enough not to feel sterile, quiet enough to recede. */
  background:var(--gray-band);
  padding:clamp(10px,1.4vw,18px) 0;overflow:hidden;
  border-top:1px solid rgba(12,27,38,.08);
  border-bottom:1px solid rgba(12,27,38,.08);
}
.filmstrip-row{display:flex;width:100%;overflow:hidden;position:relative}
.filmstrip-row + .filmstrip-row{margin-top:clamp(8px,1vw,14px)}
.filmstrip-track{display:flex;flex-shrink:0;width:max-content;will-change:transform}
.filmstrip-half{display:flex;flex-shrink:0;gap:clamp(12px,1.4vw,22px);padding-right:clamp(12px,1.4vw,22px)}
.filmstrip-row.r1 .filmstrip-track{animation:fsL 42s linear infinite}
.filmstrip-row.r2 .filmstrip-track{animation:fsR 48s linear infinite}
.filmstrip-cell{
  width:clamp(96px,10vw,140px);   /* more compact; aspect-ratio keeps proportions */
  aspect-ratio:4/3;
  flex-shrink:0;
  overflow:hidden;background:var(--paper);
  border:1px solid var(--blue-rule);
  border-radius:var(--radius);
}
.filmstrip-cell img{width:100%;height:100%;object-fit:contain;opacity:.96;background:var(--paper)}
@keyframes fsL{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fsR{from{transform:translateX(-50%)}to{transform:translateX(0)}}

/* ─────────────────────────────────────────────────────────────
   3. WHY — two-column asymmetric, ruled
   ───────────────────────────────────────────────────────────── */
.why{background:var(--paper)}
.why-head{margin-bottom:clamp(28px,3.6vw,48px)}
.why-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(28px,5vw,72px);
}
.why-col{
  padding:var(--s-6) 0 0;
  border-top:1px solid var(--ink);
  position:relative;
}
.why-col::before{
  content:"";position:absolute;top:-1px;left:0;width:56px;height:3px;background:var(--teal);
}
.why-headline{
  font-family:var(--display);font-weight:600;
  font-variation-settings:"opsz" 96;
  font-size:var(--t-h3);
  line-height:1.08;letter-spacing:-.022em;
  color:var(--ink);
  margin-bottom:var(--s-4);text-wrap:balance;
}
.why-headline .pink{
  display:inline;
  font-family:var(--serif);font-style:italic;font-weight:500;
  color:var(--blue-ink);
}
.why-body{font-size:15.5px;color:var(--ink-2);max-width:48ch;line-height:1.6}
.why-body strong{color:var(--ink);font-weight:600}
.why-list{font-size:15.5px;color:var(--ink-2);max-width:48ch;line-height:1.6;margin-top:var(--s-4);padding-left:1.1em;list-style:disc}
.why-list li{margin-bottom:var(--s-3)}
.why-list li:last-child{margin-bottom:0}
.why-list strong{color:var(--ink);font-weight:600}

@media(max-width:780px){.why-grid{grid-template-columns:1fr;gap:var(--s-7)}}

/* ─────────────────────────────────────────────────────────────
   4. SOLUTION + SCIENCE
   ───────────────────────────────────────────────────────────── */
.solution{background:var(--paper)}
.signal{
  display:grid;grid-template-columns:180px 1fr;gap:clamp(24px,4vw,64px);
  padding:clamp(36px,4.5vw,56px) 0;
  border-top:1px solid var(--blue-rule);
}
.signal:last-of-type{border-bottom:1px solid var(--blue-rule)}
.signal-side{display:flex;flex-direction:column;gap:var(--s-2)}
.signal-num{
  font-family:var(--display);font-weight:600;font-size:48px;
  font-variation-settings:"opsz" 144;
  color:var(--blue-ink);line-height:1;letter-spacing:-.03em;
}
.signal-tag{
  font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.20em;
  text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.signal-h{
  font-family:var(--display);font-weight:600;
  font-variation-settings:"opsz" 96;
  font-size:var(--t-h3);line-height:1.08;letter-spacing:-.022em;
  color:var(--ink);margin-bottom:var(--s-4);text-wrap:balance;
  max-width:24ch;
}
.signal-h em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--blue-ink)}
.signal-body{font-size:15.5px;color:var(--ink-2);max-width:62ch;line-height:1.6}

.market-facts{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.4vw,28px);margin-top:var(--s-6);
}
.market-facts--lead{margin-top:var(--s-7)}
.m-fact{
  padding:var(--s-6) clamp(20px,2vw,30px) var(--s-5) 0;
  background:transparent;
  border-top:1.5px solid var(--ink);
  display:flex;flex-direction:column;gap:var(--s-4);
  position:relative;
}
.m-fact::before{
  content:"";position:absolute;top:-1.5px;left:0;width:52px;height:4px;background:var(--blue-mid);
}
.m-fact-num{
  font-family:var(--display);font-weight:800;
  font-size:clamp(76px,10vw,148px);
  line-height:.84;letter-spacing:-.05em;
  color:var(--teal);
  font-variation-settings:"opsz" 144;
  font-variant-numeric:tabular-nums lining-nums;
  font-feature-settings:"tnum","lnum";
  display:inline-flex;align-items:flex-start;gap:2px;
}
.m-fact-num .pct{
  font-size:.30em;font-weight:700;
  color:var(--blue-mid);
  margin-left:5px;margin-top:.18em;letter-spacing:0;
  font-variation-settings:"opsz" 40;
}
.m-fact p{color:var(--ink-2);font-size:15px;max-width:34ch;line-height:1.55}

.stat-src{
  display:inline-block;
  margin-left:6px;font-size:.22em;font-weight:600;
  color:var(--ink-3);
  border-bottom:1px solid transparent;
  transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);
  vertical-align:top;line-height:1;
}
.stat-src sup{font-family:var(--body);font-size:13px;letter-spacing:0}
.stat-src:hover,.stat-src:focus-visible{
  color:var(--blue-ink);border-bottom-color:var(--blue-ink);outline:none;
}

.stat-sources{
  list-style:none;margin-top:var(--s-6);padding-top:var(--s-4);
  border-top:1px solid var(--blue-rule);
  display:flex;flex-direction:column;gap:6px;
  font-family:var(--body);font-size:12.5px;color:var(--ink-3);
  line-height:1.55;max-width:62ch;
}
.stat-sources sup{font-weight:600;color:var(--ink-2);margin-right:4px}
.stat-sources a{
  color:var(--blue-ink);
  border-bottom:1px solid var(--accent-tint);
  transition:border-color .18s;
}
.stat-sources a:hover{border-bottom-color:var(--blue-ink)}

.market-close{
  margin-top:var(--s-6);
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(18px,1.6vw,22px);color:var(--ink);
  max-width:52ch;line-height:1.4;
}

@media(max-width:780px){
  .signal{grid-template-columns:1fr;gap:var(--s-4)}
  .signal-side{flex-direction:row;align-items:baseline;gap:var(--s-4)}
  .market-facts{grid-template-columns:1fr}
}

/* ─────────────────────────────────────────────────────────────
   5. DEMO — dark, browser window as a quiet stage
   ───────────────────────────────────────────────────────────── */
.demo-section{
  border-top:1px solid rgba(245,230,168,.18);
}

.demo-cross{
  position:relative;
  display:grid;
  grid-template-columns:minmax(260px,1.1fr) minmax(0,2.2fr) minmax(260px,1.1fr);
  grid-template-rows:auto auto auto;
  gap:clamp(16px,1.8vw,24px) clamp(28px,3.4vw,52px);
  align-items:center;
}
.demo-cross .co--l1     {grid-column:1;grid-row:1;align-self:end;  transform:translateY(6%)}
.demo-cross .co--l2     {grid-column:1;grid-row:2;align-self:start;transform:translateY(-6%)}
.demo-cross .demo-center{grid-column:2;grid-row:1 / span 2;position:relative;z-index:1}
.demo-cross .co--r1     {grid-column:3;grid-row:1;align-self:end;  transform:translateY(6%)}
.demo-cross .co--r2     {grid-column:3;grid-row:2;align-self:start;transform:translateY(-6%)}
.demo-cross .co--b      {
  grid-column:2;grid-row:3;
  justify-self:center;max-width:560px;
  text-align:left;align-items:flex-start;
  margin-top:clamp(16px,2vw,28px);
}

@media(max-width:980px){
  .demo-cross{grid-template-columns:1fr;grid-template-rows:auto;gap:clamp(14px,2vw,20px)}
  .demo-cross .co--l1,.demo-cross .co--l2,.demo-cross .demo-center,
  .demo-cross .co--r1,.demo-cross .co--r2,.demo-cross .co--b{
    grid-column:1;grid-row:auto;max-width:none;text-align:left;align-items:flex-start;
    justify-self:stretch;align-self:stretch;transform:none;margin-top:0;
  }
}

/* Browser window — stage, not feature. Quiet chrome. */
.browser-window{
  background:var(--dark-elev);
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border-on-dark-strong);
  box-shadow:0 30px 80px -40px rgba(0,0,0,.7);
  opacity:0;transform:translateY(12px);
  transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1);
}
.browser-window.vis{opacity:1;transform:translateY(0)}
.browser-bar{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;background:rgba(0,0,0,.30);
  border-bottom:1px solid var(--border-on-dark);
}
.browser-dots{display:flex;gap:5px}
.browser-dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.14)}
.browser-dots span:first-child{background:rgba(255,255,255,.22)}
.browser-dots span:nth-child(2){background:rgba(255,255,255,.18)}
.browser-dots span:nth-child(3){background:rgba(255,255,255,.14)}
.browser-url{
  flex:1;background:rgba(231,239,246,.05);border-radius:3px;padding:5px 11px;
  font-family:var(--mono);font-size:10.5px;color:var(--ink-light-2);letter-spacing:.02em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.browser-controls{display:none}
.browser-screen img{width:100%;display:block}

/* Demo video — the ambient loop sitting in the browser stage */
.browser-screen{position:relative}
.demo-video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;cursor:pointer;background:var(--dark)}
.demo-expand{
  position:absolute;left:50%;bottom:14px;transform:translateX(-50%);
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  white-space:nowrap;
  padding:9px 16px;border-radius:var(--radius);cursor:pointer;
  background:rgba(0,0,0,.55);color:var(--ink-light);border:1px solid var(--border-on-dark-strong);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  transition:background .2s, transform .2s;
}
.demo-expand:hover{background:rgba(0,0,0,.72);transform:translateX(-50%) translateY(-1px)}
.demo-expand:focus-visible{outline:2px solid var(--yellow);outline-offset:2px}

/* Lightbox — full story */
.demo-lightbox{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,48px);background:rgba(0,0,0,.86);
  opacity:0;transition:opacity .25s ease;
}
.demo-lightbox.is-open{opacity:1}
.demo-lightbox[hidden]{display:none}
.demo-lightbox-inner{position:relative;width:min(1100px,100%);aspect-ratio:16/9}
.demo-full{
  width:100%;height:100%;display:block;border-radius:var(--radius);
  border:1px solid var(--border-on-dark-strong);background:#000;
}
.demo-lightbox-close{
  position:absolute;top:-14px;right:-14px;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--border-on-dark-strong);background:var(--dark-elev);color:var(--ink-light);
  font-size:22px;line-height:1;cursor:pointer;
}
.demo-lightbox-close:focus-visible{outline:2px solid var(--yellow);outline-offset:2px}
@media(max-width:980px){.demo-lightbox-close{top:8px;right:8px}}

/* Reduced motion: the loop is paused by JS; the poster + play button stand in */
@media(prefers-reduced-motion:reduce){.demo-video{cursor:pointer}}

.co{
  padding:var(--s-4) var(--s-5);
  background:transparent;
  border-left:1px solid var(--border-on-dark-strong);
  border-radius:0;
  transition:border-color .25s, background .25s;
  display:flex;flex-direction:column;gap:6px;
}
.co:hover{border-color:var(--blue-mid);background:rgba(238,241,244,.05)}
.co-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  color:var(--ink-light-2);display:block;font-weight:700;
}
.co-h{
  font-family:'Syne','Fraunces',sans-serif;
  font-weight:700;font-size:13px;color:var(--ink-light);
  letter-spacing:.06em;line-height:1.4;
  text-transform:uppercase;
}

/* ─────────────────────────────────────────────────────────────
   6. PROOF — asymmetric, cases on left, quotes on right
   ───────────────────────────────────────────────────────────── */
.proof{background:var(--paper)}
.proof-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,64px);
}
.proof-cases{display:flex;flex-direction:column;gap:var(--s-4)}
.case-card{
  background:var(--paper);
  border:1px solid var(--blue-rule);
  border-left:3px solid var(--blue-mid);
  border-radius:var(--radius);
  padding:var(--s-6);
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.case-card:hover{border-color:var(--blue-rule-strong);transform:translateX(2px)}
.case-tag{
  font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:var(--s-3);
}
.case-body{color:var(--ink-2);font-size:15px;line-height:1.6;max-width:48ch}

.proof-quotes{display:flex;flex-direction:column;gap:var(--s-4)}
.quote-card{
  position:relative;
  padding:var(--s-4) var(--s-5) var(--s-4) var(--s-7);
  border-left:1px solid var(--blue-rule-strong);
}
.quote-card::before{
  content:"\201C";
  position:absolute;top:-6px;left:6px;
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-variation-settings:"opsz" 144;
  font-size:54px;color:var(--teal);line-height:1;
}
.quote-card p{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-variation-settings:"opsz" 48;
  font-size:clamp(17px,1.5vw,21px);color:var(--ink);line-height:1.4;
  text-wrap:balance;
}

@media(max-width:880px){.proof-grid{grid-template-columns:1fr}}

/* ── Featured case study (hackathon) ───────────────────────────── */
.case-feature{margin-top:clamp(56px,7vw,100px);margin-bottom:clamp(52px,6.5vw,92px)}
.case-feature-label{
  font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:var(--s-4);
}
.case-feature-title{
  font-family:var(--display);font-weight:500;
  font-size:clamp(25px,3.2vw,40px);line-height:1.08;letter-spacing:-.01em;
  color:var(--ink);max-width:22ch;margin-bottom:var(--s-5);
}
.case-feature-lede{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-variation-settings:"opsz" 48;
  font-size:clamp(18px,1.7vw,23px);line-height:1.45;color:var(--ink-2);
  max-width:54ch;text-wrap:balance;
}
.case-feature figure{margin:0}
.case-hero{margin:clamp(28px,3.6vw,48px) 0 0}
.case-hero img{
  width:100%;aspect-ratio:16/9;object-fit:cover;display:block;
  border-radius:var(--radius-lg);border:1px solid var(--blue-rule);
}
.case-cap{
  font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.04em;
  color:var(--ink-3);margin-top:var(--s-3);
}
.case-feature-body{
  display:grid;grid-template-columns:1.5fr .85fr;gap:clamp(28px,4vw,64px);
  margin-top:clamp(32px,4vw,56px);align-items:start;
}
.case-narrative p{
  color:var(--ink-2);font-size:clamp(15px,1.1vw,17px);line-height:1.7;
  margin:0 0 var(--s-4);max-width:62ch;
}
.case-narrative p:last-child{margin-bottom:0}
.case-narrative strong{color:var(--ink);font-weight:600}
.case-stats{
  list-style:none;margin:0;padding:0 0 0 var(--s-5);
  display:flex;flex-direction:column;gap:var(--s-6);
  border-left:3px solid var(--blue-mid);
}
.case-stats .stat-num{
  display:block;font-family:var(--display);font-weight:500;
  font-size:clamp(34px,4vw,52px);line-height:1;color:var(--ink);letter-spacing:-.02em;
}
.case-stats .stat-label{
  display:block;margin-top:var(--s-2);color:var(--ink-3);
  font-size:14px;line-height:1.45;max-width:26ch;
}
/* masonry gallery — preserves every photo's native orientation */
.case-gallery{
  column-count:3;column-gap:clamp(10px,1.2vw,16px);
  margin-top:clamp(32px,4vw,56px);
}
.case-gallery figure{break-inside:avoid;margin:0 0 clamp(10px,1.2vw,16px)}
.case-gallery img{
  width:100%;height:auto;display:block;border-radius:var(--radius);
  border:1px solid var(--blue-rule);
}
.case-gallery .case-cap{margin-top:var(--s-2)}
/* winner highlight — dark band */
.case-winner{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(22px,3vw,44px);
  align-items:center;margin-top:clamp(36px,4.5vw,64px);
  background:var(--dark);border-radius:var(--radius-lg);
  padding:clamp(20px,2.6vw,34px);
}
.case-winner img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:var(--radius);display:block}
.case-winner .case-feature-label{color:var(--yellow)}
.case-winner h4{
  font-family:var(--display);font-weight:500;font-size:clamp(21px,2.4vw,30px);
  line-height:1.12;color:var(--ink-light);margin:0 0 var(--s-4);text-wrap:balance;
}
.case-winner p{color:var(--ink-light-2);font-size:15px;line-height:1.65;margin:0 0 var(--s-3)}
.case-winner p:last-child{margin-bottom:0}
.case-winner strong{color:var(--ink-light);font-weight:600}
.case-partners{
  margin-top:clamp(28px,3.5vw,48px);padding-top:var(--s-5);
  border-top:1px solid var(--blue-rule);
  color:var(--ink-3);font-size:14px;line-height:1.7;max-width:84ch;
}
.case-partners strong{color:var(--ink-2);font-weight:600}
.case-more-head{
  font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);margin:0 0 var(--s-5);
}
@media(max-width:980px){.case-gallery{column-count:2}}
@media(max-width:880px){
  .case-feature-body{grid-template-columns:1fr}
  .case-winner{grid-template-columns:1fr}
  .case-stats{flex-direction:row;flex-wrap:wrap;gap:var(--s-6)}
  .case-stats .stat-label{max-width:18ch}
}
@media(max-width:560px){.case-gallery{column-count:1}}

/* Closing founder portrait — sits just above the footer */
.closing-portrait{margin:clamp(48px,7vw,104px) 0 0}
.closing-portrait figure{margin:0;display:flex;justify-content:center}
.closing-portrait img{
  width:100%;max-width:860px;height:auto;display:block;
  border-radius:var(--radius-lg);border:1px solid var(--blue-rule);
}

/* condensed case preview inside the nav menu panel */
.menu-case-thumbs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:var(--s-4) 0;
}
.menu-case-thumbs img{
  width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius);display:block;
}
.menu-case-facts{
  list-style:none;margin:var(--s-4) 0 0;padding:0;
  display:flex;flex-wrap:wrap;gap:var(--s-3) var(--s-6);
}
.menu-case-facts li{font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.06em;color:var(--ink-2)}
.menu-case-facts b{color:var(--ink);font-weight:700}

/* ─────────────────────────────────────────────────────────────
   7. APPROACH — dark mission statement
   ───────────────────────────────────────────────────────────── */
.approach{border-top:1px solid rgba(245,230,168,.18)}
.approach-head{margin-bottom:clamp(28px,3.6vw,48px)}

.approach-question{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-variation-settings:"opsz" 96;
  font-size:clamp(24px,2.8vw,38px);
  color:var(--ink-light);
  max-width:46ch;line-height:1.28;
  margin-bottom:var(--s-7);
}

.approach-mission-stack{
  display:flex;flex-direction:column;
  gap:clamp(18px,2vw,28px);
  max-width:64ch;
  border-left:2px solid var(--ink-rule-strong);
  padding:clamp(8px,1vw,14px) 0 clamp(8px,1vw,14px) clamp(20px,2vw,28px);
}
.mission-line{
  font-family:var(--serif);font-weight:400;
  font-variation-settings:"opsz" 72;
  font-size:clamp(17px,1.6vw,21px);
  line-height:1.45;letter-spacing:-.005em;
  color:var(--ink-light-2);
  text-wrap:balance;
}
.mission-line em{font-style:italic;color:var(--ink-light);font-weight:500}
.mission-line strong{font-weight:600;color:var(--ink-light);font-style:normal}
.mission-label{
  font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-light-2);
  display:inline-block;margin-right:10px;
}
.mission-line--lead{font-size:clamp(18px,1.7vw,22px);color:var(--ink-light)}
.mission-line--major{
  font-family:var(--display);font-weight:500;
  font-variation-settings:"opsz" 96;
  font-size:clamp(24px,2.8vw,38px);
  line-height:1.15;letter-spacing:-.02em;
  color:var(--ink-light);
}
.mission-line--major em{
  font-family:var(--serif);font-style:italic;font-weight:500;color:var(--ink-light);
}
.mission-line--punch{
  font-family:var(--display);font-weight:400;
  font-variation-settings:"opsz" 96;
  font-size:clamp(19px,1.9vw,24px);
  color:var(--ink-light);letter-spacing:-.01em;
  padding-top:var(--s-3);border-top:1px solid var(--border-on-dark);
}
.mission-line--punch em{font-family:var(--serif);font-style:italic;color:var(--ink-light)}

.bc-equation{
  margin-top:var(--s-7);
  padding:clamp(24px,2.6vw,32px);
  background:var(--dark-elev);
  border:1px solid var(--border-on-dark);
  border-left:2px solid var(--yellow);
  border-radius:var(--radius);
}
.bc-lead{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(16px,1.4vw,19px);line-height:1.4;
  color:var(--ink-light-2);
  margin-bottom:var(--s-5);
  max-width:54ch;
}
.bc-lead em{color:var(--yellow);font-style:italic}
.bc-row{display:flex;align-items:center;flex-wrap:wrap;gap:clamp(8px,1.2vw,14px)}
.bc-label{
  font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-light);padding-right:var(--s-2);
}
.bc-equals{
  font-family:var(--display);font-weight:600;font-size:20px;
  color:var(--yellow);line-height:1;
}
.bc-chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 14px;
  background:rgba(245,230,168,.06);
  border:1px solid rgba(245,230,168,.28);
  border-radius:2px;
  font-family:var(--body);font-weight:500;font-size:13.5px;
  color:var(--ink-light);
}
.bc-chip-num{
  font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;
  color:var(--yellow);
  width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(245,230,168,.10);
  border:1px solid rgba(245,230,168,.28);
}
.bc-plus{
  font-family:var(--display);font-weight:600;font-size:18px;
  color:var(--yellow);opacity:.8;line-height:1;
}

.approach-cta-row{
  display:flex;flex-wrap:wrap;align-items:center;gap:var(--s-4) var(--s-5);
  margin-top:clamp(28px,3.6vw,44px);
}
.approach-cta-row .btn-primary{
  background:var(--yellow);color:#1A1A1A;
  box-shadow:inset 0 0 0 1px var(--yellow);
}
.approach-cta-row .btn-primary::before{background:#EEDC8E}
.approach-cta-row .btn-primary:hover{color:#1A1A1A;box-shadow:inset 0 0 0 1px #EEDC8E}
.approach-cta-note{
  font-family:var(--serif);font-style:italic;
  font-size:14.5px;color:var(--ink-light-2);
  max-width:42ch;line-height:1.5;
}

/* Menu Programs panel — phases */
.menu-phases{
  list-style:none;display:flex;flex-direction:column;gap:var(--s-4);
  margin:var(--s-4) 0 var(--s-6);
  border-top:1px solid var(--blue-rule);padding-top:var(--s-4);
}
.menu-phases > li{
  display:grid;grid-template-columns:auto 1fr;
  column-gap:var(--s-5);row-gap:4px;
  padding-bottom:var(--s-4);
  border-bottom:1px solid var(--blue-rule);
}
.menu-phases > li:last-child{border-bottom:0;padding-bottom:0}
.menu-phase-num{
  grid-column:1;grid-row:1 / span 4;
  width:36px;height:36px;
  display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:14px;
  color:var(--blue-ink);
  border:1.5px solid var(--blue-ink);
}
.menu-phase-name{
  grid-column:2;
  font-family:var(--display);font-weight:600;font-size:18px;
  color:var(--ink);letter-spacing:-.005em;
}
.menu-phase-len{
  font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--teal);margin-left:8px;
}
.menu-phase-mood{
  grid-column:2;
  font-family:var(--serif);font-style:italic;font-size:14px;
  color:var(--ink-3);margin-top:2px!important;
}
.menu-phases > li > p:last-child{grid-column:2}

/* In-menu equation — lift onto light surface */
.bc-equation--menu{
  margin-top:var(--s-4);
  background:var(--blue-tint);
  border:1px solid var(--blue-rule);
  border-left:2px solid var(--blue-ink);
  color:var(--ink);
}
.bc-equation--menu .bc-lead{color:var(--ink-2)}
.bc-equation--menu .bc-lead em{color:var(--blue-ink)}
.bc-equation--menu .bc-label{color:var(--ink)}
.bc-equation--menu .bc-equals,
.bc-equation--menu .bc-plus{color:var(--blue-ink)}
.bc-equation--menu .bc-chip{
  background:var(--paper);
  border-color:var(--blue-rule-strong);color:var(--ink);
}
.bc-equation--menu .bc-chip-num{
  color:var(--blue-ink);background:var(--blue-tint);border-color:var(--blue-rule);
}

@media(max-width:640px){
  .bc-row{gap:8px}
  .bc-chip{padding:8px 12px;font-size:13px}
  .bc-equals,.bc-plus{font-size:17px}
}

/* ─────────────────────────────────────────────────────────────
   8. TEAM — restrained portrait cards
   ───────────────────────────────────────────────────────────── */
.team{background:var(--paper)}
.team-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,36px);
  list-style:none;
}
/* Register of operators — clean, unruled. */
.team-card{
  position:relative;
  display:flex;flex-direction:column;align-items:flex-start;gap:var(--s-5);
  padding:var(--s-6) clamp(14px,1.2vw,20px) var(--s-4) 0;
  transition:transform .25s ease;
}
.team-card:hover{transform:translateY(-3px)}
.team-photo{
  width:clamp(96px,9vw,124px);aspect-ratio:1;border-radius:0;
  background:var(--blue-mid);
  overflow:hidden;
}
.team-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.team-name{font-family:var(--display);font-weight:600;font-size:clamp(19px,1.6vw,23px);color:var(--ink);letter-spacing:-.012em;line-height:1.1}
.team-role{font-family:var(--mono);font-size:10.5px;letter-spacing:.20em;text-transform:uppercase;color:var(--teal);font-weight:700;margin-top:-8px}

@media(max-width:880px){.team-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.team-grid{grid-template-columns:1fr}}

/* ─────────────────────────────────────────────────────────────
   FAQ
   ───────────────────────────────────────────────────────────── */
.faq{background:var(--blue-tint)}
.faq-list{
  display:flex;flex-direction:column;gap:0;
  border-top:1px solid var(--blue-rule);
  max-width:920px;
}
.faq-item{border-bottom:1px solid var(--blue-rule)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:var(--s-5) 0;
  display:flex;align-items:center;justify-content:space-between;gap:var(--s-5);
  font-family:var(--display);font-weight:600;
  font-variation-settings:"opsz" 48;
  font-size:clamp(17px,1.6vw,21px);
  color:var(--ink);letter-spacing:-.005em;
  transition:color var(--dur) var(--ease);
}
.faq-item summary:hover{color:var(--blue-ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-icon{
  width:24px;height:24px;
  border:1px solid var(--blue-rule-strong);position:relative;flex-shrink:0;
  transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.faq-icon::before,.faq-icon::after{
  content:"";position:absolute;left:50%;top:50%;background:var(--ink);
}
.faq-icon::before{width:10px;height:1.3px;transform:translate(-50%,-50%)}
.faq-icon::after{width:1.3px;height:10px;transform:translate(-50%,-50%);transition:transform var(--dur) var(--ease)}
.faq-item[open] .faq-icon{background:var(--blue-ink);border-color:var(--blue-ink)}
.faq-item[open] .faq-icon::before,
.faq-item[open] .faq-icon::after{background:#fff}
.faq-item[open] .faq-icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-item p{
  padding:0 0 var(--s-5);color:var(--ink-2);font-size:15.5px;line-height:1.6;max-width:64ch;
}

/* ─────────────────────────────────────────────────────────────
   9. CLOSING CTA — dark, centered (this one sections allowed to center)
   ───────────────────────────────────────────────────────────── */
.cta-section{border-top:1px solid rgba(245,230,168,.18)}
.cta-inner{text-align:center;max-width:880px;position:relative;z-index:1;margin:0 auto}
.cta-section .eyebrow{color:var(--yellow);margin-left:auto;margin-right:auto}
.cta-headline{
  font-family:var(--display);font-weight:600;
  font-variation-settings:"opsz" 144;
  font-size:clamp(40px,5.2vw,72px);line-height:1.02;letter-spacing:-.03em;
  color:var(--ink-light);margin-bottom:var(--s-5);text-wrap:balance;
}
.cta-headline em{
  font-family:var(--serif);font-style:italic;font-weight:500;
  color:var(--yellow);
}
.cta-sub{
  font-size:var(--t-sub);color:var(--ink-light-2);
  max-width:62ch;margin:0 auto var(--s-7);line-height:1.55;
}
.cta-btns{display:flex;flex-wrap:wrap;gap:var(--s-3);justify-content:center;margin-bottom:var(--s-5)}
.cta-section .btn-primary{
  background:var(--yellow);color:#1A1A1A;
  box-shadow:inset 0 0 0 1px var(--yellow);
}
.cta-section .btn-primary::before{background:#EEDC8E}
.cta-section .btn-primary:hover{color:#1A1A1A;box-shadow:inset 0 0 0 1px #EEDC8E}
.cta-section .btn-primary + .btn-primary{
  background:transparent;color:var(--ink-light);
  box-shadow:inset 0 0 0 1px var(--border-on-dark-strong);
}
.cta-section .btn-primary + .btn-primary::before{background:var(--ink-light)}
.cta-section .btn-primary + .btn-primary:hover{color:var(--dark)}
.cta-tail{font-family:var(--serif);font-style:italic;color:var(--ink-light-2);font-size:15px}
.cta-tail a{color:var(--yellow);border-bottom:1px solid rgba(245,230,168,.4)}
.cta-tail a:hover{color:var(--ink-light);border-color:var(--ink-light)}

/* ─────────────────────────────────────────────────────────────
   FOOTER
   ───────────────────────────────────────────────────────────── */
.footer{
  padding:clamp(40px,5.5vw,68px) var(--gutter) var(--s-6);
  background:var(--paper);
  border-top:1px solid var(--blue-rule);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(20px,3vw,48px);max-width:var(--maxw);margin:0 auto;
}
.footer-brand{
  font-family:'Syne','Fraunces',sans-serif;
  font-weight:800;font-size:18px;
  color:var(--ink);letter-spacing:.20em;margin-bottom:6px;
}
.footer-brand span{color:var(--blue-ink)}
.footer-tagline{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-3)}
.footer-col-title{
  font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.20em;text-transform:uppercase;
  color:var(--teal);margin-bottom:var(--s-4);font-weight:600;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col li,.footer-col a,.footer-col .footer-menu-link{
  font-size:14px;color:var(--ink-2);transition:color var(--dur) var(--ease);
}
.footer-col a:hover,.footer-col .footer-menu-link:hover{color:var(--blue-ink)}
.footer-col .footer-menu-link{
  background:none;border:0;padding:0;margin:0;
  font:inherit;letter-spacing:inherit;text-align:left;
  cursor:pointer;display:inline;
}
.footer-col .footer-menu-link:focus-visible{
  outline:2px solid var(--teal);outline-offset:3px;
  box-shadow:0 0 0 5px var(--teal-tint);
}
.footer-bottom{
  margin-top:var(--s-7);padding-top:var(--s-4);border-top:1px solid var(--blue-rule);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  max-width:var(--maxw);margin-left:auto;margin-right:auto;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:var(--ink-3);
  text-transform:uppercase;
}
.footer-copyright{color:var(--ink-2)}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{font-size:9.5px}
}

/* ─────────────────────────────────────────────────────────────
   MEGA MENU OVERLAY
   ───────────────────────────────────────────────────────────── */
.menu-overlay{
  position:fixed;inset:0;z-index:10000;
  background:var(--paper);
  color:var(--ink);
  opacity:0;transform:translateY(-6px);pointer-events:none;
  transition:opacity .28s ease, transform .28s ease;
  overflow:hidden;
}
.menu-overlay[hidden]{display:none}
.menu-overlay[aria-hidden="false"]{opacity:1;transform:translateY(0);pointer-events:auto}
body.menu-open{overflow:hidden}

/* Glow blobs removed — flat white menu surface. */

.menu-shell{
  position:relative;z-index:1;
  display:grid;grid-template-rows:auto 1fr auto;
  height:100%;
  max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
}

.menu-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--s-5) 0;
  border-bottom:1px solid var(--blue-rule);
}
.menu-brand{
  font-family:'Syne','Fraunces',sans-serif;
  font-weight:800;font-size:15px;
  letter-spacing:.20em;color:var(--ink);
}
.menu-brand .accent{color:var(--blue-ink)}
.menu-brand em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:12px;color:var(--ink-3);margin-left:10px;letter-spacing:0;
}
.menu-close{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.20em;font-weight:600;
  border:1px solid var(--blue-rule-strong);padding:9px 14px;border-radius:2px;
  display:inline-flex;align-items:center;gap:10px;color:var(--ink-2);
  background:transparent;
  transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease),background var(--dur) var(--ease);
  min-height:36px;
}
.menu-close:hover,.menu-close:focus-visible{
  border-color:var(--blue-ink);color:var(--ink);
  background:var(--blue-tint);outline:none;
}

.menu-body{
  display:grid;grid-template-columns:240px 1fr;
  gap:clamp(28px,4vw,64px);
  padding:clamp(24px,3.5vw,48px) 0 var(--s-6);
  min-height:0;
}

.menu-tabs{
  display:flex;flex-direction:column;gap:1px;
  border-right:1px solid var(--blue-rule);
  padding-right:var(--s-5);overflow-y:auto;align-content:flex-start;
}
.menu-tab{
  position:relative;text-align:left;
  padding:12px 16px 12px 18px;
  border-radius:2px;
  font-family:var(--body);font-weight:500;font-size:14px;
  color:var(--ink-2);letter-spacing:.005em;
  background:transparent;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),padding-left var(--dur) var(--ease);
  min-height:42px;
}
.menu-tab:hover{color:var(--ink);background:var(--blue-tint)}
.menu-tab[aria-selected="true"]{
  color:var(--ink);background:var(--blue-soft);font-weight:600;
}
.menu-tab[aria-selected="true"]::before{
  content:"";position:absolute;left:0;top:25%;bottom:25%;
  width:3px;background:var(--blue-ink);
}
.menu-tab:focus-visible{outline:2px solid var(--teal);outline-offset:3px;box-shadow:0 0 0 5px var(--teal-tint)}

.menu-divider{
  display:block;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;font-weight:600;
  color:var(--ink-3);text-transform:uppercase;
  margin:var(--s-5) 0 var(--s-2);padding:0 16px;position:relative;
}
.menu-divider::after{
  content:"";display:block;margin-top:8px;height:1px;background:var(--blue-rule);
}

.menu-panels{overflow-y:auto;padding-right:var(--s-3);scroll-padding-top:var(--s-4)}
.menu-panel{display:none;max-width:68ch}
.menu-panel:not([hidden]){display:block;animation:menuIn .32s cubic-bezier(.2,.7,.2,1)}
@keyframes menuIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.menu-eyebrow{
  display:inline-block;
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;font-weight:600;
  color:var(--teal);text-transform:uppercase;
}

.menu-panel h2{
  font-family:var(--display);font-weight:600;
  font-variation-settings:"opsz" 96;
  font-size:clamp(28px,3vw,40px);
  line-height:1.06;letter-spacing:-.025em;
  color:var(--ink);
  margin:var(--s-3) 0 var(--s-5);text-wrap:balance;
}
.menu-panel h2 em{
  font-family:var(--serif);font-style:italic;font-weight:500;
  color:var(--blue-ink);letter-spacing:-.01em;
}
.menu-panel h3{
  font-family:var(--display);font-weight:600;
  font-size:clamp(17px,1.4vw,20px);
  color:var(--ink);margin:var(--s-7) 0 var(--s-3);letter-spacing:-.005em;
  padding-top:var(--s-4);border-top:1px solid var(--blue-rule);
}
.menu-panel h4{
  font-family:var(--display);font-weight:600;
  font-size:15px;color:var(--ink);
  margin:var(--s-5) 0 var(--s-2);letter-spacing:-.003em;
}
.menu-panel h5{
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal);margin:var(--s-4) 0 var(--s-2);
}
.menu-panel p{
  font-family:var(--body);font-size:15px;
  color:var(--ink-2);max-width:68ch;margin-bottom:var(--s-3);line-height:1.65;
}
.menu-panel p strong{color:var(--ink);font-weight:600}
.menu-panel a:not(.btn){
  color:var(--ink);
  border-bottom:1px solid var(--blue-rule);
  transition:color .18s,border-color .18s;padding-bottom:1px;
}
.menu-panel a:not(.btn):hover,
.menu-panel a:not(.btn):focus-visible{
  color:var(--blue-ink);border-bottom-color:var(--blue-ink);outline:none;
}

.menu-list{
  list-style:none;display:flex;flex-direction:column;
  gap:0;margin-top:var(--s-4);
  border-top:1px solid var(--blue-rule);
}
.menu-list li{
  padding:14px 0;border-bottom:1px solid var(--blue-rule);
  font-size:15px;color:var(--ink-2);line-height:1.6;max-width:68ch;
}
.menu-list li strong{color:var(--ink);font-weight:600}

.menu-list--links{border-top:0;margin-top:var(--s-5)}
.menu-list--links li{border-bottom:1px solid var(--blue-rule);padding:0}
.menu-list--links li:first-child{border-top:1px solid var(--blue-rule)}
.menu-list--links a{
  display:flex;align-items:baseline;justify-content:space-between;gap:var(--s-4);
  padding:16px 0;
  font-family:var(--body);font-size:15px;color:var(--ink);
  border-bottom:0;line-height:1.5;
  transition:color var(--dur) var(--ease), padding-left var(--dur) var(--ease), background var(--dur) var(--ease);
}
.menu-list--links a span{
  color:var(--teal);font-family:var(--serif);font-style:italic;
  transition:transform .2s;
}
.menu-list--links a:hover,
.menu-list--links a:focus-visible{
  color:var(--blue-ink);padding-left:8px;
  background:linear-gradient(90deg, var(--blue-tint) 0%, transparent 70%);
}
.menu-list--links a:hover span,
.menu-list--links a:focus-visible span{transform:translateX(4px)}

.contact-line{
  font-family:var(--display);font-weight:600;
  font-size:clamp(18px,1.8vw,22px);
  color:var(--ink);margin-bottom:var(--s-2);line-height:1.3;
}
.contact-line a{color:var(--ink);border-bottom:1px solid var(--blue-rule)}
.contact-line a:hover{color:var(--blue-ink);border-bottom-color:var(--blue-ink)}
.contact-address{
  font-style:normal;font-family:var(--body);font-size:15px;
  color:var(--ink-2);line-height:1.7;
  margin:var(--s-5) 0;
  padding:var(--s-4) var(--s-5);
  background:var(--blue-tint);
  border-left:2px solid var(--blue-ink);
  max-width:42ch;
}
.contact-link-row{margin-top:var(--s-5)}
.contact-link-row a{
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;font-weight:600;
  color:var(--teal);border-bottom:1px solid var(--teal);
}
.contact-cta-row{margin-top:var(--s-6);max-width:none}
.contact-cta-row .btn-primary{background:var(--blue-ink);color:#fff}
.contact-cta-row .btn-primary::before{background:var(--blue-ink-hover)}

.legal-panel{max-width:none}
.legal-panel h2{margin-bottom:var(--s-5)}
.legal-panel .legal-intro{
  font-family:var(--body);font-size:15px;line-height:1.65;
  color:var(--ink);
  padding:var(--s-4) var(--s-5);
  background:var(--blue-tint);
  border-left:2px solid var(--blue-ink);
  margin-bottom:var(--s-5);max-width:46ch;
}
.legal-panel p{font-size:14px;line-height:1.7;color:var(--ink-2);max-width:70ch;margin-bottom:var(--s-3)}
.legal-panel h3{font-size:clamp(16px,1.3vw,18px);margin-top:var(--s-7);color:var(--ink)}
.legal-panel h4{font-size:14.5px;margin-top:var(--s-5);color:var(--ink)}
.legal-panel h5{font-size:11px;color:var(--teal);margin-top:var(--s-4)}
.legal-date{
  margin-top:var(--s-7);padding-top:var(--s-4);
  border-top:1px solid var(--blue-rule);
  font-family:var(--mono);font-size:11px;letter-spacing:.20em;
  text-transform:uppercase;color:var(--ink-3);font-weight:600;
}

.menu-foot{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:var(--s-4);
  padding:var(--s-5) 0;border-top:1px solid var(--blue-rule);
}
.menu-foot-meta{
  display:flex;gap:var(--s-5);flex-wrap:wrap;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.20em;font-weight:600;
  text-transform:uppercase;color:var(--ink-3);
}
.menu-cta{padding:13px 22px;background:var(--blue-ink);color:#fff}
.menu-cta::before{background:var(--blue-ink-hover)}
.menu-cta:focus-visible{outline:2px solid var(--teal);outline-offset:3px;box-shadow:0 0 0 5px var(--teal-tint)}

@media(max-width:860px){
  .menu-shell{padding:0 var(--gutter)}
  .menu-body{grid-template-columns:1fr;gap:var(--s-5);padding-top:var(--s-4)}
  .menu-tabs{
    flex-direction:row;flex-wrap:nowrap;
    overflow-x:auto;overflow-y:hidden;
    border-right:0;border-bottom:1px solid var(--blue-rule);
    padding:0 0 var(--s-3);gap:4px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .menu-tabs::-webkit-scrollbar{display:none}
  .menu-tab{flex:0 0 auto;padding:10px 14px;border-radius:2px;font-size:13px;background:transparent;min-height:38px}
  .menu-tab[aria-selected="true"]{background:var(--blue-soft)}
  .menu-tab[aria-selected="true"]::before{display:none}
  .menu-divider{flex:0 0 auto;margin:0;padding:10px 8px;align-self:center}
  .menu-divider::after{display:none}
  .menu-panel h2{font-size:clamp(24px,5.5vw,32px)}
  .menu-panels{padding-right:0}
  .menu-foot{flex-direction:column;align-items:flex-start;gap:var(--s-4)}
  .menu-cta{width:100%;justify-content:center}
}

/* ─────────────────────────────────────────────────────────────
   Editorial supporting voices
   ───────────────────────────────────────────────────────────── */
.hero-kicker{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-variation-settings:"opsz" 48;
  font-size:clamp(15px,1.1vw,17px);
  color:var(--teal);
  max-width:52ch;margin:0;line-height:1.45;
}
.section-lede{
  margin-top:var(--s-4);
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-variation-settings:"opsz" 72;
  font-size:clamp(18px,1.6vw,22px);
  color:var(--blue-ink);
  max-width:52ch;line-height:1.4;
}
.signal-aside{
  margin-top:var(--s-5);
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(16px,1.4vw,19px);
  color:var(--ink);
  max-width:52ch;line-height:1.45;
  padding-top:var(--s-4);
  border-top:1px solid var(--blue-rule);
}
.cta-kicker{
  margin:var(--s-3) 0 var(--s-4);
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(17px,1.5vw,20px);
  color:var(--yellow);line-height:1.4;
}
.menu-panel .menu-kicker{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(16px,1.4vw,19px);
  color:var(--blue-ink);margin-bottom:var(--s-4);
}
.menu-panel .menu-thesis{
  margin-top:var(--s-5);
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(18px,1.5vw,22px);
  color:var(--ink);line-height:1.4;
}
.menu-panel .menu-thesis em{color:var(--blue-ink);font-weight:600}

/* ─────────────────────────────────────────────────────────────
   Inline link — one refined editorial underline, used everywhere
   a sentence-level link appears. Replaces the three different
   border-bottom treatments with a single signature: a hairline
   rule set a touch below the baseline, skipping descenders,
   resting quiet and resolving to the link's own ink on hover.
   Scoped to prose links only — never .btn / .nav-cta.
   ───────────────────────────────────────────────────────────── */
.stat-sources a,
.menu-panel a:not(.btn),
.contact-line a,
.cta-tail a{
  border-bottom:0;
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
  text-decoration-skip-ink:auto;
  text-decoration-color:color-mix(in srgb, currentColor 32%, transparent);
  transition:color var(--dur,.25s) var(--ease,ease),
             text-decoration-color var(--dur,.25s) var(--ease,ease);
}
.stat-sources a:hover,.stat-sources a:focus-visible,
.menu-panel a:not(.btn):hover,.menu-panel a:not(.btn):focus-visible,
.contact-line a:hover,.contact-line a:focus-visible,
.cta-tail a:hover,.cta-tail a:focus-visible{
  text-decoration-color:currentColor;
}

/* ─────────────────────────────────────────────────────────────
   GERMAN (lang="de") — typographic overrides.
   German copy runs ~30–40% longer than the English source. The hero
   headline was sized for the short English line and overflowed to 5
   lines (7 on mobile); these rules retune it so the German page keeps
   the same editorial rhythm — a compact, balanced four-line headline.
   Scoped to html[lang="de"] so the English page is untouched.
   ───────────────────────────────────────────────────────────── */
html[lang="de"] .hero-title{
  /* smaller than --t-display: a 4-line German headline at the English
     120px would stand taller than the viewport. */
  font-size:clamp(34px,4.9vw,74px);
  line-height:1.05;            /* eased from .98 — room for ä/ö/ü dots */
  letter-spacing:-.026em;
  max-width:20ch;
}
/* Indent of the stepped second clause scaled to the smaller type. */
html[lang="de"] .hero-title-l2{
  padding-left:clamp(16px,2.4vw,40px);
}
/* The longer German nav CTA ("Buchen Sie einen Termin") wraps and
   collides with the language switcher on phones — drop it on small
   screens, where the hamburger menu and hero CTA already cover it. */
@media(max-width:600px){
  html[lang="de"] .nav-cta{display:none}
}

/* Demo entry CTA under the Product-section heading. Sits on the dark
   demo surface, so the primary button's white-on-navy reads cleanly. */
.demo-cta-row{margin-top:26px}
.demo-cta-micro{
  margin:12px 0 0;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-light-2);
}
