/* ============================================================
   FHS LIVING — HOMEPAGE (V2)
   Official design system: "Layered Communities" route.
   Neue Haas Display · Principal Purple · one magenta moment
   per view · stacked-diamond motif · zero radius · sharp,
   mechanical motion (120–360ms, no bounce, no blur).
   ============================================================ */

/* ---------- Brand fonts (self-hosted, from the DS handoff) ---------- */
@font-face { font-family: 'Neue Haas Display'; src: url('../assets/fonts/NeueHaasDisplayLight.ttf') format('truetype'); font-weight: 300; font-style: normal; font-display: swap; }
@font-face { font-family: 'Neue Haas Display'; src: url('../assets/fonts/NeueHaasDisplayLightItalic.ttf') format('truetype'); font-weight: 300; font-style: italic; font-display: swap; }
@font-face { font-family: 'Neue Haas Display'; src: url('../assets/fonts/NeueHaasDisplayMedium.ttf') format('truetype'); font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: 'Neue Haas Display'; src: url('../assets/fonts/NeueHaasDisplayBold.ttf') format('truetype'); font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: 'Neue Haas Display'; src: url('../assets/fonts/NeueHaasDisplayBlack.ttf') format('truetype'); font-weight: 900; font-style: normal; font-display: swap; }

/* ---------- Tokens (from tokens/colors.css + spacing.css) ---------- */
:root {
  --fhs-principal-purple: #3C1053;
  --fhs-deep-burgundy: #5E0D40;
  --fhs-vibrant-magenta: #9F007E;
  --fhs-soft-rose: #FBD4CD;
  --fhs-warm-cream: #FAEDE7;
  --fhs-ink: #2A0B3A;
  --fhs-white: #FFFFFF;

  --purple-100: #C9BBD0; --purple-200: #B19FB9; --purple-300: #9D88A9;
  --purple-400: #8A6F98; --purple-500: #785887; --purple-600: #634076;
  --purple-700: #502864; --purple-800: #3C1053; --purple-900: #2A0B3A;

  --magenta-300: #D89ACB; --magenta-400: #C466B2; --magenta-500: #B13397;
  --magenta-600: #9F007E; --magenta-700: #7A0061;

  --rose-100: #FBE6E3; --rose-200: #FBD4CD; --rose-300: #F7C1B7;
  --cream-100: #FDF7F3; --cream-200: #FAEDE7;

  --surface-dark: var(--fhs-principal-purple);
  --surface-deep: var(--fhs-deep-burgundy);
  --surface-light: var(--cream-200);
  --surface-raised: var(--cream-100);
  --surface-tint: var(--rose-200);

  --text-primary: var(--fhs-ink);
  --text-secondary: var(--purple-600);
  --text-on-dark: var(--fhs-warm-cream);
  --text-on-dark-muted: var(--purple-200);

  --accent: var(--fhs-vibrant-magenta);
  --accent-hover: var(--magenta-700);

  --border-on-light: rgba(60, 16, 83, 0.16);
  --border-on-dark: rgba(250, 237, 231, 0.20);

  /* chart palette — validated vs #FAEDE7 warm cream (dataviz six checks) */
  --c-capital: #d9654f; --c-developers: #9a6ad8;
  --c-operators: #1f8f72; --c-enablers: #a1771c;

  --font-display: 'Neue Haas Display', 'Helvetica Neue', Helvetica, Arial, sans-serif;

  --type-display: clamp(24px, 3.7vw, 54px);
  --type-h2: clamp(32px, 4.2vw, 58px);
  --type-h3: 22px;
  --type-label: 13px;
  --type-body-lg: 19px;
  --type-body: 16px;

  --ls-label: 0.14em;
  --lh-display: 0.92;

  --container-max: 1280px;
  --gutter: clamp(20px, 3.4vw, 32px);
  --section-y: clamp(72px, 10vw, 136px);

  --ease-out: cubic-bezier(0.2, 0.6, 0.2, 1);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --dur-fast: 120ms;
  --dur: 200ms;
  --dur-slow: 360ms;

  --header-h: 76px;
}

/* ---------- Base ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 8px); }
body {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--type-body);
  line-height: 1.55;
  color: var(--text-primary);
  background: var(--surface-light);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font: inherit; background: none; border: 0; color: inherit; cursor: pointer; }
::selection { background: var(--fhs-vibrant-magenta); color: var(--fhs-white); }
:focus-visible { outline: 2px solid var(--fhs-vibrant-magenta); outline-offset: 3px; }

.skip-link { position: absolute; left: -9999px; top: 0; z-index: 400; background: var(--fhs-vibrant-magenta); color: #fff; padding: 12px 20px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--ls-label); font-size: 12px; }
.skip-link:focus { left: 0; }

.container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--gutter); }
.sect { padding-block: var(--section-y); position: relative; }

/* ---------- Type ---------- */
.label {
  font-weight: 500; font-size: var(--type-label);
  letter-spacing: var(--ls-label); text-transform: uppercase; line-height: 1.3;
}
.label--muted-light { color: var(--text-secondary); }
.label--muted-dark { color: var(--purple-300); }
.label--magenta { color: var(--fhs-vibrant-magenta); }
.label--magenta-dark { color: var(--magenta-400); }

.display {
  font-weight: 900; text-transform: uppercase;
  font-size: var(--type-display); line-height: var(--lh-display);
  letter-spacing: -0.015em;
}
.h2 {
  font-weight: 900; text-transform: uppercase;
  font-size: var(--type-h2); line-height: 0.98; letter-spacing: -0.005em;
}
.on-dark { color: var(--text-on-dark); }
.accent-line { color: var(--magenta-400); }
.light-sect .accent-line { color: var(--fhs-vibrant-magenta); }

.lede { font-weight: 300; font-size: clamp(16px, 1.5vw, 19px); line-height: 1.6; max-width: 54ch; }
.dark-sect .lede { color: var(--text-on-dark-muted); }
.light-sect .lede { color: var(--text-secondary); }

/* section head */
.sect-head { display: grid; gap: 18px; max-width: 880px; margin-bottom: clamp(44px, 6vw, 72px); }
.sect-head .rule { width: 56px; height: 3px; background: var(--fhs-vibrant-magenta); }

.dark-sect { background: var(--surface-dark); color: var(--text-on-dark); }
.deep-sect { background: var(--surface-deep); color: var(--text-on-dark); }
.light-sect { background: var(--surface-light); color: var(--text-primary); }
.raised-sect { background: var(--surface-raised); }
.tint-sect { background: var(--surface-tint); }

/* ---------- Buttons (Button.jsx spec: sharp, 2px border, uppercase) ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-weight: 500; letter-spacing: var(--ls-label); text-transform: uppercase;
  line-height: 1; white-space: nowrap; cursor: pointer; border-radius: 0;
  padding: 17px 34px; font-size: 15px;
  transition: background var(--dur) var(--ease-out), color var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out);
}
.btn--md { padding: 13px 24px; font-size: 13px; }
.btn--primary { background: var(--fhs-vibrant-magenta); color: var(--fhs-white); border: 2px solid var(--fhs-vibrant-magenta); }
.btn--primary:hover { background: var(--magenta-700); border-color: var(--magenta-700); }
.btn--outline-light { background: transparent; color: var(--fhs-warm-cream); border: 2px solid var(--border-on-dark); }
.btn--outline-light:hover { border-color: var(--fhs-warm-cream); }
.btn--outline { background: transparent; color: var(--fhs-principal-purple); border: 2px solid var(--fhs-principal-purple); }
.btn--outline:hover { background: var(--fhs-principal-purple); color: var(--fhs-warm-cream); }
.btn--solid { background: var(--fhs-principal-purple); color: var(--fhs-warm-cream); border: 2px solid var(--fhs-principal-purple); }
.btn--solid:hover { background: var(--fhs-deep-burgundy); border-color: var(--fhs-deep-burgundy); }
.btn .arrow { transition: transform var(--dur) var(--ease-out); }
.btn:hover .arrow { transform: translateX(4px); }

/* tags (Tag.jsx) */
.tag {
  display: inline-flex; align-items: center;
  padding: 7px 12px; font-size: 11px; font-weight: 500;
  letter-spacing: var(--ls-label); text-transform: uppercase; line-height: 1;
}
.tag--magenta { background: var(--fhs-vibrant-magenta); color: var(--fhs-white); }
.tag--outline-light { border: 1px solid var(--border-on-dark); color: var(--fhs-warm-cream); }
.tag--outline-magenta { border: 1px solid var(--fhs-vibrant-magenta); color: var(--fhs-vibrant-magenta); }
.tag--outline-ink { border: 1px solid var(--border-on-light); color: var(--fhs-ink); }

/* ============================================================
   Preloader — diamond stack assembles, counter, sharp wipe
   ============================================================ */
.preloader {
  position: fixed; inset: 0; z-index: 300;
  background: var(--cream-200);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 34px;
  transition: transform 520ms var(--ease-in-out);
}
.preloader.done { transform: translateY(-100%); }
.preloader__stack { position: relative; width: 150px; height: 186px; }
.preloader__d {
  position: absolute; left: 0; width: 150px; height: 97px;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  opacity: 0; transform: translateY(26px);
  transition: opacity 300ms var(--ease-out), transform 340ms var(--ease-out);
}
.preloader.play .preloader__d { opacity: 1; transform: none; }
.preloader__meta { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.preloader__count {
  font-weight: 900; font-size: 15px; letter-spacing: .22em;
  color: var(--fhs-ink); font-variant-numeric: tabular-nums;
}
html.no-js .preloader { display: none; }

/* ============================================================
   Cursor — sharp diamond follower (fine pointers only)
   ============================================================ */
.cursor-dot, .cursor-ring { display: none; }
@media (hover: hover) and (pointer: fine) {
  .cursor-dot, .cursor-ring {
    display: block; position: fixed; top: 0; left: 0; z-index: 290;
    pointer-events: none;
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  }
  .cursor-dot { width: 8px; height: 8px; background: var(--fhs-vibrant-magenta); }
  .cursor-ring {
    width: 34px; height: 34px;
    background: transparent;
    border: 0;
    outline: 1.5px solid var(--magenta-400);
    outline-offset: -1.5px;
    clip-path: none;
    transform: rotate(45deg);
    opacity: .55;
    transition: width 160ms var(--ease-out), height 160ms var(--ease-out), opacity 160ms;
  }
  .cursor-ring.grow { width: 56px; height: 56px; opacity: .9; }
  html.has-cursor a, html.has-cursor button { cursor: none; }
  html.has-cursor { cursor: none; }
}

/* ============================================================
   Header — sticky purple + magenta scroll progress
   ============================================================ */
.site-header {
  position: fixed; inset-inline: 0; top: 0; z-index: 100;
  background: var(--cream-200);
  border-bottom: 1px solid var(--border-on-light);
  transform: translateY(0);
  transition: transform var(--dur-slow) var(--ease-out);
}
.site-header .container {
  max-width: 1400px; height: var(--header-h);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.brand img { height: 44px; width: auto; }
.site-nav { display: flex; align-items: center; gap: clamp(18px, 2.4vw, 34px); }
.site-nav a {
  font-size: 13px; font-weight: 500; letter-spacing: var(--ls-label); text-transform: uppercase;
  color: var(--fhs-ink); opacity: .78; padding: 6px 0; position: relative;
  transition: opacity var(--dur);
}
.site-nav a::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 100%;
  background: var(--fhs-vibrant-magenta);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur-slow) var(--ease-out);
}
.site-nav a:hover { opacity: 1; }
.site-nav a:hover::after { transform: scaleX(1); }
.header-cta { display: flex; align-items: center; gap: 16px; }

.progress { position: absolute; left: 0; bottom: -1px; height: 2px; width: 100%; background: transparent; }
.progress span { display: block; height: 100%; width: 100%; background: var(--fhs-vibrant-magenta); transform: scaleX(0); transform-origin: left; }

.nav-toggle { display: none; width: 44px; height: 44px; position: relative; }
.nav-toggle i, .nav-toggle::before, .nav-toggle::after {
  content: ""; position: absolute; left: 10px; right: 10px; height: 2px;
  background: var(--fhs-ink);
  transition: transform var(--dur-slow) var(--ease-out), opacity var(--dur), top var(--dur-slow) var(--ease-out);
}
.nav-toggle::before { top: 15px; } .nav-toggle i { top: 21px; } .nav-toggle::after { top: 27px; }
.nav-toggle[aria-expanded="true"]::before { top: 21px; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] i { opacity: 0; }
.nav-toggle[aria-expanded="true"]::after { top: 21px; transform: rotate(-45deg); }

@media (max-width: 980px) {
  .site-nav {
    position: fixed; inset: var(--header-h) 0 0 0; z-index: 90;
    flex-direction: column; justify-content: center; gap: 6px;
    background: var(--cream-200);
    opacity: 0; pointer-events: none; transition: opacity var(--dur-slow) var(--ease-out);
  }
  .site-nav.open { opacity: 1; pointer-events: auto; }
  .site-nav a { font-size: 24px; font-weight: 700; padding: 12px; color: var(--fhs-ink); }
  .nav-toggle { display: block; }
  .header-cta .btn { display: none; }
}

/* ============================================================
   Hero — pinned scene; Paris field; 3D motif; kinetic headline
   ============================================================ */
