/* ============================================================
 * Vanar marketing site - matches reference index.html aesthetic
 * Light pastel wash · white tiles · dark gradient titles · pill nav
 * Tweaks: theme (light/dark) · density (airy/normal/dense) · grain
 * ============================================================ */

@font-face {
  font-family: "Akira";
  src: url("fonts/Akira-SuperBold.otf") format("opentype");
  font-weight: 800; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Akira";
  src: url("fonts/Akira-Bold.otf") format("opentype");
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Metaluna";
  src: url("fonts/Metaluna-Bold.otf") format("opentype");
  font-weight: 700; font-style: normal; font-display: swap;
}

:root {
  /* type */
  --display: "Big Shoulders Display", "Akira", Impact, "Helvetica Neue", sans-serif;
  --sans:    "Inter Tight", -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --wordmark:"Metaluna", "Big Shoulders Display", Impact, sans-serif;

  /* gradient canvas - mint → lilac → warm (source) */
  --bg-1: #D9EFE3;
  --bg-2: #E9E8F2;
  --bg-3: #F1E6DC;
  --bg-4: #E3D9EE;
  --bg-page: #E6EBE4;

  /* foreground */
  --fg:       #111318;
  --fg-dim:   #5B5F66;
  --fg-mute:  #8A8D94;

  /* rules / surfaces */
  --rule:        rgba(17,19,24,0.10);
  --rule-strong: rgba(17,19,24,0.22);
  --card:        #FFFFFF;
  --card-ink:    #111318;
  --glass:       rgba(255,255,255,0.55);
  --glass-2:     rgba(255,255,255,0.78);

  /* emerald accent */
  --emerald:        #143E36;
  --emerald-deep:   #0E3C35;
  --emerald-ink:    #D8E6D3;
  --emerald-mint:   #8FCFB0;
  --green-pill:     #163A2E;
  --green-pill-ink: #E7F1E4;
  --violet:         #6E5BE0;

  /* shadows */
  --shadow-card:       0 1px 0 rgba(17,19,24,.04), 0 10px 30px -12px rgba(17,19,24,.12), 0 2px 6px -2px rgba(17,19,24,.06);
  --shadow-card-hover: 0 1px 0 rgba(17,19,24,.06), 0 22px 50px -18px rgba(17,19,24,.20), 0 4px 10px -3px rgba(17,19,24,.08);
  --shadow-nav:        0 6px 24px -8px rgba(17,19,24,.10);
  --shadow-feature:    0 1px 0 rgba(17,19,24,.06), 0 28px 60px -20px rgba(22,58,46,.35);
  --shadow-pill:       0 10px 30px -10px rgba(22,58,46,.55);

  /* density rhythm */
  --pad-section: 64px;
  --pad-block:   28px;
  --gap-grid:    14px;

  --grain-opacity: 0.30;
  --grain-tile: 220px;

  /* hero title multi-stop gradient (source) */
  --hero-grad: linear-gradient(90deg, #163A2E 0%, #060C0A 18%, #1A3A30 34%, #345A4F 55%, #1D3D33 72%, #060C0A 88%, #0E1F19 100%);
  --glow-grad: linear-gradient(90deg, #1D5E4E 0%, #6E5BE0 100%);
}

/* THEME variants */
.theme-light, :root { /* default */ }

.theme-dark {
  --bg-page:    #061812;
  --fg:         #E2EAD9;
  --fg-dim:     rgba(226,234,217,0.78);
  --fg-mute:    rgba(226,234,217,0.50);
  --rule:        rgba(216,230,211,0.10);
  --rule-strong: rgba(216,230,211,0.22);
  --card:        rgba(216,230,211,0.04);
  --card-ink:    #E2EAD9;
  --glass:       rgba(216,230,211,0.06);
  --glass-2:     rgba(216,230,211,0.10);
  --green-pill:  #8FCFB0;
  --green-pill-ink: #061812;
  --hero-grad: linear-gradient(90deg, #B8E8CB 0%, #8FCFB0 30%, #B6A8F2 70%, #E7D7B0 100%);
  --shadow-card:       0 1px 0 rgba(255,255,255,.04) inset, 0 22px 44px -22px rgba(0,0,0,.55);
  --shadow-card-hover: 0 1px 0 rgba(255,255,255,.06) inset, 0 30px 60px -22px rgba(0,0,0,.7);
  --shadow-feature:    0 30px 60px -22px rgba(0,0,0,.7);
  --shadow-pill:       0 10px 30px -10px rgba(143,207,176,.45);
}

/* DENSITY */
.dens-airy   { --pad-section: 96px;  --pad-block: 44px; --gap-grid: 20px; }
.dens-normal { --pad-section: 64px;  --pad-block: 28px; --gap-grid: 14px; }
.dens-dense  { --pad-section: 44px;  --pad-block: 20px; --gap-grid: 10px; }

/* GRAIN intensity */
.grain-off  { --grain-opacity: 0; }
.grain-low  { --grain-opacity: 0.18; }
.grain-mid  { --grain-opacity: 0.30; }
.grain-high { --grain-opacity: 0.55; }

/* ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
html {
  background: var(--bg-page);
  color: var(--fg);
  scroll-behavior: smooth;
  scroll-padding-top: 100px;
}
body {
  background: transparent;
  font-family: var(--sans);
  font-size: 15.5px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  color: var(--fg);
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; padding: 0; cursor: pointer; }
::selection { background: var(--emerald); color: var(--emerald-ink); }

/* ============================================================
 * BG WASH - pastel radial drift (light) / emerald grain (dark)
 * ============================================================ */
.bg-wash {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(230,235,228,0.65) 0%, rgba(232,228,239,0.6) 40%, rgba(238,227,222,0.7) 100%);
}
.bg-wash::before, .bg-wash::after {
  content: ""; position: absolute; inset: -20%; pointer-events: none; will-change: transform;
}
.bg-wash::before {
  background:
    radial-gradient(900px 700px at 20% 30%, rgba(207,232,218,0.85) 0%, transparent 60%),
    radial-gradient(1000px 800px at 80% 20%, rgba(226,216,240,0.78) 0%, transparent 62%);
  animation: wash-drift-a 22s ease-in-out infinite alternate;
}
.bg-wash::after {
  background:
    radial-gradient(1100px 900px at 60% 85%, rgba(242,227,212,0.8) 0%, transparent 60%),
    radial-gradient(800px 700px at 10% 90%, rgba(217,239,227,0.7) 0%, transparent 62%),
    radial-gradient(700px 600px at 90% 60%, rgba(227,217,238,0.7) 0%, transparent 62%);
  animation: wash-drift-b 28s ease-in-out infinite alternate;
}
@keyframes wash-drift-a {
  0% { transform: translate3d(0,0,0) scale(1); }
  50% { transform: translate3d(4%,-2%,0) scale(1.08); }
  100% { transform: translate3d(-3%,3%,0) scale(1.04); }
}
@keyframes wash-drift-b {
  0% { transform: translate3d(0,0,0) scale(1.05); }
  50% { transform: translate3d(-4%,2%,0) scale(1); }
  100% { transform: translate3d(3%,-3%,0) scale(1.08); }
}

/* Dark theme wash override */
.theme-dark .bg-wash {
  background: linear-gradient(180deg, rgba(6,24,18,0.92) 0%, rgba(11,33,26,0.92) 50%, rgba(6,24,18,0.96) 100%);
}
.theme-dark .bg-wash::before {
  background:
    radial-gradient(900px 700px at 20% 30%, rgba(143,207,176,0.10) 0%, transparent 60%),
    radial-gradient(1000px 800px at 80% 20%, rgba(110,91,224,0.10) 0%, transparent 62%);
}
.theme-dark .bg-wash::after {
  background:
    radial-gradient(1100px 900px at 60% 85%, rgba(143,207,176,0.06) 0%, transparent 60%),
    radial-gradient(800px 700px at 10% 90%, rgba(110,91,224,0.06) 0%, transparent 62%);
}

/* Grain overlay removed - flat surfaces */
@media (prefers-reduced-motion: reduce) {
  .bg-wash::before, .bg-wash::after { animation: none; }
}

/* ============================================================
 * WRAP / LAYOUT
 * ============================================================ */
.wrap { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
@media (max-width: 900px) { .wrap { padding: 0 20px; } }

main, header, footer { position: relative; z-index: 1; }

/* ============================================================
 * TYPE UTILITIES
 * ============================================================ */
.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-dim);
  font-weight: 500;
  display: inline-block;
}
.eyebrow--dot::before {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--emerald-mint);
  box-shadow: 0 0 8px rgba(143,207,176,.75);
  margin-right: 8px;
  vertical-align: middle;
}
.kicker {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-mute);
  font-weight: 500;
}

h1, h2, h3, h4, h5 {
  font-family: var(--display);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  margin: 0;
  line-height: 0.95;
  color: var(--fg);
}

.display {
  font-family: var(--display);
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  line-height: 0.88;
}

.h-display { font: 800 clamp(64px, 12vw, 180px)/0.86 var(--display); text-transform: uppercase; letter-spacing: -0.01em; }
.h-section { font: 800 clamp(34px, 5vw, 72px)/0.95 var(--display); text-transform: uppercase; letter-spacing: -0.005em; }
.h-card    { font: 800 clamp(24px, 2.4vw, 32px)/1 var(--display); text-transform: uppercase; letter-spacing: -0.005em; }
.h-tile    { font: 800 22px/1 var(--display); text-transform: uppercase; letter-spacing: -0.005em; }

p { margin: 0; }
.lede {
  font-size: 17px;
  line-height: 1.5;
  color: var(--fg);
  max-width: 56ch;
}
.body { font-size: 15px; line-height: 1.55; color: var(--fg-dim); }
.body-sm { font-size: 13px; line-height: 1.5; color: var(--fg-dim); }
.mono { font-family: var(--mono); font-size: 12px; color: var(--fg-dim); letter-spacing: 0.04em; }

/* glow gradient on emphasized words */
.glow {
  font-style: normal;
  background: var(--glow-grad);
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: glow-shift 10s ease-in-out infinite;
}
@keyframes glow-shift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}
em.mint { font-style: normal; color: #1D5E4E; }
em.violet { font-style: normal; color: var(--violet); }
.theme-dark em.mint { color: var(--emerald-mint); }
.theme-dark em.violet { color: #B6A8F2; }

/* Brand wordmark */
.brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--wordmark);
  font-weight: 700;
  font-size: 26px;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  color: var(--fg);
  -webkit-text-stroke: 0.6px currentColor;
  text-shadow: 0 0 0.5px currentColor;
}
.brand__mark {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: conic-gradient(from 140deg, #8FCFB0, #C6B8EA, #F0D6C2, #8FCFB0);
  box-shadow: inset 0 0 0 1px rgba(17,19,24,0.12);
  flex: 0 0 auto;
}

/* ============================================================
 * NAV - pill, frosted glass, sticky
 * ============================================================ */
.nav { position: sticky; top: 0; z-index: 40; padding-top: 20px; }
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 8px 8px 8px 20px;
  box-shadow: var(--shadow-nav);
  gap: 16px;
}
.theme-dark .nav__inner {
  background: rgba(6,24,18,0.72);
  border-color: rgba(216,230,211,0.18);
}
.nav__links {
  display: flex; gap: 2px; align-items: center;
  font-size: 13.5px;
  color: var(--fg-dim);
  flex: 1;
  margin-left: 18px;
  font-family: var(--sans);
  font-weight: 500;
}
.nav__link {
  padding: 8px 12px;
  border-radius: 999px;
  transition: background .15s, color .15s;
  font-family: var(--sans);
  white-space: nowrap;
  cursor: pointer;
  border: 0;
  background: none;
}
.nav__link:hover { background: rgba(17,19,24,0.05); color: var(--fg); }
.theme-dark .nav__link:hover { background: rgba(216,230,211,0.08); }
.nav__link.is-active {
  background: var(--fg);
  color: var(--bg-page);
  font-weight: 600;
  letter-spacing: 0.01em;
}
.theme-dark .nav__link.is-active {
  background: var(--emerald-mint);
  color: #061812;
}

/* Vertical group separator */
.nav__sep {
  width: 1px; height: 16px;
  background: var(--rule-strong);
  margin: 0 6px;
  opacity: 0.55;
  flex: 0 0 auto;
}

/* Dropdown */
.nav__dd { position: relative; isolation: isolate; display: inline-flex; align-items: center; }
.nav__link--dd {
  display: inline-flex; align-items: center; gap: 5px;
  font: inherit; color: inherit;
}
.nav__caret { width: 9px; height: 5px; transition: transform .15s ease; opacity: 0.7; }
.nav__dd:hover .nav__caret,
.nav__dd.is-open .nav__caret { transform: rotate(180deg); }
.nav__dd:hover .nav__link--dd { background: rgba(17,19,24,0.05); color: var(--fg); }
.theme-dark .nav__dd:hover .nav__link--dd { background: rgba(216,230,211,0.08); }
.nav__menu {
  position: absolute;
  top: calc(100% + 10px); left: 50%;
  transform: translateX(-50%);
  min-width: 260px;
  padding: 6px;
  background: rgba(250,249,247,0.96);
  backdrop-filter: blur(24px);
  border: 1px solid var(--rule);
  border-radius: 14px;
  box-shadow: 0 22px 50px -18px rgba(17,19,24,0.30), 0 0 0 1px rgba(255,255,255,0.5) inset;
  z-index: 50;
  display: none;
  flex-direction: column;
  gap: 2px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity .14s ease;
}
.theme-dark .nav__menu {
  background: rgba(11,33,26,0.96);
  border-color: rgba(216,230,211,0.16);
  box-shadow: 0 22px 50px -18px rgba(0,0,0,0.6);
}
.nav__menu::before {
  content: "";
  position: absolute;
  top: -5px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 10px; height: 10px;
  background: inherit;
  border-left: 1px solid var(--rule);
  border-top: 1px solid var(--rule);
}
.nav__dd:hover .nav__menu, .nav__dd:focus-within .nav__menu {
  display: flex;
  opacity: 1;
}
.nav__menu-item {
  display: block;
  padding: 9px 12px;
  border-radius: 9px;
  color: var(--fg);
  transition: background .12s, color .12s;
  cursor: pointer;
}
.nav__menu-item:hover { background: rgba(17,19,24,0.05); }
.theme-dark .nav__menu-item:hover { background: rgba(216,230,211,0.08); }
.nav__menu-item.is-active { background: var(--fg); color: var(--bg-page); }
.theme-dark .nav__menu-item.is-active { background: var(--emerald-mint); color: #061812; }
.nav__menu-name { font-family: var(--sans); font-weight: 600; font-size: 13.5px; line-height: 1.1; display: block; }
.nav__menu-hint {
  display: block;
  margin-top: 3px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.nav__menu-item.is-active .nav__menu-hint { color: rgba(216,230,211,0.7); }

/* Right side */
.nav__right { display: flex; align-items: center; gap: 8px; flex: 0 0 auto; }
.nav__meta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--fg-mute);
  text-transform: uppercase;
  padding: 0 8px;
}
.nav__meta .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--emerald-mint);
  box-shadow: 0 0 8px var(--emerald-mint);
  animation: pulse-dot 2.4s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: .55; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.35); }
}
@media (max-width: 1100px) {
  .nav__links { font-size: 13px; }
  .nav__link { padding: 7px 10px; }
  .nav__sep { margin: 0 4px; }
  .nav__meta { display: none; }
}
@media (max-width: 980px) {
  .nav__links { display: none; }
}

/* ============================================================
 * BUTTONS
 * ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  height: 44px;
  padding: 0 20px;
  border-radius: 999px;
  font-family: var(--sans);
  font-weight: 500;
  font-size: 14px;
  border: 1px solid transparent;
  transition: transform .15s, box-shadow .2s, background .2s, color .2s, border-color .2s;
  white-space: nowrap;
}
.btn--pill {
  background: var(--green-pill);
  color: var(--green-pill-ink);
}
.btn--pill:hover { background: #0f2b22; transform: translateY(-1px); }
.theme-dark .btn--pill:hover { background: #B8E8CB; }
.btn--ghost {
  background: rgba(255,255,255,0.6);
  backdrop-filter: blur(8px);
  color: var(--fg);
  border-color: var(--rule-strong);
}
.theme-dark .btn--ghost { background: rgba(216,230,211,0.06); }
.btn--ghost:hover { background: #fff; border-color: var(--fg); }
.theme-dark .btn--ghost:hover { background: rgba(216,230,211,0.12); border-color: var(--fg); }
.btn--outline {
  border-color: var(--rule-strong);
  color: var(--fg);
}
.btn--outline:hover { border-color: var(--fg); background: rgba(255,255,255,0.5); }
.btn--lg {
  height: 60px;
  padding: 0 32px;
  font-size: 18px;
  font-weight: 600;
  font-family: "Big Shoulders Display", var(--display);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.btn--lg.btn--pill { box-shadow: var(--shadow-pill); }
.btn--lg.btn--pill:hover { box-shadow: 0 14px 36px -10px rgba(22,58,46,.65); }
.arrow { font-family: var(--display); font-weight: 700; font-size: 14px; line-height: 1; }

/* ============================================================
 * HERO
 * ============================================================ */
.hero { padding: 56px 0 72px; position: relative; }
.hero__top {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 40px;
  gap: 20px;
}
.hero__top .eyebrow { display: inline-flex; align-items: center; gap: 12px; }
.hero__top .eyebrow::before {
  content: ""; width: 28px; height: 1px;
  background: var(--fg-mute);
  display: inline-block;
}

.hero__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(54px, 11.9vw, 187px);
  line-height: 0.82;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0;
  background: var(--hero-grad);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  animation: hero-rise 1.1s cubic-bezier(.2,.8,.2,1) both;
}
.hero__title .glow {
  background: var(--glow-grad);
  background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  animation: glow-shift 10s ease-in-out infinite;
}
.hero__title .stroke {
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 1.5px var(--fg);
  color: transparent;
}
@keyframes hero-rise {
  from { opacity: 0; transform: translateY(28px); }
  to { opacity: 1; transform: none; }
}
@keyframes hero-fade {
  from { opacity: 0; } to { opacity: 1; }
}

.hero__sub-row {
  margin-top: 48px;
  padding-top: 28px;
  border-top: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 36px;
  animation: hero-rise 1.1s cubic-bezier(.2,.8,.2,1) .2s both;
}
.hero__sub {
  font-size: 17px;
  line-height: 1.55;
  max-width: 58ch;
  color: var(--fg);
  margin: 0;
}
.hero__sub strong { font-weight: 600; }

/* sub + pullquote two-column row */
.hero__sub-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}
@media (max-width: 860px) {
  .hero__sub-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* hero pullquote - cycling carousel */
.hero__pullquote {
  margin: 0;
  padding: 0 0 0 22px;
  border-left: 1px solid var(--rule);
  max-width: 58ch;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
@media (max-width: 860px) {
  .hero__pullquote {
    padding: 18px 0 0;
    border-left: 0;
    border-top: 1px dashed var(--rule);
  }
}
.hero__pullquote-track {
  position: relative;
  display: grid;
}
.hero__pullquote-slide {
  grid-area: 1 / 1;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .6s ease, transform .6s cubic-bezier(.2,.8,.2,1);
  pointer-events: none;
}
.hero__pullquote-slide.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.hero__pullquote-slide blockquote {
  margin: 0;
  font-family: var(--display, "Big Shoulders Display", system-ui, sans-serif);
  font-weight: 600;
  font-size: clamp(20px, 1.9vw, 26px);
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--fg);
  text-wrap: balance;
}
.hero__pullquote-slide blockquote em.glow {
  font-style: normal;
  background: var(--glow-grad);
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: glow-shift 10s ease-in-out infinite;
}
.hero__pullquote figcaption {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-2, var(--fg));
  opacity: 0.78;
}
.hero__pullquote-name { font-weight: 600; color: var(--fg); opacity: 1; }
.hero__pullquote-sep { opacity: 0.5; }

.hero__pullquote-dots {
  display: inline-flex;
  gap: 8px;
  margin-top: 2px;
}
.hero__pullquote-dot {
  width: 22px;
  height: 4px;
  border-radius: 999px;
  background: var(--rule);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: background .25s ease, width .25s ease;
}
.hero__pullquote-dot.is-active {
  background: var(--fg);
  width: 32px;
}
.hero__pullquote-dot:hover { background: rgba(17,19,24,0.45); }
.theme-dark .hero__pullquote-dot:hover { background: rgba(216,230,211,0.55); }

.hero__ctas {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: flex-start;
}

/* ============================================================
 * HERO QUOTES STRIP
 * ============================================================ */
.hero__quotes {
  margin: 0;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  padding: 0;
  position: relative;
  min-height: 180px;
}
.hero-quote__track {
  position: relative;
  flex: 1 1 auto;
  min-height: 140px;
}
.hero-quote {
  position: absolute;
  inset: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: center;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity 600ms ease, transform 600ms cubic-bezier(.2,.8,.2,1);
}
.hero-quote.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.hero-quote blockquote {
  margin: 0;
  font-family: var(--sans);
  font-size: 22px;
  line-height: 1.35;
  color: var(--fg);
  font-weight: 500;
  letter-spacing: -0.005em;
}
.hero-quote figcaption {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0;
  border: 0;
}
.hero-quote__dots {
  display: flex;
  gap: 8px;
  margin-top: 4px;
}
.hero-quote__dot {
  width: 22px;
  height: 4px;
  border-radius: 999px;
  border: 0;
  padding: 0;
  background: var(--rule);
  cursor: pointer;
  transition: background 240ms ease, width 240ms ease;
}
.hero-quote__dot.is-active {
  background: var(--fg);
  width: 32px;
}
@media (prefers-reduced-motion: reduce) {
  .hero-quote { transition: opacity 0s; transform: none; }
}
.hero-quote blockquote {
  margin: 0;
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.5;
  color: var(--fg);
  font-weight: 500;
}
.hero-quote blockquote em {
  font-style: normal;
  background: var(--glow-grad);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-weight: 600;
}
.hero-quote figcaption {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-top: 10px;
  border-top: 1px solid var(--rule);
}
.hero-quote__name {
  font-family: "Big Shoulders Display", var(--display);
  font-weight: 800;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--fg);
}
.hero-quote__role {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-mute);
}

/* ============================================================
 * TEE STRIP - sealed runtime callout under hero ticker
 * ============================================================ */
.tee-strip {
  margin-top: 14px;
  display: flex; align-items: center; gap: 18px;
  padding: 16px 22px;
  background: rgba(14,60,53,.06);
  border: 1px solid rgba(14,60,53,.18);
  border-radius: 16px;
  flex-wrap: wrap;
}
.theme-dark .tee-strip {
  background: rgba(143,207,176,0.06);
  border-color: rgba(143,207,176,0.22);
}
.tee-strip__lead {
  display: inline-flex; align-items: center; gap: 10px;
  font: 800 14px var(--display); letter-spacing: 0.04em; text-transform: uppercase;
  color: #1D5E4E;
  flex: 0 0 auto;
}
.theme-dark .tee-strip__lead { color: var(--emerald-mint); }
.tee-strip__lead svg {
  width: 18px; height: 20px;
  fill: none; stroke: currentColor; stroke-width: 1.8;
  stroke-linecap: round; stroke-linejoin: round;
}
.tee-strip__copy {
  font: 400 14px/1.5 var(--sans);
  color: var(--fg);
  flex: 1 1 320px;
  margin: 0;
}
.tee-strip__copy strong { font-weight: 600; }
.tee-strip__more {
  font: 500 10.5px var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1D5E4E;
  cursor: pointer;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(14,60,53,.05);
  border: 1px solid rgba(14,60,53,.22);
  transition: background .15s, color .15s, border-color .15s;
  display: inline-flex; align-items: center; gap: 6px;
}
.tee-strip__more:hover {
  background: var(--emerald);
  color: var(--emerald-ink);
  border-color: var(--emerald);
}
.theme-dark .tee-strip__more {
  color: var(--emerald-mint);
  background: rgba(143,207,176,0.06);
  border-color: rgba(143,207,176,0.30);
}
.theme-dark .tee-strip__more:hover {
  background: var(--emerald-mint);
  color: #061812;
  border-color: var(--emerald-mint);
}
@media (max-width: 640px) {
  .tee-strip { padding: 14px 16px; gap: 12px; }
  .tee-strip__copy { font-size: 13px; }
}

/* Hero ticker */
.hero__ticker {
  margin-top: 56px;
  background: rgba(255,255,255,0.5);
  backdrop-filter: blur(6px);
  border: 1px solid var(--rule);
  border-radius: 16px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  animation: hero-rise 1.1s cubic-bezier(.2,.8,.2,1) .35s both;
}
.theme-dark .hero__ticker { background: rgba(216,230,211,0.04); }
.hero__ticker > div {
  padding: 18px 22px;
  border-left: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 4px;
}
.hero__ticker > div:first-child { border-left: 0; }
.hero__ticker .num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--fg-mute);
  text-transform: uppercase;
}
.hero__ticker .lbl {
  font-family: "Akira", "Big Shoulders Display", var(--display);
  font-size: 15px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.1;
  margin-top: 6px;
  font-weight: 800;
}
.hero__ticker .desc {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--fg-dim);
  text-transform: uppercase;
  margin-top: 2px;
}
@media (max-width: 780px) {
  .hero__ticker { grid-template-columns: repeat(2, 1fr); }
  .hero__ticker > div:nth-child(3) { border-left: 0; border-top: 1px solid var(--rule); }
  .hero__ticker > div:nth-child(4) { border-top: 1px solid var(--rule); }
}

/* ============================================================
 * SECTION + HEADER
 * ============================================================ */
.sec { padding: var(--pad-section) 0; }
.sec--divider { border-top: 1px solid var(--rule); }
.sec__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: var(--pad-block);
  align-items: end;
}
.sec__head--center {
  grid-template-columns: 1fr;
  text-align: center;
  max-width: 880px;
  margin: 0 auto var(--pad-block);
}
.sec__head--center .lede { margin: 18px auto 0; }
.sec__head--left { grid-template-columns: 1fr; }
@media (max-width: 880px) { .sec__head { grid-template-columns: 1fr; gap: 16px; } }

.sec__sig {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 14px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.sec__sig::before {
  content: "";
  width: 24px; height: 1px;
  background: var(--fg-mute);
}
.sec__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(34px, 5vw, 72px);
  letter-spacing: -0.005em;
  text-transform: uppercase;
  line-height: 0.95;
  margin: 0;
  max-width: 18ch;
}
.sec__head--center .sec__title {
  margin-left: auto; margin-right: auto;
}

/* ============================================================
 * TILES (white cards, emerald variant)
 * ============================================================ */
.tile {
  background: var(--card);
  color: var(--card-ink);
  border-radius: 20px;
  box-shadow: var(--shadow-card);
  padding: 28px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
  overflow: hidden;
  transition: transform .25s, box-shadow .25s, background .25s, color .25s;
  border: 1px solid transparent;
}
.tile:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.theme-dark .tile { border-color: var(--rule); }

.tile__label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.tile__title {
  font-family: "Big Shoulders Display", var(--display);
  font-weight: 800;
  font-size: 28px;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  margin: 0;
  line-height: 1;
  color: var(--fg);
}
.tile__body {
  font-size: 14px;
  line-height: 1.55;
  color: var(--fg-dim);
  margin: 0;
}
.tile__foot {
  margin-top: auto;
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
}
.tile__meta { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.04em; color: var(--fg-mute); }