.hero-pin { position: relative; height: 210vh; background: var(--surface-light); }
.hero {
  position: sticky; top: 0; height: 100svh; overflow: hidden;
  display: flex; flex-direction: column;
  color: var(--text-primary);
}
.hero h1 { color: var(--fhs-ink); }
.hero h1 .accent-line { color: var(--fhs-vibrant-magenta); }
/* full-bleed brand photography under a flat purple field (no gradients) */
.hero__bg { display: none; }
.hero__bg img {
  width: 100%; height: 100%; object-fit: cover; object-position: 50% 42%;
  filter: saturate(.5) contrast(1.04);
  will-change: transform;
}
.hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background: var(--fhs-principal-purple);
  opacity: .88;
  mix-blend-mode: multiply;
}
.hero__bg::before {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: rgba(42, 11, 58, .30);
}
.hero__inner { position: relative; z-index: 2; }
.hero__inner {
  flex: 1; display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(0, 0.88fr);
  gap: clamp(24px, 4vw, 56px); align-items: center;
  padding-top: var(--header-h);
}
.hero__tags { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 30px; }
.hero h1 { font-size: var(--type-display); }
.hero h1 .line { display: block; overflow: hidden; }
.hero h1 .line > span { display: inline-block; }
.hero__sub {
  margin-top: 30px; max-width: 46ch;
  font-size: var(--type-body-lg); line-height: 1.55; color: var(--text-secondary);
}
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 40px; }

/* motif — geometry from LayeredBands (ratio .648, rhythm slivers).
   3D: the stack lives in real Z space and tilts with the pointer. */
.hero__motif-wrap { perspective: 1200px; }
.motif { position: relative; margin-inline: auto; transform-style: preserve-3d; }
.motif__layer {
  position: absolute; left: 0; width: 100%;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  background-size: cover; background-position: center;
  transform: translateZ(calc(var(--z, 0) * 1px));
}

/* 3D tilt cards — self-perspective, mechanical smoothing */
.tilt {
  transform: perspective(900px) rotateX(calc(var(--rx, 0) * 1deg)) rotateY(calc(var(--ry, 0) * 1deg));
  transform-style: preserve-3d;
  transition: transform var(--dur) var(--ease-out);
  will-change: transform;
}
.tilt .pop { transform: translateZ(28px); }
@media (prefers-reduced-motion: reduce) { .tilt { transform: none !important; } }
.hero__foot { border-top: 1px solid var(--border-on-light); background: var(--surface-tint); position: relative; z-index: 3; }
.marquee { overflow: hidden; }
.marquee__track { display: flex; width: max-content; animation: marquee 40s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__group { display: flex; align-items: center; flex-shrink: 0; }
.marquee__item {
  display: flex; align-items: center; gap: 24px; padding: 19px 24px 19px 0;
  font-weight: 700; font-size: 14px; letter-spacing: var(--ls-label); text-transform: uppercase;
  color: var(--purple-700); white-space: nowrap;
}
.marquee__item::after {
  content: ""; width: 7px; height: 7px;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  background: var(--fhs-vibrant-magenta);
}
@keyframes marquee { to { transform: translateX(-50%); } }

.scroll-cue {
  position: absolute; right: var(--gutter); bottom: 76px; z-index: 3;
  display: flex; align-items: center; gap: 10px;
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase; font-weight: 500;
  color: var(--purple-500);
}
.scroll-cue::after { content: ""; width: 1px; height: 44px; background: var(--border-on-light); }

@media (max-width: 900px) {
  .hero-pin { height: auto; }
  .hero { position: relative; height: auto; min-height: 100svh; }
  .hero__inner { grid-template-columns: 1fr; align-content: center; padding-block: calc(var(--header-h) + 40px) 40px; }
  .hero__motif-wrap { display: none; }
  .scroll-cue { display: none; }
}

/* ============================================================
   Stats — numbers are the hero (KPI row, dataviz stat-tile)
   ============================================================ */
.stats { border-top: 1px solid var(--border-on-light); }
.stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: clamp(24px, 3vw, 44px) clamp(20px, 2.6vw, 40px); border-left: 1px solid var(--border-on-light); display: grid; align-content: start; gap: 12px; }
.stat:first-child { border-left: 0; padding-left: 0; }
.stat__value {
  font-weight: 900; font-size: clamp(40px, 4.6vw, 76px); line-height: 0.95;
  letter-spacing: -0.015em; color: var(--fhs-ink); text-transform: uppercase; white-space: nowrap;
}
.stat__value.is-accent { color: var(--fhs-vibrant-magenta); }
.stat__label { font-size: 14.5px; line-height: 1.5; color: var(--text-secondary); max-width: 26ch; }
.stats__note { padding-top: 26px; font-size: 12px; color: var(--text-secondary); opacity: .8; }
@media (max-width: 860px) {
  .stats__grid { grid-template-columns: 1fr 1fr; }
  .stat { border-left: 0; border-top: 1px solid var(--border-on-light); }
  .stat:nth-child(-n+2) { border-top: 0; }
  .stat:nth-child(odd) { padding-left: 0; }
}
@media (max-width: 480px) {
  .stats__grid { grid-template-columns: 1fr; }
  .stat { padding-inline: 0; border-top: 1px solid var(--border-on-light); }
  .stat:first-child { border-top: 0; }
}

/* ============================================================
   Conviction — line-reveal statement + proof cards
   ============================================================ */
.conviction .statement {
  font-weight: 900; text-transform: uppercase;
  font-size: clamp(30px, 4.6vw, 64px); line-height: 0.96; letter-spacing: -0.01em;
  max-width: 22ch;
}
.conviction .statement .line { display: block; overflow: hidden; }
.conviction .statement .line > span { display: inline-block; }
.conviction__grid {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: clamp(36px, 5vw, 88px); margin-top: clamp(44px, 6vw, 72px);
}
.conviction__aside { position: sticky; top: calc(var(--header-h) + 32px); align-self: start; display: grid; gap: 22px; }
.conviction__coda { font-weight: 700; text-transform: uppercase; font-size: 21px; line-height: 1.2; color: var(--magenta-400); max-width: 30ch; }
.capital-map {
  border: 1px solid var(--border-on-dark);
  border-top: 3px solid var(--fhs-vibrant-magenta);
  background: #2C1A3C;
  line-height: 0;
}
.capital-map svg { width: 100%; height: auto; display: block; }
.proof { display: grid; gap: 14px; }
.proof--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 760px) { .proof--3 { grid-template-columns: 1fr; } }
.proof__card {
  background: var(--purple-700);
  border-top: 3px solid var(--fhs-vibrant-magenta);
  padding: clamp(24px, 3vw, 36px);
  display: grid; grid-template-columns: auto 1fr; gap: 20px;
  transition: background var(--dur) var(--ease-out);
}
.proof__card:hover { background: var(--fhs-deep-burgundy); }
.proof__num { font-weight: 900; font-size: 14px; letter-spacing: .14em; color: var(--magenta-400); padding-top: 4px; }
.proof__card h3 { font-weight: 700; text-transform: uppercase; font-size: 19px; letter-spacing: 0; margin-bottom: 8px; color: var(--fhs-warm-cream); }
.proof__card p { font-size: 15px; line-height: 1.55; color: var(--purple-200); max-width: 52ch; }
@media (max-width: 900px) {
  .conviction__grid { grid-template-columns: 1fr; }
  .conviction__aside { position: static; }
}

/* ============================================================
   Pillars — invertible cards (kit SectorCard behaviour)
   ============================================================ */
.pillars__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: var(--border-on-light); }
.pillar {
  background: var(--surface-raised);
  border-top: 3px solid transparent;
  padding: 0 0 30px;
  transition: background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out);
}
.pillar__media { aspect-ratio: 16 / 10; overflow: hidden; position: relative; }
.pillar__media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.9); transition: filter var(--dur-slow) var(--ease-out), transform 700ms var(--ease-out); }
.pillar__body { padding: 26px 26px 0; }
.pillar__num { font-weight: 700; font-size: 13px; letter-spacing: var(--ls-label); color: var(--text-secondary); transition: color var(--dur); }
.pillar h3 { font-weight: 700; text-transform: uppercase; font-size: 25px; line-height: 1; margin: 14px 0 12px; color: var(--fhs-ink); transition: color var(--dur); }
.pillar p { font-size: 15px; line-height: 1.55; color: var(--text-secondary); transition: color var(--dur); }
.pillar:hover { background: var(--fhs-principal-purple); border-top-color: var(--fhs-vibrant-magenta); }
.pillar:hover .pillar__num { color: var(--magenta-400); }
.pillar:hover h3 { color: var(--fhs-warm-cream); }
.pillar:hover p { color: var(--purple-200); }
.pillar:hover .pillar__media img { transform: scale(1.03); filter: saturate(1); }
@media (max-width: 900px) { .pillars__grid { grid-template-columns: 1fr; } }

/* ============================================================
   Sectors — axis-shift: vertical scroll drives horizontal track
   ============================================================ */
.sectors-pin { position: relative; background: var(--surface-tint); }
.sectors { position: sticky; top: 0; height: 100svh; overflow: hidden; display: flex; flex-direction: column; justify-content: center; color: var(--text-primary); }
.sectors__head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 24px;
  margin-bottom: clamp(28px, 4vh, 52px);
}
.sectors__count { font-weight: 900; font-size: clamp(20px, 2.4vw, 30px); letter-spacing: .06em; color: var(--fhs-vibrant-magenta); font-variant-numeric: tabular-nums; white-space: nowrap; }
.sectors__track-wrap { overflow: hidden; }
.sectors__track { display: flex; gap: 2px; will-change: transform; }
.sector-panel {
  flex: 0 0 auto; width: clamp(280px, 30vw, 400px);
  background: var(--surface-raised);
  border-top: 3px solid transparent;
  padding: 26px 26px 30px;
  display: flex; flex-direction: column; gap: 0;
  transition: background var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out);
}
.sector-panel:hover { background: var(--fhs-principal-purple); border-top-color: var(--fhs-vibrant-magenta); }
.sector-panel__idx { font-weight: 900; font-size: 15px; letter-spacing: .14em; color: var(--fhs-vibrant-magenta); transition: color var(--dur); }
.sector-panel:hover .sector-panel__idx { color: var(--magenta-400); }
.sector-panel__media { aspect-ratio: 4 / 3; overflow: hidden; margin: 18px 0 20px; }
.sector-panel__media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.85); transition: transform 700ms var(--ease-out), filter var(--dur-slow); }
.sector-panel:hover .sector-panel__media img { transform: scale(1.04); filter: saturate(1); }
.sector-panel h3 { font-weight: 700; text-transform: uppercase; font-size: 22px; line-height: 1; color: var(--fhs-ink); transition: color var(--dur); }
.sector-panel:hover h3 { color: var(--fhs-warm-cream); }
.sector-panel p { margin-top: 10px; font-size: 14.5px; line-height: 1.5; color: var(--text-secondary); transition: color var(--dur); }
.sector-panel:hover p { color: var(--purple-200); }
@media (max-width: 900px), (prefers-reduced-motion: reduce) {
  .sectors-pin { height: auto !important; }
  .sectors { position: relative; height: auto; padding-block: var(--section-y); }
  .sectors__track-wrap { overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: var(--purple-300) transparent; padding-bottom: 16px; }
  .sectors__track { transform: none !important; }
  .sector-panel { scroll-snap-align: start; }
}

/* ============================================================
   Advisors
   ============================================================ */
.advisors__grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 2px; }
.advisors__grid .advisor { box-shadow: 0 0 0 1px var(--border-on-light); }
.advisor { background: var(--surface-raised); padding-bottom: 18px; border-top: 3px solid transparent; transition: border-color var(--dur); position: relative; }
.advisor:hover { border-top-color: var(--fhs-vibrant-magenta); }
.advisor__media { aspect-ratio: 4 / 5; overflow: hidden; }
.advisor__media img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 20%; filter: grayscale(1); transition: filter var(--dur-slow) var(--ease-out); }
.advisor:hover .advisor__media img, .advisor:focus-within .advisor__media img { filter: grayscale(0); }
.advisor__info { padding: 14px 14px 0; }
.advisor__info h3 { font-weight: 700; text-transform: uppercase; font-size: 14px; letter-spacing: .02em; line-height: 1.25; color: var(--fhs-ink); }
.advisor__info p { font-size: 12.5px; line-height: 1.45; color: var(--text-secondary); margin-top: 4px; }
.advisor__info .co { color: var(--fhs-vibrant-magenta); font-weight: 500; }
.advisors__foot { display: flex; justify-content: center; margin-top: clamp(40px, 5vw, 60px); }
@media (max-width: 1080px) { .advisors__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px) { .advisors__grid { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   Quotes — deep burgundy
   ============================================================ */
.quotes__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(28px, 4vw, 56px); }
.quote { display: grid; align-content: start; gap: 22px; border-top: 1px solid var(--border-on-light); padding-top: 24px; }
.quote blockquote { font-weight: 300; font-size: clamp(18px, 1.7vw, 22px); line-height: 1.45; color: var(--fhs-ink); }
.quote blockquote::before { content: "“"; display: block; font-weight: 900; font-size: 56px; line-height: .6; margin-bottom: 18px; color: var(--fhs-vibrant-magenta); }
.quote figcaption { display: flex; align-items: center; gap: 12px; }
.quote figcaption img { width: 44px; height: 44px; object-fit: cover; filter: grayscale(.15); }
.quote figcaption strong { display: block; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--fhs-ink); }
.quote figcaption span { font-size: 12.5px; color: var(--text-secondary); }
@media (max-width: 900px) { .quotes__grid { grid-template-columns: 1fr; gap: 40px; } }

/* ============================================================
   Who gathers — proportion chart (dataviz spec, brand-sharp)
   ============================================================ */