/* Emerald variant - accent tiles */
.tile--dark {
  background: var(--emerald);
  color: var(--emerald-ink);
  background-image: linear-gradient(135deg, rgba(8,28,22,.18), rgba(8,28,22,0));
  background-size: cover;
}
.tile--dark .tile__title,
.tile--dark h2,
.tile--dark h3,
.tile--dark h4,
.tile--dark .h-card,
.tile--dark .h-tile,
.tile--dark .h-section { color: var(--emerald-mint); }
.tile--dark p,
.tile--dark .body,
.tile--dark .tile__body { color: rgba(216,230,211,0.85); }
.tile--dark .body-sm { color: rgba(216,230,211,0.65); }
.tile--dark .lede { color: rgba(216,230,211,0.85); }
.tile--dark .eyebrow,
.tile--dark .tile__label { color: rgba(216,230,211,0.72); }
.tile--dark .kicker { color: rgba(216,230,211,0.55); }
.tile--dark .mono { color: rgba(216,230,211,0.65); }
.tile--dark .tile__foot { border-top-color: rgba(216,230,211,0.16); }
.tile--dark .tile__meta { color: rgba(216,230,211,0.70); }
.tile--dark .divider,
.tile--dark hr { background: rgba(216,230,211,0.14); border: 0; }

/* ============================================================
 * GRIDS
 * ============================================================ */
.grid { display: grid; gap: var(--gap-grid); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1000px) {
  .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
}

/* ============================================================
 * PILL / TAG
 * ============================================================ */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px;
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: rgba(255,255,255,0.6);
  color: var(--fg-dim);
  border: 1px solid var(--rule);
  font-weight: 500;
}
.theme-dark .pill { background: rgba(216,230,211,0.06); }
.pill--mint {
  background: rgba(143,207,176,.14);
  color: #1D5E4E;
  border-color: rgba(143,207,176,.4);
}
.theme-dark .pill--mint { color: var(--emerald-mint); }
.pill--violet {
  background: rgba(110,91,224,.10);
  color: #4A3CB8;
  border-color: rgba(110,91,224,.4);
}
.theme-dark .pill--violet { color: #B6A8F2; }
.pill--amber {
  background: rgba(245,158,11,.10);
  color: #92400E;
  border-color: rgba(245,158,11,.4);
}
.theme-dark .pill--amber { color: #F5C97A; }
.pill__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 6px currentColor;
}

/* ============================================================
 * SCHEMATIC FRAME - terminal-style chrome (used for envelope stack, composer, OCP flow)
 * ============================================================ */
.schema {
  border: 1px solid var(--rule);
  border-radius: 22px;
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  position: relative;
}
.theme-dark .schema { background: rgba(216,230,211,0.04); }
.schema__bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 22px;
  border-bottom: 1px solid var(--rule);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--fg-mute);
  text-transform: uppercase;
  font-weight: 500;
}
.schema__bar-left { display: flex; align-items: center; gap: 14px; }
.schema__lights { display: flex; gap: 6px; }
.schema__lights span {
  width: 9px; height: 9px;
  border-radius: 50%;
  background: rgba(17,19,24,0.18);
}
.theme-dark .schema__lights span { background: rgba(216,230,211,0.2); }
.schema__lights span:first-child { background: #8FCFB0; box-shadow: 0 0 6px rgba(143,207,176,.7); }
.schema__lights span:nth-child(2) { background: #C6B8EA; }
.schema__lights span:nth-child(3) { background: #F0D6C2; }

/* ============================================================
 * 13 ENVELOPE STACK
 * ============================================================ */
.stack-wrap {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  min-height: 560px;
}
@media (max-width: 980px) { .stack-wrap { grid-template-columns: 1fr; } }

.stack-3d {
  position: relative;
  padding: 60px 40px;
  display: flex; align-items: center; justify-content: center;
  border-right: 1px solid var(--rule);
  background:
    radial-gradient(60% 80% at 50% 100%, rgba(14,60,53,.10), transparent 70%),
    linear-gradient(180deg, rgba(217,239,227,0.35), rgba(227,217,238,0.2));
}
.theme-dark .stack-3d {
  background:
    linear-gradient(180deg, rgba(6,24,18,0.45) 0%, rgba(14,60,53,.30) 100%);
  background-size: cover;
}
@media (max-width: 980px) {
  .stack-3d { border-right: 0; border-bottom: 1px solid var(--rule); }
}

.stack-scene {
  width: 100%;
  max-width: 480px;
  aspect-ratio: 1.6 / 1;
  perspective: 1400px;
  perspective-origin: 50% 30%;
  position: relative;
}
.stack-scene__inner {
  width: 100%; height: 100%;
  transform-style: preserve-3d;
  transform: rotateX(58deg) rotateZ(-12deg);
  position: relative;
}
.env {
  position: absolute;
  left: 12%; right: 12%;
  top: 50%;
  height: 36%;
  border: 1px solid rgba(29,94,78,0.45);
  background: linear-gradient(180deg, rgba(143,207,176,.10), rgba(143,207,176,.28));
  border-radius: 6px;
  transform-style: preserve-3d;
  backdrop-filter: blur(2px);
}
.env::before {
  content: "";
  position: absolute;
  top: 4px; left: 12px; right: 12px;
  height: 1px;
  background: linear-gradient(90deg, transparent, #1D5E4E 30%, #8FCFB0 70%, transparent);
  opacity: 0.7;
}
.env--v {
  border-color: rgba(110,91,224,.5);
  background: linear-gradient(180deg, rgba(110,91,224,.10), rgba(110,91,224,.24));
}
.env--v::before { background: linear-gradient(90deg, transparent, var(--violet) 30%, #B6A8F2 70%, transparent); }
.env--a {
  border-color: rgba(214,138,40,.45);
  background: linear-gradient(180deg, rgba(245,201,122,.10), rgba(245,201,122,.26));
}
.env--a::before { background: linear-gradient(90deg, transparent, #D68A28 30%, #F5C97A 70%, transparent); }

.theme-dark .env {
  border-color: rgba(143,207,176,0.4);
  background: linear-gradient(180deg, rgba(143,207,176,.06), rgba(143,207,176,.18));
}
.theme-dark .env--v { border-color: rgba(182,168,242,.4); background: linear-gradient(180deg, rgba(110,91,224,.06), rgba(110,91,224,.18)); }
.theme-dark .env--a { border-color: rgba(245,201,122,.4); background: linear-gradient(180deg, rgba(245,201,122,.06), rgba(245,201,122,.18)); }

.stack-legend {
  padding: 36px 40px;
  display: flex; flex-direction: column; gap: 18px;
  background: rgba(255,255,255,0.4);
}
.theme-dark .stack-legend { background: rgba(216,230,211,0.04); }
.stack-legend__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: 26px;
  text-transform: uppercase;
  line-height: 1.05;
  margin: 0;
  max-width: 18ch;
}
.stack-legend__rows {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--rule);
  margin-top: 4px;
}
.stack-legend__row {
  display: grid;
  grid-template-columns: 32px 110px 1fr 14px;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule);
  align-items: center;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--fg-dim);
}
.stack-legend__row .num { color: var(--fg-mute); font-size: 10.5px; letter-spacing: 0.16em; }
.stack-legend__row .name {
  font-family: "Big Shoulders Display", var(--display);
  font-weight: 800;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--fg);
}
.stack-legend__row .desc {
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--fg-dim);
  letter-spacing: 0;
}
.stack-legend__row .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #1D5E4E;
  box-shadow: 0 0 6px rgba(29,94,78,.5);
  justify-self: end;
}
.stack-legend__row .dot--v { background: var(--violet); box-shadow: 0 0 6px rgba(110,91,224,.5); }
.stack-legend__row .dot--a { background: #D68A28; box-shadow: 0 0 6px rgba(214,138,40,.5); }

/* ============================================================
 * SPEC ROWS (used in feature cards)
 * ============================================================ */
.spec-rows { display: flex; flex-direction: column; }
.spec-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.spec-row:last-child { border-bottom: 0; }
.spec-row .k {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.spec-row .v {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
  color: var(--fg);
}
.tile--dark .spec-row { border-bottom-color: rgba(216,230,211,0.14); }
.tile--dark .spec-row .k { color: rgba(216,230,211,0.55); }
.tile--dark .spec-row .v { color: rgba(216,230,211,0.92); }

/* ============================================================
 * BUILD / BRING / HIRE / BACK rail
 * ============================================================ */
.bbhb {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap-grid);
}
@media (max-width: 980px) { .bbhb { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .bbhb { grid-template-columns: 1fr; } }
.bbhb__cell {
  background: var(--card);
  border-radius: 22px;
  box-shadow: var(--shadow-card);
  padding: 26px 26px 22px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
  min-height: 380px;
  transition: transform .25s, box-shadow .25s;
  border: 1px solid transparent;
}
.theme-dark .bbhb__cell { border-color: var(--rule); }
.bbhb__cell:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }
.bbhb__num {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  color: var(--fg-mute);
  text-transform: uppercase;
}
.bbhb__viz {
  height: 92px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 6px 0 8px;
}
.bbhb__viz svg { width: auto; height: 100%; max-width: 100%; }
.bbhb__verb {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(40px, 4.5vw, 64px);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 0.9;
  color: var(--fg);
  margin: 0;
}
.bbhb__lede {
  font-family: var(--display);
  font-weight: 800;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--fg);
  margin: 4px 0 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0 6px;
}
.bbhb__arrow {
  background: var(--glow-grad);
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: glow-shift 10s ease-in-out infinite;
  font-weight: 700;
  display: inline-block;
  transform: translateY(1px);
}
.bbhb__copy {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--fg-dim);
  margin: 0;
}
.bbhb__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid var(--rule-strong, var(--rule));
  background: rgba(255,255,255,0.65);
  color: var(--fg);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.bbhb__cta:hover {
  background: #1D5E4E;
  border-color: #1D5E4E;
  color: #FAFAF7;
  transform: translateY(-1px);
  box-shadow: 0 10px 24px -10px rgba(29,94,78,.55);
}
.bbhb__cta-arrow {
  font-family: var(--display);
  font-weight: 700;
  font-size: 14px;
  line-height: 1;
  transition: transform .2s ease;
}
.bbhb__cta:hover .bbhb__cta-arrow { transform: translateX(3px); }
.theme-dark .bbhb__cta { background: rgba(216,230,211,0.06); }
.theme-dark .bbhb__cta:hover { background: #8FCFB0; border-color: #8FCFB0; color: #0E3F33; }

/* ---------- bbhb tile SVG hover animations ---------- */
/* All animations replay on rollover; defaults are preserved when idle. */
.bbhb__viz svg { overflow: visible; }
.bbhb__viz svg .b-org-face,
.bbhb__viz svg .b-slot polygon,
.bbhb__viz svg .bn-dest polygon,
.bbhb__viz svg .bn-agent circle,
.bbhb__viz svg .h-stamp,
.bbhb__viz svg .h-usdc,
.bbhb__viz svg .bk-dot,
.bbhb__viz svg .bk-token {
  transform-box: fill-box;
  transform-origin: center;
}

/* BUILD - dashed slot prisms fill in with staggered colour; org bobs */
.bbhb__cell--build:hover .b-slot-1 polygon:nth-child(1) { animation: b-fill-1 .9s ease both .05s; }
.bbhb__cell--build:hover .b-slot-1 polygon:nth-child(2) { animation: b-fill-2 .9s ease both .12s; }
.bbhb__cell--build:hover .b-slot-1 polygon:nth-child(3) { animation: b-fill-3 .9s ease both .19s; }
.bbhb__cell--build:hover .b-slot-2 polygon:nth-child(1) { animation: b-fill-1 .9s ease both .30s; }
.bbhb__cell--build:hover .b-slot-2 polygon:nth-child(2) { animation: b-fill-2 .9s ease both .37s; }
.bbhb__cell--build:hover .b-slot-2 polygon:nth-child(3) { animation: b-fill-3 .9s ease both .44s; }
.bbhb__cell--build:hover .b-slot { animation: b-slot-opacity .9s ease both; }
@keyframes b-slot-opacity { from { opacity: 0.5; } to { opacity: 1; } }
@keyframes b-fill-1 { from { fill: none; } to { fill: #1D5E4E; } }
@keyframes b-fill-2 { from { fill: none; } to { fill: #0E3F33; } }
@keyframes b-fill-3 { from { fill: none; } to { fill: #163F35; } }
.bbhb__cell--build:hover .b-org-face { animation: b-org-bob 1.6s ease-in-out infinite; }
@keyframes b-org-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-1.5px); }
}

/* BRING - flow dashes stream toward the destination org; agents glow; dest pulses */
.bbhb__cell--bring:hover .bn-flow { animation: bn-flow-dash 1s linear infinite; }
@keyframes bn-flow-dash { to { stroke-dashoffset: -14; } }
.bbhb__cell--bring:hover .bn-agent-1 circle:nth-of-type(2) { animation: bn-glow 1.6s ease-in-out infinite; }
.bbhb__cell--bring:hover .bn-agent-2 circle:nth-of-type(2) { animation: bn-glow 1.6s ease-in-out infinite .25s; }
@keyframes bn-glow {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.25); }
}
.bbhb__cell--bring:hover .bn-dest polygon { animation: bn-dest-pulse 1.6s ease-in-out infinite; }
@keyframes bn-dest-pulse {
  0%, 60%, 100% { transform: scale(1); }
  75%           { transform: scale(1.07); }
  88%           { transform: scale(1); }
}

/* HIRE - receipt lifts, check stamp lands, USDC pulses, lines draw in */
.bbhb__cell--hire:hover .h-receipt { animation: h-lift 1.8s ease-in-out infinite; }
@keyframes h-lift {
  0%, 100% { translate: 0 0; }
  50%      { translate: 0 -2px; }
}
.bbhb__cell--hire:hover .h-stamp { animation: h-stamp 1.4s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes h-stamp {
  0%   { transform: scale(0) rotate(-25deg); opacity: 0; }
  35%  { transform: scale(1.35) rotate(10deg); opacity: 1; }
  55%  { transform: scale(1) rotate(0deg); opacity: 1; }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}
.h-line { stroke-dasharray: 80; }
.bbhb__cell--hire:hover .h-line-1 { animation: h-line-draw .55s ease both .35s; }
.bbhb__cell--hire:hover .h-line-2 { animation: h-line-draw .55s ease both .48s; }
@keyframes h-line-draw {
  from { stroke-dashoffset: 80; }
  to   { stroke-dashoffset: 0; }
}
.bbhb__cell--hire:hover .h-usdc { animation: h-usdc-pulse 1.4s ease-in-out infinite .6s; }
@keyframes h-usdc-pulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.08); }
}