.chart { margin-top: clamp(36px, 5vw, 56px); }
.chart__labels { display: flex; margin-bottom: 14px; }
.chart__label { display: grid; gap: 4px; padding-right: 14px; min-width: 0; }
.chart__label .pct { font-weight: 900; font-size: clamp(22px, 2.4vw, 34px); line-height: 1; color: var(--fhs-ink); font-variant-numeric: tabular-nums; }
.chart__label .name { display: flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 500; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chart__label .swatch { flex: none; width: 9px; height: 9px; clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); }
.chart__bar { display: flex; gap: 2px; height: 22px; }
.chart__seg { position: relative; transform-origin: left center; transition: filter var(--dur); }
.chart__seg:hover, .chart__seg:focus-visible { filter: brightness(1.18); }
.js .chart__bar .chart__seg { transform: scaleX(0); }
.js .chart.in .chart__seg { transform: scaleX(1); transition: transform 700ms var(--ease-out), filter var(--dur); }
.js .chart.in .chart__seg:nth-child(2) { transition-delay: 70ms; }
.js .chart.in .chart__seg:nth-child(3) { transition-delay: 140ms; }
.js .chart.in .chart__seg:nth-child(4) { transition-delay: 210ms; }
.chart__legend { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(16px, 2.2vw, 32px); margin-top: clamp(32px, 4vw, 48px); }
.legend-item { border-top: 1px solid var(--border-on-light); padding-top: 16px; display: grid; gap: 10px; align-content: start; }
.legend-item__head { display: flex; align-items: center; gap: 9px; }
.legend-item__head .swatch { width: 10px; height: 10px; clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); flex: none; }
.legend-item__head strong { font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--fhs-ink); }
.legend-item__head .pct-sm { margin-left: auto; font-size: 13px; color: var(--text-secondary); font-variant-numeric: tabular-nums; }
.legend-item ul { display: grid; gap: 5px; }
.legend-item li { font-size: 14px; color: var(--text-secondary); line-height: 1.45; }
.chart-tip {
  position: fixed; z-index: 240; pointer-events: none;
  background: var(--purple-900); border: 1px solid var(--border-on-dark);
  padding: 12px 14px; font-size: 13px; line-height: 1.5; color: var(--purple-200);
  max-width: 280px; opacity: 0; transform: translateY(4px);
  transition: opacity var(--dur-fast), transform var(--dur-fast);
}
.chart-tip strong { display: block; color: var(--fhs-warm-cream); font-weight: 700; text-transform: uppercase; font-size: 12px; letter-spacing: .06em; margin-bottom: 3px; }
.chart-tip.show { opacity: 1; transform: none; }
@media (max-width: 720px) {
  .chart__labels { display: none; }
  .chart__legend { grid-template-columns: 1fr 1fr; }
  .legend-item__head .pct-sm { font-size: 15px; color: var(--fhs-ink); }
}

/* ============================================================
   Experience
   ============================================================ */
.exp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: var(--border-on-light); }
.exp-card { background: var(--surface-raised); border-top: 3px solid transparent; padding-bottom: 24px; transition: border-color var(--dur); }
.exp-card:hover { border-top-color: var(--fhs-vibrant-magenta); }
.exp-card__media { aspect-ratio: 3 / 2; overflow: hidden; position: relative; }
.exp-card__media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.88); transition: transform 700ms var(--ease-out), filter var(--dur-slow); }
.exp-card:hover .exp-card__media img { transform: scale(1.03); filter: saturate(1); }
.exp-card__media .idx {
  position: absolute; top: 0; left: 0; z-index: 2;
  background: var(--fhs-principal-purple); color: var(--fhs-warm-cream);
  font-weight: 700; font-size: 12px; letter-spacing: .14em;
  padding: 8px 12px;
}
.exp-card h3 { font-weight: 700; text-transform: uppercase; font-size: 19px; line-height: 1.05; padding: 20px 22px 8px; color: var(--fhs-ink); }
.exp-card p { font-size: 14.5px; line-height: 1.5; color: var(--text-secondary); padding: 0 22px; }
@media (max-width: 900px) { .exp-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px) { .exp-grid { grid-template-columns: 1fr; } }

/* ============================================================
   Around the world — soft rose
   ============================================================ */
.world__list { border-top: 1px solid var(--border-on-light); }
.event-row {
  display: grid; grid-template-columns: 140px minmax(0, 2.2fr) minmax(0, 1.7fr) minmax(0, 1.4fr) auto;
  align-items: center; gap: clamp(16px, 2.4vw, 40px);
  padding: 18px 0; border-bottom: 1px solid var(--border-on-light);
  border-left: 3px solid transparent;
  transition: background var(--dur), border-color var(--dur), padding-left var(--dur) var(--ease-out);
  position: relative;
}
.event-row:hover { background: rgba(60, 16, 83, .05); border-left-color: var(--fhs-vibrant-magenta); padding-left: 14px; }
.event-row__logo { height: 58px; width: 140px; background: var(--fhs-principal-purple); display: flex; align-items: center; justify-content: center; padding: 10px 14px; }
.event-row__logo img { max-height: 100%; max-width: 100%; width: auto; object-fit: contain; }
.event-row__name { font-weight: 700; text-transform: uppercase; font-size: clamp(16px, 1.7vw, 21px); letter-spacing: .02em; color: var(--fhs-ink); display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.event-row__place, .event-row__date { font-size: 14.5px; color: var(--text-secondary); }
.event-row__arrow { color: var(--fhs-vibrant-magenta); opacity: 0; transform: translateX(-6px); transition: opacity var(--dur), transform var(--dur) var(--ease-out); }
.event-row:hover .event-row__arrow { opacity: 1; transform: none; }
.event-row--live { background: rgba(159, 0, 126, .06); border-left-color: var(--fhs-vibrant-magenta); }
@media (max-width: 860px) {
  .event-row { grid-template-columns: 104px 1fr auto; }
  .event-row__logo { width: 104px; height: 46px; }
  .event-row__place { display: none; }
  .event-row__arrow { display: none; }
}

/* ============================================================
   CTA — cream, motif bleeding off the edge
   ============================================================ */
.cta-band { background: var(--surface-tint); overflow: hidden; position: relative; }
.cta-band .container { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr); gap: 48px; align-items: center; padding-block: var(--section-y); }
.cta-band h2 { color: var(--fhs-ink); max-width: 14ch; }
.cta-band h2 em { font-style: normal; color: var(--fhs-vibrant-magenta); }
.cta-band .lede { margin-top: 20px; }
.cta-band .actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }
.cta-band__motif { position: relative; height: 100%; min-height: 300px; }
.cta-band__motif .motif { position: absolute; right: -18%; top: 50%; transform: translateY(-50%); }
@media (max-width: 900px) {
  .cta-band .container { grid-template-columns: 1fr; }
  .cta-band__motif { display: none; }
}

/* ============================================================
   Footer — ink
   ============================================================ */
.site-footer { background: var(--purple-900); color: var(--purple-200); }
.site-footer .top {
  display: grid; grid-template-columns: minmax(0, 2fr) repeat(3, minmax(0, 1fr));
  gap: clamp(32px, 4vw, 64px);
  padding-block: clamp(52px, 7vw, 84px) clamp(36px, 5vw, 56px);
  border-bottom: 1px solid var(--border-on-dark);
}
.site-footer .brand-col { display: grid; gap: 20px; align-content: start; }
.site-footer .brand-col img { height: 48px; width: auto; justify-self: start; }
.site-footer .brand-col p { font-size: 14px; line-height: 1.55; color: var(--purple-300); max-width: 30ch; }
.footer-col h4 { font-size: 12px; font-weight: 700; letter-spacing: var(--ls-label); text-transform: uppercase; color: var(--purple-400); margin-bottom: 16px; }
.footer-col ul { display: grid; gap: 9px; }
.footer-col a { font-size: 14.5px; color: var(--purple-200); transition: color var(--dur); }
.footer-col a:hover { color: var(--fhs-warm-cream); }
.socials { display: flex; gap: 16px; margin-top: 4px; }
.socials a { font-size: 12px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--purple-300); border-bottom: 1px solid transparent; transition: color var(--dur), border-color var(--dur); }
.socials a:hover { color: var(--fhs-warm-cream); border-color: var(--fhs-vibrant-magenta); }
.site-footer .bottom { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px; padding-block: 24px; font-size: 12.5px; color: var(--purple-400); }
.site-footer .bottom .bench { display: flex; align-items: center; gap: 12px; }
.site-footer .bottom .bench img { height: 26px; width: auto; opacity: .85; }
@media (max-width: 900px) { .site-footer .top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .site-footer .top { grid-template-columns: 1fr; } }

/* ============================================================
   Reveal system (mechanical: quick fades + rises, tight stagger)
   ============================================================ */
.js .reveal { opacity: 0; transform: translateY(22px); transition: opacity 480ms var(--ease-out), transform 480ms var(--ease-out); transition-delay: var(--d, 0ms); }
.js .reveal.in { opacity: 1; transform: none; }

.js .mask-line .line > span { transform: translateY(112%); transition: transform 620ms var(--ease-out); transition-delay: var(--ld, 0ms); }
.js .mask-line.in .line > span { transform: none; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .js .reveal, .js .mask-line .line > span { opacity: 1 !important; transform: none !important; transition: none !important; }
  .marquee__track { animation: none; }
  .js .chart__bar .chart__seg { transform: none; transition: none; }
  .preloader { display: none !important; }
  .cursor-dot, .cursor-ring { display: none !important; }
  .hero-pin { height: auto !important; }
  .hero { position: relative; height: auto; min-height: 100svh; }
  * { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

/* ===== PAGES (generated) ===== */
.page-hero { padding: calc(var(--header-h) + clamp(48px, 7vw, 84px)) 0 clamp(48px, 6vw, 72px); }
.page-hero .container { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(0, .9fr); gap: clamp(32px, 5vw, 72px); align-items: center; }
.page-hero h1 { font-size: var(--type-display); font-weight: 900; text-transform: uppercase; line-height: .95; letter-spacing: -0.012em; color: var(--fhs-ink); }
.page-hero h1 .accent-line { color: var(--fhs-vibrant-magenta); }
.page-hero .lede { margin-top: 24px; }
.page-hero .label { margin-bottom: 18px; display: inline-block; }
.page-hero .actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.page-hero__media { position: relative; }
.page-hero__media .motif { width: min(30vw, 330px); }
@media (max-width: 900px) { .page-hero .container { grid-template-columns: 1fr; } .page-hero__media { display: none; } }

.letter { max-width: 900px; }
.letter blockquote { font-weight: 300; font-size: clamp(20px, 2.3vw, 30px); line-height: 1.45; color: var(--fhs-warm-cream); }
.letter blockquote strong { font-weight: 700; }
.letter .sig { margin-top: 30px; display: grid; gap: 4px; }
.letter .sig strong { font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--fhs-warm-cream); font-size: 15px; }
.letter .sig span { font-size: 13.5px; color: var(--purple-200); }

.card-light {
  background: var(--surface-raised); border-top: 3px solid var(--fhs-vibrant-magenta);
  padding: clamp(24px, 3vw, 36px); display: grid; grid-template-columns: auto 1fr; gap: 20px;
}
.card-light .num { font-weight: 900; font-size: 14px; letter-spacing: .14em; color: var(--fhs-vibrant-magenta); padding-top: 4px; }
.card-light h3 { font-weight: 700; text-transform: uppercase; font-size: 19px; margin-bottom: 8px; color: var(--fhs-ink); }
.card-light p { font-size: 15px; line-height: 1.55; color: var(--text-secondary); }
.cards-col { display: grid; gap: 14px; }
.cards-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.cards-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 900px) { .cards-3, .cards-2 { grid-template-columns: 1fr; } }
.cards-3 .card-light, .cards-2 .card-light { grid-template-columns: 1fr; gap: 10px; }

.day-block { display: grid; grid-template-columns: minmax(0, .85fr) minmax(0, 2fr); gap: clamp(28px, 4vw, 72px); padding-block: clamp(40px, 5vw, 64px); border-top: 1px solid var(--border-on-light); }
.day-block:first-of-type { border-top: 0; }
.day-block__aside { position: sticky; top: calc(var(--header-h) + 28px); align-self: start; }
.day-block__aside .k { font-weight: 900; font-size: 14px; letter-spacing: .14em; color: var(--fhs-vibrant-magenta); text-transform: uppercase; }
.day-block__aside h3 { font-weight: 900; text-transform: uppercase; font-size: clamp(26px, 2.8vw, 40px); line-height: .98; color: var(--fhs-ink); margin-top: 10px; }
.day-block__aside p { margin-top: 14px; font-size: 15px; color: var(--text-secondary); max-width: 34ch; }
.session { display: grid; grid-template-columns: auto 1fr; gap: 18px; padding: 18px 0; border-bottom: 1px solid var(--border-on-light); }
.session:last-child { border-bottom: 0; }
.session .idx { font-weight: 900; font-size: 12.5px; letter-spacing: .12em; color: var(--fhs-vibrant-magenta); padding-top: 3px; min-width: 30px; }
.session h4 { font-weight: 700; text-transform: uppercase; font-size: 16.5px; color: var(--fhs-ink); }
.session p { font-size: 14.5px; color: var(--text-secondary); margin-top: 3px; }
@media (max-width: 860px) { .day-block { grid-template-columns: 1fr; } .day-block__aside { position: static; } }

.chip { display: inline-block; font-size: 10.5px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; border: 1px solid var(--border-on-light); color: var(--text-secondary); padding: 4px 8px; margin: 3px 4px 0 0; }
.advisor__info .geo { display: block; margin-top: 6px; font-size: 11.5px; color: var(--purple-400); letter-spacing: .04em; }

.contact-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 800px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-card { background: var(--surface-raised); border-top: 3px solid var(--fhs-vibrant-magenta); padding: clamp(24px, 3vw, 36px); }
.contact-card .k { font-weight: 500; font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--text-secondary); }
.contact-card h3 { font-weight: 700; text-transform: uppercase; font-size: 20px; color: var(--fhs-ink); margin-top: 12px; }
.contact-card p { font-size: 14.5px; color: var(--text-secondary); margin-top: 4px; }
.contact-card a { color: var(--fhs-vibrant-magenta); font-weight: 500; border-bottom: 1px solid transparent; transition: border-color var(--dur); }
.contact-card a:hover { border-color: currentColor; }

.form-panel { background: var(--surface-raised); border-top: 3px solid var(--fhs-vibrant-magenta); padding: clamp(28px, 4vw, 52px); max-width: 880px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media (max-width: 720px) { .form-grid { grid-template-columns: 1fr; } }
.field { display: grid; gap: 8px; }
.field--full { grid-column: 1 / -1; }
.field label { font-weight: 500; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--fhs-ink); }
.field label .req { color: var(--fhs-vibrant-magenta); }
.field input, .field select {
  font: inherit; font-weight: 300; color: var(--fhs-ink);
  background: var(--fhs-white); border: 1px solid var(--border-on-light); border-radius: 0;
  padding: 14px 14px; min-height: 50px; width: 100%;
  transition: border-color var(--dur);
}
.field input:focus, .field select:focus { outline: none; border-color: var(--fhs-vibrant-magenta); }
.field select { appearance: none; background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%239F007E' stroke-width='2'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; }
.form-note { font-size: 12.5px; color: var(--text-secondary); margin-top: 18px; }
.form-success { display: none; border: 1px solid var(--fhs-vibrant-magenta); padding: 16px 18px; margin-top: 20px; font-size: 14.5px; color: var(--fhs-ink); }
.form-success.show { display: block; }

.media-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; background: var(--border-on-light); }
.media-strip figure { aspect-ratio: 4 / 3; overflow: hidden; background: var(--surface-raised); }
.media-strip img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.85); transition: transform 700ms var(--ease-out), filter var(--dur-slow); }
.media-strip figure:hover img { transform: scale(1.04); filter: saturate(1); }
@media (max-width: 720px) { .media-strip { grid-template-columns: 1fr 1fr; } }

.site-nav a[aria-current="page"] { opacity: 1; }
.site-nav a[aria-current="page"]::after { transform: scaleX(1); }

/* ===== CLASSDEX ===== */
.classdex { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr); gap: clamp(28px, 4vw, 72px); align-items: start; }
.classdex__list { display: grid; }
.classdex__row {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: clamp(12px, 1.6vw, 24px);
  padding: clamp(14px, 1.8vw, 20px) 10px;
  border-bottom: 1px solid var(--border-on-light);
  text-align: left; width: 100%;
  transition: background var(--dur) var(--ease-out), padding-left var(--dur) var(--ease-out);
}
.classdex__row:first-child { border-top: 1px solid var(--border-on-light); }
.classdex__idx { font-weight: 900; font-size: 13px; letter-spacing: .12em; color: var(--text-secondary); transition: color var(--dur); }
.classdex__name {
  font-weight: 900; text-transform: uppercase; letter-spacing: -0.005em; line-height: 1;
  font-size: clamp(20px, 2.6vw, 34px); color: var(--fhs-ink);
  transition: color var(--dur), transform var(--dur) var(--ease-out);
}
.classdex__sig { display: none; }
.classdex__arrow { color: var(--fhs-vibrant-magenta); opacity: 0; transform: translateX(-8px); transition: opacity var(--dur), transform var(--dur) var(--ease-out); align-self: center; }
.classdex__row:hover { background: var(--rose-100); padding-left: 18px; }
.classdex__row.is-active { background: var(--rose-100); padding-left: 18px; }
.classdex__row.is-active .classdex__idx { color: var(--fhs-vibrant-magenta); }
.classdex__row.is-active .classdex__name { color: var(--fhs-vibrant-magenta); }
.classdex__row.is-active .classdex__sig, .classdex__row:hover .classdex__sig { opacity: 1; transform: none; }
.classdex__row.is-active .classdex__arrow { opacity: 1; transform: none; }

.classdex__view { position: sticky; top: calc(var(--header-h) + 28px); }
.classdex__media {
  position: relative; aspect-ratio: 4 / 3; overflow: hidden;
  border-top: 3px solid var(--fhs-vibrant-magenta);
  background: var(--surface-raised);
}
.classdex__img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transform: scale(1.035);
  transition: opacity 320ms var(--ease-out), transform 560ms var(--ease-out);
  filter: saturate(.9);
}
.classdex__img.is-active { opacity: 1; transform: scale(1); }
.classdex__info { position: relative; }
.classdex__detail {
  position: absolute; inset: 0; padding-top: 20px;
  opacity: 0; transform: translateY(10px);
  transition: opacity 240ms var(--ease-out), transform 240ms var(--ease-out);
  pointer-events: none;
}
.classdex__detail.is-active { position: relative; opacity: 1; transform: none; pointer-events: auto; }
.classdex__watermark {
  position: absolute; right: 0; top: -6px;
  font-weight: 900; font-size: clamp(64px, 7vw, 110px); line-height: 1;
  color: var(--rose-200); z-index: -1; user-select: none;
}
.classdex__siglabel { display: flex; align-items: baseline; gap: 12px; font-weight: 700; text-transform: uppercase; font-size: 14px; letter-spacing: .06em; color: var(--fhs-vibrant-magenta); }
.classdex__siglabel span { font-weight: 500; font-size: 11px; letter-spacing: .16em; color: var(--text-secondary); }
.classdex__body { margin-top: 12px; font-size: 15.5px; line-height: 1.6; color: var(--text-secondary); max-width: 52ch; }
@media (max-width: 900px) {
  .classdex { grid-template-columns: 1fr; }
  .classdex__view { position: static; order: -1; margin-bottom: 8px; }
  .classdex__name { font-size: 19px; }
  .classdex__sig { display: none; }
  .classdex__watermark { font-size: 56px; }
}
@media (prefers-reduced-motion: reduce) {
  .classdex__img, .classdex__detail { transition: none; }
}

/* ===== ADVISOR WALL + COVERAGE ===== */
.adv-wall { display: grid; gap: 10px; overflow: hidden; padding-top: 8px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.adv-wall__row { overflow: hidden; }
.adv-wall__track { display: flex; width: max-content; animation: marquee 80s linear infinite; }
.adv-wall__track--rev { animation-direction: reverse; animation-duration: 96s; }
.adv-wall__row:hover .adv-wall__track { animation-play-state: paused; }
.adv-wall__group { display: flex; flex-shrink: 0; gap: 10px; padding-right: 10px; }
.adv-wall__tile { width: clamp(96px, 10vw, 148px); aspect-ratio: 1; flex: none;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); background: var(--rose-200); }
.adv-wall__tile img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 28%;
  filter: grayscale(1); transition: filter var(--dur-slow) var(--ease-out); }
.adv-wall__tile:hover img { filter: grayscale(0); }

.cov { display: grid; gap: 22px; margin-bottom: clamp(32px, 4vw, 48px); }
.cov__rail { display: flex; flex-wrap: wrap; gap: 8px; }
.cov-chip { display: inline-flex; align-items: center; gap: 10px; min-height: 44px;
  padding: 10px 16px; border: 1px solid var(--border-on-light);
  font-weight: 500; font-size: 12.5px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--fhs-ink); background: transparent; border-radius: 0;
  transition: background var(--dur) var(--ease-out), color var(--dur), border-color var(--dur); }
.cov-chip .n { font-weight: 900; font-size: 11.5px; color: var(--fhs-vibrant-magenta);
  font-variant-numeric: tabular-nums; transition: color var(--dur); }
.cov-chip:hover { border-color: var(--fhs-vibrant-magenta); }
.cov-chip.is-empty { opacity: .38; cursor: not-allowed; }
.cov-chip.is-empty:hover { border-color: var(--border-on-light); }
.cov-chip.is-active { background: var(--fhs-vibrant-magenta); border-color: var(--fhs-vibrant-magenta); color: var(--fhs-white); }
.cov-chip.is-active .n { color: var(--fhs-white); }
.cov__readout { border-top: 1px solid var(--border-on-light); padding-top: 20px; }
.cov__readout .big { font-weight: 900; text-transform: uppercase; letter-spacing: -0.005em;
  font-size: clamp(24px, 3.2vw, 44px); line-height: 1.02; color: var(--fhs-ink); }
.cov__readout .big.accent { color: var(--fhs-vibrant-magenta); }

#advGrid .advisor { transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); }
#advGrid .advisor.is-off { opacity: 0; transform: scale(.97); pointer-events: none; }
#advGrid .advisor.is-gone { display: none; }

@media (prefers-reduced-motion: reduce) {
  .adv-wall__track { animation: none; }
  .adv-wall__row { overflow-x: auto; }
}

/* ===== EXPERIENCE ITINERARY ===== */
.xp { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(32px, 5vw, 88px); align-items: start; }
.xp__viewer { position: sticky; top: calc(var(--header-h) + 24px); display: grid; grid-template-columns: 1fr auto; gap: 0 18px; }
.xp__clockrow { grid-column: 1; display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 14px; }
.xp__clock { font-weight: 900; font-size: clamp(44px, 4.6vw, 72px); line-height: .9; letter-spacing: -0.02em; color: var(--fhs-ink); font-variant-numeric: tabular-nums; }
.xp__clock .ap { font-size: .34em; font-weight: 700; letter-spacing: .1em; margin-left: 8px; color: var(--fhs-vibrant-magenta); }
.xp__day { align-self: flex-end; }
.xp__media { grid-column: 1; position: relative; aspect-ratio: 4 / 3; overflow: hidden; border-top: 3px solid var(--fhs-vibrant-magenta); background: var(--surface-raised); }
.xp__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transform: scale(1.04); transition: opacity 320ms var(--ease-out), transform 560ms var(--ease-out); filter: saturate(.9); }
.xp__img.is-active { opacity: 1; transform: scale(1); }
.xp__railwrap { grid-column: 2; grid-row: 1 / 3; position: relative; width: 12px; display: flex; justify-content: center; }
.xp__rail { width: 1px; background: var(--border-on-light); position: absolute; inset-block: 6px; }
.xp__fill { display: block; width: 100%; height: 0%; background: var(--fhs-vibrant-magenta); transition: height 360ms var(--ease-out); }
.xp__nodes { position: absolute; inset-block: 6px; display: flex; flex-direction: column; justify-content: space-between; align-items: center; }
.xp__node { width: 9px; height: 9px; clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); background: var(--purple-100); transition: background var(--dur); }
.xp__node.is-active { background: var(--fhs-vibrant-magenta); }

.xp__steps { display: grid; padding-block: 6vh 16vh; }
.xp__step { padding: clamp(28px, 4vh, 44px) 0 clamp(28px, 4vh, 44px) clamp(18px, 2vw, 28px); border-left: 2px solid var(--border-on-light); opacity: .45; transition: opacity var(--dur-slow) var(--ease-out), border-color var(--dur-slow); }
.xp__step.is-active { opacity: 1; border-left-color: var(--fhs-vibrant-magenta); }
.xp__step-media { display: none; }
.xp__step-meta { display: flex; align-items: baseline; gap: 14px; margin-bottom: 10px; font-weight: 700; }
.xp__step-meta .idx { font-size: 12px; letter-spacing: .14em; color: var(--text-secondary); }
.xp__step-meta .t { display: none; }
.xp__step-meta .d { font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--fhs-vibrant-magenta); font-weight: 700; }
.xp__step h3 { font-weight: 900; text-transform: uppercase; font-size: clamp(22px, 2.4vw, 34px); line-height: 1; color: var(--fhs-ink); }
.xp__step-body { margin-top: 10px; font-size: 15.5px; line-height: 1.6; color: var(--text-secondary); max-width: 46ch; }

@media (max-width: 900px) {
  .xp { grid-template-columns: 1fr; }
  .xp__viewer { display: none; }
  .xp__steps { padding-block: 0; }
  .xp__step { opacity: 1; }
  .xp__step-media { display: block; aspect-ratio: 16 / 9; overflow: hidden; border-top: 3px solid var(--fhs-vibrant-magenta); margin-bottom: 16px; }
  .xp__step-media img { width: 100%; height: 100%; object-fit: cover; }
}
@media (prefers-reduced-motion: reduce) {
  .xp__img, .xp__fill, .xp__step { transition: none; }
  .xp__step { opacity: 1; }
}