/* BACK - chart draws on, dots pop in sequence, token lands */
.bk-line { stroke-dasharray: 100; }
.bbhb__cell--back:hover .bk-line { animation: bk-draw 1s ease both; }
@keyframes bk-draw {
  from { stroke-dashoffset: 100; }
  to   { stroke-dashoffset: 0; }
}
.bbhb__cell--back:hover .bk-dot-1 { animation: bk-pop .4s cubic-bezier(.34,1.56,.64,1) both .12s; }
.bbhb__cell--back:hover .bk-dot-2 { animation: bk-pop .4s cubic-bezier(.34,1.56,.64,1) both .26s; }
.bbhb__cell--back:hover .bk-dot-3 { animation: bk-pop .4s cubic-bezier(.34,1.56,.64,1) both .40s; }
.bbhb__cell--back:hover .bk-dot-4 { animation: bk-pop-accent .5s cubic-bezier(.34,1.56,.64,1) both .54s; }
.bbhb__cell--back:hover .bk-dot-5 { animation: bk-pop .4s cubic-bezier(.34,1.56,.64,1) both .70s; }
@keyframes bk-pop {
  0%   { transform: scale(0); }
  60%  { transform: scale(1.6); }
  100% { transform: scale(1); }
}
@keyframes bk-pop-accent {
  0%   { transform: scale(0); }
  60%  { transform: scale(1.9); }
  100% { transform: scale(1); }
}
.bbhb__cell--back:hover .bk-token { animation: bk-token-land .9s cubic-bezier(.34,1.56,.64,1) both .85s; }
@keyframes bk-token-land {
  0%   { translate: 0 -8px; opacity: 0; }
  60%  { translate: 0 2px;  opacity: 1; }
  80%  { translate: 0 -1px; opacity: 1; }
  100% { translate: 0 0;    opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .bbhb__cell *, .bbhb__cell *::before, .bbhb__cell *::after {
    animation: none !important;
    transition: none !important;
  }
}

/* ============================================================
 * ORG LIST (marketplace rows)
 * ============================================================ */
.org-list {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--rule);
  border-radius: 20px;
  overflow: hidden;
  background: rgba(255,255,255,0.5);
  backdrop-filter: blur(12px);
}
.theme-dark .org-list { background: rgba(216,230,211,0.04); }
.org-row {
  display: grid;
  grid-template-columns: 60px 1fr 130px 130px 110px 80px;
  gap: 18px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--rule);
  align-items: center;
  font-size: 14px;
  color: var(--fg-dim);
  transition: background .15s;
}
.org-row:last-child { border-bottom: 0; }
.org-row:hover { background: rgba(255,255,255,0.7); }
.theme-dark .org-row:hover { background: rgba(216,230,211,0.08); }
.org-row.org-row--head {
  background: rgba(255,255,255,0.6);
  color: var(--fg-mute);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.theme-dark .org-row.org-row--head { background: rgba(216,230,211,0.06); }
.org-row__num {
  color: var(--fg-mute);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
}
.org-row__name {
  font-family: "Big Shoulders Display", var(--display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  line-height: 1;
  color: var(--fg);
}
.org-row__desc {
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--fg-dim);
  line-height: 1.4;
  margin-top: 4px;
}
.org-row__price {
  font-family: var(--mono);
  font-size: 12.5px;
  color: #1D5E4E;
  letter-spacing: 0.02em;
}
.theme-dark .org-row__price { color: var(--emerald-mint); }
.org-row__score {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--fg);
  letter-spacing: 0.02em;
  font-weight: 500;
}
@media (max-width: 980px) {
  .org-row, .org-row--head { grid-template-columns: 1fr; gap: 6px; padding: 14px 18px; }
  .org-row--head { display: none; }
}

/* ============================================================
 * BAND (large emerald or white wrapper)
 * ============================================================ */
.band {
  border-radius: 24px;
  padding: clamp(36px, 5vw, 64px);
  background: rgba(255,255,255,0.5);
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-card);
}
.theme-dark .band { background: rgba(216,230,211,0.04); }
.band--emerald {
  background: var(--emerald);
  color: var(--emerald-ink);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background-image: linear-gradient(135deg, rgba(8,28,22,.18), rgba(8,28,22,0));
  background-size: cover;
  border-color: rgba(216,230,211,0.16);
  box-shadow: var(--shadow-feature);
}
.band--emerald .sec__sig { color: rgba(216,230,211,0.65); }
.band--emerald .sec__sig::before { background: rgba(216,230,211,0.65); }
.band--emerald h2,
.band--emerald h3,
.band--emerald .sec__title,
.band--emerald .h-section,
.band--emerald .h-display { color: var(--emerald-ink); }
.band--emerald .sec__title em.glow,
.band--emerald .glow { /* gradient already overrides - leave alone */ }
.band--emerald .lede,
.band--emerald p { color: rgba(216,230,211,0.85); }
.band--emerald .eyebrow { color: rgba(216,230,211,0.70); }
.band--emerald .tile { background: rgba(216,230,211,0.06); color: var(--emerald-ink); border-color: rgba(216,230,211,0.16); }
.band--emerald .tile h2,
.band--emerald .tile h3,
.band--emerald .tile h4,
.band--emerald .tile .h-tile,
.band--emerald .tile .h-card,
.band--emerald .tile .tile__title { color: var(--emerald-mint); }
.band--emerald .tile p,
.band--emerald .tile .body,
.band--emerald .tile .tile__body { color: rgba(216,230,211,0.85); }
.band--emerald .tile .eyebrow,
.band--emerald .tile .tile__label { color: rgba(216,230,211,0.65); }
.band--emerald .tile__foot { border-top-color: rgba(216,230,211,0.16); }
.band__ghost {
  position: absolute;
  top: 6%;
  right: -16px;
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(180px, 22vw, 320px);
  line-height: 0.8;
  letter-spacing: -0.04em;
  color: var(--emerald-mint);
  opacity: 0.08;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.band--emerald > *:not(.band__ghost) { position: relative; z-index: 1; }
.band--emerald .btn--pill {
  background: var(--emerald-mint);
  color: #061812;
  border: 0;
}
.band--emerald .btn--pill:hover {
  background: #B8E8CB;
  transform: translateY(-1px);
}

/* ============================================================
 * REVEAL on scroll
 * ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1);
}
.reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.is-in { opacity: 1; transform: none; transition: none; }
  .hero__title, .hero__sub-row, .hero__ticker { animation: none; }
}

/* ============================================================
 * SITE FOOTER
 * ============================================================ */
.site-foot {
  padding: 64px 0 32px;
  margin-top: var(--pad-section);
  border-top: 1px solid var(--rule);
}
.site-foot__inner {
  display: grid;
  grid-template-columns: 1.5fr repeat(3, 1fr);
  gap: 40px;
  margin-bottom: 40px;
}
@media (max-width: 900px) { .site-foot__inner { grid-template-columns: 1fr 1fr; } }
.site-foot h6 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin: 0 0 14px;
  font-weight: 500;
}
.site-foot ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.site-foot a { font-size: 13.5px; color: var(--fg-dim); transition: color .15s; }
.site-foot a:hover { color: var(--fg); }
.site-foot__brand .brand { font-size: 32px; }
.site-foot__brand p { margin-top: 14px; color: var(--fg-dim); font-size: 14px; max-width: 32ch; line-height: 1.55; }
.site-foot__sig { margin-top: 14px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; color: var(--fg-mute); text-transform: uppercase; }
.site-foot__rule {
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 11.5px;
  color: var(--fg-mute);
  letter-spacing: 0.04em;
}

/* ============================================================
 * TWEAKS PANEL
 * ============================================================ */
.tweaks {
  position: fixed;
  right: 18px; bottom: 18px;
  width: 280px;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(20px);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: 16px;
  z-index: 100;
  display: none;
  box-shadow: 0 20px 60px -20px rgba(17,19,24,0.25);
  color: var(--fg);
  font-family: var(--sans);
}
.theme-dark .tweaks { background: rgba(6,24,18,0.96); border-color: var(--rule); }
.tweaks.is-open { display: block; }
.tweaks__head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 12px;
}
.tweaks__title { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.tweaks__close { font-family: var(--mono); font-weight: 600; font-size: 14px; padding: 4px 8px; border-radius: 6px; }
.tweaks__close:hover { background: rgba(17,19,24,0.06); }
.theme-dark .tweaks__close:hover { background: rgba(216,230,211,0.1); }
.tweak {
  display: flex; flex-direction: column; gap: 8px;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule);
}
.tweak:last-child { border-bottom: 0; }
.tweak__label { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-mute); }
.tweak__opts { display: flex; gap: 4px; }
.tweak__opt {
  flex: 1;
  padding: 7px 8px;
  border-radius: 8px;
  background: rgba(17,19,24,0.04);
  border: 1px solid var(--rule);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fg-dim);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.theme-dark .tweak__opt { background: rgba(216,230,211,0.06); color: var(--fg-dim); }
.tweak__opt:hover { background: rgba(143,207,176,0.18); color: var(--fg); }
.tweak__opt.is-active {
  background: var(--fg);
  color: var(--bg-page);
  border-color: var(--fg);
}
.theme-dark .tweak__opt.is-active {
  background: var(--emerald-mint);
  color: #061812;
  border-color: var(--emerald-mint);
}

/* ============================================================
 * ONCHAIN HERO CARDS - 4 SVG diagrams in 2×2 grid
 * ============================================================ */
.onchain-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap-grid);
}
@media (max-width: 1100px) { .onchain-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .onchain-grid { grid-template-columns: 1fr; } }

.onchain-card--hero {
  padding: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow: hidden;
}
.onchain-card__hero {
  background: #FAFAF7;
  border-bottom: 1px solid var(--rule);
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 520 / 360;
  overflow: hidden;
  position: relative;
}
.theme-dark .onchain-card__hero { background: rgba(216,230,211,0.04); }
.onchain-card__hero .hero-svg { width: 100%; height: 100%; display: block; }

.onchain-card__foot {
  padding: 18px 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.onchain-card__head { display: flex; align-items: center; }
.onchain-card__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(20px, 1.7vw, 24px);
  line-height: 1.0;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--fg);
  margin: 0;
}
.onchain-card__body {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--fg-dim);
  margin: 0;
}

/* shared animation reset */
.hero-svg [class*="hero-"],
.hero-svg .pie-slice,
.hero-svg .prim-block {
  transition: transform .7s cubic-bezier(.2,.8,.2,1), opacity .5s ease;
}

/* IDENTITY - meridians sweep, badges bob, patch slides */
.hero-svg--identity .hero-meridian { transform-box: fill-box; }
.onchain-card--hero:hover .hero-svg--identity .hero-meridian {
  animation: hero-meridian 6s linear infinite;
  animation-delay: var(--phase, 0s);
}
@keyframes hero-meridian {
  0%   { rx: 110; }
  25%  { rx: 0; }
  50%  { rx: 110; }
  75%  { rx: 0; }
  100% { rx: 110; }
}
.hero-svg--identity .hero-meridian-patch { transform-box: fill-box; transform-origin: 260px 180px; }
.onchain-card--hero:hover .hero-svg--identity .hero-meridian-patch {
  animation: hero-patch-sweep 6s linear infinite;
}
@keyframes hero-patch-sweep {
  0%   { transform: translateX(-20px) scaleX(1); opacity: 0.10; }
  50%  { transform: translateX(0)     scaleX(0.4); opacity: 0.25; }
  100% { transform: translateX(20px)  scaleX(1); opacity: 0.10; }
}
.hero-svg--identity .hero-bob { transform-box: fill-box; }
.onchain-card--hero:hover .hero-svg--identity .hero-bob {
  animation: hero-bob 3.6s ease-in-out infinite;
}
@keyframes hero-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* OWNERSHIP - slices explode outward */
.hero-svg--ownership .pie-slice {
  transition: transform .55s cubic-bezier(.2,.8,.2,1);
  transform: translate(0,0);
}
.onchain-card--hero:hover .hero-svg--ownership .pie-slice {
  transform: translate(var(--dx), var(--dy));
  transition-delay: var(--delay);
}

/* COMPOSE - wire draws, scroll pulses, doc travels */
.hero-svg--compose .hero-wire {
  stroke-dasharray: 100;
  stroke-dashoffset: 0;
}
.onchain-card--hero:hover .hero-svg--compose .hero-wire {
  animation: hero-draw 2s ease-in-out infinite;
}
@keyframes hero-draw {
  0% { stroke-dashoffset: 100; }
  60%, 100% { stroke-dashoffset: 0; }
}
.hero-svg--compose .hero-scroll__inner {
  transform-origin: 39px 17px;
  transform-box: fill-box;
}
.onchain-card--hero:hover .hero-svg--compose .hero-scroll__inner {
  animation: hero-pulse 2.4s ease-in-out infinite;
}
@keyframes hero-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}
.hero-svg--compose .hero-doc { opacity: 0; }
.onchain-card--hero:hover .hero-svg--compose .hero-doc {
  opacity: 1;
  animation: hero-doc-fly 3s linear infinite;
}
@keyframes hero-doc-fly {
  0%   { transform: translate(130px, 230px); }
  33%  { transform: translate(260px, 115px); }
  66%  { transform: translate(390px, 230px); }
  100% { transform: translate(130px, 230px); }
}

/* PRIMITIVES - three blocks stack on hover, connectors fade */
.hero-svg--primitives .prim-block {
  transition: transform .7s cubic-bezier(.2,.8,.2,1);
  transform: translateY(0);
}
.onchain-card--hero:hover .hero-svg--primitives .prim-block {
  transform: translateY(var(--stack-dy));
  transition-delay: var(--delay);
}
.hero-svg--primitives .prim-connectors,
.hero-svg--primitives .prim-pluses {
  transition: opacity .35s ease;
  opacity: 1;
}
.onchain-card--hero:hover .hero-svg--primitives .prim-connectors,
.onchain-card--hero:hover .hero-svg--primitives .prim-pluses {
  opacity: 0;
}