/* ===== HERO VIDEO + CORRIDOR + TRIPTYCH ===== */
/* hero video: full-bleed under a flat warm-cream veil (light-first stays law) */
.hero__video { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero__video video { width: 100%; height: 100%; object-fit: cover; filter: saturate(.7); }
.hero__video::after { content: ""; position: absolute; inset: 0; background: var(--cream-200); opacity: .86; }
.motif__layer--video { overflow: hidden; }
.motif__layer--video video { width: 100%; height: 100%; object-fit: cover; display: block; }
.motif__layer--video .rm-poster { display: none; width: 100%; height: 100%; object-fit: cover; }
@media (prefers-reduced-motion: reduce) {
  .hero__video { display: none; }
  .motif__layer--video video { display: none; }
  .motif__layer--video .rm-poster { display: block; }
}

/* capital corridor */
.corridor { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr); gap: clamp(24px, 3.4vw, 56px); align-items: start; margin-top: clamp(40px, 5vw, 64px); }
.corridor__map { margin: 0; }
.corridor__map .capital-map { border: 1px solid var(--border-on-dark); border-top: 3px solid var(--fhs-vibrant-magenta); background: #2C1A3C; line-height: 0; }
.corridor__caption { margin-top: 14px; font-size: 13.5px; line-height: 1.55; color: var(--purple-200); max-width: 60ch; }
.corridor__routes { display: grid; align-content: start; }
.corridor__route { display: grid; grid-template-columns: auto 1fr; gap: 18px; padding: clamp(18px, 2.4vh, 26px) 0 clamp(18px, 2.4vh, 26px) 14px; border-top: 1px solid var(--border-on-dark); border-left: 2px solid transparent; transition: border-color var(--dur), padding-left var(--dur) var(--ease-out), background var(--dur); }
.corridor__route:hover { border-left-color: var(--fhs-vibrant-magenta); padding-left: 22px; background: rgba(42, 11, 58, .35); }
.corridor__route .num { font-weight: 900; font-size: 13px; letter-spacing: .14em; color: var(--magenta-400); padding-top: 4px; }
.corridor__route h3 { font-weight: 700; text-transform: uppercase; font-size: 18px; color: var(--fhs-warm-cream); }
.corridor__route p { margin-top: 6px; font-size: 14.5px; line-height: 1.55; color: var(--purple-200); max-width: 46ch; }
.corridor__close { border-top: 1px solid var(--border-on-dark); padding-top: 26px; display: grid; gap: 18px; justify-items: start; }
.corridor__ticker { border-top: 1px solid var(--border-on-dark); margin-top: clamp(44px, 6vw, 72px); }
.conviction.sect { padding-bottom: 0; }
.marquee__item--dark { color: var(--purple-200); font-weight: 500; }
@media (max-width: 900px) { .corridor { grid-template-columns: 1fr; } }

/* expanding triptych */
.triptych { display: flex; gap: 2px; height: clamp(440px, 58vh, 600px); }
.tri-panel { position: relative; flex: 1; overflow: hidden; background: var(--purple-900); transition: flex-grow 420ms var(--ease-out); display: block; }
.tri-panel.is-open { flex-grow: 2.6; }
.tri-panel__bg { position: absolute; inset: 0; }
.tri-panel__bg img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.75); transition: filter var(--dur-slow) var(--ease-out), transform 700ms var(--ease-out); }
.tri-panel__bg::after { content: ""; position: absolute; inset: 0; background: rgba(42, 11, 58, .62); transition: opacity var(--dur-slow) var(--ease-out); }
.tri-panel.is-open .tri-panel__bg img { filter: saturate(1); transform: scale(1.03); }
.tri-panel.is-open .tri-panel__bg::after { opacity: .34; }
.tri-panel__head { position: absolute; left: 0; right: 0; bottom: 0; z-index: 3; display: flex; align-items: baseline; gap: 14px; padding: 20px 22px; text-align: left; width: 100%; border-top: 3px solid transparent; background: rgba(42, 11, 58, .55); transition: border-color var(--dur), background var(--dur); }
.tri-panel.is-open .tri-panel__head { border-top-color: var(--fhs-vibrant-magenta); background: rgba(42, 11, 58, .72); }
.tri-panel__num { font-weight: 900; font-size: 13px; letter-spacing: .14em; color: var(--magenta-400); }
.tri-panel__title { font-weight: 900; text-transform: uppercase; letter-spacing: -0.005em; font-size: 16px; line-height: 1.05; color: var(--fhs-warm-cream); transition: font-size 420ms var(--ease-out); }
.tri-panel.is-open .tri-panel__title { font-size: clamp(20px, 2.2vw, 30px); }
.tri-panel__body { position: absolute; left: 22px; right: 22px; bottom: 84px; z-index: 2; background: rgba(42, 11, 58, .82); padding: 16px 18px; opacity: 0; transform: translateY(12px); transition: opacity 260ms var(--ease-out), transform 260ms var(--ease-out); }
.tri-panel.is-open .tri-panel__body { opacity: 1; transform: none; transition-delay: 140ms; }
.tri-panel__body p { font-size: 15px; line-height: 1.55; color: var(--fhs-warm-cream); max-width: 52ch; }
@media (max-width: 900px) {
  .triptych { flex-direction: column; height: min(170vw, 720px); }
  .tri-panel__title { white-space: normal; }
  .tri-panel__body { position: static; order: 2; padding: 14px 18px 18px; display: none; }
  .tri-panel { display: flex; flex-direction: column; justify-content: flex-end; }
  .tri-panel.is-open .tri-panel__body { display: block; }
  .tri-panel__head { position: static; }
}
@media (prefers-reduced-motion: reduce) {
  .tri-panel, .tri-panel__body, .tri-panel__bg img, .tri-panel__bg::after { transition: none; }
}

/* ===== V5: SPOTLIGHT / CONV-PIN / DIALOGUE / BOARD ===== */
/* --- advisor spotlight --- */
.spotlight { display: grid; gap: clamp(24px, 3vw, 40px); }
.spotlight__stage { position: relative; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr); align-items: end; }
.spotlight__media { grid-column: 2; position: relative; aspect-ratio: 4 / 5; max-height: 560px; overflow: hidden; border-top: 3px solid var(--fhs-vibrant-magenta); background: var(--surface-raised); }
.spotlight__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 50% 18%; opacity: 0; transform: scale(1.03); transition: opacity 300ms var(--ease-out), transform 540ms var(--ease-out); }
.spotlight__img.is-active { opacity: 1; transform: scale(1); }
.spotlight__name { position: absolute; left: 0; bottom: 18%; z-index: 3; max-width: 62%; font-weight: 900; text-transform: uppercase; letter-spacing: -0.012em; line-height: .92; font-size: clamp(40px, 5.2vw, 84px); color: var(--fhs-ink); }
.spotlight__role { grid-column: 1; align-self: end; padding: 0 24px 6px 0; display: grid; gap: 2px; }
.spotlight__role span { font-size: 15px; color: var(--text-secondary); }
.spotlight__role .co { color: var(--fhs-vibrant-magenta); font-weight: 700; text-transform: uppercase; font-size: 13px; letter-spacing: .1em; }
.spotlight__bar { position: absolute; right: 0; bottom: -14px; width: min(46%, 420px); height: 2px; background: var(--border-on-light); }
.spotlight__bar i { display: block; height: 100%; width: 0%; background: var(--fhs-vibrant-magenta); }
.spotlight.is-playing .spotlight__bar i { animation: spotbar var(--spot-dur, 4200ms) linear infinite; }
@keyframes spotbar { from { width: 0%; } to { width: 100%; } }
.spotlight__rail { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.spotlight__thumb { width: 58px; height: 58px; clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); overflow: hidden; padding: 0; opacity: .45; transition: opacity var(--dur); background: var(--rose-200); }
.spotlight__thumb img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 25%; filter: grayscale(1); transition: filter var(--dur); }
.spotlight__thumb:hover { opacity: .8; }
.spotlight__thumb.is-active { opacity: 1; }
.spotlight__thumb.is-active img { filter: grayscale(0); }
.spotlight__foot { display: flex; }
@media (max-width: 900px) {
  .spotlight__stage { grid-template-columns: 1fr; }
  .spotlight__media { grid-column: 1; max-height: none; }
  .spotlight__name { position: static; max-width: none; margin-bottom: 12px; }
  .spotlight__role { padding: 12px 0 0; }
  .spotlight__bar { position: static; margin-top: 10px; width: 100%; }
}

/* --- conviction pinned act --- */
html.conv-pinned .conv-pin { position: relative; }
html.conv-pinned .conviction { position: sticky; top: 0; min-height: 100svh; display: flex; flex-direction: column; justify-content: center; padding-block: calc(var(--header-h) + 12px) 0; }
html.conv-pinned .conviction .statement { font-size: clamp(26px, 3.6vw, 52px); }
html.conv-pinned .corridor { margin-top: clamp(24px, 3vh, 40px); }
html.conv-pinned .corridor__map .capital-map svg { max-height: 42svh; width: auto; margin-inline: auto; }
html.conv-pinned .corridor__caption { display: none; }
html.conv-pinned .conviction .reveal { opacity: 1; transform: none; transition: none; }
html.conv-pinned .conv-step { opacity: 0; transform: translateY(26px); transition: opacity 380ms var(--ease-out), transform 380ms var(--ease-out); }
html.conv-pinned .conv-step.on { opacity: 1; transform: none; }
html.conv-pinned .corridor__route.conv-step { transform: translateX(-26px); }
html.conv-pinned .corridor__route.conv-step.on { transform: none; }
html.conv-pinned .corridor__ticker { margin-top: clamp(20px, 3vh, 40px); }

/* --- dialogue collage --- */
.dialogue { display: grid; grid-template-columns: minmax(0, 7fr) minmax(0, 4fr); gap: clamp(28px, 4vw, 72px); align-items: start; }
.dialogue__asks { display: grid; }
.ask { position: relative; background: var(--surface-raised); border-top: 3px solid var(--fhs-vibrant-magenta); padding: clamp(24px, 3vw, 38px) clamp(22px, 2.6vw, 34px) clamp(20px, 2.4vw, 28px); max-width: 82%; }
.ask + .ask { margin-top: clamp(20px, 3vw, 36px); }
.ask:nth-child(2) { margin-left: auto; margin-top: -18px; }
.ask:nth-child(3) { margin-left: 9%; }
.ask::before { content: "\201C"; position: absolute; top: -8px; left: -14px; font-weight: 900; font-size: 88px; line-height: .6; color: var(--fhs-vibrant-magenta); }
.ask blockquote { font-weight: 300; font-size: clamp(17px, 1.7vw, 22px); line-height: 1.45; color: var(--fhs-ink); }
.ask figcaption { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.ask figcaption img { width: 40px; height: 40px; object-fit: cover; filter: grayscale(.15); }
.ask figcaption strong { display: block; font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--fhs-ink); }
.ask figcaption span { font-size: 12px; color: var(--text-secondary); }
.dialogue__answer { position: sticky; top: calc(var(--header-h) + 40px); display: grid; gap: 18px; justify-items: start; border-left: 2px solid var(--fhs-vibrant-magenta); padding-left: clamp(20px, 2.4vw, 32px); }
.dialogue__mark { font-weight: 900; font-size: 110px; line-height: .5; color: var(--fhs-vibrant-magenta); margin-top: 8px; }
.dialogue__line { font-weight: 900; text-transform: uppercase; letter-spacing: -0.01em; line-height: .95; font-size: clamp(34px, 3.6vw, 56px); color: var(--fhs-ink); }
@media (max-width: 900px) {
  .dialogue { grid-template-columns: 1fr; }
  .ask, .ask:nth-child(2), .ask:nth-child(3) { max-width: 100%; margin-left: 0; margin-top: 20px; }
  .dialogue__answer { position: static; }
}

/* --- departure board --- */
.board { border-top: 2px solid var(--fhs-ink); }
.board__head { display: grid; grid-template-columns: minmax(0, 2.4fr) minmax(0, 1.2fr) minmax(0, 1.8fr) minmax(0, 1.6fr) 30px; gap: clamp(12px, 2vw, 28px); padding: 12px 0; font-size: 10.5px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--text-secondary); border-bottom: 1px solid var(--border-on-light); }
.board__row { display: grid; grid-template-columns: minmax(0, 2.4fr) minmax(0, 1.2fr) minmax(0, 1.8fr) minmax(0, 1.6fr) 30px; gap: clamp(12px, 2vw, 28px); align-items: center; padding: 17px 0; border-bottom: 1px solid var(--border-on-light); border-left: 3px solid transparent; transition: background var(--dur), padding-left var(--dur) var(--ease-out), border-color var(--dur); }
.board__row:hover { background: var(--cream-100); border-left-color: var(--fhs-vibrant-magenta); padding-left: 12px; }
.board__row .ev { font-weight: 900; text-transform: uppercase; letter-spacing: .01em; font-size: clamp(16px, 1.6vw, 22px); color: var(--fhs-ink); font-variant-numeric: tabular-nums; }
.board__row .city { font-weight: 700; text-transform: uppercase; font-size: 13px; letter-spacing: .12em; color: var(--fhs-vibrant-magenta); font-variant-numeric: tabular-nums; }
.board__row .ven { font-size: 13.5px; color: var(--text-secondary); }
.board__row .date { font-size: 13.5px; color: var(--fhs-ink); font-variant-numeric: tabular-nums; display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }
.board__arrow { color: var(--fhs-vibrant-magenta); opacity: 0; transform: translateX(-6px); transition: opacity var(--dur), transform var(--dur) var(--ease-out); }
.board__row:hover .board__arrow { opacity: 1; transform: none; }
.board__row--live { background: rgba(159, 0, 126, .05); border-left-color: var(--fhs-vibrant-magenta); }
@media (max-width: 860px) {
  .board__head { display: none; }
  .board__row { grid-template-columns: minmax(0, 1fr) auto; grid-template-areas: "ev city" "ven ven" "date date"; row-gap: 4px; }
  .board__row .ev { grid-area: ev; } .board__row .city { grid-area: city; justify-self: end; }
  .board__row .ven { grid-area: ven; } .board__row .date { grid-area: date; }
  .board__arrow { display: none; }
}

/* ===== WHY-NOW: FORCES + WINDOW + 5-STATS ===== */
.stats__grid--5 { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 1100px) {
  .stats__grid--5 { grid-template-columns: repeat(3, 1fr); }
  .stats__grid--5 .stat { border-left: 0; border-top: 1px solid var(--border-on-light); padding-left: 0; }
  .stats__grid--5 .stat:nth-child(-n+3) { border-top: 0; }
}
@media (max-width: 680px) {
  .stats__grid--5 { grid-template-columns: 1fr; }
  .stats__grid--5 .stat { border-top: 1px solid var(--border-on-light); }
  .stats__grid--5 .stat:first-child { border-top: 0; }
}

.forces { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.6vw, 40px); }
.force { position: relative; border-top: 1px solid var(--border-on-light); padding-top: 18px; display: grid; grid-template-rows: auto 1fr; }
.force__num { position: absolute; right: 0; top: 6px; font-weight: 900; font-size: clamp(56px, 6vw, 96px); line-height: .8; color: var(--rose-200); user-select: none; z-index: 0; }
.force h3 { position: relative; z-index: 1; font-weight: 700; text-transform: uppercase; font-size: 19px; color: var(--fhs-ink); margin-bottom: 10px; }
.force p { position: relative; z-index: 1; font-size: 15px; line-height: 1.6; color: var(--text-secondary); max-width: 40ch; }
@media (max-width: 860px) { .forces { grid-template-columns: 1fr; } }

.window { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(0, .75fr); gap: clamp(32px, 5vw, 88px); align-items: center; }
.window__panel { border-left: 2px solid var(--fhs-vibrant-magenta); padding-left: clamp(22px, 2.6vw, 36px); display: grid; gap: 12px; justify-items: start; }
.window__figure { font-weight: 900; font-size: clamp(84px, 9vw, 150px); line-height: .85; letter-spacing: -0.02em; color: var(--fhs-warm-cream); font-variant-numeric: tabular-nums; }
.window__caption { font-weight: 700; text-transform: uppercase; letter-spacing: .14em; font-size: 13px; color: var(--magenta-400); }
.window__line { font-size: 15.5px; line-height: 1.55; color: var(--purple-200); max-width: 30ch; margin-top: 6px; }
.window__panel .btn { margin-top: 10px; }
@media (max-width: 900px) { .window { grid-template-columns: 1fr; } }

/* ===== PROGRAMME MOSAIC + SESSIONS ===== */
.fmosaic { display: grid; grid-template-columns: minmax(0, 1.18fr) minmax(0, .82fr); grid-auto-rows: minmax(140px, 176px); gap: 2px; }
.fmo { position: relative; overflow: hidden; margin: 0; background: var(--purple-900); }
.fmo--main { grid-row: 1 / 4; }
.fmo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.85); transition: transform 700ms var(--ease-out), filter var(--dur-slow); }
.fmo::before { content: ""; position: absolute; inset: 0; background: rgba(42, 11, 58, .34); transition: opacity var(--dur-slow); z-index: 1; }
.fmo:hover img { transform: scale(1.04); filter: saturate(1); }
.fmo:hover::before { opacity: .5; }
.fmo figcaption { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 12px 16px 14px; background: rgba(42, 11, 58, .78); border-top: 3px solid transparent; transition: border-color var(--dur); }
.fmo:hover figcaption { border-top-color: var(--fhs-vibrant-magenta); }
.fmo__meta { display: flex; align-items: baseline; gap: 12px; }
.fmo__meta .num { font-weight: 900; font-size: 12px; letter-spacing: .14em; color: var(--magenta-400); }
.fmo__meta .t { font-weight: 700; text-transform: uppercase; font-size: clamp(15px, 1.4vw, 19px); color: var(--fhs-warm-cream); line-height: 1.1; }
.fmo__line { margin-top: 4px; font-size: 13px; color: var(--purple-200); }
.fmo--main .fmo__meta .t { font-size: clamp(19px, 2vw, 26px); }
.fmo--main .fmo__line { font-size: 14.5px; }
@media (max-width: 860px) {
  .fmosaic { grid-template-columns: 1fr; grid-auto-rows: auto; }
  .fmo { aspect-ratio: 16 / 10; position: relative; }
  .fmo--main { grid-row: auto; }
}

.session { border-left: 2px solid transparent; padding-left: 14px; transition: border-color var(--dur), background var(--dur), padding-left var(--dur) var(--ease-out); }
.session:hover { border-left-color: var(--fhs-vibrant-magenta); background: var(--cream-100); padding-left: 20px; }
.session h4 { font-size: 18px; }

/* ===== AGENDA SPREAD ===== */
.spread-head { display: flex; align-items: baseline; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: clamp(24px, 3vw, 40px); }
.spread-note { font-size: 12.5px; letter-spacing: .04em; color: var(--text-secondary); }

.prebar { display: grid; grid-template-columns: auto 1fr 1fr; gap: clamp(18px, 2.6vw, 44px); align-items: center;
  border-block: 2px solid var(--fhs-ink); padding: 18px 0; margin-bottom: clamp(36px, 4.5vw, 60px); }
.prebar__day { display: grid; gap: 2px; padding-right: clamp(10px, 2vw, 28px); border-right: 1px solid var(--border-on-light); }
.prebar__day .k { font-weight: 700; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--fhs-vibrant-magenta); }
.prebar__day strong { font-weight: 900; text-transform: uppercase; font-size: clamp(17px, 1.7vw, 22px); color: var(--fhs-ink); line-height: 1; }
.prebar__item { display: flex; gap: 14px; align-items: baseline; }
.prebar__item h4 { font-weight: 700; text-transform: uppercase; font-size: 15px; color: var(--fhs-ink); }
.prebar__item p { font-size: 13px; color: var(--text-secondary); margin-top: 2px; }

.spread { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 72px); align-items: start; }
.spread-col__head { position: relative; padding: 6px 0 18px; border-bottom: 2px solid var(--fhs-ink); margin-bottom: 6px; }
.spread-col__head .ghost { position: absolute; right: 0; top: -22px; font-weight: 900; font-size: clamp(72px, 8vw, 128px); line-height: 1; color: var(--rose-200); user-select: none; z-index: 0; }
.spread-col__head .k { position: relative; z-index: 1; font-weight: 700; font-size: 11.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--fhs-vibrant-magenta); }
.spread-col__head h3 { position: relative; z-index: 1; font-weight: 900; text-transform: uppercase; font-size: clamp(26px, 2.8vw, 40px); line-height: .98; color: var(--fhs-ink); margin-top: 8px; }
.spread-col__head p { position: relative; z-index: 1; margin-top: 10px; font-size: 14px; color: var(--text-secondary); max-width: 40ch; }

.stag { display: inline-block; vertical-align: 2px; margin-left: 10px; padding: 3px 8px; border: 1px solid var(--border-on-light);
  font-weight: 500; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-secondary); white-space: nowrap; }
.stag--loud { border-color: var(--fhs-vibrant-magenta); background: var(--fhs-vibrant-magenta); color: var(--fhs-white); font-weight: 700; }

@media (max-width: 980px) {
  .spread { grid-template-columns: 1fr; }
  .prebar { grid-template-columns: 1fr; border-bottom: 0; padding-bottom: 0; }
  .prebar__day { border-right: 0; border-bottom: 1px solid var(--border-on-light); padding: 0 0 12px; }
  .prebar__item { padding-bottom: 12px; border-bottom: 1px solid var(--border-on-light); }
  .prebar__item:last-child { border-bottom: 2px solid var(--fhs-ink); padding-bottom: 16px; }
}

/* ===== ABOUT V2 ===== */
.chair { display: grid; grid-template-columns: minmax(0, .72fr) minmax(0, 1.28fr); gap: clamp(28px, 4.5vw, 80px); align-items: start; }
.chair__portrait { margin: 0; position: sticky; top: calc(var(--header-h) + 28px); }
.chair__portrait img { width: 100%; height: auto; border-top: 3px solid var(--fhs-vibrant-magenta); filter: grayscale(1); }
.chair__portrait figcaption { display: grid; gap: 2px; padding: 14px 0 0; }
.chair__portrait strong { font-weight: 700; text-transform: uppercase; font-size: 14px; letter-spacing: .06em; color: var(--fhs-warm-cream); }
.chair__portrait span { font-size: 12.5px; color: var(--purple-200); }
.chair__pull { font-weight: 900; text-transform: uppercase; letter-spacing: -0.01em; line-height: .96; font-size: clamp(30px, 3.8vw, 56px); color: var(--fhs-warm-cream); }
.chair__pull .accent-line { color: var(--magenta-400); font-style: normal; }
.chair__body { margin-top: clamp(22px, 3vw, 34px); display: grid; gap: 16px; max-width: 58ch; }
.chair__body p { font-weight: 300; font-size: clamp(16px, 1.5vw, 19px); line-height: 1.6; color: var(--purple-200); }
.chair__close { color: var(--fhs-warm-cream) !important; font-weight: 500 !important; }
@media (max-width: 900px) {
  .chair { grid-template-columns: 1fr; }
  .chair__portrait { position: static; max-width: 420px; }
}

.decades { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr); gap: clamp(28px, 4.5vw, 72px); align-items: start; }
.decades__media { margin: 0; display: grid; gap: 14px; justify-items: start; }
.decades__media img { width: 100%; height: auto; border-top: 3px solid var(--fhs-vibrant-magenta); }
.decades__media figcaption { font-size: 11.5px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--text-secondary); }
.decades__facts { display: grid; gap: 22px; }
.decades__stats { display: grid; grid-template-columns: 1fr 1fr; }
.decades__stats .stat { border-left: 0; border-top: 1px solid var(--border-on-light); padding: 16px 18px 16px 0; }
.decades__stats .stat:nth-child(-n+2) { border-top: 0; padding-top: 0; }
.decades__stats .stat .stat__value { font-size: clamp(34px, 3.4vw, 52px); }
.decades__coda { font-weight: 700; text-transform: uppercase; font-size: 15px; letter-spacing: .04em; color: var(--fhs-vibrant-magenta); }
@media (max-width: 900px) { .decades { grid-template-columns: 1fr; } }

/* ===== PARTNERS V2 ===== */
.supbar { display: flex; align-items: center; gap: clamp(24px, 4vw, 64px); flex-wrap: wrap;
  border-block: 1px solid var(--border-on-light); padding: 18px 0; }
.supbar__group { display: flex; align-items: center; gap: 18px; }
.supbar__group .k { font-weight: 700; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--text-secondary); }
.supbar__logo { display: flex; align-items: center; height: 44px; }
.supbar__logo img { max-height: 100%; width: auto; max-width: 150px; object-fit: contain; }
.supbar__note { margin-left: auto; font-size: 12.5px; color: var(--text-secondary); }
@media (max-width: 720px) { .supbar__note { margin-left: 0; } }

.dcards { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(16px, 2vw, 28px); }
.dcard { background: var(--surface-raised); box-shadow: 0 0 0 1px var(--border-on-light); display: grid; }
.dcard__media { aspect-ratio: 16 / 9; overflow: hidden; border-top: 3px solid var(--fhs-vibrant-magenta); }
.dcard__media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.85); transition: transform 700ms var(--ease-out), filter var(--dur-slow); }
.dcard:hover .dcard__media img { transform: scale(1.04); filter: saturate(1); }
.dcard__body { display: grid; grid-template-columns: auto 1fr; gap: 18px; padding: clamp(20px, 2.4vw, 30px); }
.dcard__body .num { font-weight: 900; font-size: 13px; letter-spacing: .14em; color: var(--fhs-vibrant-magenta); padding-top: 4px; }
.dcard__body h3 { font-weight: 700; text-transform: uppercase; font-size: 18px; color: var(--fhs-ink); margin-bottom: 8px; }
.dcard__body p { font-size: 14.5px; line-height: 1.55; color: var(--text-secondary); }
@media (max-width: 860px) { .dcards { grid-template-columns: 1fr; } }

.vt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2.4vw, 36px); }
.vt { margin: 0; display: grid; gap: 14px; }
.vt__frame { position: relative; aspect-ratio: 16 / 9; overflow: hidden; padding: 0; width: 100%;
  border-top: 3px solid var(--fhs-vibrant-magenta); background: var(--purple-900); cursor: pointer; }
.vt__frame img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.85); transition: transform 600ms var(--ease-out), filter var(--dur-slow), opacity var(--dur-slow); }
.vt__frame:hover img { transform: scale(1.04); filter: saturate(1); }
.vt__frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.vt__play { position: absolute; left: 50%; top: 50%; width: 58px; height: 58px; transform: translate(-50%, -50%) rotate(45deg);
  background: var(--fhs-vibrant-magenta); display: flex; align-items: center; justify-content: center;
  transition: background var(--dur), transform var(--dur) var(--ease-out); }
.vt__play svg { transform: rotate(-45deg); color: var(--fhs-white); }
.vt__frame:hover .vt__play { background: var(--magenta-700); transform: translate(-50%, -50%) rotate(45deg) scale(1.08); }
.vt.is-playing .vt__play { display: none; }
.vt figcaption { display: grid; gap: 2px; }
.vt figcaption strong { font-weight: 700; text-transform: uppercase; font-size: 14px; letter-spacing: .04em; color: var(--fhs-warm-cream); }
.vt figcaption span { font-size: 12.5px; color: var(--purple-200); }
.vt figcaption .at { color: var(--magenta-400); font-weight: 500; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; margin-top: 2px; }
@media (max-width: 860px) { .vt-grid { grid-template-columns: 1fr; } }

.mw { display: grid; grid-template-columns: minmax(0, .62fr) minmax(0, 1.38fr); gap: clamp(28px, 4.5vw, 72px); align-items: center; }
.mw__photo { margin: 0; max-width: 380px; }
.mw__photo img { width: 100%; border-top: 3px solid var(--fhs-vibrant-magenta); filter: grayscale(1); transition: filter var(--dur-slow) var(--ease-out); }
.mw__photo:hover img { filter: grayscale(0); }
.mw__panel { display: grid; gap: 16px; justify-items: start; }
.mw__card { border-left: 2px solid var(--fhs-vibrant-magenta); padding-left: 18px; display: grid; gap: 2px; }
.mw__card strong { font-weight: 700; text-transform: uppercase; font-size: 15px; color: var(--fhs-ink); }
.mw__card span { font-size: 13.5px; color: var(--text-secondary); }
.mw__card a { font-size: 14px; font-weight: 500; color: var(--fhs-vibrant-magenta); }
.mw__card a:hover { text-decoration: underline; }
@media (max-width: 860px) { .mw { grid-template-columns: 1fr; } .mw__photo { max-width: 300px; } }