/* TRUSTED - scan sweeps shield, pulse rings expand, seals tick in */
.hero-svg--trusted .tee-scan {
  transform: translateY(0);
}
.onchain-card--hero:hover .hero-svg--trusted .tee-scan {
  animation: tee-scan 2.8s cubic-bezier(.4,0,.6,1) infinite;
}
@keyframes tee-scan {
  0%   { transform: translateY(0);   opacity: 0; }
  10%  { opacity: 0.55; }
  90%  { opacity: 0.55; }
  100% { transform: translateY(260px); opacity: 0; }
}
.hero-svg--trusted .tee-rings circle { transform-box: fill-box; transform-origin: center; }
.onchain-card--hero:hover .hero-svg--trusted .tee-rings circle {
  animation: tee-ring-pulse 3.2s ease-out infinite;
}
.onchain-card--hero:hover .hero-svg--trusted .tee-rings circle:nth-child(2) { animation-delay: -1s; }
.onchain-card--hero:hover .hero-svg--trusted .tee-rings circle:nth-child(3) { animation-delay: -2s; }
@keyframes tee-ring-pulse {
  0%   { transform: scale(0.92); opacity: 0; }
  20%  { opacity: 1; }
  100% { transform: scale(1.08); opacity: 0; }
}
.hero-svg--trusted .tee-seals > g {
  transition: opacity .4s ease;
  opacity: 0.7;
}
.hero-svg--trusted .tee-seal__inner {
  transform-box: fill-box;
  transform-origin: 0 0;
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
}
.onchain-card--hero:hover .hero-svg--trusted .tee-seals > g {
  opacity: 1;
}
.onchain-card--hero:hover .hero-svg--trusted .tee-seal__inner {
  transform: scale(1.12);
}
.onchain-card--hero:hover .hero-svg--trusted .tee-seals > g:nth-child(1) { transition-delay: 0ms; }
.onchain-card--hero:hover .hero-svg--trusted .tee-seals > g:nth-child(2) { transition-delay: 80ms; }
.onchain-card--hero:hover .hero-svg--trusted .tee-seals > g:nth-child(3) { transition-delay: 160ms; }
.onchain-card--hero:hover .hero-svg--trusted .tee-seals > g:nth-child(4) { transition-delay: 240ms; }

@media (prefers-reduced-motion: reduce) {
  .onchain-card--hero:hover .hero-svg [class*="hero-"],
  .onchain-card--hero:hover .hero-svg .pie-slice,
  .onchain-card--hero:hover .hero-svg .prim-block,
  .onchain-card--hero:hover .hero-svg--trusted .tee-scan,
  .onchain-card--hero:hover .hero-svg--trusted .tee-rings circle {
    animation: none !important;
    transform: none !important;
  }
}

/* ============================================================
 * SEA BAND - sovereign employee agent section
 * ============================================================ */
.sea-band {
  border-radius: 24px;
  padding: clamp(36px, 5vw, 56px);
  background: var(--emerald);
  color: var(--emerald-ink);
  background-image: linear-gradient(135deg, rgba(8,28,22,.18), rgba(8,28,22,0));
  background-size: cover;
  border: 1px solid rgba(216,230,211,0.16);
  box-shadow: var(--shadow-feature);
  display: flex; flex-direction: column;
  gap: clamp(24px, 3vw, 36px);
}
.sea-band__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
}
@media (max-width: 900px) { .sea-band__head { grid-template-columns: 1fr; gap: 16px; } }
.sea-band__lbl {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(216,230,211,0.65);
}
.sea-band__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(34px, 5vw, 64px);
  text-transform: uppercase;
  line-height: 0.96;
  letter-spacing: -0.005em;
  margin: 14px 0 0;
  max-width: 18ch;
  color: var(--emerald-ink);
}
.sea-band__title em {
  font-style: normal;
  background: linear-gradient(90deg, var(--emerald-mint) 0%, #B6A8F2 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.sea-band__lede {
  font-size: 16px;
  line-height: 1.55;
  color: rgba(216,230,211,0.82);
  max-width: 54ch;
  margin: 36px 0 0;
}
.sea-band__lede strong { color: var(--emerald-mint); font-weight: 600; }

/* TEE strip inside the emerald SEA band */
.sea-band .tee-strip {
  background: rgba(143,207,176,0.10);
  border-color: rgba(143,207,176,0.30);
}
.sea-band .tee-strip__lead { color: var(--emerald-mint); }
.sea-band .tee-strip__copy { color: var(--emerald-ink); }
.sea-band .tee-strip__copy strong { color: #fff; font-weight: 600; }

.sea-expansion {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 900px) { .sea-expansion { grid-template-columns: 1fr; } }
.sea-expansion__cell {
  position: relative;
  padding: 26px 26px 24px;
  background: rgba(216,230,211,0.06);
  border: 1px solid rgba(216,230,211,0.16);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow: hidden;
  isolation: isolate;
}
.sea-expansion__ghost {
  position: absolute;
  right: -18px;
  bottom: -48px;
  font-family: var(--display);
  font-weight: 800;
  font-size: 220px;
  line-height: 0.8;
  letter-spacing: -0.04em;
  color: var(--emerald-mint);
  opacity: 0.07;
  pointer-events: none;
  z-index: 0;
}
.sea-expansion__idx {
  position: relative;
  z-index: 1;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(216,230,211,0.55);
}
.sea-expansion__word {
  position: relative;
  z-index: 1;
  font-family: "Big Shoulders Display", var(--display);
  font-weight: 800;
  font-size: clamp(34px, 3.6vw, 46px);
  line-height: 0.95;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--emerald-ink);
  margin-top: 2px;
}
.sea-expansion__desc {
  position: relative;
  z-index: 1;
  font-size: 13.5px;
  line-height: 1.5;
  color: rgba(216,230,211,0.78);
  margin: 10px 0 0;
  max-width: 32ch;
}

.sea-caps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
@media (max-width: 980px) { .sea-caps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .sea-caps { grid-template-columns: 1fr; } }
.sea-cap {
  padding: 18px 20px;
  background: rgba(216,230,211,0.04);
  border: 1px solid rgba(216,230,211,0.14);
  border-radius: 14px;
  display: flex; flex-direction: column;
  gap: 6px;
}
.sea-cap__num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(216,230,211,0.55);
}
.sea-cap__title {
  font-family: "Big Shoulders Display", var(--display);
  font-weight: 800;
  font-size: 17px;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  color: var(--emerald-mint);
  margin: 4px 0 0;
}
.sea-cap__desc {
  font-size: 12.5px;
  line-height: 1.45;
  color: rgba(216,230,211,0.72);
  margin: 0;
}

.sea-vs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 700px) { .sea-vs { grid-template-columns: 1fr; } }
.sea-vs__cell {
  padding: 22px 24px;
  background: rgba(216,230,211,0.04);
  border: 1px solid rgba(216,230,211,0.14);
  border-radius: 16px;
}
.sea-vs__cell h6 {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(216,230,211,0.55);
  margin: 0 0 10px;
  font-weight: 500;
}
.sea-vs__cell p {
  font-size: 13.5px;
  line-height: 1.55;
  color: rgba(216,230,211,0.75);
  margin: 0;
}
.sea-vs__cell--us {
  background: rgba(143,207,176,0.10);
  border-color: rgba(143,207,176,0.32);
}
.sea-vs__cell--us h6 { color: var(--emerald-mint); }
.sea-vs__cell--us p { color: rgba(216,230,211,0.90); }

.sea-band__sig {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(216,230,211,0.55);
  text-align: center;
}

/* ============================================================
 * THREE SCENARIOS
 * ============================================================ */
.scenarios {
  display: grid;
  grid-template-columns: 1fr 1.15fr 1fr;
  gap: var(--gap-grid);
}
@media (max-width: 980px) { .scenarios { grid-template-columns: 1fr; } }
.scen {
  background: var(--card);
  border: 1px solid transparent;
  border-radius: 22px;
  padding: 26px;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column; gap: 12px;
  transition: transform .25s, box-shadow .25s;
  cursor: pointer;
}
.theme-dark .scen { border-color: var(--rule); }
.scen:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.scen__lede {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.scen__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(24px, 2.6vw, 30px);
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  margin: 6px 0 4px;
  max-width: 14ch;
  color: var(--fg);
}
.scen__copy {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--fg);
  margin: 0;
}
.scen__copy strong { color: var(--fg); font-weight: 600; }
.scen__example {
  margin-top: auto;
  padding: 14px 16px;
  background: rgba(255,255,255,0.5);
  border: 1px solid var(--rule);
  border-radius: 12px;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--fg-dim);
}
.theme-dark .scen__example { background: rgba(216,230,211,0.04); }
.scen__example span {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 6px;
}
.scen__example b { color: var(--fg); font-weight: 600; }
.scen__cta {
  margin-top: 4px;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid var(--rule-strong, var(--rule));
  background: rgba(255,255,255,0.7);
  color: var(--fg);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease, color .2s ease;
}
.scen__cta:hover {
  background: #1D5E4E;
  border-color: #1D5E4E;
  color: #FAFAF7;
  transform: translateY(-1px);
  box-shadow: 0 10px 24px -10px rgba(29,94,78,.55);
}
.scen__cta .arrow {
  font-family: var(--display);
  font-weight: 700;
  font-size: 14px;
  line-height: 1;
  transition: transform .2s ease;
}
.scen__cta:hover .arrow { transform: translateX(3px); }
.theme-dark .scen__cta { background: rgba(216,230,211,0.06); border-color: rgba(216,230,211,0.18); }
.theme-dark .scen__cta:hover { background: #8FCFB0; border-color: #8FCFB0; color: #0E3F33; }
.scen--ceo {
  background: var(--card);
  border-color: var(--rule);
  color: var(--fg);
}
.scen--ceo .scen__lede { color: var(--fg-mute); }
.scen--ceo .scen__title { color: var(--fg); }
.scen--ceo .scen__copy { color: var(--fg); }
.scen--ceo .scen__copy strong { color: var(--fg); }
.scen--ceo .scen__example { background: rgba(17,19,24,0.04); border-color: var(--rule); color: var(--fg); }
.scen--ceo .scen__example span { color: var(--fg-mute); }
.scen--ceo .scen__example b { color: var(--fg); }

/* ---------- scenario SVG vizes ---------- */
.scen__viz {
  margin: 4px -6px 8px;
  padding: 10px 12px 6px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(217,239,227,0.30) 0%, rgba(233,232,242,0.22) 100%);
  border: 1px solid var(--rule);
  overflow: hidden;
}
.theme-dark .scen__viz {
  background: linear-gradient(180deg, rgba(143,207,176,0.06) 0%, rgba(110,91,224,0.05) 100%);
  border-color: rgba(216,230,211,0.16);
}
.scen__viz svg { display: block; width: 100%; height: auto; overflow: visible; }
.scen__viz svg .sv1-org-face,
.scen__viz svg .sv1-role,
.scen__viz svg .sv2-ceo,
.scen__viz svg .sv2-ceo-dot,
.scen__viz svg .sv2-worker,
.scen__viz svg .sv3-agent,
.scen__viz svg .sv3-slot,
.scen__viz svg .sv3-staff {
  transform-box: fill-box;
  transform-origin: center;
}

/* SCEN-1 build: idea bubble pulses, flow streams, roles pop, org bobs */
.sv1-flow { stroke-dasharray: 3 4; }
.scen--build:hover .sv1-flow { animation: sv1-flow-dash 1s linear infinite; }
@keyframes sv1-flow-dash { to { stroke-dashoffset: -14; } }
.scen--build:hover .sv1-idea { animation: sv1-idea-pulse 1.8s ease-in-out infinite; }
@keyframes sv1-idea-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.65; }
}
.scen--build:hover .sv1-org-face { animation: sv1-org-bob 1.6s ease-in-out infinite; }
@keyframes sv1-org-bob {
  0%, 100% { translate: 0 0; }
  50%      { translate: 0 -1.5px; }
}
.scen--build:hover .sv1-role-1 { animation: sv1-pop .45s cubic-bezier(.34,1.56,.64,1) both .15s; }
.scen--build:hover .sv1-role-2 { animation: sv1-pop .45s cubic-bezier(.34,1.56,.64,1) both .32s; }
.scen--build:hover .sv1-role-3 { animation: sv1-pop .45s cubic-bezier(.34,1.56,.64,1) both .49s; }
@keyframes sv1-pop {
  0%   { scale: 0.85; opacity: 0.4; }
  60%  { scale: 1.08; opacity: 1; }
  100% { scale: 1; opacity: 1; }
}
.sv1-wires path { stroke-dasharray: 50; stroke-dashoffset: 0; }
.scen--build:hover .sv1-wires path { animation: sv1-wire-draw .9s ease both; }
.scen--build:hover .sv1-wires path:nth-child(1) { animation-delay: .05s; }
.scen--build:hover .sv1-wires path:nth-child(2) { animation-delay: .22s; }
.scen--build:hover .sv1-wires path:nth-child(3) { animation-delay: .39s; }
@keyframes sv1-wire-draw {
  from { stroke-dashoffset: 50; opacity: 0.5; }
  to   { stroke-dashoffset: 0; opacity: 0.7; }
}