.lr { margin-top: clamp(44px, 6vw, 72px); display: grid; gap: 12px; }
.lr__label { width: 100%; margin-bottom: 4px; }
.lr__row { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); }
.lr__row .marquee__track { animation-duration: 110s; }
.lr__row .marquee__track--rev { animation-direction: reverse; animation-duration: 126s; }
.lr__group { display: flex; gap: 12px; padding-right: 12px; flex-shrink: 0; }
.lr__chip { flex: none; width: 132px; height: 64px; background: var(--cream-100); box-shadow: 0 0 0 1px var(--border-on-light);
  display: flex; align-items: center; justify-content: center; padding: 10px 14px; }
.lr__chip img { max-width: 100%; max-height: 100%; object-fit: contain; }
@media (prefers-reduced-motion: reduce) { .lr__row { overflow-x: auto; } .lr__row .marquee__track { animation: none; } }

/* ===== PARTNERS V3: TIERS + STACK ===== */
.tiers { display: grid; border-top: 2px solid var(--fhs-ink); }
.tier { display: grid; grid-template-columns: minmax(0, .38fr) minmax(0, 1.62fr); gap: clamp(20px, 3vw, 48px);
  align-items: center; padding: clamp(22px, 3vw, 36px) 0; border-bottom: 1px solid var(--border-on-light); }
.tier__rail .k { font-weight: 700; font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--fhs-vibrant-magenta); }
.tier__rail h3 { font-weight: 900; text-transform: uppercase; font-size: clamp(20px, 2.2vw, 30px); line-height: 1; color: var(--fhs-ink); margin-top: 6px; }
.tier__tiles { display: flex; flex-wrap: wrap; gap: 16px; }
.tier__tile { display: flex; align-items: center; justify-content: center;
  width: clamp(240px, 26vw, 340px); height: clamp(120px, 12vw, 160px);
  background: var(--cream-100); box-shadow: 0 0 0 1px var(--border-on-light);
  border-top: 3px solid transparent; padding: 22px 30px;
  transition: border-color var(--dur), box-shadow var(--dur); }
.tier__tile:hover { border-top-color: var(--fhs-vibrant-magenta); box-shadow: 0 0 0 1px var(--fhs-vibrant-magenta); }
.tier__tile img { max-width: 100%; max-height: 100%; object-fit: contain; }
.tier__slot { display: grid; gap: 8px; align-content: center; justify-items: start;
  width: min(100%, 560px); min-height: clamp(120px, 12vw, 160px);
  border: 1px dashed var(--border-strong, var(--fhs-principal-purple)); border-width: 1.5px;
  padding: 22px 30px; transition: background var(--dur), border-color var(--dur); }
.tier__slot:hover { background: var(--rose-100); border-color: var(--fhs-vibrant-magenta); }
.tier__slot-big { font-weight: 900; text-transform: uppercase; font-size: clamp(20px, 2.2vw, 30px); line-height: 1; color: var(--fhs-vibrant-magenta); }
.tier__slot-line { display: inline-flex; align-items: center; gap: 8px; font-size: 13.5px; color: var(--text-secondary); }
.tier__slot-line svg { color: var(--fhs-vibrant-magenta); }
@media (max-width: 800px) { .tier { grid-template-columns: 1fr; gap: 14px; } .tier__tile { width: 100%; } }

.stack { display: grid; gap: clamp(20px, 3vh, 32px); }
.stk { position: sticky; top: calc(var(--header-h) + 18px + (var(--i) * 16px));
  display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  min-height: min(62vh, 560px);
  background: var(--surface-raised);
  border-top: 3px solid var(--fhs-vibrant-magenta);
  box-shadow: 0 0 0 1px var(--border-on-light), 0 -18px 40px rgba(42, 11, 58, .10); }
.stk--flip .stk__media { order: 2; }
.stk__media { overflow: hidden; }
.stk__media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.88); }
.stk__body { display: grid; align-content: center; gap: 14px; padding: clamp(26px, 4vw, 64px); }
.stk__num { font-weight: 900; font-size: 15px; letter-spacing: .14em; color: var(--fhs-vibrant-magenta); }
.stk__num .of { color: var(--text-secondary); font-weight: 500; }
.stk__body h3 { font-weight: 900; text-transform: uppercase; font-size: clamp(24px, 2.8vw, 40px); line-height: .98; color: var(--fhs-ink); max-width: 16ch; }
.stk__body p { font-size: clamp(15px, 1.4vw, 17px); line-height: 1.6; color: var(--text-secondary); max-width: 48ch; }
@media (max-width: 860px) {
  .stk { grid-template-columns: 1fr; min-height: 0; top: calc(var(--header-h) + 10px + (var(--i) * 10px)); }
  .stk--flip .stk__media { order: 0; }
  .stk__media { aspect-ratio: 16 / 9; }
}
@media (prefers-reduced-motion: reduce) { .stk { position: static; box-shadow: 0 0 0 1px var(--border-on-light); } }

/* ===== SCREENING ROOM ===== */
.screen { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(0, .85fr); gap: clamp(24px, 3.5vw, 64px); align-items: start; }
.screen__now { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--magenta-400); margin-bottom: 14px; }
.screen__now .dot { width: 8px; height: 8px; clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); background: var(--fhs-vibrant-magenta); animation: nowpulse 2.2s cubic-bezier(.2,.6,.2,1) infinite; }
@keyframes nowpulse { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }
.screen__stage { position: relative; aspect-ratio: 16 / 9; background: var(--purple-900); border-top: 3px solid var(--fhs-vibrant-magenta); overflow: hidden; }
.screen__stage .yt { position: absolute; inset: 0; width: 100%; padding: 0; cursor: pointer; }
.screen__stage .yt img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.9); transition: transform 600ms var(--ease-out), filter var(--dur-slow); }
.screen__stage .yt:hover img { transform: scale(1.03); filter: saturate(1); }
.screen__stage iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.screen__meta { display: grid; gap: 3px; padding-top: 18px; }
.screen__name { font-weight: 900; text-transform: uppercase; letter-spacing: -0.008em; font-size: clamp(24px, 2.6vw, 38px); line-height: 1; color: var(--fhs-warm-cream); }
.screen__role { font-size: 14.5px; color: var(--purple-200); }
.screen__at { font-weight: 700; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--magenta-400); margin-top: 6px; }
.screen__queue { display: grid; gap: 14px; align-content: start; }
.screen__q { display: grid; grid-template-columns: 148px 1fr; gap: 14px; align-items: center; padding: 0; text-align: left;
  background: rgba(42, 11, 58, .45); box-shadow: 0 0 0 1px var(--border-on-dark); border-left: 3px solid transparent;
  transition: background var(--dur), border-color var(--dur), transform var(--dur) var(--ease-out); cursor: pointer; }
.screen__q:hover { background: var(--fhs-deep-burgundy); border-left-color: var(--fhs-vibrant-magenta); transform: translateX(4px); }
.screen__q-thumb { position: relative; aspect-ratio: 16 / 9; overflow: hidden; }
.screen__q-thumb img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.8); }
.screen__q-thumb::after { content: ""; position: absolute; inset: 0; background: rgba(42, 11, 58, .25); }
.screen__q-play { position: absolute; left: 50%; top: 50%; width: 26px; height: 26px; transform: translate(-50%, -50%) rotate(45deg); background: var(--fhs-vibrant-magenta); display: flex; align-items: center; justify-content: center; z-index: 2; }
.screen__q-play svg { transform: rotate(-45deg); color: var(--fhs-white); }
.screen__q-info { padding-right: 14px; }
.screen__q-info strong { display: block; font-weight: 700; text-transform: uppercase; font-size: 13.5px; letter-spacing: .03em; color: var(--fhs-warm-cream); line-height: 1.2; }
.screen__q-info span { font-size: 12px; color: var(--purple-200); line-height: 1.4; display: block; margin-top: 3px; }
.screen__note { font-size: 12.5px; color: var(--purple-300); border-top: 1px solid var(--border-on-dark); padding-top: 14px; }
@media (max-width: 900px) {
  .screen { grid-template-columns: 1fr; }
  .screen__q { grid-template-columns: 120px 1fr; }
}
@media (prefers-reduced-motion: reduce) { .screen__now .dot { animation: none; } }

/* roster semantics (replaces queue) */
.screen__roster { display: grid; gap: 14px; align-content: start; }
.screen__r { display: grid; grid-template-columns: 132px 1fr auto; gap: 14px; align-items: center; padding: 0 14px 0 0; text-align: left;
  background: rgba(42, 11, 58, .45); box-shadow: 0 0 0 1px var(--border-on-dark); border-left: 3px solid transparent;
  opacity: .62; transition: background var(--dur), border-color var(--dur), opacity var(--dur); cursor: pointer; }
.screen__r:hover { background: var(--fhs-deep-burgundy); opacity: 1; }
.screen__r.is-active { border-left-color: var(--fhs-vibrant-magenta); background: rgba(42, 11, 58, .78); opacity: 1; }
.screen__r .state { font-weight: 700; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--purple-300); white-space: nowrap; }
.screen__r.is-active .state { color: var(--magenta-400); }
@media (max-width: 900px) { .screen__r { grid-template-columns: 110px 1fr auto; } }

/* ===== CONTACT V2 ===== */
.bigline { border-block: 2px solid var(--fhs-ink); padding: clamp(20px, 3vw, 36px) 0; display: grid; gap: 10px; }
.bigline__mail { display: inline-flex; align-items: baseline; gap: .18em;
  font-weight: 900; text-transform: lowercase; letter-spacing: -0.02em; line-height: .95;
  font-size: clamp(30px, 6.4vw, 96px); color: var(--fhs-ink); width: fit-content;
  transition: color var(--dur); }
.bigline__mail svg { color: var(--fhs-vibrant-magenta); transition: transform var(--dur) var(--ease-out); align-self: center; }
.bigline__mail:hover { color: var(--fhs-vibrant-magenta); }
.bigline__mail:hover svg { transform: translate(4px, -4px); }

.people { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(16px, 2vw, 28px); }
.person { display: grid; align-content: start; background: var(--surface-raised); box-shadow: 0 0 0 1px var(--border-on-light); border-top: 3px solid transparent; transition: border-color var(--dur); }
.person:hover { border-top-color: var(--fhs-vibrant-magenta); }
.person__media { aspect-ratio: 1; overflow: hidden; }
.person__media img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 22%; filter: grayscale(1); transition: filter var(--dur-slow) var(--ease-out); }
.person:hover .person__media img, .person:focus-within .person__media img { filter: grayscale(0); }
.person__kicker { font-weight: 700; font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--fhs-vibrant-magenta); padding: 16px 16px 0; }
.person__name { font-weight: 900; text-transform: uppercase; font-size: clamp(17px, 1.5vw, 21px); line-height: 1.02; color: var(--fhs-ink); padding: 6px 16px 0; }
.person__role { font-size: 13px; color: var(--text-secondary); padding: 3px 16px 0; }
.person__mail { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 12px 16px 0; }
.person__mail a { font-size: 12.5px; font-weight: 500; color: var(--fhs-vibrant-magenta); word-break: break-all; }
.person__mail a:hover { text-decoration: underline; }
.copy { flex: none; font-weight: 700; font-size: 9.5px; letter-spacing: .14em; text-transform: uppercase;
  border: 1px solid var(--border-on-light); padding: 4px 8px; color: var(--text-secondary);
  transition: background var(--dur), color var(--dur), border-color var(--dur); }
.copy:hover { border-color: var(--fhs-vibrant-magenta); color: var(--fhs-vibrant-magenta); }
.copy.is-done { background: var(--fhs-vibrant-magenta); border-color: var(--fhs-vibrant-magenta); color: var(--fhs-white); }
.person__tel { font-size: 12.5px; color: var(--text-secondary); padding: 6px 16px 16px; }
.person__tel:hover { color: var(--fhs-vibrant-magenta); }
.person > :last-child { padding-bottom: 16px; }
@media (max-width: 1000px) { .people { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .people { grid-template-columns: 1fr; } }

/* ===== ABOUT V3 ===== */
.fr { overflow: hidden; border-block: 1px solid var(--border-on-light); padding: 14px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); }
.fr .marquee__track { animation-duration: 64s; }
.fr__group { display: flex; gap: 14px; padding-right: 14px; flex-shrink: 0; }
.fr__chip { flex: none; width: 168px; height: 66px; background: var(--fhs-principal-purple);
  display: flex; align-items: center; justify-content: center; padding: 12px 18px; }
.fr__chip img { max-width: 100%; max-height: 100%; object-fit: contain; }
@media (prefers-reduced-motion: reduce) { .fr { overflow-x: auto; } .fr .marquee__track { animation: none; } }

.slabs { display: grid; grid-template-columns: repeat(3, 1fr); }
.slab { border-left: 1px solid var(--border-on-light); padding: clamp(8px, 1.4vw, 16px) clamp(20px, 2.6vw, 40px);
  border-top: 3px solid transparent; transition: border-top-color var(--dur); display: grid; align-content: start; gap: 10px; }
.slab:first-child { border-left: 0; padding-left: 0; }
.slab:hover { border-top-color: var(--fhs-vibrant-magenta); }
.slab p.slab__value { font-weight: 900; font-size: clamp(52px, 6vw, 96px); line-height: .9; letter-spacing: -0.02em;
  color: var(--fhs-ink); font-variant-numeric: tabular-nums; white-space: nowrap; }
.slab p.slab__value.is-accent { color: var(--fhs-vibrant-magenta); }
.slab h3 { font-weight: 700; text-transform: uppercase; font-size: 17px; color: var(--fhs-ink); margin-top: 6px; }
.slab p:not(.slab__value) { font-size: 14.5px; line-height: 1.55; color: var(--text-secondary); max-width: 34ch; }
@media (max-width: 860px) { .slabs { grid-template-columns: 1fr; } .slab { border-left: 0; border-top: 1px solid var(--border-on-light); padding: 20px 0; } .slab:first-child { border-top: 0; } }