/* SCEN-2 ceo: founder pulses, wires stream, workers fill in sequence */
.scen--ceo:hover .sv2-ceo { animation: sv2-ceo-breathe 2s ease-in-out infinite; }
@keyframes sv2-ceo-breathe {
  0%, 100% { scale: 1; }
  50%      { scale: 1.06; }
}
.scen--ceo:hover .sv2-ceo-dot { animation: sv2-dot-pulse 1.2s ease-in-out infinite; }
@keyframes sv2-dot-pulse {
  0%, 100% { scale: 1; }
  50%      { scale: 1.3; }
}
.sv2-wires path { stroke-dasharray: 3 4; }
.scen--ceo:hover .sv2-wires path { animation: sv2-flow-dash 1.2s linear infinite; }
@keyframes sv2-flow-dash { to { stroke-dashoffset: -14; } }
.scen--ceo:hover .sv2-worker-1 { animation: sv2-worker-pop .55s cubic-bezier(.34,1.56,.64,1) both .12s; }
.scen--ceo:hover .sv2-worker-2 { animation: sv2-worker-pop .55s cubic-bezier(.34,1.56,.64,1) both .28s; }
.scen--ceo:hover .sv2-worker-3 { animation: sv2-worker-pop .55s cubic-bezier(.34,1.56,.64,1) both .44s; }
.scen--ceo:hover .sv2-worker-4 { animation: sv2-worker-pop .55s cubic-bezier(.34,1.56,.64,1) both .60s; }
@keyframes sv2-worker-pop {
  0%   { translate: 0 -6px; scale: 0.85; opacity: 0; }
  60%  { translate: 0 0;    scale: 1.08; opacity: 1; }
  100% { translate: 0 0;    scale: 1;    opacity: 1; }
}

/* SCEN-3 drop: agent travels into open slot; slot fills */
.sv3-flow { stroke-dasharray: 3 4; }
.scen--drop:hover .sv3-flow { animation: sv3-flow-dash 1s linear infinite; }
@keyframes sv3-flow-dash { to { stroke-dashoffset: -14; } }
.scen--drop:hover .sv3-agent { animation: sv3-agent-trip 2.4s cubic-bezier(.65,0,.35,1) infinite; }
@keyframes sv3-agent-trip {
  0%   { translate: 0 0;        scale: 1;  opacity: 1; }
  40%  { translate: 110px 36px; scale: .7; opacity: 1; }
  48%  { translate: 110px 36px; scale: .7; opacity: 0; }
  60%  { translate: 0 0;        scale: 1;  opacity: 0; }
  72%  { translate: 0 0;        scale: 1;  opacity: 1; }
  100% { translate: 0 0;        scale: 1;  opacity: 1; }
}
.scen--drop:hover .sv3-slot { animation: sv3-slot-fill 2.4s cubic-bezier(.65,0,.35,1) infinite; }
@keyframes sv3-slot-fill {
  0%, 35%, 75%, 100% { opacity: 1; scale: 1; }
  42%                { opacity: 0.4; scale: 1.15; }
  55%                { opacity: 1; scale: 1; }
}
.scen--drop:hover .sv3-staff { animation: sv3-staff-bob 1.8s ease-in-out infinite; }
.scen--drop:hover .sv3-staff:nth-of-type(odd) { animation-delay: .2s; }
@keyframes sv3-staff-bob {
  0%, 100% { translate: 0 0; }
  50%      { translate: 0 -1.5px; }
}

@media (prefers-reduced-motion: reduce) {
  .scen__viz *, .scen__viz *::before, .scen__viz *::after {
    animation: none !important;
    transition: none !important;
  }
}

/* mini visualisations inside scenarios */
.scen-viz {
  margin: 8px 0;
  padding: 18px;
  background: linear-gradient(180deg, rgba(217,239,227,0.5) 0%, rgba(227,217,238,0.4) 100%);
  border: 1px dashed var(--rule);
  border-radius: 12px;
  display: flex; flex-direction: column;
  gap: 8px; align-items: center;
  text-align: center;
  font-family: var(--mono);
}
.theme-dark .scen-viz { background: rgba(216,230,211,0.04); }
.scen--ceo .scen-viz {
  background: rgba(216,230,211,0.05);
  border-color: rgba(216,230,211,0.20);
}
.scen-viz__center {
  padding: 8px 18px;
  border-radius: 999px;
  background: rgba(143,207,176,0.18);
  border: 1px solid rgba(143,207,176,0.40);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.04em;
  color: #1D5E4E;
  text-transform: uppercase;
}
.scen--ceo .scen-viz__center { color: var(--emerald-mint); border-color: rgba(143,207,176,0.50); }
.scen-viz__row {
  display: flex; flex-wrap: wrap; gap: 4px; justify-content: center;
}
.scen-viz__chip {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-dim);
  background: rgba(255,255,255,0.6);
  border: 1px solid var(--rule);
}
.scen--ceo .scen-viz__chip { background: rgba(216,230,211,0.08); border-color: rgba(216,230,211,0.18); color: rgba(216,230,211,0.72); }
.scen-viz__caption {
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--fg-mute);
  text-transform: uppercase;
}

/* ============================================================
 * UTILITIES
 * ============================================================ */
.cluster { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.cluster--center { justify-content: center; }
.cluster--end { justify-content: flex-end; }
.divider { height: 1px; background: var(--rule); margin: var(--pad-block) 0; }
.text-center { text-align: center; }
.mt-1 { margin-top: 8px; } .mt-2 { margin-top: 16px; } .mt-3 { margin-top: 24px; } .mt-4 { margin-top: 36px; }

/* ============================================================
 * SEA CAPS - collapsible reveal
 * ============================================================ */
.sea-caps-toggle { margin-top: 24px; text-align: center; }
.sea-caps-toggle > .sea-caps-toggle__btn {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 10px 18px;
  border: 1px solid rgba(216,230,211,0.32);
  border-radius: 999px;
  background: rgba(250,250,247,0.92);
  color: #163A2E;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: background 220ms ease, border-color 220ms ease, transform 220ms ease;
  user-select: none;
}
.sea-caps-toggle > .sea-caps-toggle__btn::-webkit-details-marker { display: none; }
.sea-caps-toggle > .sea-caps-toggle__btn:hover {
  background: #FAFAF7;
  border-color: rgba(216,230,211,0.55);
  transform: translateY(-1px);
}
.sea-caps-toggle__lbl { color: #1D3D33; }
.sea-caps-toggle__hint {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 12px;
  border-radius: 999px;
  background: #1D5E4E;
  color: #FAFAF7;
  font-weight: 700;
  letter-spacing: 0.14em;
  box-shadow: 0 6px 14px -8px rgba(29,94,78,.7);
  transition: background 200ms ease, transform 200ms ease;
}
.sea-caps-toggle > .sea-caps-toggle__btn:hover .sea-caps-toggle__hint {
  background: #0E3F33;
  transform: translateX(2px);
}
.sea-caps-toggle__hint--open { display: none; }
.sea-caps-toggle[open] .sea-caps-toggle__hint:not(.sea-caps-toggle__hint--open) { display: none; }
.sea-caps-toggle[open] .sea-caps-toggle__hint--open { display: inline; }
.sea-caps-toggle .sea-caps {
  margin-top: 16px;
  animation: sea-caps-reveal .35s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes sea-caps-reveal {
  0%   { opacity: 0; transform: translateY(-6px); }
  100% { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .sea-caps-toggle .sea-caps { animation: none; }
}

/* ============================================================
 * SCENARIO 3D VISUALISATIONS - CSS-3D mini diagrams
 *   .viz-build      - Foundry composing roles from an idea
 *   .viz-founder3d  - Founder Agent + team org chart
 *   .viz-drop       - Imported agent docking into an Org
 * ============================================================ */
.viz-build,
.viz-drop,
.viz-founder3d {
  position: relative;
  width: 100%;
  aspect-ratio: 5 / 3;
  perspective: 900px;
  perspective-origin: 50% 40%;
  margin: 8px 0 10px;
  overflow: hidden;
}
.viz-build__stage,
.viz-drop__stage,
.viz-founder3d__stage {
  position: absolute; inset: 0;
  transform-style: preserve-3d;
  transform: rotateX(22deg) rotateZ(-4deg);
}
.viz-build__stage      { animation: viz-spin-a 18s ease-in-out infinite alternate; }
.viz-drop__stage       { animation: viz-spin-a 16s ease-in-out infinite alternate; }
.viz-founder3d__stage  { animation: viz-spin-b 18s ease-in-out infinite alternate; }
@keyframes viz-spin-a {
  0%   { transform: rotateX(22deg) rotateZ(-4deg) rotateY(-2deg); }
  100% { transform: rotateX(22deg) rotateZ(-4deg) rotateY(2deg);  }
}
@keyframes viz-spin-b {
  0%   { transform: rotateX(22deg) rotateZ(-4deg) rotateY(-3deg); }
  100% { transform: rotateX(22deg) rotateZ(-4deg) rotateY(3deg);  }
}

/* shared floor */
.viz-build .viz-founder3d__floor,
.viz-drop__floor,
.viz-founder3d__floor {
  position: absolute; left: 12%; right: 12%; bottom: 4%;
  height: 6px;
  background: radial-gradient(50% 100% at 50% 0%, rgba(17,19,24,.18), transparent 80%);
  transform: rotateX(80deg) translateZ(-2px);
  border-radius: 50%;
  filter: blur(3px);
}

/* === BUILD === */
.viz-build__org {
  position: absolute;
  left: 8%; right: 8%; top: 22%; bottom: 18%;
  border: 1.5px dashed rgba(17,19,24,.22);
  border-radius: 12px;
  background: rgba(255,255,255,.5);
  transform: translateZ(0);
}
.viz-build__org-label {
  position: absolute; top: -22px; left: 12px;
  font: 500 9px var(--mono); letter-spacing: .18em; text-transform: uppercase;
  color: var(--fg-mute);
}
.viz-build__org-name {
  position: absolute; top: -22px; right: 12px;
  font: 700 11px var(--display); letter-spacing: .04em; text-transform: uppercase;
  color: var(--fg);
}
.viz-build__org-name::before {
  content: ""; display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--emerald-mint); margin-right: 6px; vertical-align: middle;
  box-shadow: 0 0 6px var(--emerald-mint);
}
.viz-build__slot {
  position: absolute;
  background: rgba(255,255,255,.95);
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 5px 7px;
  font: 700 8.5px var(--display); letter-spacing: .04em; text-transform: uppercase;
  color: var(--fg);
  box-shadow: 0 6px 12px -6px rgba(17,19,24,.22), 0 1px 0 rgba(255,255,255,.5) inset;
  white-space: nowrap;
  min-width: 60px;
  text-align: center;
  transform: translateZ(12px);
  animation: viz-slot-fill .6s cubic-bezier(.2,.8,.2,1) both;
}
.viz-build__slot small { display: block; font: 500 7px var(--mono); letter-spacing: .12em; color: var(--fg-mute); margin-top: 1px; }
.viz-build__slot--1 { left: 10%; top: 36%; animation-delay: .2s; }
.viz-build__slot--2 { left: 38%; top: 36%; animation-delay: .4s; }
.viz-build__slot--3 { left: 66%; top: 36%; animation-delay: .6s; }
.viz-build__slot--4 { left: 23%; top: 60%; animation-delay: .8s; }
.viz-build__slot--5 { left: 52%; top: 60%; animation-delay: 1.0s; }
@keyframes viz-slot-fill {
  0%   { opacity: 0; transform: translateZ(12px) scale(.85); }
  100% { opacity: 1; transform: translateZ(12px) scale(1); }
}
.viz-build__idea {
  position: absolute;
  left: 50%; top: 6%;
  transform: translate(-50%, 0) translateZ(40px);
  background: linear-gradient(180deg, #163A2E, #0B1E18);
  color: var(--emerald-mint);
  border: 1px solid rgba(216,230,211,.22);
  border-radius: 999px;
  padding: 6px 12px;
  font: 500 9px var(--mono); letter-spacing: .14em; text-transform: uppercase;
  box-shadow: 0 12px 20px -8px rgba(11,30,24,.5);
  white-space: nowrap;
}
.viz-build__idea::after {
  content: "";
  position: absolute; left: 50%; bottom: -10px;
  width: 1px; height: 14px;
  background: rgba(143,207,176,.6);
  transform: translateX(-50%);
}

/* === FOUNDER ORG CHART === */
.viz-founder3d__node {
  position: absolute;
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.78));
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 6px 8px;
  font: 700 9px var(--display); letter-spacing: .04em; text-transform: uppercase;
  color: var(--fg);
  box-shadow: 0 8px 16px -8px rgba(17,19,24,.28), 0 1px 0 rgba(255,255,255,.5) inset;
  min-width: 56px;
  max-width: 92px;
  text-align: center;
  transform-style: preserve-3d;
  white-space: nowrap;
}
.viz-founder3d__node small {
  display: block;
  font: 500 7px var(--mono);
  letter-spacing: .14em;
  color: var(--fg-mute);
  margin-top: 2px;
}
.viz-founder3d__node--ceo {
  background: linear-gradient(180deg, #163A2E, #0B1E18);
  color: var(--emerald-mint);
  border-color: rgba(216,230,211,.22);
  box-shadow: 0 14px 24px -10px rgba(11,30,24,.55), 0 0 0 1px rgba(143,207,176,.16) inset;
  min-width: 76px;
  padding: 8px 10px;
}
.viz-founder3d__node--ceo small { color: rgba(216,230,211,.7); }
.viz-founder3d__node--ceo::after {
  content: "";
  position: absolute; left: 50%; bottom: -3px;
  width: 6px; height: 6px;
  background: var(--emerald-mint);
  border-radius: 50%;
  transform: translate(-50%, 0);
  box-shadow: 0 0 8px var(--emerald-mint);
}
.viz-founder3d__node--ceo-pos { left: 50%; top: 6%;  transform: translate(-50%, 0) translateZ(50px); }
.viz-founder3d__node--t1-pos  { left: 6%;  top: 64%; transform: translateZ(18px); }
.viz-founder3d__node--t2-pos  { left: 30%; top: 76%; transform: translateZ(18px); }
.viz-founder3d__node--t3-pos  { left: 52%; top: 76%; transform: translateZ(18px); }
.viz-founder3d__node--t4-pos  { left: 76%; top: 64%; transform: translateZ(18px); }
.viz-founder3d__lines {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  transform: translateZ(6px);
}
.viz-founder3d__lines line {
  stroke: var(--rule-strong);
  stroke-width: 0.8;
  stroke-dasharray: 2 3;
  opacity: .8;
}

/* === DROP === */
.viz-drop__org {
  position: absolute;
  left: 6%; right: 6%; top: 24%; bottom: 14%;
  background: rgba(255,255,255,.6);
  border: 1px solid var(--rule-strong);
  border-radius: 12px;
  box-shadow: 0 10px 24px -10px rgba(17,19,24,.18);
  transform: translateZ(0);
}
.viz-drop__org-label {
  position: absolute; top: -22px; left: 12px;
  font: 500 9px var(--mono); letter-spacing: .18em; text-transform: uppercase;
  color: var(--fg-mute);
}
.viz-drop__org-name {
  position: absolute; top: -22px; right: 12px;
  font: 700 11px var(--display); letter-spacing: .04em; text-transform: uppercase;
  color: var(--fg);
}
.viz-drop__slot {
  position: absolute;
  border-radius: 6px;
  padding: 5px 7px;
  font: 700 8.5px var(--display); letter-spacing: .04em; text-transform: uppercase;
  color: var(--fg);
  white-space: nowrap;
  text-align: center;
  transform: translateZ(10px);
  min-width: 56px;
}
.viz-drop__slot--filled {
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.78));
  border: 1px solid var(--rule);
  box-shadow: 0 6px 12px -6px rgba(17,19,24,.22);
}
.viz-drop__slot--empty {
  background: transparent;
  border: 1.5px dashed rgba(110,91,224,.55);
  color: rgba(110,91,224,.7);
  animation: viz-empty-pulse 2.2s ease-in-out infinite;
}
@keyframes viz-empty-pulse {
  0%, 100% { border-color: rgba(110,91,224,.55); background: transparent; }
  50%      { border-color: rgba(110,91,224,.95); background: rgba(110,91,224,.06); }
}
.viz-drop__slot small { display: block; font: 500 7px var(--mono); letter-spacing: .12em; color: var(--fg-mute); margin-top: 1px; }
.viz-drop__slot--empty small { color: rgba(110,91,224,.55); }
.viz-drop__slot--s1 { left: 10%; top: 40%; }
.viz-drop__slot--s2 { left: 36%; top: 40%; }
.viz-drop__slot--s3 { left: 62%; top: 40%; }
.viz-drop__slot--s4 { left: 23%; top: 64%; }
.viz-drop__slot--s5 { left: 50%; top: 64%; }
.viz-drop__agent {
  position: absolute;
  left: 70%; top: 6%;
  background: linear-gradient(180deg, rgba(180,162,255,.9), rgba(110,91,224,.85));
  color: #F2EFE9;
  border: 1.5px solid rgba(110,91,224,.55);
  border-radius: 8px;
  padding: 6px 10px;
  font: 700 9.5px var(--display); letter-spacing: .04em; text-transform: uppercase;
  box-shadow: 0 12px 20px -8px rgba(74,60,184,.5);
  transform: translateZ(45px);
  animation: viz-agent-dock 4.5s cubic-bezier(.2,.8,.2,1) infinite;
  white-space: nowrap;
}
.viz-drop__agent small { display: block; font: 500 7.5px var(--mono); letter-spacing: .14em; color: rgba(242,239,233,.78); margin-top: 1px; }
@keyframes viz-agent-dock {
  0%   { transform: translateZ(45px) translate(0%, 0%);   opacity: 1; }
  50%  { transform: translateZ(20px) translate(-22%, 36px); opacity: 1; }
  60%  { transform: translateZ(10px) translate(-22%, 36px); opacity: 0; }
  80%  { transform: translateZ(45px) translate(0%, 0%);   opacity: 0; }
  100% { transform: translateZ(45px) translate(0%, 0%);   opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .viz-build__stage, .viz-drop__stage, .viz-founder3d__stage { animation: none; }
  .viz-build__slot, .viz-drop__slot--empty, .viz-drop__agent { animation: none; }
}


/* ============================================================
 * BYOA PAGE - Ported from source · components: attr badge,
 * variant tabs, source strip, pipeline, imp card, asc, iac,
 * css diagram (connect skill), becomes, founder-viz, char card,
 * caps grid, sec--protocol, cta block, tee-badge
 * ============================================================ */

/* helpers used by source */
.caps-sub { max-width: 48ch; margin: 18px auto 0; font: 400 1rem/1.55 var(--sans); color: var(--fg-dim); }
.sec__head--left .caps-sub { margin-left: 0; }
.caps-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; margin-top: 36px; }
.caps-grid--2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.caps-grid--4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
@media (max-width: 880px) { .caps-grid, .caps-grid--2, .caps-grid--4 { grid-template-columns: 1fr; } }

/* TEE badge (reusable) */
.tee-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px 4px 8px; border-radius: 999px;
  font: 500 10px var(--mono); letter-spacing: .12em; text-transform: uppercase;
  background: rgba(14,60,53,.08); color: var(--emerald);
  border: 1px solid rgba(14,60,53,.22);
  white-space: nowrap;
}
.tee-badge svg { width: 11px; height: 12px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.tee-badge--emerald { background: rgba(216,230,211,.14); color: var(--emerald-mint); border-color: rgba(143,207,176,.42); }

/* Attribution badges */
.attr {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 999px;
  font: 500 10.5px var(--mono); letter-spacing: .08em; text-transform: uppercase;
  border: 1px solid;
  background: var(--attr-bg, rgba(143,207,176,.14));
  color: var(--attr-ink, #1D5E4E);
  border-color: var(--attr-edge, rgba(143,207,176,.5));
}
.attr::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--attr-dot, currentColor); box-shadow: 0 0 8px var(--attr-dot, currentColor); }
.attr--owned       { --attr-bg: rgba(143,207,176,.14); --attr-ink: #1D5E4E; --attr-edge: rgba(143,207,176,.5); --attr-dot: #1D5E4E; }
.attr--authorized  { --attr-bg: rgba(110,91,224,.10);  --attr-ink: #4A3CB8; --attr-edge: rgba(110,91,224,.4);  --attr-dot: #6E5BE0; }
.attr--inspired    { --attr-bg: rgba(245,158,11,.10);  --attr-ink: #92400E; --attr-edge: rgba(245,158,11,.4);  --attr-dot: #D97706; }
.attr--unverified  { --attr-bg: rgba(17,19,24,.05);    --attr-ink: var(--fg-dim); --attr-edge: var(--rule-strong); --attr-dot: var(--fg-mute); }

/* BYOA variant tabs */
.byoa-variant-tabs {
  display: inline-flex; gap: 4px;
  padding: 4px;
  background: rgba(255,255,255,.62);
  border: 1px solid var(--rule);
  border-radius: 999px;
  margin: 0 0 28px;
}
.byoa-variant-tabs button {
  padding: 7px 14px; border-radius: 999px;
  font: 500 11px var(--mono); letter-spacing: .14em; text-transform: uppercase;
  color: var(--fg-dim); cursor: pointer; background: transparent; border: 0;
  transition: background .15s, color .15s;
}
.byoa-variant-tabs button.is-active { background: var(--fg); color: #F2EFE9; }

/* BYOA source strip (hero footer) */
.byoa-source-strip {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px;
  margin-top: 24px; padding-top: 24px;
  border-top: 1px solid var(--rule);
}
@media (max-width: 880px) { .byoa-source-strip { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px) { .byoa-source-strip { grid-template-columns: repeat(2, 1fr); } }
.byoa-source-card {
  background: rgba(255,255,255,.65);
  border: 1px solid var(--rule);
  border-radius: 14px;
  padding: 12px;
  display: flex; flex-direction: column; gap: 6px;
  min-height: 84px;
  transition: background .2s, transform .2s;
  text-decoration: none; color: inherit;
  cursor: pointer;
}
.byoa-source-card:hover { background: rgba(255,255,255,.85); transform: translateY(-1px); }
.byoa-source-card__icon { width: 24px; height: 24px; color: var(--fg-dim); }
.byoa-source-card__icon svg { width: 100%; height: 100%; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.byoa-source-card__label { font: 500 11px var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--fg); }
.byoa-source-card__proof { font: 400 9.5px var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--fg-mute); margin-top: auto; }

/* Pipeline */
.pipeline {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0; margin-top: 36px;
  background: rgba(255,255,255,.5);
  backdrop-filter: blur(12px);
  border: 1px solid var(--rule);
  border-radius: 24px;
  overflow: hidden;
}
@media (max-width: 960px) { .pipeline { grid-template-columns: 1fr 1fr; } }
.pipeline__stage {
  padding: 24px 22px;
  border-left: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 10px;
  position: relative;
  min-height: 240px;
  transition: background .25s;
}
.pipeline__stage:first-child { border-left: 0; }
.pipeline__stage:hover { background: rgba(255,255,255,.4); }
.pipeline__num { font: 500 10.5px var(--mono); letter-spacing: .18em; color: var(--fg-mute); text-transform: uppercase; }
.pipeline__title { font: 700 1.125rem/1.05 var(--display); text-transform: uppercase; margin: 0; letter-spacing: 0; }
.pipeline__copy { font: 400 12.5px/1.5 var(--sans); color: var(--fg-dim); margin: 0; }
.pipeline__chip {
  margin-top: auto;
  display: inline-flex; align-items: center; gap: 6px; align-self: flex-start;
  padding: 4px 10px; border-radius: 999px;
  font: 500 9.5px var(--mono); letter-spacing: .12em; text-transform: uppercase;
  background: rgba(255,255,255,.7); border: 1px solid var(--rule); color: var(--fg-dim);
}
.pipeline__stage--active .pipeline__chip { background: var(--emerald); color: var(--emerald-ink); border-color: var(--emerald); }
.pipeline__arrow {
  position: absolute; right: -8px; top: 38px;
  width: 16px; height: 16px; border-radius: 50%;
  background: rgba(255,255,255,.92); border: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: center;
  z-index: 2; color: var(--fg-mute); font-size: 10px;
}
.pipeline__stage:last-child .pipeline__arrow { display: none; }

/* Agent Source Card */
.asc {
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: 24px;
  box-shadow: var(--shadow-card);
}
.asc__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.asc__head .source { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.asc__name { font: 800 28px/1 var(--display); text-transform: uppercase; margin: 14px 0 6px; }
.asc__voice { font: 400 14px/1.5 var(--sans); color: var(--fg-dim); margin: 0 0 18px; font-style: italic; max-width: 50ch; }
.asc--grid .asc__fields { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.asc__field { background: rgba(255,255,255,.55); border: 1px solid var(--rule); border-radius: 14px; padding: 12px 14px; }
.asc__field .k { font: 500 9.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.asc__field .v { font: 500 13px/1.4 var(--sans); color: var(--fg); margin-top: 4px; display: block; }
.asc__progress { margin-top: 18px; }
.asc__progress .label { display: flex; justify-content: space-between; font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 8px; }
.asc__progress .bar { height: 6px; background: rgba(17,19,24,.08); border-radius: 999px; overflow: hidden; }
.asc__progress .fill { height: 100%; background: var(--glow-grad); background-size: 220% 100%; border-radius: 999px; transition: width .8s cubic-bezier(.2,.8,.2,1); }
.asc__gaps { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 6px; }
.asc__gap {
  font: 500 10.5px var(--mono); letter-spacing: .04em;
  padding: 4px 10px 4px 8px; border-radius: 999px;
  background: rgba(217,119,6,.08); color: #92400E;
  border: 1px dashed rgba(217,119,6,.45);
  text-transform: lowercase;
  display: inline-flex; align-items: center; gap: 6px;
}
.asc__gap::before { content: "?"; font-weight: 700; }
.asc__gap.is-filled { background: rgba(143,207,176,.14); color: #1D5E4E; border-style: solid; border-color: rgba(143,207,176,.4); }
.asc__gap.is-filled::before { content: "✓"; }
.asc--spec .asc__rows { display: grid; grid-template-columns: 1fr; }
.asc--spec .asc__rows .row { display: grid; grid-template-columns: 120px 1fr; gap: 16px; padding: 11px 0; border-top: 1px solid var(--rule); align-items: baseline; }
.asc--spec .asc__rows .row:first-child { border-top: 0; }
.asc--spec .asc__rows .k { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.asc--spec .asc__rows .v { font: 400 13.5px/1.45 var(--sans); color: var(--fg); }
.asc--spec .asc__rows .v .pill-small { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 999px; font: 500 9.5px var(--mono); letter-spacing: .08em; text-transform: uppercase; background: rgba(255,255,255,.6); border: 1px solid var(--rule); color: var(--fg-dim); margin-right: 4px; }
.asc--voice .asc__voice-large {
  font: 400 18px/1.45 var(--sans);
  color: var(--fg);
  margin: 14px 0 18px;
  max-width: 44ch;
  border-left: 3px solid var(--emerald);
  padding-left: 14px;
}
.asc--voice .asc__voice-large em { color: var(--emerald); font-style: italic; font-weight: 500; }
.asc--voice .asc__samples { display: flex; gap: 8px; flex-wrap: wrap; }
.asc--voice .asc__sample { font: 400 12px/1.4 var(--sans); color: var(--fg-dim); background: rgba(255,255,255,.5); border: 1px solid var(--rule); border-radius: 12px; padding: 8px 12px; max-width: 32ch; }

/* Imported Agent Card */
.iac {
  background-color: var(--emerald);
  background-image: linear-gradient(135deg, rgba(8,28,22,.45), rgba(8,28,22,0));
  color: var(--emerald-ink);
  border: 1px solid rgba(216,230,211,.18);
  border-radius: 22px;
  padding: 22px 24px;
  box-shadow: var(--shadow-feature);
  display: flex; flex-direction: column;
}
.iac__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; }
.iac__src { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(216,230,211,.7); }
.iac__name { font: 800 30px/1 var(--display); text-transform: uppercase; margin: 12px 0 4px; color: var(--emerald-mint); }
.iac__role { font: 500 11px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(216,230,211,.8); }
.iac__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px; margin-top: 16px; }
.iac__field { background: rgba(216,230,211,.08); border: 1px solid rgba(216,230,211,.18); border-radius: 12px; padding: 10px 12px; }
.iac__field .k { font: 500 9.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(216,230,211,.6); display: block; }
.iac__field .v { font: 500 13px/1.35 var(--sans); color: #F2EFE9; margin-top: 4px; display: block; }
.iac__foot { display: flex; align-items: center; justify-content: space-between; margin-top: 16px; gap: 12px; flex-wrap: wrap; }
.iac__meta { font: 400 11px var(--mono); letter-spacing: .04em; color: rgba(216,230,211,.65); }
.iac .attr--authorized { background: rgba(110,91,224,.20); color: #D6CCFC; border-color: rgba(180,162,255,.45); }
.iac .attr--authorized::before { background: #D6CCFC; box-shadow: 0 0 8px rgba(214,204,252,.5); }
.iac .attr--owned { background: rgba(143,207,176,.18); color: #B8E8CB; border-color: rgba(143,207,176,.42); }
.iac .attr--owned::before { background: #8FCFB0; box-shadow: 0 0 8px rgba(143,207,176,.6); }
.iac .attr--inspired { background: rgba(245,158,11,.18); color: #F5C97A; border-color: rgba(245,158,11,.45); }
.iac .attr--inspired::before { background: #F5C97A; box-shadow: 0 0 8px rgba(245,201,122,.55); }

/* Connect Skill diagram */
.css-diagram {
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: 24px;
  box-shadow: var(--shadow-card);
}
.css-diagram__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.css-diagram__head .lbl { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.css-diagram__head .gates-summary { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--emerald); }
.css-flow { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 14px; background: rgba(255,255,255,.55); border: 1px solid var(--rule); border-radius: 16px; }
.css-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 12px; border-radius: 999px;
  font: 500 11px var(--mono); letter-spacing: .04em; text-transform: uppercase;
  background: rgba(255,255,255,.7); border: 1px solid var(--rule);
  color: var(--fg); white-space: nowrap;
}
.css-pill.native { background: rgba(143,207,176,.18); color: #1D5E4E; border-color: rgba(143,207,176,.5); }
.css-pill.skill  { background: rgba(110,91,224,.12); color: #4A3CB8; border-color: rgba(110,91,224,.4); }
.css-pill.ext    { background: rgba(17,19,24,.06); color: var(--fg-dim); border-color: var(--rule-strong); border-style: dashed; }
.css-arrow { font: 700 16px var(--display); color: var(--fg-mute); }
.css-gates { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 12px; }
.css-gate {
  font: 500 9.5px var(--mono); letter-spacing: .12em; text-transform: uppercase;
  padding: 4px 9px; border-radius: 999px;
  background: rgba(14,60,53,.06); color: var(--emerald); border: 1px solid rgba(14,60,53,.18);
}
.css-desc { font: 400 13px/1.5 var(--sans); color: var(--fg-dim); margin: 14px 0 0; max-width: 60ch; }

/* Importer grid */
.imp-grid { display: grid; gap: 10px; margin-top: 30px; }
.imp-grid--3 { grid-template-columns: repeat(3, 1fr); }
.imp-grid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 880px) { .imp-grid--3, .imp-grid--2 { grid-template-columns: 1fr; } }
.imp-card {
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: 20px;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column; gap: 8px;
  transition: transform .25s, box-shadow .25s;
  cursor: pointer;
  position: relative;
  min-height: 168px;
  text-decoration: none;
  color: inherit;
}
.imp-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.imp-card__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.imp-card__icon { width: 38px; height: 38px; border-radius: 12px; background: linear-gradient(135deg, rgba(207,232,218,.95), rgba(226,216,240,.85)); display: flex; align-items: center; justify-content: center; color: var(--fg); }
.imp-card__icon svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.imp-card__title { font: 700 1.125rem/1.05 var(--display); text-transform: uppercase; margin: 8px 0 4px; letter-spacing: 0; }
.imp-card__inputs { font: 400 12.5px/1.45 var(--sans); color: var(--fg-dim); margin: 0; }
.imp-card__foot { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: 12px; gap: 8px; flex-wrap: wrap; }
.imp-card__proof { font: 500 9.5px var(--mono); letter-spacing: .12em; text-transform: uppercase; color: var(--fg-mute); }
.imp-card__arrow { font: 700 14px var(--display); color: var(--fg-mute); }
.imp-card.is-recommended { background: rgba(255,255,255,.85); border-color: rgba(14,60,53,.25); }
.imp-card.is-recommended::after { content: "RECOMMENDED"; position: absolute; top: 14px; right: 14px; font: 500 9px var(--mono); letter-spacing: .14em; padding: 3px 8px; border-radius: 999px; background: var(--emerald); color: var(--emerald-ink); }

/* Becomes grid */
.becomes { display: grid; grid-template-columns: 1fr 1.25fr 1fr; gap: 14px; margin-top: 36px; align-items: stretch; }
@media (max-width: 980px) { .becomes { grid-template-columns: 1fr; } }
.becomes .scen { padding: 24px; }
.becomes .scen--ceo {
  background: var(--emerald);
  background-image: linear-gradient(140deg, rgba(8,28,22,.45), rgba(8,28,22,0));
  color: var(--emerald-ink);
  border-color: rgba(216,230,211,.18);
  box-shadow: var(--shadow-feature);
}
.becomes .scen--ceo .scen__lede { color: rgba(216,230,211,.65); }
.becomes .scen--ceo .scen__title { color: var(--emerald-mint); }
.becomes .scen--ceo .scen__copy { color: rgba(216,230,211,.85); }
.becomes .scen--ceo .scen__copy strong { color: var(--emerald-ink); }
.becomes .scen--ceo .scen__cta { color: var(--emerald-mint); }
.becomes .scen--ceo .scen__example { background: rgba(216,230,211,.08); border-color: rgba(216,230,211,.18); color: rgba(216,230,211,.9); }
.becomes .scen--ceo .scen__example span { color: rgba(216,230,211,.65); }
.becomes .scen--ceo .scen__example b { color: var(--emerald-ink); }

/* Founder viz mini chart */
.founder-viz {
  margin-top: 12px;
  padding: 12px;
  background: rgba(255,255,255,.5);
  border: 1px solid var(--rule);
  border-radius: 14px;
  display: flex; flex-direction: column; gap: 6px;
}
.founder-viz__top {
  display: inline-flex; align-items: center; gap: 8px;
  align-self: flex-start;
  padding: 6px 12px; border-radius: 999px;
  background: var(--fg); color: #F2EFE9;
}
.founder-viz__top::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--emerald-mint);
}
.founder-viz__top span { font: 500 10.5px var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.founder-viz__top b { font: 700 12px var(--display); letter-spacing: 0; text-transform: uppercase; }
.founder-viz__line { width: 1px; height: 14px; background: rgba(17,19,24,.18); margin-left: 22px; }
.founder-viz__team { display: flex; gap: 6px; flex-wrap: wrap; padding-left: 8px; }
.founder-viz__team span {
  padding: 4px 10px;
  font: 500 10px var(--mono); letter-spacing: .08em; text-transform: uppercase;
  background: rgba(255,255,255,.6);
  border: 1px solid var(--rule);
  border-radius: 999px;
  color: var(--fg-dim);
}

/* Char card (founder showcase) */
.char-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 36px;
}
@media (max-width: 880px) { .char-grid { grid-template-columns: 1fr; } }
.char-card {
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  cursor: pointer;
  display: flex; flex-direction: column;
  transition: transform .25s, box-shadow .25s;
}
.char-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }
.char-card__portrait { position: relative; aspect-ratio: 200 / 112; background: rgba(255,255,255,.4); border-bottom: 1px solid var(--rule); }
.char-card__portrait svg { width: 100%; height: 100%; display: block; }
.char-card__rank {
  position: absolute; top: 12px; left: 12px;
  background: var(--fg); color: #F2EFE9;
  padding: 4px 9px; border-radius: 999px;
  font: 500 11px var(--mono); letter-spacing: .04em;
}
.char-card__hot {
  position: absolute; top: 12px; right: 12px;
  background: rgba(245,158,11,.92); color: #fff;
  padding: 4px 9px; border-radius: 999px;
  font: 500 10px var(--mono); letter-spacing: .04em; text-transform: uppercase;
}
.char-card__body { padding: 18px 20px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.char-card__head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.char-card__name { font: 800 1.5rem/1 var(--display); text-transform: uppercase; margin: 0; }
.char-card__token { font: 700 13px var(--mono); letter-spacing: .04em; color: var(--emerald); }
.char-card__bio { font: 400 13.5px/1.5 var(--sans); color: var(--fg-dim); margin: 0; }
.char-card__metrics {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  background: rgba(255,255,255,.4);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: 4px;
  margin-top: auto;
}
.char-card__metric { background: rgba(255,255,255,.85); padding: 10px 12px; display: flex; flex-direction: column; gap: 2px; border-radius: 8px; }
.char-card__metric .k { font: 500 9.5px var(--mono); letter-spacing: .14em; color: var(--fg-mute); text-transform: uppercase; }
.char-card__metric .v { font: 800 16px/1 var(--display); letter-spacing: 0; font-variant-numeric: tabular-nums; }
.char-card__metric .d { font: 500 9.5px var(--mono); letter-spacing: .04em; color: var(--fg-mute); margin-top: 2px; }
.char-card__team {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; padding-top: 8px; border-top: 1px solid var(--rule);
  font: 500 11px var(--mono); letter-spacing: .04em; color: var(--fg-mute); text-transform: uppercase;
}
.char-card__avatars { display: flex; }
.char-card__avatars span {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--emerald); color: var(--emerald-ink);
  display: inline-flex; align-items: center; justify-content: center;
  font: 700 9px var(--mono); letter-spacing: .04em;
  border: 2px solid #FAFAF7;
  margin-left: -8px;
}
.char-card__avatars span:first-child { margin-left: 0; }

/* sec--protocol - emerald wrapper inside section */
.sec--protocol {
  background-color: var(--emerald);
  background-image: linear-gradient(135deg, rgba(8,28,22,.55), rgba(8,28,22,0));
  color: var(--emerald-ink);
  border-radius: 28px;
  padding: clamp(40px, 5vw, 64px);
  margin-top: 40px;
  position: relative;
}
.sec--protocol .sec__title { color: var(--emerald-ink); }
.sec--protocol .caps-sub { color: rgba(216,230,211,.85); }
.sec--protocol .eyebrow { color: rgba(216,230,211,.7); }

/* CTA block (used by BYOA final CTA) */
.cta {
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 24px;
  box-shadow: var(--shadow-card);
  padding: clamp(36px, 5vw, 56px);
  text-align: center;
}
.cta h2 { font: 800 clamp(2.5rem, 5vw, 5rem)/0.95 var(--display); text-transform: uppercase; max-width: 18ch; margin: 0 auto; }
.cta h2 .glow { font-style: normal; background: var(--glow-grad); background-size: 220% 100%; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.cta p { margin: 22px auto 28px; max-width: 60ch; font: 400 1.0625rem/1.55 var(--sans); color: rgba(17,19,24,.82); }
.cta__ctas { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }

/* btn--ink-dim - variant used in source for emerald-bg buttons */
.btn--ink-dim {
  background: rgba(216,230,211,.14);
  color: var(--emerald-ink);
  border: 1px solid rgba(216,230,211,.30);
}
.btn--ink-dim:hover { background: rgba(216,230,211,.22); border-color: rgba(216,230,211,.5); }

/* ============================================================
 * DEMO VIDEO
 * ============================================================ */
.demo {
  margin: 8px auto 0;
  max-width: 1040px;
  padding: 0;
}
.demo__frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 18px;
  overflow: hidden;
  background: #0A2B24;
  border: 1px solid var(--rule-strong);
  box-shadow:
    0 1px 0 rgba(17,19,24,.06),
    0 30px 70px -24px rgba(17,19,24,.32),
    0 8px 22px -8px rgba(17,19,24,.12);
  isolation: isolate;
}
.demo__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  background: #0A2B24;
  object-fit: cover;
  z-index: 0;
}

/* poster plate */
.demo__plate {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
  border: 0;
  cursor: pointer;
  background: transparent;
  color: inherit;
  appearance: none;
  -webkit-appearance: none;
  font: inherit;
  transition: opacity .35s ease;
}
.demo__plate-bg {
  position: absolute;
  inset: 0;
  display: block;
}
.demo__plate-bg svg {
  width: 100%;
  height: 100%;
  display: block;
}
.demo__plate-fg {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  text-align: center;
  padding: 24px;
  color: var(--emerald-ink);
  text-shadow: 0 1px 0 rgba(10,43,36,.4);
}
.demo__plate-stamp {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(216,230,211,0.78);
  padding: 6px 12px;
  border: 1px solid rgba(216,230,211,0.30);
  border-radius: 999px;
  background: rgba(10,43,36,0.35);
  backdrop-filter: blur(2px);
}
.demo__play {
  display: inline-flex;
  width: 88px;
  height: 88px;
  margin: 6px 0 2px;
  filter: drop-shadow(0 14px 28px rgba(0,0,0,0.35));
  transition: transform .25s ease;
}
.demo__play svg { width: 100%; height: 100%; display: block; }
.demo__plate:hover .demo__play { transform: scale(1.04); }
.demo__plate:active .demo__play { transform: scale(0.98); }
.demo__plate-label {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: 0.01em;
  color: #FAFAF7;
}
.demo__plate-meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: rgba(216,230,211,0.70);
}

/* playing state — hide the plate */
.demo.is-playing .demo__plate {
  opacity: 0;
  pointer-events: none;
}

/* caption strip below */
.demo__cap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px 14px;
  margin-top: 18px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.demo__cap-num { white-space: nowrap; }
.demo__cap-sep { color: var(--rule-strong); }

@media (max-width: 640px) {
  .demo__play { width: 64px; height: 64px; }
  .demo__plate-fg { gap: 10px; }
  .demo__cap { font-size: 10px; letter-spacing: 0.12em; gap: 8px 10px; }
  .demo__cap-sep { display: none; }
}

/* theme-dark adjustments — band reads on dark bg */
.theme-dark .demo__frame { border-color: rgba(216,230,211,0.22); }