.creds { display: grid; grid-template-columns: repeat(4, 1fr); border-block: 2px solid var(--fhs-ink); }
.cred { padding: clamp(18px, 2.4vw, 30px) clamp(16px, 2vw, 28px); border-left: 1px solid var(--border-on-light); }
.cred:first-child { border-left: 0; padding-left: 0; }
.cred__v { font-weight: 900; font-size: clamp(30px, 3.4vw, 54px); line-height: .95; letter-spacing: -0.015em; color: var(--fhs-ink); white-space: nowrap; }
.cred__v.is-accent { color: var(--fhs-vibrant-magenta); }
.cred__l { margin-top: 6px; font-size: 12.5px; line-height: 1.45; color: var(--text-secondary); }
.creds__coda { display: flex; align-items: baseline; gap: 18px; flex-wrap: wrap; margin-top: 18px;
  font-weight: 700; text-transform: uppercase; font-size: 14px; letter-spacing: .04em; color: var(--fhs-ink); }
@media (max-width: 860px) { .creds { grid-template-columns: 1fr 1fr; } .cred:nth-child(odd) { border-left: 0; padding-left: 0; } .cred:nth-child(n+3) { border-top: 1px solid var(--border-on-light); } }

.film { margin-top: clamp(32px, 4.5vw, 56px); display: grid; gap: 10px; padding-bottom: clamp(48px, 6vw, 88px); }
.film__row { overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent); }
.film__row .marquee__track { animation-duration: 92s; }
.film__row .marquee__track--rev { animation-direction: reverse; animation-duration: 108s; }
.film__group { display: flex; gap: 10px; padding-right: 10px; flex-shrink: 0; }
.film__frame { flex: none; width: clamp(220px, 24vw, 330px); aspect-ratio: 16 / 10; overflow: hidden; background: var(--rose-100); }
.film__frame img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.85); transition: filter var(--dur-slow); }
.film__frame:hover img { filter: saturate(1); }
@media (prefers-reduced-motion: reduce) { .film__row { overflow-x: auto; } .film__row .marquee__track { animation: none; } }

/* ===== HOME V6: CORRIDOR CINEMA + METHOD + WALL ===== */
.conviction__lede { margin-top: 18px; font-size: 14.5px; line-height: 1.6; color: var(--purple-200); max-width: 62ch; }
.corr2 { position: relative; margin-top: clamp(32px, 4.5vw, 56px);
  border: 1px solid var(--border-on-dark); border-top: 3px solid var(--fhs-vibrant-magenta); }
.corr2 .capital-map { border: 0; line-height: 0; background: #2C1A3C; }
.corr2 .capital-map svg { width: 100%; height: auto; display: block; }
.corr2__strip { position: absolute; inset-inline: 0; bottom: 0; display: grid; grid-template-columns: repeat(3, 1fr);
  background: rgba(26, 7, 36, .84); border-top: 1px solid var(--border-on-dark); }
.corr2__cell { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start;
  padding: clamp(14px, 1.8vw, 22px) clamp(16px, 2vw, 26px); border-left: 1px solid var(--border-on-dark); }
.corr2__cell:first-child { border-left: 0; }
.corr2__cell .num { font-weight: 900; font-size: 12px; letter-spacing: .14em; color: var(--magenta-400); padding-top: 3px; }
.corr2__cell h3 { font-weight: 700; text-transform: uppercase; font-size: 14.5px; letter-spacing: .02em; color: var(--fhs-warm-cream); }
.corr2__cell p { margin-top: 4px; font-size: 12.5px; line-height: 1.5; color: var(--purple-200); max-width: 40ch; }
.corr2__coda { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap;
  margin-top: clamp(22px, 3vw, 34px); }
@media (max-width: 900px) {
  .corr2__strip { position: static; grid-template-columns: 1fr; }
  .corr2__cell { border-left: 0; border-top: 1px solid var(--border-on-dark); }
  .corr2__cell:first-child { border-top: 0; }
}

.method { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: clamp(12px, 1.6vw, 24px); align-items: stretch; }
.method__stage { display: grid; align-content: start; gap: 12px; background: var(--surface-raised);
  box-shadow: 0 0 0 1px var(--border-on-light); border-top: 3px solid transparent;
  padding-bottom: clamp(18px, 2.2vw, 26px); transition: border-top-color var(--dur); }
.method__stage:hover { border-top-color: var(--fhs-vibrant-magenta); }
.method__media { aspect-ratio: 16 / 10; overflow: hidden; }
.method__media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.85);
  transition: filter var(--dur-slow) var(--ease-out), transform 600ms var(--ease-out); }
.method__stage:hover .method__media img { filter: saturate(1); transform: scale(1.03); }
.method__num { font-weight: 900; font-size: 13px; letter-spacing: .16em; color: var(--fhs-vibrant-magenta); padding: 8px 20px 0; }
.method__num .of { color: var(--text-secondary); font-weight: 500; }
.method__stage h3 { font-weight: 900; text-transform: uppercase; font-size: clamp(22px, 2.2vw, 32px); line-height: 1; color: var(--fhs-ink); padding: 0 20px; }
.method__stage p { font-size: 14.5px; line-height: 1.6; color: var(--text-secondary); padding: 0 20px; max-width: 40ch; }
.method__link { align-self: center; display: flex; gap: 7px; }
.method__link i { width: 10px; height: 10px; clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  background: var(--fhs-vibrant-magenta); opacity: .25; animation: mlink 1.6s cubic-bezier(.2, .6, .2, 1) infinite; }
.method__link i:nth-child(2) { animation-delay: .22s; }
.method__link i:nth-child(3) { animation-delay: .44s; }
@keyframes mlink { 0%, 100% { opacity: .22; transform: none; } 35% { opacity: 1; transform: translateX(3px); } }
@media (max-width: 960px) {
  .method { grid-template-columns: 1fr; }
  .method__link { transform: rotate(90deg); justify-self: center; padding: 4px 0; }
}
@media (prefers-reduced-motion: reduce) { .method__link i { animation: none; opacity: .7; } }

.advisors__foot { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  margin-top: clamp(20px, 3vw, 32px); }
.advisors__hint { font-weight: 700; font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--text-secondary); }

/* ===== WORLD MAP ===== */
.wmap { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(0, .9fr); gap: clamp(28px, 4vw, 64px); align-items: center; }
.wmap__map svg { width: 100%; height: auto; display: block; }
.wm-dots { fill: var(--rose-300); }
.wm { cursor: pointer; outline: none; }
.wm-d { fill: var(--fhs-ink); transform-box: fill-box; transform-origin: center;
  transition: transform var(--dur) var(--ease-out), fill var(--dur); }
.wm--live .wm-d { fill: var(--fhs-vibrant-magenta); }
.wm-pulse { fill: none; stroke: var(--fhs-ink); stroke-width: 1; opacity: .5; }
.wm--live .wm-pulse { stroke: var(--fhs-vibrant-magenta); stroke-width: 1.4; }
.wm-t { font-weight: 700; font-size: 12.5px; letter-spacing: .08em; text-transform: uppercase; fill: var(--fhs-ink); }
.wm--live .wm-t { fill: var(--fhs-vibrant-magenta); font-size: 14px; }
.wm.is-hot .wm-d, .wm:focus-visible .wm-d { transform: rotate(45deg) scale(1.45); fill: var(--fhs-vibrant-magenta); }
.wm.is-hot .wm-t, .wm:focus-visible .wm-t { fill: var(--fhs-vibrant-magenta); }

.wmap__rail { display: grid; align-content: center; border-top: 2px solid var(--fhs-ink); }
.wmap__row { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start;
  padding: clamp(12px, 1.6vw, 18px) 10px clamp(12px, 1.6vw, 18px) 12px;
  border-bottom: 1px solid var(--border-on-light); border-left: 3px solid transparent;
  transition: background var(--dur), border-left-color var(--dur); }
.wmap__row.is-hot, .wmap__row:hover { background: var(--rose-100); border-left-color: var(--fhs-vibrant-magenta); }
.wmap__row--live { border-left-color: var(--fhs-vibrant-magenta); background: var(--cream-100); }
.wmap__num { font-weight: 900; font-size: 12px; letter-spacing: .14em; color: var(--fhs-vibrant-magenta); padding-top: 3px; }
.wmap__city { font-weight: 900; text-transform: uppercase; font-size: 16.5px; letter-spacing: .01em; color: var(--fhs-ink);
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.wmap__ev { font-size: 12.5px; line-height: 1.5; color: var(--text-secondary); margin-top: 3px; }
.wmap__ev strong { font-weight: 700; color: var(--fhs-ink); }
@media (max-width: 900px) { .wmap { grid-template-columns: 1fr; } }

/* ===== HOME V7: FLOW + PRINCIPALS + MAP CAP ===== */
/* conviction map no longer full-bleed; strip sits under the map, not over it */
.corr2, .corr2__coda { max-width: min(100%, 920px); margin-inline: auto; }
.corr2 .corr2__strip { position: static; }
.corr2__coda { margin-top: clamp(20px, 2.6vw, 30px); }

/* method flow: numbered display rows with inline photo chips */
.flow { display: grid; border-top: 2px solid var(--fhs-ink); }
.flow__row { display: grid; grid-template-columns: auto 1fr; gap: clamp(16px, 3vw, 44px);
  padding: clamp(22px, 3.2vw, 40px) 0; border-bottom: 1px solid var(--border-on-light); }
.flow__num { font-weight: 900; font-size: 13px; letter-spacing: .16em; color: var(--fhs-vibrant-magenta);
  padding-top: clamp(10px, 1.5vw, 24px); min-width: 30px; }
.flow__word { font-weight: 900; text-transform: uppercase; line-height: .95; letter-spacing: -0.015em;
  font-size: clamp(38px, 6vw, 88px); color: var(--fhs-ink);
  display: flex; align-items: center; gap: clamp(14px, 1.8vw, 26px); flex-wrap: wrap;
  transition: color var(--dur); }
.flow__chip { display: inline-block; height: .88em; aspect-ratio: 16 / 10; overflow: hidden; flex: none;
  border: 1px solid var(--border-on-light); }
.flow__chip img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.82);
  transition: transform 600ms var(--ease-out), filter var(--dur-slow); }
.flow__row:hover .flow__word { color: var(--fhs-vibrant-magenta); }
.flow__row:hover .flow__chip img { transform: scale(1.06); filter: saturate(1); }
.flow__line { margin-top: clamp(8px, 1.2vw, 14px); font-size: 15px; line-height: 1.6;
  color: var(--text-secondary); max-width: 58ch; }
@media (max-width: 640px) { .flow__row { grid-template-columns: 1fr; gap: 8px; } .flow__num { padding-top: 0; } }

/* principals: featured stage + roster */
.prin { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: clamp(24px, 3.5vw, 56px);
  align-items: stretch; margin-bottom: clamp(28px, 4vw, 48px); }
.prin__stage { position: relative; display: grid; align-content: start; }
.prin__media { position: relative; aspect-ratio: 4 / 5; overflow: hidden; background: var(--rose-100);
  border-top: 3px solid var(--fhs-vibrant-magenta); }
.prin__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 50% 22%;
  opacity: 0; transition: opacity 420ms var(--ease-out); }
.prin__img.is-active { opacity: 1; }
.prin__plate { padding-top: 16px; display: grid; gap: 3px; }
.prin__name { font-weight: 900; text-transform: uppercase; letter-spacing: -0.008em;
  font-size: clamp(22px, 2.4vw, 34px); line-height: 1; color: var(--fhs-ink); }
.prin__role { font-size: 14px; color: var(--text-secondary); }
.prin__co { font-weight: 700; font-size: 11.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--fhs-vibrant-magenta); }
.prin__bar { position: absolute; left: 0; top: 0; width: 100%; height: 3px; overflow: hidden; z-index: 2; }
.prin__bar i { display: block; height: 100%; width: 0; background: var(--fhs-ink); }
@keyframes prinbar { from { width: 0; } to { width: 100%; } }
.prin__roster { display: grid; align-content: stretch; border-top: 2px solid var(--fhs-ink); }
.prin__row { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: center; text-align: left;
  padding: clamp(8px, 1.1vw, 13px) 10px clamp(8px, 1.1vw, 13px) 12px; width: 100%;
  border-bottom: 1px solid var(--border-on-light); border-left: 3px solid transparent;
  cursor: pointer; transition: background var(--dur), border-left-color var(--dur); }
.prin__row .n { font-weight: 900; font-size: 11px; letter-spacing: .14em; color: var(--text-secondary); transition: color var(--dur); }
.prin__row .who { display: grid; gap: 1px; }
.prin__row .who strong { font-weight: 700; text-transform: uppercase; font-size: 14px; letter-spacing: .02em; color: var(--fhs-ink); line-height: 1.15; }
.prin__row .who span { font-size: 12px; line-height: 1.35; color: var(--text-secondary); }
.prin__row:hover { background: var(--rose-100); }
.prin__row.is-active { background: var(--cream-100); border-left-color: var(--fhs-vibrant-magenta); }
.prin__row.is-active .n { color: var(--fhs-vibrant-magenta); }
@media (max-width: 900px) {
  .prin { grid-template-columns: 1fr; }
  .prin__media { aspect-ratio: 16 / 11; }
  .prin__img { object-position: 50% 18%; }
}

/* ===== HOME V8 ===== */
/* hero headlines share --type-display on every page (h1-long override retired) */
/* subpage hero motifs share the homepage 3D pointer tilt */
.page-hero__media { perspective: 1200px; }

/* ===== RESPONSIVE SAFETY (V10) ===== */
/* long CTA labels may wrap on small phones instead of forcing horizontal scroll */
@media (max-width: 480px) {
  .btn { white-space: normal; text-align: center; padding: 15px 22px; }
}
