/* ============================================================
   inde LABS · Design System  —  "LIQUID PLATINUM"
   Monochrome luxury-tech. Pure black + pure white only.
   Platinum / brushed-silver is the sole "colour". Light is the
   accent — photonic beams, shimmer, electric hairlines in motion.
   Curves where they belong (cards, pills), edges where they sharpen.
   ============================================================ */

:root {
  /* ---- Monochrome canvas ---- */
  --bg: #FFFFFF;          /* light sections base */
  --bg-2: #F4F4F6;        /* light gray panel */
  --paper: #FFFFFF;
  --ink: #0B0B0D;         /* near-black neutral */
  --ink-2: #2A2B2F;
  --ink-3: #6B6D73;
  --ink-4: #A4A6AC;
  --line: #E8E8EB;        /* hairline on light */
  --line-2: #D6D7DB;
  --deep: #060607;        /* true near-black sections */
  --deep-2: #131316;
  --cream-on-deep: #F5F6F8;  /* near-white text on black */

  /* ---- Accent = graphite on light, flips to platinum on dark.
     No hue. Product lines differ by index/label, not colour. ---- */
  --ember: #111114;   --ember-2: #3A3C42;
  --moss:  #111114;   --moss-2:  #3A3C42;
  --gold:  #111114;   --gold-2:  #3A3C42;
  --api:   #111114;   --api-2:   #3A3C42;
  --xetf:    var(--ember);  --xetf-2:  var(--ember-2);
  --eratra:  var(--moss);   --eratra-2: var(--moss-2);
  --indeone: var(--gold);   --indeone-2: var(--gold-2);

  /* ---- Metal ---- */
  /* Chrome text/edges on DARK backgrounds */
  --platinum: linear-gradient(176deg, #FFFFFF 0%, #E9ECF1 24%, #A7ACB6 50%, #F2F4F7 66%, #B9BEC7 88%, #8C909A 100%);
  /* Brushed metal on LIGHT backgrounds (darker chrome) */
  --platinum-ink: linear-gradient(176deg, #54565D 0%, #15161A 30%, #2C2E34 52%, #0C0D10 74%, #3C3E45 100%);
  --metal-edge: linear-gradient(180deg, rgba(255,255,255,0.9), rgba(255,255,255,0.0) 38%, rgba(0,0,0,0.18));
  --beam: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.0) 8%, rgba(255,255,255,0.85) 50%, rgba(255,255,255,0.0) 92%, transparent 100%);
  /* faint electric — a whisper of cool light, used ONLY in thin moving lines */
  --spark: rgba(214,228,255,0.9);

  /* ---- Geometry · curves where they belong ---- */
  --r-1: 6px;
  --r-2: 10px;
  --r-3: 16px;
  --r-4: 24px;
  --r-btn: 999px;   /* pills — modern, premium */

  --pad: clamp(20px, 4vw, 48px);
  --max: 1280px;

  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  /* ---- Detailing ---- */
  --hair: rgba(11,11,13,0.08);
  --hair-strong: rgba(11,11,13,0.14);
  --hair-deep: rgba(245,246,248,0.10);
  --grid-light:
    linear-gradient(rgba(11,11,13,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11,11,13,0.03) 1px, transparent 1px);
  --grid-deep:
    linear-gradient(rgba(245,246,248,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,246,248,0.045) 1px, transparent 1px);
  --grid-size: 32px 32px;

  /* ---- Gradients (monochrome, used sparingly) ---- */
  --grad-ember: var(--platinum-ink);
  --grad-spectrum: var(--platinum-ink);
  /* Deep mesh — faint silver light pools behind black sections */
  --mesh-deep:
    radial-gradient(60% 80% at 12% 0%, rgba(255,255,255,0.10), transparent 60%),
    radial-gradient(50% 70% at 92% 8%, rgba(255,255,255,0.06), transparent 62%),
    radial-gradient(80% 90% at 80% 100%, rgba(255,255,255,0.05), transparent 60%);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: 'Space Grotesk', system-ui, -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

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

/* Fine film-grain — neutral, barely-there texture (keeps black from going flat) */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.025;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: multiply;
}

/* ===== Typography — Sora (voice / headings) · Space Grotesk (craft / body) ===== */
.serif { font-family: 'Sora', system-ui, sans-serif; letter-spacing: -0.025em; font-weight: 600; }
.mono  { font-family: 'JetBrains Mono', ui-monospace, monospace; font-feature-settings: "tnum"; }
.italic-serif { font-family: 'Sora', system-ui, sans-serif; font-style: normal; font-weight: 600; }

h1, h2, h3, h4 { margin: 0; font-family: 'Sora', system-ui, sans-serif; letter-spacing: -0.02em; line-height: 1.02; font-weight: 600; }
/* Accent words in headlines: upright grotesk (no faux-italic), colour kept */
h1 em, h2 em, h3 em, h4 em,
.eco-headline em, .pz-name em, .hero-headline em,
.partner-cta h2 em, .portal h3 em, .orbit-node .nm em { font-style: normal; }
p  { margin: 0; }
a  { color: inherit; text-decoration: none; }

.eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.eyebrow::before {
  content: "";
  width: 18px; height: 1px;
  /* --tint: a whisper of per-product colour on the eyebrow marker only.
     Neutral graphite everywhere it isn't set, so the system stays black & white. */
  background: var(--tint, var(--ink-3));
}
.eyebrow.no-bar::before { display: none; }
.eyebrow.ember { color: var(--ember); }
.eyebrow.ember::before { background: var(--ember); }

.h-display {
  font-family: 'Sora', system-ui, sans-serif;
  font-weight: 640;
  font-size: clamp(48px, 7.4vw, 112px);
  line-height: 0.94;
  letter-spacing: -0.045em;
}
.h-section {
  font-family: 'Sora', system-ui, sans-serif;
  font-weight: 620;
  font-size: clamp(34px, 5vw, 66px);
  line-height: 1.0;
  letter-spacing: -0.035em;
}
.h-card {
  font-family: 'Sora', system-ui, sans-serif;
  font-weight: 580;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.lead {
  font-size: clamp(17px, 1.5vw, 22px);
  color: var(--ink-2);
  line-height: 1.5;
  max-width: 640px;
}

/* ===== Layout ===== */
.wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad);
  position: relative;
  z-index: 2;
}
section { position: relative; z-index: 2; }

.divider {
  height: 1px;
  background: var(--line);
  width: 100%;
}

/* ===== Nav · fixed dark-glass bar (light text + platinum mark in every state) ===== */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  /* at the top: solid black behind the bar, fading down so it merges into the hero video */
  background: linear-gradient(180deg, rgba(6,6,8,0.96) 0%, rgba(6,6,8,0.55) 55%, rgba(6,6,8,0) 100%);
  border-bottom: 1px solid transparent;
  transition: background .4s var(--ease), border-color .4s var(--ease);
}
/* scrolled past the hero, and on all inner pages: frosted dark glass */
.nav--solid {
  background: rgba(10,11,13,0.66);
  -webkit-backdrop-filter: blur(24px) saturate(1.4);
  backdrop-filter: blur(24px) saturate(1.4);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.nav-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 14px var(--pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-shrink: 0;
}
/* Real inde diamond mark (pure-path platinum SVG) — kept in every state. */
.brand-mark-img { height: 22px; width: 22px; display: block; }
.brand-mark--dark { display: none; }
.brand-word {
  font-family: 'Sora', sans-serif;
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.02em;
  color: var(--cream-on-deep);
}
.footer .brand-mark-img { height: 26px; width: 26px; }
.footer .brand-word { color: var(--paper); font-size: 19px; }
.nav-links {
  display: flex;
  gap: 28px;
  align-items: center;
  font-size: 14px;
  color: rgba(245,246,248,0.74);
}
.nav-links a { transition: color .2s; color: inherit; }
.nav-links a:hover { color: #fff; }
/* nav CTA: solid white pill in both states (flat, no metal) */
.nav .btn-primary { background: var(--paper); color: var(--ink); border: 1px solid var(--paper); }
.nav .btn-primary:hover { background: #ECECEE; transform: translateY(-1px); }

.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 20px;
  border-radius: var(--r-btn);
  font-size: 13.5px;
  font-weight: 500;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.005em;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all .25s var(--ease);
  white-space: nowrap;
  -webkit-font-smoothing: antialiased;
}
.btn-primary {
  background: var(--ink);
  color: var(--paper);
}
.btn-primary:hover {
  background: #26272B;
  transform: translateY(-1px);
}
.btn-ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(11,11,13,0.2);
}
.btn-ghost:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
  transform: translateY(-1px);
}
.btn-ember {
  background: var(--ink);
  color: var(--paper);
}
.btn-ember:hover {
  background: #26272B;
  transform: translateY(-1px);
}
.btn-ghost-dark {
  background: transparent;
  color: var(--cream-on-deep);
  border: 1px solid rgba(245,246,248,0.28);
}
.btn-ghost-dark:hover {
  background: rgba(233,236,241,0.14);
  border-color: rgba(233,236,241,0.4);
  transform: translateY(-1px);
}
.btn .arrow { transition: transform .25s var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

.nav-toggle {
  display: none;
  /* iOS glass menu button */
  background: rgba(255,255,255,0.5);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.65);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7), 0 2px 6px rgba(16,16,19,0.08);
  border-radius: 999px;
  padding: 8px 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  cursor: pointer;
  color: var(--ink);
  transition: all .2s var(--ease-out);
}
.nav-toggle:hover {
  background: rgba(255,255,255,0.72);
  transform: translateY(-1px);
}

/* Language switcher (EN / DE) — iOS segmented control */
.lang-switch {
  display: inline-flex;
  background: rgba(255,255,255,0.45);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.65);
  border-radius: 999px;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7), 0 2px 6px rgba(16,16,19,0.07);
}
.lang-switch button {
  appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  padding: 7px 11px;
  color: var(--ink-3);
  transition: background .2s var(--ease-out), color .2s var(--ease-out);
}
.lang-switch button + button { border-left: 1px solid rgba(255,255,255,0.5); }
.lang-switch button.active {
  background: var(--ink);
  color: var(--paper);
  box-shadow: 0 1px 4px rgba(16,16,19,0.22);
}
.lang-switch button:not(.active):hover { color: var(--ink); background: rgba(255,255,255,0.3); }

/* Nav is dark glass in every state → light glass controls throughout */
.nav .lang-switch,
.nav .nav-toggle {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.22);
  box-shadow: none;
  color: var(--cream-on-deep);
}
.nav .lang-switch button { color: rgba(245,246,248,0.7); }
.nav .lang-switch button + button { border-left-color: rgba(255,255,255,0.18); }
.nav .lang-switch button.active { background: var(--paper); color: var(--ink); }
.nav .nav-toggle { color: var(--cream-on-deep); }

/* ===== iOS-style glass utilities (frosted translucent surfaces) ===== */
.glass {
  /* Crisper engineered glass: tighter blur, a hairline outer rule + bright
     top highlight, and a shorter, harder-edged drop shadow. */
  background:
    linear-gradient(180deg, rgba(255,255,255,0.62), rgba(255,255,255,0.42));
  backdrop-filter: blur(20px) saturate(1.7);
  -webkit-backdrop-filter: blur(20px) saturate(1.7);
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: var(--r-3);
  box-shadow:
    0 0 0 1px var(--hair),
    0 18px 38px -26px rgba(16,16,19,0.34),
    inset 0 1px 0 rgba(255,255,255,0.9);
}
.glass-dark {
  background:
    linear-gradient(180deg, rgba(233,236,241,0.09), rgba(233,236,241,0.045));
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(233,236,241,0.14);
  border-radius: var(--r-3);
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.25),
    0 22px 46px -30px rgba(0,0,0,0.7),
    inset 0 1px 0 rgba(255,255,255,0.08);
}
/* iOS glass for form inputs */
input[type="email"],
input[type="text"],
input[type="search"],
select,
textarea {
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(16px) saturate(1.5);
  -webkit-backdrop-filter: blur(16px) saturate(1.5);
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: var(--r-2);
  box-shadow: 0 0 0 1px var(--hair), inset 0 1px 0 rgba(255,255,255,0.8);
  transition: border-color .2s var(--ease-out), box-shadow .2s var(--ease-out);
}
input[type="email"]:focus,
input[type="text"]:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--ember);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 0 0 3px color-mix(in srgb, var(--ember) 18%, transparent);
}

/* ============================================================
   ENGINEERED DETAILING · hairline grids, corner ticks, rules
   The signature "technical" layer — what separates the sharp,
   instrument-panel feel from a soft editorial template.
   ============================================================ */

/* Corner-bracket ticks. Drop an empty <span class="tick-frame"> inside any
   position:relative container; it draws 4 thin L-brackets at the corners.
   Honors --accent (per-product tone) when present. */
.tick-frame {
  display: none; /* corner brackets removed — cleaner, classic look */
  position: absolute;
  inset: 10px;
  pointer-events: none;
  z-index: 4;
  --tk-len: 13px;
  --tk-col: color-mix(in srgb, var(--accent, var(--ink)) 60%, transparent);
  background:
    linear-gradient(var(--tk-col),var(--tk-col)) 0 0      / var(--tk-len) 1px no-repeat,
    linear-gradient(var(--tk-col),var(--tk-col)) 0 0      / 1px var(--tk-len) no-repeat,
    linear-gradient(var(--tk-col),var(--tk-col)) 100% 0   / var(--tk-len) 1px no-repeat,
    linear-gradient(var(--tk-col),var(--tk-col)) 100% 0   / 1px var(--tk-len) no-repeat,
    linear-gradient(var(--tk-col),var(--tk-col)) 0 100%   / var(--tk-len) 1px no-repeat,
    linear-gradient(var(--tk-col),var(--tk-col)) 0 100%   / 1px var(--tk-len) no-repeat,
    linear-gradient(var(--tk-col),var(--tk-col)) 100% 100%/ var(--tk-len) 1px no-repeat,
    linear-gradient(var(--tk-col),var(--tk-col)) 100% 100%/ 1px var(--tk-len) no-repeat;
}
.tick-frame.deep { --tk-col: color-mix(in srgb, var(--accent, var(--paper)) 55%, transparent); }

/* Hairline blueprint grid behind a section. Add class .grid-bg to a
   position:relative section; fades out toward the edges via mask. */
.grid-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: var(--grid-light);
  background-size: var(--grid-size);
  -webkit-mask-image: radial-gradient(120% 90% at 50% 0%, #000 35%, transparent 80%);
          mask-image: radial-gradient(120% 90% at 50% 0%, #000 35%, transparent 80%);
}
.grid-bg.deep::before { background-image: var(--grid-deep); }
.grid-bg > * { position: relative; z-index: 1; }

/* Mono "spec" caption — small uppercase technical label with leading + */
.spec-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.spec-label::before { content: "+"; color: var(--ember); font-weight: 600; }

/* Sharp accent rule — a short gradient bar used as an underline accent */
.accent-rule {
  width: 56px; height: 2px; border-radius: 1px;
  background: var(--grad-ember);
  margin: 18px 0;
}

/* ----- Photographic backdrop (real imagery, color-graded to palette) -----
   Drop <span class="photo-bd" style="--img:url(...)"></span> as a direct child
   of a deep section. The photo is desaturated + darkened and tinted with the
   warm/moss mesh so cream text stays legible and it reads on-brand, not stock. */
.photo-bd {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.photo-bd::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--img);
  background-size: cover;
  background-position: var(--img-pos, center);
  filter: grayscale(0.45) contrast(1.06) brightness(0.46) saturate(0.9);
  opacity: 0.5;
  transform: scale(1.02);
}
.photo-bd::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(70% 90% at 84% 6%, rgba(206,211,220,0.30), transparent 60%),
    radial-gradient(60% 80% at 6% 100%, rgba(150,156,168,0.26), transparent 62%),
    linear-gradient(180deg, rgba(8,8,10,0.55) 0%, rgba(8,8,10,0.30) 45%, rgba(8,8,10,0.78) 100%);
}

/* ===== Hero ===== */
.hero {
  padding: clamp(56px, 9vw, 120px) 0 clamp(64px, 8vw, 120px);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  top: -200px; right: -200px;
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(206,211,220,0.08), transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
}
.hero-left { position: relative; }
.hero-headline {
  margin-top: 22px;
}
.hero-headline em {
  font-style:normal;
  color: var(--ember);
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.hero-sub {
  margin-top: 28px;
  max-width: 560px;
}
.hero-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 36px;
}
.hero-partner-line {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px dashed var(--line-2);
  font-size: 14px;
  color: var(--ink-3);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.hero-partner-line a {
  color: var(--ember);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  text-decoration-color: rgba(206,211,220,0.4);
  transition: text-decoration-color .2s;
}
.hero-partner-line a:hover { text-decoration-color: var(--ember); }

.hero-proofs {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  margin-top: 40px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.hero-proofs li {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.hero-proofs li::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--moss);
}

/* ===== Hero Composition (right side) ===== */
.spec {
  position: relative;
  height: clamp(440px, 56vw, 580px);
  perspective: 1200px;
}

.spec-card {
  position: absolute;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 30px 60px -25px rgba(16,16,19,0.18),
    0 8px 16px -8px rgba(16,16,19,0.08);
  padding: 18px;
  transition: transform .6s var(--ease-out);
}

.spec-portfolio {
  top: 0; left: 0;
  width: 64%;
  z-index: 3;
  animation: float-a 7s ease-in-out infinite;
}
.spec-agent {
  bottom: 8%; right: 0;
  width: 60%;
  z-index: 4;
  animation: float-b 8s ease-in-out infinite;
}
.spec-remit {
  top: 14%; right: -2%;
  width: 44%;
  z-index: 5;
  background: var(--deep);
  color: var(--cream-on-deep);
  border-color: var(--deep-2);
  animation: float-c 6s ease-in-out infinite;
}
.spec-theme {
  bottom: 0; left: 12%;
  width: 36%;
  z-index: 2;
  padding: 0;
  overflow: hidden;
  animation: float-d 9s ease-in-out infinite;
}

@keyframes float-a { 0%,100% { transform: translateY(0) rotate(-1.2deg);} 50% { transform: translateY(-8px) rotate(-0.8deg);} }
@keyframes float-b { 0%,100% { transform: translateY(0) rotate(1.5deg);} 50% { transform: translateY(-6px) rotate(1.2deg);} }
@keyframes float-c { 0%,100% { transform: translateY(0) rotate(-2deg);} 50% { transform: translateY(-10px) rotate(-1.6deg);} }
@keyframes float-d { 0%,100% { transform: translateY(0) rotate(2deg);} 50% { transform: translateY(-7px) rotate(1.5deg);} }

.spec-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 12px;
}
.spec-head .label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.spec-portfolio .title {
  font-family: 'Sora', sans-serif;
  font-size: 18px;
  letter-spacing: -0.01em;
}
.holding {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  padding: 7px 0;
  font-size: 13px;
  align-items: center;
  border-bottom: 1px dashed rgba(214,215,220,0.6);
}
.holding:last-child { border: none; }
.holding .ticker { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--ink-3); }
.holding .name { display: flex; flex-direction: column; }
.holding .pct { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--ink-2); }
.holding .delta { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--moss); }
.holding .delta.neg { color: var(--ember); }

/* Bar visual under holdings */
.alloc-bar {
  display: flex;
  height: 6px;
  border-radius: 999px;
  overflow: hidden;
  margin-top: 12px;
  background: var(--bg-2);
}
.alloc-bar span { display: block; height: 100%; }

/* Agent card */
.agent-msg {
  font-size: 13px;
  color: var(--ink-2);
  line-height: 1.45;
  padding: 8px 0;
}
.agent-msg.user {
  color: var(--ink);
  font-family: 'Sora', sans-serif;
  font-size: 15px;
  font-style:normal;
  border-left: 2px solid var(--ember);
  padding-left: 12px;
  margin: 6px 0 10px;
}
.agent-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.chip {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  padding: 4px 9px;
  border-radius: 999px;
  background: var(--bg-2);
  color: var(--ink-2);
  letter-spacing: 0.04em;
}
.chip.live { background: var(--moss); color: var(--paper); display: inline-flex; align-items: center; gap: 6px; }
.chip.live::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--paper);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

/* Remit card */
.spec-remit .label { color: rgba(233,236,241,0.55); }
.fx-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: 10px;
}
.fx-num {
  font-family: 'Sora', sans-serif;
  font-size: 28px;
  letter-spacing: -0.02em;
}
.fx-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  background: rgba(255,255,255,0.1);
  padding: 3px 7px;
  border-radius: 999px;
  letter-spacing: 0.05em;
}
.fx-tag.win { background: var(--ember); color: var(--paper); }
.fx-meta {
  margin-top: 10px;
  font-size: 11px;
  color: rgba(233,236,241,0.55);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.04em;
}

/* Theme card */
.spec-theme img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  display: block;
}
.spec-theme .meta {
  padding: 12px 14px;
}
.spec-theme .meta strong {
  font-family: 'Sora', sans-serif;
  font-weight: 480;
  font-size: 16px;
  letter-spacing: -0.01em;
  display: block;
}
.spec-theme .meta span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--ink-3);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ===== Ticker bar ===== */
.ticker {
  background: var(--deep);
  color: var(--cream-on-deep);
  overflow: hidden;
  border-top: 1px solid var(--deep-2);
  border-bottom: 1px solid var(--deep-2);
}
.ticker-track {
  display: flex;
  gap: 56px;
  padding: 14px 0;
  white-space: nowrap;
  animation: marquee 50s linear infinite;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.06em;
}
.ticker-track span { display: inline-flex; align-items: center; gap: 10px; }
.ticker-track strong { color: var(--paper); font-weight: 500; }
.ticker-track .up { color: #CDD2DB; }
.ticker-track .down { color: #B8BCC4; }
.ticker-track .dot { color: var(--ember); }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ===== Section base ===== */
.section {
  padding: clamp(72px, 10vw, 130px) 0;
  position: relative;
}
.section-deep {
  background: var(--deep);
  color: var(--cream-on-deep);
  overflow: hidden;
}
.section-deep::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: var(--mesh-deep);
  opacity: 0.9;
}
.section-deep .lead { color: rgba(233,236,241,0.7); }
.section-deep .eyebrow { color: rgba(233,236,241,0.55); }
.section-deep .eyebrow::before { background: rgba(233,236,241,0.35); }
.section-paper {
  background: var(--paper);
}

.section-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: end;
  margin-bottom: 56px;
}
.section-head .right { padding-bottom: 4px; }

/* ===== Pillars ===== */
.pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  overflow: hidden;
}
.pillar {
  background: var(--paper);
  padding: 36px 32px 40px;
  position: relative;
  transition: background .3s;
}
.pillar:hover { background: #F3F7FD; }
.pillar .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--ember);
  letter-spacing: 0.1em;
}
.pillar h3 {
  margin-top: 14px;
  font-size: 32px;
  line-height: 1.05;
  font-weight: 380;
}
.pillar p {
  margin-top: 18px;
  font-size: 15px;
  color: var(--ink-2);
  line-height: 1.55;
}
.pillar .badge {
  display: inline-block;
  margin-top: 22px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: var(--bg-2);
  padding: 4px 10px;
  border-radius: 999px;
  color: var(--ink-2);
}
.pillar .badge.guarantee {
  background: var(--ember);
  color: var(--paper);
}
.pillar-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 22px;
  font-size: 13px;
  color: var(--ember);
  font-weight: 500;
}
.pillar-link .arrow { transition: transform .2s; }
.pillar:hover .pillar-link .arrow { transform: translateX(4px); }

/* ===== UCITS callout ===== */
.ucits-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.ucits-visual {
  background: var(--deep);
  color: var(--cream-on-deep);
  border-radius: var(--r-3);
  padding: 40px;
  position: relative;
  overflow: hidden;
  min-height: 380px;
}
.ucits-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 80%, rgba(206,211,220,0.18), transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(198,201,209,0.14), transparent 50%);
  pointer-events: none;
}
.ucits-visual .row {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid rgba(233,236,241,0.1);
  align-items: center;
  position: relative;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
}
.ucits-visual .row:first-of-type { border-top: 1px solid rgba(233,236,241,0.1); }
.ucits-visual .label { color: rgba(233,236,241,0.55); letter-spacing: 0.08em; text-transform: uppercase; font-size: 10px; }
.ucits-visual .vs { color: var(--ember); font-weight: 600; }
.ucits-visual .us { color: rgba(233,236,241,0.45); text-decoration: line-through; font-family: 'Sora', sans-serif; font-size: 18px; }
.ucits-visual .uc { color: var(--paper); font-family: 'Sora', sans-serif; font-size: 22px; }
.ucits-visual .check { color: var(--moss); }

/* ===== Themes ===== */
.themes-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.theme {
  position: relative;
  border-radius: var(--r-3);
  overflow: hidden;
  aspect-ratio: 4/5;
  cursor: pointer;
  border: 1px solid var(--line);
  background: var(--bg-2);
  transition: transform .4s var(--ease-out);
}
.theme:hover { transform: translateY(-4px); }
.theme img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.95) contrast(1.05);
  transition: transform .8s var(--ease-out), filter .4s;
}
.theme:hover img { transform: scale(1.06); filter: saturate(1.1); }
.theme::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 22%, rgba(8,8,10,0.45) 55%, rgba(8,8,10,0.96) 100%);
  pointer-events: none;
}
.theme .info {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 22px 22px 24px;
  z-index: 2;
  color: var(--paper);
}
.theme .info .tag {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(233,236,241,0.7);
  margin-bottom: 8px;
}
.theme .info h4 {
  font-size: 24px;
  font-weight: 420;
  letter-spacing: -0.02em;
  font-family: 'Sora', sans-serif;
}
.theme .info .perf {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: #DDE0E6;
  margin-top: 6px;
  letter-spacing: 0.04em;
}
.theme .info .perf .up { color: #58C281; font-weight: 600; }
.theme.featured {
  grid-row: span 2;
  aspect-ratio: auto;
}

/* ===== Agent ===== */
.agent-stage {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.agent-prompts {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.prompt-card {
  background: rgba(233,236,241,0.04);
  border: 1px solid rgba(233,236,241,0.1);
  border-radius: var(--r-3);
  padding: 22px 24px;
  position: relative;
  transition: all .3s var(--ease);
}
.prompt-card:hover {
  background: rgba(233,236,241,0.06);
  border-color: rgba(233,236,241,0.18);
}
.audience-tag {
  position: absolute;
  top: 14px;
  right: 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 3px;
  border: 1px solid;
}
.audience-tag.india {
  color: #C2C5CD;
  border-color: rgba(196,198,206,0.3);
  background: rgba(198,201,209,0.08);
}
.audience-tag.eu {
  color: #AEB4BF;
  border-color: rgba(150,156,168,0.3);
  background: rgba(150,156,168,0.12);
}
.prompt-card .me {
  font-family: 'Sora', sans-serif;
  font-style:normal;
  font-size: clamp(17px, 1.6vw, 21px);
  line-height: 1.35;
  color: var(--paper);
}
.prompt-card .me::before {
  content: "❝ ";
  color: var(--ember);
  font-style: normal;
}
.prompt-card .by {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(233,236,241,0.45);
  margin-bottom: 12px;
}
.prompt-card .actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.prompt-card .actions span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.06em;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(233,236,241,0.08);
  color: rgba(233,236,241,0.75);
}
.prompt-card .actions span.green { background: rgba(202,206,214,0.18); color: #D6D9E0; }
.prompt-card .actions span.amber { background: rgba(198,201,209,0.22); color: #C7CAD2; }

.mcp-block {
  margin-top: 36px;
  padding: 24px 28px;
  border: 1px solid rgba(233,236,241,0.16);
  border-radius: var(--r-3);
  background: rgba(206,211,220,0.06);
}
.mcp-block strong {
  font-family: 'Sora', sans-serif;
  font-weight: 420;
  font-size: 17px;
}
.mcp-block p {
  margin-top: 6px;
  font-size: 13px;
  color: rgba(233,236,241,0.65);
}
.mcp-logos {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: rgba(233,236,241,0.6);
}
.mcp-logos span { display: flex; align-items: center; gap: 8px; }
.mcp-logos span::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--ember);
}

/* ===== EU teaser ===== */
.eu-teaser {
  padding: 60px 0;
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.eu-row {
  display: grid;
  grid-template-columns: 1.4fr auto;
  gap: 40px;
  align-items: center;
}
.eu-row h3 {
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 380;
}
.eu-row .tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ember);
  margin-bottom: 10px;
  display: inline-block;
}

/* ===== Partners CTA (homepage) ===== */
.partner-cta {
  background: var(--deep);
  color: var(--cream-on-deep);
  border-radius: var(--r-4);
  padding: clamp(40px, 6vw, 80px);
  position: relative;
  overflow: hidden;
  border: 1px solid var(--deep-2);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.5), 0 40px 90px -40px rgba(0,0,0,0.6);
}
.partner-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(48% 70% at 88% 6%, rgba(206,211,220,0.28), transparent 60%),
    radial-gradient(40% 60% at 8% 100%, rgba(198,201,209,0.16), transparent 62%);
  pointer-events: none;
}
/* hairline blueprint grid inside the CTA block */
.partner-cta::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: var(--grid-deep);
  background-size: var(--grid-size);
  -webkit-mask-image: radial-gradient(90% 90% at 80% 10%, #000, transparent 75%);
          mask-image: radial-gradient(90% 90% at 80% 10%, #000, transparent 75%);
  opacity: 0.7;
}
.partner-cta-inner {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 60px;
  align-items: center;
  position: relative;
  z-index: 2;
}
.partner-cta h2 {
  font-size: clamp(34px, 4.5vw, 60px);
  font-weight: 360;
}
.partner-cta h2 em { color: var(--ember); font-style:normal; }
.partner-cta p {
  margin-top: 22px;
  font-size: 16px;
  color: rgba(233,236,241,0.75);
  max-width: 520px;
}
.partner-cta .who {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.partner-cta .who span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(233,236,241,0.08);
  color: rgba(233,236,241,0.75);
}
.partner-cta-side {
  border-left: 1px solid rgba(233,236,241,0.14);
  padding-left: 40px;
}
.partner-cta-side .pt {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(233,236,241,0.5);
}
.partner-cta-side h4 {
  margin-top: 12px;
  font-size: 22px;
  font-weight: 380;
  font-family: 'Sora', sans-serif;
}
.partner-cta-side ul {
  margin: 18px 0 28px;
  padding: 0;
  list-style: none;
}
.partner-cta-side li {
  padding: 10px 0;
  border-bottom: 1px solid rgba(233,236,241,0.1);
  font-size: 14px;
  color: rgba(233,236,241,0.85);
  display: flex;
  align-items: center;
  gap: 10px;
}
.partner-cta-side li::before {
  content: "→";
  color: var(--ember);
  font-family: 'JetBrains Mono', monospace;
}

/* ===== Roadmap ===== */
.roadmap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  overflow: hidden;
}
.phase {
  background: var(--paper);
  padding: 36px 32px;
  position: relative;
}
.phase .when {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: flex;
  align-items: center;
  gap: 10px;
}
.phase .when::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--ink-4);
}
.phase.now { background: #F3F7FD; }
.phase.now .when { color: var(--ember); }
.phase.now .when::before { background: var(--ember); animation: pulse 1.6s infinite; }
.phase h3 {
  margin-top: 16px;
  font-size: 24px;
  font-weight: 420;
}
.phase ul {
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}
.phase li {
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 14px;
  color: var(--ink-2);
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.phase li::before {
  content: "·";
  color: var(--ink-4);
  font-family: 'JetBrains Mono', monospace;
}

/* ===== FAQ ===== */
.faq-list { border-top: 1px solid var(--line); }
.faq-item {
  border-bottom: 1px solid var(--line);
  cursor: pointer;
}
.faq-item summary {
  list-style: none;
  padding: 28px 0;
  font-family: 'Sora', sans-serif;
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 420;
  letter-spacing: -0.015em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "＋";
  font-family: 'JetBrains Mono', monospace;
  font-size: 22px;
  color: var(--ember);
  transition: transform .3s;
  margin-left: 24px;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-body {
  padding: 0 0 28px;
  color: var(--ink-2);
  font-size: 16px;
  line-height: 1.6;
  max-width: 720px;
}

/* ===== Footer ===== */
/* ===== Real-image band (one per page, before the footer) ===== */
.img-band {
  position: relative;
  min-height: clamp(320px, 42vw, 520px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--deep);
}
.img-band .ib-img {
  position: absolute; inset: 0;
  background-image: var(--ib);
  background-size: cover; background-position: center;
  filter: grayscale(1) contrast(1.04) brightness(0.72);
  transform: scale(1.04);
}
.img-band::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(6,6,8,0.32) 0%, rgba(6,6,8,0.55) 55%, rgba(6,6,8,0.92) 100%);
}
.img-band .wrap { position: relative; z-index: 2; padding: 64px var(--pad) 58px; color: var(--cream-on-deep); }
.img-band .ib-eyebrow {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: rgba(245,246,248,0.6);
}
.img-band h3 {
  font-family: 'Sora', sans-serif; font-weight: 600; letter-spacing: -0.03em;
  font-size: clamp(28px, 4vw, 54px); line-height: 1.02; margin: 14px 0 14px; max-width: 16ch;
}
.img-band p { font-size: clamp(15px, 1.4vw, 18px); line-height: 1.55; color: rgba(245,246,248,0.74); max-width: 540px; margin: 0; }

.footer {
  background: var(--deep);
  color: var(--cream-on-deep);
  padding: 80px 0 40px;
  position: relative;
  overflow: hidden;
}
/* Real city skyline etched into the base of the footer (monochrome, faded up) */
.footer::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 300px; z-index: 0;
  background: url('assets/img/photo-1477959858617.jpg?v=99e93769') bottom center / cover no-repeat;
  filter: grayscale(1) brightness(0.55) contrast(1.1);
  opacity: 0.18;
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 85%);
          mask-image: linear-gradient(180deg, transparent 0%, #000 85%);
  pointer-events: none;
}
.footer .wrap { position: relative; z-index: 1; }
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 60px;
  border-bottom: 1px solid rgba(233,236,241,0.1);
}
.footer h5 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(233,236,241,0.45);
  margin: 0 0 18px;
  font-weight: 400;
}
.footer ul { list-style: none; padding: 0; margin: 0; }
.footer li { padding: 7px 0; font-size: 14px; color: rgba(233,236,241,0.78); }
.footer li a:hover { color: var(--ember); }
.footer-brand .tagline {
  margin-top: 14px;
  max-width: 280px;
  font-family: 'Sora', sans-serif;
  font-size: 17px;
  font-style:normal;
  color: rgba(233,236,241,0.65);
}
.footer-bottom {
  padding-top: 30px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(233,236,241,0.4);
}

/* ===== Reveal animation ===== */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s var(--ease-out), transform .9s var(--ease-out);
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}
.reveal.delay-1 { transition-delay: .08s; }
.reveal.delay-2 { transition-delay: .16s; }
.reveal.delay-3 { transition-delay: .24s; }
.reveal.delay-4 { transition-delay: .32s; }

/* ===== Responsive ===== */
@media (max-width: 1024px) {
  .hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .ucits-block { grid-template-columns: 1fr; gap: 36px; }
  .agent-stage { grid-template-columns: 1fr; gap: 36px; }
  .partner-cta-inner { grid-template-columns: 1fr; gap: 36px; }
  .partner-cta-side { border-left: none; border-top: 1px solid rgba(233,236,241,0.14); padding: 30px 0 0; }
  .section-head { grid-template-columns: 1fr; gap: 20px; }
  .themes-grid { grid-template-columns: repeat(2, 1fr); }
  .theme--xtra { display: none; }
  .pillars { grid-template-columns: 1fr; }
  .roadmap-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .spec { height: 520px; max-width: 540px; margin: 0 auto; }
}
@media (max-width: 640px) {
  .nav-links { display: none; }
  .nav-toggle { display: inline-flex; }
  /* Keep the bar from overflowing: tighter spacing, the primary CTA moves
     into the dropdown menu (injected by main.js), switcher + toggle stay. */
  .nav-inner { gap: 10px; padding: 12px var(--pad); }
  .nav-inner > div { gap: 8px; }
  .nav-inner .btn-primary:not(.menu-cta) { display: none; }
  .nav-toggle { padding: 8px 12px; }
  .lang-switch button { padding: 7px 9px; }
  .brand small.labs-tag { display: none; }
  .themes-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .theme.featured { grid-row: auto; aspect-ratio: 4/5; }
  /* Shrink theme typography so headings/figures fit narrow 2-up cards */
  .theme .info { padding: 12px 12px 14px; }
  .theme .info .tag { font-size: 8.5px; letter-spacing: 0.08em; margin-bottom: 6px; }
  .theme .info h4 { font-size: 15.5px; line-height: 1.14; overflow-wrap: break-word; }
  .theme .info .perf { font-size: 9.5px; margin-top: 5px; line-height: 1.25; }
  .hero-cta-row { flex-direction: column; align-items: stretch; }
  .hero-cta-row .btn { justify-content: center; }
  .footer-grid { grid-template-columns: 1fr; gap: 30px; padding-bottom: 36px; }
  .spec-portfolio { width: 78%; }
  .spec-agent { width: 70%; }
  .spec-remit { width: 56%; }
  .spec-theme { width: 46%; }
  .partner-cta { padding: 32px 24px; }
  .ucits-visual { padding: 28px 22px; }
  .pillar { padding: 28px 24px; }
}

/* ============================================================
   inde LABS · Ecosystem layer
   New components for the universe / 3-product hub model
   ============================================================ */

/* ----- Brand mark (ecosystem variant) ----- */
.brand-mark.lab {
  background: var(--ink);
}
.brand-mark.lab::after {
  background: radial-gradient(circle at 30% 30%, var(--ember-2) 0%, var(--ember) 60%, var(--gold) 120%);
}
.brand small.labs-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 400;
  margin-left: 4px;
}

/* ----- Per-product accent utilities ----- */
.accent-xetf    { --accent: var(--xetf);    --accent-2: var(--xetf-2); }
.accent-eratra  { --accent: var(--eratra);  --accent-2: var(--eratra-2); }
.accent-indeone { --accent: var(--indeone); --accent-2: var(--indeone-2); }
.accent-api     { --accent: var(--api);     --accent-2: var(--api-2); }
/* Minimal per-product tint (eyebrow marker only — buttons stay black & white).
   Set on <body class="accent-*"> of each product page. */
body.accent-xetf    { --tint: #B5491F; }  /* muted terracotta-orange */
body.accent-eratra  { --tint: #2F6B4F; }  /* muted forest green */
body.accent-indeone { --tint: #9A7B2E; }  /* muted antique gold */
.eyebrow.accent::before { background: var(--accent); }
.eyebrow.accent { color: var(--accent); }

/* ============================================================
   ECOSYSTEM HERO · orbital / universe
   ============================================================ */
/* ===== HERO — full-bleed real-people video on black ===== */
.eco-hero {
  position: relative;
  min-height: clamp(600px, 90vh, 920px);
  display: flex;
  align-items: center;
  padding: clamp(120px, 17vh, 210px) 0 clamp(72px, 10vh, 120px);
  overflow: hidden;
  background: #000;
}
.eco-hero::before, .eco-hero::after { content: none; display: none; }
.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
  z-index: 0;
  /* keep it inside the monochrome system, dimmed so the headline always wins */
  filter: grayscale(0.4) contrast(1.05) brightness(0.74);
}
.hero-veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(0,0,0,0.94) 0%, rgba(0,0,0,0.74) 40%, rgba(0,0,0,0.40) 72%, rgba(0,0,0,0.58) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.6) 0%, transparent 28%, transparent 58%, rgba(0,0,0,0.82) 100%);
}
/* the hero wrap is a flex child of a centered flex container — without an explicit
   width it shrinks to its content and gets centered. Force full width so the copy
   stays hard-left. */
/* Hero uses the same centered grid + page padding as every other section;
   the copy is left-aligned within it (max-width block, margin-right auto). */
.eco-hero > .wrap { width: 100%; }
.hero-content {
  position: relative;
  z-index: 2;
  max-width: 680px;
  margin-right: auto;
}
@media (max-width: 640px){ .hero-content { padding-left: 16px; } }
.eco-headline {
  font-family:'Sora', system-ui, sans-serif;
  font-weight:600;
  font-size: clamp(44px, 6vw, 96px);
  line-height: 0.98;
  letter-spacing:-0.045em;
  margin-top:18px;
}
.eco-sub {
  margin-top:24px;
  max-width:540px;
  font-size: clamp(16px, 1.4vw, 20px);
  line-height:1.55;
  color: var(--ink-2);
}
.hero-cta-row { display:flex; flex-wrap:wrap; gap:12px; margin-top:34px; }

/* Orbit composition (right side of eco hero) */
.orbit-stage {
  position:relative;
  width:100%;
  aspect-ratio: 1 / 1;
  max-width: 560px;
  margin: 0 auto;
  overflow: visible;
}
.orbit-ring {
  position:absolute;
  inset:0;
  border-radius:50%;
  border:1px dashed rgba(16,16,19,0.18);
  pointer-events:none;
}
.orbit-ring.r1 { inset: 4%;  border-color: rgba(206,211,220,0.22); }
.orbit-ring.r2 { inset: 18%; border-color: rgba(198,201,209,0.22); }
.orbit-ring.r3 { inset: 34%; border-color: rgba(150,156,168,0.22); }

.orbit-core {
  position:absolute;
  top:50%; left:50%;
  width: clamp(120px, 18%, 170px);
  height: clamp(120px, 18%, 170px);
  border-radius:50%;
  transform:translate(-50%, -50%);
  background:
    radial-gradient(circle at 32% 30%, #EDEFF3 0%, var(--ember-2) 28%, var(--ember) 55%, #26272C 100%);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.4) inset,
    0 0 60px rgba(206,211,220,0.45),
    0 0 120px rgba(206,211,220,0.25);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:var(--paper);
  font-family:'Sora', sans-serif;
  font-weight:500;
  font-size: clamp(15px, 1.3vw, 19px);
  letter-spacing:-0.01em;
  text-align:center;
  line-height:1.1;
  z-index:5;
}
.orbit-core::after {
  content:"";
  position:absolute;
  inset:-14px;
  border-radius:50%;
  border:1px solid rgba(206,211,220,0.18);
  animation: corona 3.6s ease-in-out infinite;
}
@keyframes corona {
  0%,100% { transform:scale(1);   opacity:.5; }
  50%     { transform:scale(1.12); opacity:0; }
}
.orbit-core small {
  display:block;
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color: rgba(247,247,250,0.7);
  margin-top:4px;
  font-weight:400;
}

.orbit-node {
  position:absolute;
  width: clamp(140px, 15vw, 180px);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.62), rgba(255,255,255,0.42));
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border:1px solid rgba(255,255,255,0.72);
  border-radius: var(--r-3);
  padding:14px 16px;
  box-shadow:
    0 0 0 1px var(--hair),
    0 20px 42px -24px rgba(16,16,19,0.3),
    inset 0 1px 0 rgba(255,255,255,0.85);
  text-decoration:none;
  color:var(--ink);
  z-index:6;
  transform: translate(-50%, -50%);
  transition: box-shadow .35s var(--ease-out), border-color .25s, transform .35s var(--ease-out);
}
.orbit-node:hover {
  border-color: var(--accent);
  box-shadow:
    0 30px 60px -22px rgba(16,16,19,0.25),
    0 8px 16px -6px rgba(16,16,19,0.1);
}
.orbit-node .dot {
  display:inline-block;
  width:8px; height:8px;
  border-radius:50%;
  background: var(--accent);
  margin-right:8px;
  vertical-align:middle;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);
}
.orbit-node .tag {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color: var(--ink-3);
  display:inline-block;
  vertical-align:middle;
}
.orbit-node .nm {
  font-family:'Sora', sans-serif;
  font-size: 22px;
  letter-spacing:-0.015em;
  margin-top:6px;
  line-height:1.05;
}
.orbit-node .nm em {
  color: var(--accent);
  font-style:normal;
}
.orbit-node .desc {
  font-size:11.5px;
  color:var(--ink-3);
  margin-top:6px;
  line-height:1.45;
}
.orbit-node .arrow-mini {
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  color: var(--accent);
  margin-top:8px;
  letter-spacing:0.06em;
  display:inline-flex;
  gap:5px;
  align-items:center;
}

/* Node positions · top/left as % of the stage; transform centers the node on that point.
   Refined diagonal: a steady top-left → right → bottom sweep, Eratra pulled in so it
   no longer clips the right edge, with evenly graded vertical spacing. */
.orbit-node.n-xetf    { top: 18%; left: 26%; }
.orbit-node.n-eratra  { top: 47%; left: 80%; }
.orbit-node.n-indeone { top: 81%; left: 40%; }

/* Connectors (decorative svg arcs) */
.orbit-svg {
  position:absolute;
  inset:0;
  width:100%; height:100%;
  pointer-events:none;
  z-index:1;
}
.orbit-svg .arc {
  fill:none;
  stroke-width: 1;
  stroke-dasharray: 3 6;
  opacity: 0.45;
}
.orbit-svg .arc.a-xetf    { stroke: var(--ember); }
.orbit-svg .arc.a-eratra  { stroke: var(--moss); }
.orbit-svg .arc.a-indeone { stroke: var(--gold); }

.orbit-rotor {
  position:absolute;
  inset:0;
  animation: orbit-rotate 80s linear infinite;
  pointer-events:none;
}
@keyframes orbit-rotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.orbit-rotor .speck {
  position:absolute;
  width:6px; height:6px;
  border-radius:50%;
  background: var(--ember);
  box-shadow: 0 0 12px rgba(206,211,220,0.6);
}
.orbit-rotor .speck.s2 { background: var(--gold); box-shadow:0 0 12px rgba(198,201,209,0.55); }
.orbit-rotor .speck.s3 { background: var(--moss); box-shadow:0 0 12px rgba(150,156,168,0.55); }
.orbit-rotor .speck.p1 { top: 6%;  left: 50%; }
.orbit-rotor .speck.p2 { top: 50%; left: 94%; }
.orbit-rotor .speck.p3 { top: 92%; left: 38%; }
.orbit-rotor .speck.p4 { top: 26%; left: 12%; }

/* ----- Hero CTA row reused (no override needed) ----- */

/* ============================================================
   PRODUCT PORTAL CARDS (below eco hero on landing)
   ============================================================ */
.portals {
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
/* ElevenLabs-style cards: clean bordered tiles that lift on hover, with a
   corner arrow chip that fills in. No glass, no metal. */
.portal {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  padding: 30px 28px 26px;
  display:flex;
  flex-direction:column;
  position:relative;
  text-decoration:none;
  color: var(--ink);
  transition: transform .4s var(--ease-out), border-color .3s var(--ease), box-shadow .4s var(--ease-out);
  isolation:isolate;
  overflow:hidden;
}
.portal::before {
  /* corner arrow chip */
  content:"↗";
  position:absolute;
  top:24px; right:24px;
  width:34px; height:34px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line);
  border-radius:50%;
  font-size:15px; color:var(--ink-3);
  transition: background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), transform .4s var(--ease-out);
}
.portal:hover {
  transform: translateY(-5px);
  border-color: var(--ink);
  box-shadow: 0 24px 50px -28px rgba(11,11,13,0.4);
}
.portal:hover::before { background: var(--ink); color: var(--paper); border-color: var(--ink); transform: rotate(8deg); }
.portal > * { position:relative; z-index:1; }
.portal .p-tag {
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color: var(--ink-3);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.portal .p-tag::before {
  content:""; width:7px; height:7px; border-radius:50%;
  background: var(--tint, var(--ink));
}
.portal h3 {
  font-family:'Sora', sans-serif;
  font-size: clamp(24px, 2.6vw, 32px);
  letter-spacing:-0.025em;
  font-weight:600;
  margin-top: 18px;
  line-height:1.05;
  max-width: 92%;
}
.portal h3 em { color: var(--accent); font-style:normal; }
.portal p {
  margin-top: 16px;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
.portal ul {
  list-style:none;
  margin: 18px 0 0;
  padding: 18px 0 0;
  border-top: 1px dashed var(--line);
  font-size:13px;
  color: var(--ink-2);
}
.portal ul li {
  padding: 5px 0;
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.portal ul li::before {
  content:"◆";
  color: var(--accent);
  font-size:8px;
  padding-top:7px;
  flex-shrink:0;
}
.portal .p-cta {
  margin-top: 22px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:'Space Grotesk', sans-serif;
  font-size:13px;
  font-weight:500;
  color: var(--accent);
}
.portal .p-cta .arrow { transition: transform .25s var(--ease); }
.portal:hover .p-cta .arrow { transform: translateX(5px); }

/* ============================================================
   PRODUCT ZONES · deep narrative sections per product on hub
   ============================================================ */
.pz {
  padding: clamp(80px, 10vw, 130px) 0;
  position: relative;
  overflow: hidden;
}
.pz-paper { background: var(--paper); }
.pz-deep {
  background: var(--deep);
  color: var(--cream-on-deep);
}
.pz-deep::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(60% 80% at 88% 6%, rgba(150,156,168,0.28), transparent 60%),
    radial-gradient(50% 70% at 8% 96%, rgba(206,211,220,0.14), transparent 62%);
}
.pz-deep .wrap { position: relative; z-index: 1; }
.pz-deep .lead { color: rgba(233,236,241,0.74); }
.pz-deep .eyebrow { color: rgba(233,236,241,0.55); }
.pz-deep .eyebrow::before { background: rgba(233,236,241,0.4); }

.pz-tag {
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color: var(--accent);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.pz-tag::before {
  content:"";
  width:32px; height:1px;
  background: var(--accent);
}
.pz-tag .num {
  font-weight:600;
  color: var(--accent);
}
.pz-name {
  font-family:'Sora', system-ui, sans-serif;
  font-size: clamp(34px, 4.6vw, 62px);
  font-weight: 620;
  letter-spacing:-0.04em;
  line-height: 1.0;
  margin-top: 18px;
}
.pz-name em { color: var(--accent); font-style:normal; }
.pz-name .gradient {
  background: linear-gradient(100deg, var(--accent) 0%, var(--accent-2) 70%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  font-style:normal;
}
.pz-lead {
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 560px;
  margin-top: 22px;
}
.pz-deep .pz-lead { color: rgba(233,236,241,0.74); }

.pz-grid {
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(40px, 5vw, 80px);
  align-items:center;
  margin-top: clamp(40px, 5vw, 64px);
}
.pz-features {
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border:1px solid var(--line);
  border-radius: var(--r-3);
  overflow:hidden;
  margin-top: 36px;
}
.pz-deep .pz-features {
  background: rgba(233,236,241,0.08);
  border-color: rgba(233,236,241,0.1);
}
.pz-feat {
  background: var(--paper);
  padding: 24px 24px;
  font-size: 14px;
  line-height: 1.5;
}
.pz-deep .pz-feat { background: rgba(233,236,241,0.02); color: rgba(233,236,241,0.85); }
.pz-feat strong {
  font-family:'Sora', sans-serif;
  font-weight: 460;
  font-size: 17px;
  letter-spacing:-0.012em;
  display:block;
  margin-bottom:8px;
}
.pz-feat .k {
  font-family:'JetBrains Mono', monospace;
  font-size: 9px;
  color: var(--accent, var(--ink-3));
  letter-spacing: 0.16em;
  text-transform:uppercase;
}

/* inde API · cross-border corridors */
.api-corridors {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 18px;
}
.corridor {
  position: relative;
  padding: 28px 28px 26px;
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  background: var(--bg-2);
}
.corridor .cor-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.corridor h4 {
  margin: 12px 0 8px;
  font-size: clamp(19px, 1.9vw, 24px);
  letter-spacing: -0.02em;
}
.corridor p { color: var(--ink-2); font-size: 15px; line-height: 1.55; margin: 0; }
.api-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }

/* inde API · connectivity / stack strip */
.api-stack {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 18px;
}
.api-stack-item {
  padding: 22px 22px 20px;
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  background: var(--paper);
}
.api-stack-item .k {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.api-stack-item strong {
  display: block;
  font-family: 'Sora', sans-serif;
  font-weight: 500;
  font-size: 17px;
  letter-spacing: -0.012em;
  margin: 8px 0 8px;
}
.api-stack-item p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--ink-2); }

@media (max-width: 980px) { .api-stack { grid-template-columns: 1fr 1fr; } }
@media (max-width: 760px) { .api-corridors, .api-stack { grid-template-columns: 1fr; } }

/* ===== Build-on-inde-LABS section (institutions + partners, merged) ===== */
.build { position: relative; overflow: hidden; }
.build-photo {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: url('assets/img/photo-1486406146926.jpg?v=8646eef0') center/cover no-repeat;
  filter: grayscale(1) contrast(1.05) brightness(0.5);
  opacity: 0.14;
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 40%, #000 70%, transparent);
          mask-image: linear-gradient(180deg, transparent, #000 40%, #000 70%, transparent);
}
.build .wrap { position: relative; z-index: 1; }
.build-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 40px; }
.build-card {
  display: block; text-decoration: none; color: var(--cream-on-deep);
  background: rgba(245,246,248,0.03);
  border: 1px solid rgba(245,246,248,0.12);
  border-radius: var(--r-3);
  padding: 32px 30px 28px;
  transition: transform .4s var(--ease-out), border-color .3s var(--ease), background .3s var(--ease);
}
.build-card:hover { transform: translateY(-5px); border-color: rgba(245,246,248,0.35); background: rgba(245,246,248,0.05); }
.bc-tag { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(245,246,248,0.55); }
.build-card h3 { font-family: 'Sora', sans-serif; font-weight: 600; letter-spacing: -0.025em; font-size: clamp(26px, 2.8vw, 36px); line-height: 1.04; margin: 16px 0 14px; }
.build-card > p { font-size: 15px; line-height: 1.55; color: rgba(245,246,248,0.7); margin: 0; }
.bc-list { list-style: none; margin: 20px 0 22px; padding: 18px 0 0; border-top: 1px solid rgba(245,246,248,0.1); }
.bc-list li { font-size: 13.5px; color: rgba(245,246,248,0.72); padding: 5px 0 5px 18px; position: relative; }
.bc-list li::before { content: ""; position: absolute; left: 0; top: 12px; width: 7px; height: 1px; background: rgba(245,246,248,0.5); }
.bc-cta { font-family: 'Space Grotesk', sans-serif; font-size: 14px; font-weight: 600; color: #fff; display: inline-flex; gap: 7px; align-items: center; }
.bc-cta .arrow { transition: transform .25s var(--ease); }
.build-card:hover .bc-cta .arrow { transform: translateX(4px); }
.corridor-strip { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 28px; margin-top: 22px; padding: 22px 28px; border: 1px solid rgba(245,246,248,0.12); border-radius: var(--r-3); background: rgba(245,246,248,0.02); }
.cs-item { display: flex; flex-direction: column; gap: 4px; }
.cs-route { font-family: 'Sora', sans-serif; font-size: clamp(15px, 1.5vw, 18px); color: var(--cream-on-deep); letter-spacing: -0.01em; }
.cs-route b { font-weight: 600; }
.cs-arrow { color: rgba(245,246,248,0.5); margin: 0 4px; }
.cs-note { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,246,248,0.45); }
.cs-sep { width: 1px; height: 44px; background: rgba(245,246,248,0.14); }
@media (max-width: 820px) {
  .build-grid { grid-template-columns: 1fr; }
  .corridor-strip { grid-template-columns: 1fr; gap: 18px; }
  .cs-sep { width: 100%; height: 1px; }
}

.pz-cta-row {
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  margin-top: 34px;
}
.btn-accent {
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
}
.btn-accent:hover {
  background: #26272B;
  transform: translateY(-1px);
}
.btn-accent-outline {
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(11,11,13,0.2);
}
.btn-accent-outline:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
  transform: translateY(-1px);
}
/* On dark surfaces the accent (e.g. moss green) is too low-contrast as text — use
   cream text with an accent-tinted glass + lighter accent border so it stays legible
   and on-brand. */
.pz-deep .btn-accent-outline,
.section-deep .btn-accent-outline,
.px-foot-cta .btn-accent-outline,
.ucits-cmp .btn-accent-outline,
.platform-block .btn-accent-outline,
.trap-section .btn-accent-outline,
.etf-section .btn-accent-outline,
.partner-cta .btn-accent-outline {
  background: transparent;
  color: var(--cream-on-deep);
  border: 1px solid rgba(245,246,248,0.28);
}
.pz-deep .btn-accent-outline:hover,
.section-deep .btn-accent-outline:hover,
.px-foot-cta .btn-accent-outline:hover,
.ucits-cmp .btn-accent-outline:hover,
.platform-block .btn-accent-outline:hover,
.trap-section .btn-accent-outline:hover,
.etf-section .btn-accent-outline:hover,
.partner-cta .btn-accent-outline:hover {
  background: var(--paper);
  border-color: var(--paper);
  color: var(--ink);
}

/* ============================================================
   xETF visual · basket builder card (used in pz / xetf.html)
   ============================================================ */
.xetf-builder {
  background: var(--paper);
  border:1px solid var(--line);
  border-radius: var(--r-3);
  padding: 26px 26px 22px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 30px 60px -25px rgba(16,16,19,0.18),
    0 8px 16px -8px rgba(16,16,19,0.08);
  position:relative;
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
}
.xetf-builder .xb-head {
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
}
.xetf-builder .xb-title {
  font-family:'Sora', sans-serif;
  font-size: 20px;
  letter-spacing:-0.015em;
}
.xetf-builder .xb-meta {
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color: var(--ember);
  display:flex;
  gap:8px;
  align-items:center;
}
.xetf-builder .xb-meta::before {
  content:""; width:6px; height:6px; border-radius:50%;
  background:var(--ember); animation: pulse 1.6s ease-in-out infinite;
}
.xetf-builder .xb-row {
  display:grid;
  grid-template-columns: 1.2fr 0.6fr 0.6fr;
  gap:14px;
  align-items:center;
  padding: 10px 0;
  font-size:13px;
  border-bottom:1px dashed rgba(214,215,220,0.55);
}
.xetf-builder .xb-row:last-child { border-bottom: none; }
.xetf-builder .xb-row .nm {
  display:flex; flex-direction:column;
}
.xetf-builder .xb-row .nm small {
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  color: var(--ink-3);
  letter-spacing:0.06em;
}
.xetf-builder .xb-row .w {
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  color: var(--ink-2);
}
.xetf-builder .xb-row .w input[type="range"] {
  width: 80px;
}
.xetf-builder .xb-row .chip-mini {
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  padding: 3px 7px;
  background: var(--bg-2);
  border-radius:999px;
  color: var(--ink-2);
}
.xetf-builder .xb-foot {
  margin-top:16px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  padding-top:14px;
  border-top:1px solid var(--line);
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color: var(--ink-3);
}
.xetf-builder .xb-foot .v {
  font-family:'Sora', sans-serif;
  font-size: 18px;
  letter-spacing:-0.015em;
  color: var(--ink);
  margin-bottom: 3px;
  text-transform:none;
}
.xetf-builder .xb-foot .v.up { color: var(--moss); }
.xetf-builder .xb-foot .v.em { color: var(--ember); }

/* ============================================================
   Eratra AI visual · agent terminal
   ============================================================ */
.era-terminal {
  background: linear-gradient(180deg, #0B141A 0%, #070C12 100%);
  color: var(--cream-on-deep);
  border-radius: var(--r-3);
  padding: 26px 28px;
  border: 1px solid rgba(108,112,122,0.3);
  box-shadow:
    0 30px 60px -25px rgba(16,16,19,0.5),
    0 8px 16px -8px rgba(0,0,0,0.2);
  position:relative;
  overflow:hidden;
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}
.era-terminal::before {
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 80% 0%, rgba(108,112,122,0.18), transparent 50%);
  pointer-events:none;
}
.era-terminal .e-bar {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-bottom:14px;
  border-bottom:1px solid rgba(233,236,241,0.08);
  margin-bottom: 16px;
  position:relative;
}
.era-terminal .e-bar .dots {
  display:flex; gap:6px;
}
.era-terminal .e-bar .dots span {
  width:8px; height:8px; border-radius:50%;
  background: rgba(233,236,241,0.18);
}
.era-terminal .e-bar .dots span:first-child { background: var(--moss-2); }
.era-terminal .e-bar .name {
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color: rgba(233,236,241,0.55);
}
.era-msg {
  font-family:'JetBrains Mono', monospace;
  font-size:12.5px;
  line-height:1.6;
  color: rgba(233,236,241,0.85);
  padding: 6px 0;
}
.era-msg.user {
  font-family:'Sora', sans-serif;
  font-style:normal;
  font-size: 15.5px;
  color: var(--paper);
  border-left: 2px solid var(--moss-2);
  padding-left: 12px;
  margin: 8px 0;
}
.era-msg .ok { color:#CDD2DB; }
.era-msg .ang{ color:#C7CAD2; }
.era-msg .em { color:#B8BCC4; }
.era-msg .ar { color: var(--moss-2); margin-right:6px; }
.era-tool {
  display:flex; flex-wrap:wrap; gap:6px;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(233,236,241,0.08);
}
.era-tool span {
  font-family:'JetBrains Mono', monospace;
  font-size:9.5px;
  padding: 4px 8px;
  border-radius:999px;
  background: rgba(108,112,122,0.18);
  color: #DDE0E6;
  letter-spacing:0.04em;
}
.era-tool span.api { background: rgba(206,211,220,0.18); color: #CFD3DB; }
.era-tool span.mcp { background: rgba(198,201,209,0.18); color: #CDD0D8; }

/* ============================================================
   inde ONE visual · phone composition (EU app)
   ============================================================ */
.io-stage {
  position:relative;
  width: 100%;
  max-width: 500px;
  aspect-ratio: 5/6;
  margin: 0 auto;
}
.io-phone {
  position:absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  height: 92%;
  aspect-ratio: 9/19;
  background: var(--deep);
  border-radius: 26px;
  border: 1px solid var(--deep-2);
  padding: 16px;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.4), 0 40px 80px -28px rgba(16,16,19,0.55);
  display:flex; flex-direction:column;
  color: var(--cream-on-deep);
  overflow:hidden;
  z-index: 2;
}
.io-phone::before {
  content:"";
  width: 56px; height:5px;
  background: rgba(233,236,241,0.18);
  border-radius:999px;
  margin: 0 auto 16px;
  flex-shrink:0;
}
.io-phone .io-bal {
  font-family:'JetBrains Mono', monospace;
  font-size:9.5px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color: rgba(233,236,241,0.5);
}
.io-phone .io-eur {
  font-family:'Sora', sans-serif;
  font-size: 28px;
  letter-spacing:-0.02em;
  margin-top:4px;
  color: var(--paper);
}
.io-phone .io-delta {
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  color: #D6D9E0;
  margin-top:2px;
}
.io-phone .io-tabs {
  display:flex;
  gap:6px;
  margin-top:16px;
}
.io-phone .io-tabs span {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  padding: 4px 8px;
  border-radius:999px;
  background: rgba(233,236,241,0.06);
  color: rgba(233,236,241,0.7);
  letter-spacing:0.06em;
}
.io-phone .io-tabs span.act {
  background: var(--gold);
  color: var(--ink);
}
.io-phone .io-list {
  margin-top:14px;
  display:flex;
  flex-direction:column;
  gap: 8px;
  flex:1;
}
.io-phone .io-row {
  display:flex; justify-content:space-between; align-items:center;
  padding: 8px 10px;
  background: rgba(233,236,241,0.05);
  border:1px solid rgba(233,236,241,0.07);
  border-radius: var(--r-2);
  font-size: 10.5px;
}
.io-phone .io-row .l {
  font-family:'Sora', sans-serif;
  font-size: 11.5px;
  color: var(--paper);
}
.io-phone .io-row .l small {
  display:block;
  font-family:'JetBrains Mono', monospace;
  font-size:8.5px;
  color: rgba(233,236,241,0.45);
  letter-spacing:0.06em;
  margin-top:2px;
}
.io-phone .io-row .r {
  font-family:'JetBrains Mono', monospace;
  font-size: 10.5px;
  color: #D6D9E0;
}
.io-phone .io-row .r.em { color: #B8BCC4; }
.io-phone .io-cta {
  margin-top:auto;
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  color: var(--ink);
  padding: 11px;
  border-radius: var(--r-2);
  font-family:'Space Grotesk', sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-align:center;
}
.io-float {
  position:absolute;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.7), rgba(255,255,255,0.5));
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border:1px solid rgba(255,255,255,0.7);
  border-radius: var(--r-3);
  padding: 14px 16px;
  box-shadow: 0 0 0 1px var(--hair), 0 18px 44px -22px rgba(16,16,19,0.28), inset 0 1px 0 rgba(255,255,255,0.85);
  font-size: 12px;
  z-index: 3;
}
.io-float.f-remit {
  bottom: 14%;
  left: -2%;
  width: 46%;
}
.io-float.f-stocks {
  top: 8%;
  right: -2%;
  width: 42%;
}
.io-float .lab {
  font-family:'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform:uppercase;
  color: var(--ink-3);
}
.io-float .v {
  font-family:'Sora', sans-serif;
  font-size: 22px;
  letter-spacing:-0.015em;
  margin-top: 4px;
  line-height:1.05;
}
.io-float .v small {
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--moss);
  margin-left: 4px;
}
.io-float .sub {
  font-family:'JetBrains Mono', monospace;
  font-size: 9px;
  color: var(--ink-3);
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-top: 6px;
}

/* ============================================================
   PARTNERS · Two product columns (NEW)
   ============================================================ */
.p2col {
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.p2 {
  background: var(--paper);
  border:1px solid var(--line);
  border-radius: var(--r-4);
  padding: 38px 36px 32px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.p2.deep {
  background: var(--deep);
  color: var(--cream-on-deep);
  border-color: var(--deep-2);
}
.p2::before {
  content:"";
  position:absolute;
  inset:auto -100px -160px auto;
  width: 360px; height: 360px;
  border-radius:50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 22%, transparent), transparent 65%);
  z-index:0;
}
.p2.deep::before { background: radial-gradient(circle, color-mix(in srgb, var(--accent) 30%, transparent), transparent 60%); }
.p2 > * { position:relative; z-index:1; }
.p2 .p2-tag {
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform:uppercase;
  color: var(--accent);
  display:inline-flex; gap:8px; align-items:center;
}
.p2 .p2-tag::before {
  content:""; width:8px; height:8px; border-radius:50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 16%, transparent);
}
.p2 h3.p2-name {
  font-family:'Sora', sans-serif;
  font-size: clamp(30px, 3.4vw, 44px);
  line-height: 1.04;
  letter-spacing:-0.022em;
  font-weight: 400;
  margin-top: 14px;
}
.p2 h3.p2-name em { color: var(--accent); font-style:normal; }
.p2 .p2-lead {
  margin-top: 18px;
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--ink-2);
  max-width: 460px;
}
.p2.deep .p2-lead { color: rgba(233,236,241,0.72); }

.p2-offers {
  list-style:none;
  padding: 18px 0 0;
  margin: 22px 0 0;
  border-top: 1px dashed var(--line);
  display:flex;
  flex-direction: column;
  gap: 0;
}
.p2.deep .p2-offers { border-top-color: rgba(233,236,241,0.12); }
.p2-offers li {
  padding: 14px 0;
  border-bottom: 1px dashed var(--line);
  display:grid;
  grid-template-columns: 22px 1fr;
  gap: 12px;
  align-items: start;
}
.p2.deep .p2-offers li { border-bottom-color: rgba(233,236,241,0.1); }
.p2-offers li:last-child { border-bottom: none; }
.p2-offers li .k {
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.08em;
  padding-top: 3px;
}
.p2-offers li strong {
  font-family:'Sora', sans-serif;
  font-weight: 460;
  font-size: 16.5px;
  letter-spacing:-0.012em;
  display:block;
  margin-bottom: 4px;
}
.p2.deep .p2-offers li strong { color: var(--paper); }
.p2-offers li .d {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-2);
}
.p2.deep .p2-offers li .d { color: rgba(233,236,241,0.7); }

.p2 .p2-who {
  margin-top: 22px;
  display:flex;
  flex-wrap:wrap;
  gap: 6px;
}
.p2 .p2-who span {
  font-family:'JetBrains Mono', monospace;
  font-size: 10px;
  padding: 5px 10px;
  border-radius:999px;
  background: var(--bg-2);
  color: var(--ink-2);
  letter-spacing: 0.06em;
}
.p2.deep .p2-who span {
  background: rgba(233,236,241,0.08);
  color: rgba(233,236,241,0.8);
}
.p2 .p2-cta {
  margin-top: 26px;
}

/* ============================================================
   GSAP-prep helpers (transform-friendly defaults)
   ============================================================ */
[data-gsap-fade] { opacity: 0; transform: translateY(28px); }
[data-gsap-orbit] { will-change: transform; }
.no-js [data-gsap-fade] { opacity: 1; transform: none; }

/* ============================================================
   RESPONSIVE additions
   ============================================================ */
/* The orbital composition needs a wide stage (~520px+) or the absolute cards
   collide with the core. Below the 2-col breakpoint we give the orbit the full
   column so its square stage can breathe and the ring visual is preserved. */
@media (max-width: 1200px) {
  .eco-grid { grid-template-columns: minmax(0, 1fr); gap: 48px; }
  .hero-left, .hero-right { min-width: 0; }
  .eco-sub, .hero-proofs { max-width: 100%; }
}
@media (max-width: 1024px) {
  .portals { grid-template-columns: 1fr; }
  .pz-grid { grid-template-columns: 1fr; gap: 36px; }
  .pz-features { grid-template-columns: 1fr; }
  .p2col { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .io-stage { max-width: 360px; }
  .p2 { padding: 28px 24px; }

  /* Stack the hero proof points so long lines wrap instead of clipping */
  .hero-proofs { flex-direction: column; gap: 12px; align-items: flex-start; }
  .hero-proofs li { max-width: 100%; align-items: flex-start; }
  .hero-proofs li::before { margin-top: 5px; flex: none; }

  /* Phone: keep the rings + core, but the stage is small, so collapse each
     product card to a compact "satellite" pill (dot + name) orbiting the core. */
  .orbit-stage { max-width: 300px; }
  /* Globe pinned dead-centre of the rings (no scroll drift on phones). */
  .orbit-core {
    width: 112px; height: 112px;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
  }
  .orbit-node {
    display: flex;
    align-items: center;
    gap: 8px;
    width: auto;
    padding: 8px 13px;
    border-radius: 999px;
    white-space: nowrap;
  }
  .orbit-node .tag,
  .orbit-node .desc,
  .orbit-node .arrow-mini { display: none; }
  .orbit-node .dot { margin-right: 0; width: 7px; height: 7px; }
  .orbit-node .nm { margin-top: 0; font-size: 15px; }
  /* Evenly spaced 3-point ring around the centred globe. */
  .orbit-node.n-xetf    { top: 11%; left: 50%; }
  .orbit-node.n-eratra  { top: 71%; left: 27%; }
  .orbit-node.n-indeone { top: 71%; left: 73%; }
}

/* ============================================================
   ADDITIONS · launching-soon nav badge, animated prompt bar,
   Earth globe, ETF studio cards, agent desk
   ============================================================ */

/* ---- Nav: launching-soon badge ---- */
.nav-soon { position: relative; display: inline-flex; align-items: center; gap: 7px; }
.soon-pill {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ember);
  background: color-mix(in srgb, var(--ember) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--ember) 35%, transparent);
  padding: 2px 6px; border-radius: 999px; line-height: 1.2;
  display: inline-flex; align-items: center; gap: 5px;
  white-space: nowrap;
}
.soon-pill::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: var(--ember);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--ember) 60%, transparent);
  animation: soonpulse 2s infinite;
}
@keyframes soonpulse {
  0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--ember) 55%, transparent); }
  70% { box-shadow: 0 0 0 7px rgba(206,211,220,0); }
  100% { box-shadow: 0 0 0 0 rgba(206,211,220,0); }
}

/* ---- Animated prompt / ask bar ---- */
.prompt-bar {
  --pc: var(--accent, var(--ember));
  display: flex; align-items: center; gap: 14px;
  width: 100%;
  padding: 15px 16px 15px 18px;
  border-radius: var(--r-3);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.62), rgba(255,255,255,0.44));
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.72);
  box-shadow: 0 0 0 1px var(--hair), 0 18px 40px -28px rgba(16,16,19,0.34), inset 0 1px 0 rgba(255,255,255,0.85);
  position: relative; overflow: hidden;
}
.prompt-bar.on-deep {
  background: rgba(233,236,241,0.05);
  border-color: rgba(233,236,241,0.14);
  box-shadow: 0 22px 46px -28px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.06);
}
.prompt-bar .pb-spark {
  flex: none; width: 34px; height: 34px; border-radius: var(--r-2);
  display: flex; align-items: center; justify-content: center;
  color: var(--pc);
  background: color-mix(in srgb, var(--pc) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--pc) 30%, transparent);
}
.prompt-bar .pb-spark svg { width: 18px; height: 18px; }
.prompt-bar .pb-field {
  flex: 1; min-width: 0; overflow: hidden;
  font-family: 'Space Grotesk', sans-serif; font-size: clamp(14px, 1.3vw, 16px);
  color: var(--ink); line-height: 1.4;
  display: flex; align-items: center;
}
.prompt-bar.on-deep .pb-field { color: var(--paper); }
.prompt-bar .pb-text { white-space: pre; }
.prompt-bar .pb-caret {
  display: inline-block; width: 2px; height: 1.15em; margin-left: 1px;
  background: var(--pc); border-radius: 1px;
  animation: pbcaret 1s steps(1) infinite; vertical-align: -2px;
}
@keyframes pbcaret { 0%,50% { opacity: 1; } 50.01%,100% { opacity: 0; } }
.prompt-bar .pb-send {
  flex: none; display: inline-flex; align-items: center; gap: 7px;
  font-family: 'Space Grotesk', sans-serif; font-size: 13.5px; font-weight: 500;
  color: var(--paper); background: var(--pc);
  border: none; border-radius: var(--r-btn); padding: 9px 16px; cursor: pointer;
  transition: transform .2s var(--ease-out), filter .2s;
}
.prompt-bar .pb-send:hover { transform: translateY(-1px); filter: brightness(1.06); }
.prompt-bar .pb-send .arrow { transition: transform .2s var(--ease-out); }
.prompt-bar .pb-send:hover .arrow { transform: translateX(3px); }
.prompt-hint {
  margin-top: 12px; font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.04em; color: var(--ink-3);
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.prompt-hint.on-deep { color: rgba(233,236,241,0.5); }
.prompt-hint b { color: var(--accent, var(--ember)); font-weight: 500; }
@media (max-width: 768px) {
  /* Two-row composer so the (long, animated) prompt text wraps in full instead of
     being clipped behind the send button. Spark + text on row 1, send on row 2. */
  .prompt-bar {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas:
      "spark field"
      "send  send";
    align-items: start;
    column-gap: 11px; row-gap: 10px;
    padding: 13px 14px;
  }
  .prompt-bar .pb-spark { grid-area: spark; width: 30px; height: 30px; border-radius: 9px; margin-top: 1px; }
  .prompt-bar .pb-spark svg { width: 16px; height: 16px; }
  .prompt-bar .pb-field {
    grid-area: field; display: block; overflow: visible;
    font-size: 14px; white-space: normal; min-height: 2.7em;
  }
  .prompt-bar .pb-text { white-space: pre-wrap; }
  .prompt-bar .pb-send {
    grid-area: send; justify-self: end; align-self: end;
    padding: 9px 18px; border-radius: 999px;
  }
}
@media (max-width: 420px) {
  .prompt-bar { padding: 11px 12px; column-gap: 9px; }
  .prompt-hint { font-size: 10px; gap: 6px; }
}

/* ---- Home ecosystem prompt block ---- */
.eco-prompt { position: relative; z-index: 2; margin-top: clamp(36px, 5vw, 64px); }
.eco-prompt .ep-lead {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3);
  margin-bottom: 14px; display: flex; align-items: center; gap: 9px;
}
.eco-prompt .ep-lead::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--moss);
}

/* ---- Earth globe (replaces orbit-core flat disc) ---- */
.orbit-core.earth {
  /* Blue-marble: deep ocean sphere lit top-left, with a faint ember rim halo
     to tie back to the accent. Fits the cold white canvas far better than a
     warm sun. */
  background: radial-gradient(circle at 30% 26%, #C7CBD2 0%, #6E7178 45%, #17181C 100%);
  box-shadow:
    inset -10px -12px 36px rgba(10,11,14,0.6),
    inset 9px 9px 24px rgba(222,227,237,0.5),
    0 0 0 1px rgba(255,255,255,0.4),
    0 0 64px rgba(176,183,196,0.4),
    0 0 130px rgba(206,211,220,0.14);
  overflow: hidden; isolation: isolate; color: transparent;
}
.orbit-core.earth small { display: none; }
/* Real world map filling the sphere, framed on the India / eastern hemisphere */
.earth-map {
  position: absolute; inset: 0; border-radius: 50%; pointer-events: none;
  background-image: url("earth-map.svg?v=08d83016");
  background-repeat: repeat-x;
  background-size: 236% 138%;
  /* Start offset so India / South Asia is centred when the page loads
     (74% frames India at ~80°E, with China above and Europe to the upper-left).
     The animation then scrolls exactly one full tile (74% → -99.5%) seamlessly. */
  background-position-x: 74%;
  background-position-y: 44%;
  opacity: 0.96;
  z-index: 1;
  animation: earth-spin 42s linear infinite;
}
@keyframes earth-spin {
  from { background-position-x: 74%; }
  to   { background-position-x: -99.5%; }   /* 74 - 173.5 = -99.5 — exactly one tile */
}
@media (prefers-reduced-motion: reduce) {
  .earth-map { animation: none; background-position-x: 74%; }
}
.earth-grat {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border-radius: 50%; pointer-events: none; z-index: 2;
}
.earth-grat ellipse, .earth-grat circle, .earth-grat line {
  fill: none; stroke: rgba(228,233,242,0.22); stroke-width: 1;
  vector-effect: non-scaling-stroke;
}
.earth-shine {
  position: absolute; inset: 0; border-radius: 50%; pointer-events: none;
  background:
    radial-gradient(circle at 30% 26%, rgba(255,255,255,0.6), transparent 42%),
    radial-gradient(circle at 76% 82%, rgba(11,12,15,0.55), transparent 56%);
  z-index: 3;
}

/* ============================================================
   ============  LIQUID PLATINUM · design layer  ==============
   Monochrome + metal overrides, photonic motion, dark hero,
   real-asset chart + scroll-story components.
   ============================================================ */

/* ---- Display scale tuned for Sora ---- */
.eco-headline, .h-display { font-weight: 600; letter-spacing: -0.03em; line-height: 0.98; }
.h-section, .pz-name { font-weight: 600; letter-spacing: -0.025em; }
.eyebrow { font-weight: 500; }

/* ---- Accent words in headlines — solid, classic (no metal) ---- */
.metal, .eco-headline .gradient, .pz-name .gradient {
  color: var(--ink-3);
  -webkit-text-fill-color: currentColor;
}
.section-deep .metal, .pz-deep .metal, .eco-hero .metal,
.section-deep .gradient, .pz-deep .gradient, .eco-hero .gradient {
  color: rgba(245,246,248,0.55);
  -webkit-text-fill-color: currentColor;
}

/* ---- ELECTRIC HAIRLINE / BEAM ---- */
.beam {
  position: absolute; left: 0; right: 0; height: 1px;
  background: var(--beam);
  opacity: .0; pointer-events: none;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 20%, #000 80%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 20%, #000 80%, transparent);
}
.beam.run { animation: beamRun 2.6s var(--ease-out) forwards; }
@keyframes beamRun {
  0% { opacity: 0; transform: translateX(-30%) scaleX(.4); }
  30% { opacity: .9; }
  100% { opacity: .35; transform: translateX(0) scaleX(1); }
}
/* a thin travelling spark line that loops along a track */
.spark-track { position: relative; overflow: hidden; }
.spark-track::after {
  content: ""; position: absolute; top: 0; left: -30%; width: 30%; height: 100%;
  background: linear-gradient(90deg, transparent, var(--spark), transparent);
  filter: blur(.3px);
  animation: sparkRun 3.2s linear infinite;
}
@keyframes sparkRun { from { left: -35%; } to { left: 105%; } }

/* rotating conic "electric ring" — wrap any element; pseudo paints the ring */
.elring { position: relative; isolation: isolate; }
.elring::before {
  content: ""; position: absolute; inset: -1px; border-radius: inherit; z-index: -1;
  padding: 1px;
  background: conic-gradient(from 0deg, transparent 0deg, rgba(255,255,255,0.0) 200deg, rgba(255,255,255,0.85) 300deg, var(--spark) 330deg, transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: ringSpin 5.5s linear infinite;
  opacity: .0; transition: opacity .4s;
}
.elring:hover::before, .elring.live::before { opacity: 1; }
@keyframes ringSpin { to { transform: rotate(360deg); } }

/* ---- PREMIUM GLASS (curved, metal-edged) — overrides earlier sharp glass ---- */
.glass {
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(255,255,255,0.55));
  -webkit-backdrop-filter: blur(22px) saturate(1.4); backdrop-filter: blur(22px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.85);
  border-radius: var(--r-3);
  box-shadow: 0 0 0 1px var(--hair), 0 30px 60px -34px rgba(11,11,13,0.4), inset 0 1px 0 rgba(255,255,255,0.95);
}
.glass-dark {
  background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.02));
  -webkit-backdrop-filter: blur(22px) saturate(1.2); backdrop-filter: blur(22px) saturate(1.2);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r-3);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.14), inset 0 0 0 1px rgba(255,255,255,0.04), 0 40px 80px -40px rgba(0,0,0,0.8);
}

/* ---- BUTTONS · flat, classic black & white (no metal, no glass) ---- */
.btn { font-family: 'Space Grotesk', system-ui, sans-serif; font-weight: 600; letter-spacing: 0; box-shadow: none; }
.btn-primary {
  background: var(--ink); color: var(--paper);
  border: 1px solid var(--ink);
}
.btn-primary:hover { background: #26272B; transform: translateY(-1px); }
/* on dark surfaces the primary simply inverts to a solid white pill */
.eco-hero .btn-primary, .section-deep .btn-primary, .pz-deep .btn-primary {
  background: var(--paper); color: var(--ink); border: 1px solid var(--paper);
}
.eco-hero .btn-primary:hover, .section-deep .btn-primary:hover, .pz-deep .btn-primary:hover { background: #ECECEE; transform: translateY(-1px); }
.eco-hero .btn-ghost, .section-deep .btn-ghost {
  background: transparent; color: var(--cream-on-deep);
  border: 1px solid rgba(245,246,248,0.30);
}
.eco-hero .btn-ghost:hover, .section-deep .btn-ghost:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }

/* ============================================================
   DARK HERO
   ============================================================ */
.eco-hero {
  color: var(--cream-on-deep);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.eco-hero .eco-sub { color: rgba(245,246,248,0.78); }
.eco-hero .eyebrow { color: rgba(245,246,248,0.72); }
.eco-hero .eyebrow::before, .eco-hero .eyebrow.ember::before { background: rgba(245,246,248,0.6); }
.eco-hero .eyebrow.ember { color: rgba(245,246,248,0.82); }

/* metal globe — brushed platinum sphere; map etched (desaturated) */
.earth-map { filter: grayscale(1) contrast(1.15) brightness(1.18); opacity: .5; mix-blend-mode: screen; }
.orbit-core.earth {
  background:
    radial-gradient(circle at 34% 26%, #FAFBFD 0%, #C9CDD4 30%, #6E7178 60%, #2A2C31 100%);
  box-shadow:
    inset -12px -14px 40px rgba(0,0,0,0.6),
    inset 12px 12px 30px rgba(255,255,255,0.55),
    0 0 0 1px rgba(255,255,255,0.4),
    0 0 70px rgba(255,255,255,0.18),
    0 30px 70px -20px rgba(0,0,0,0.85);
}
.orbit-ring.r1 { border-color: rgba(255,255,255,0.16); }
.orbit-ring.r2 { border-color: rgba(255,255,255,0.12); }
.orbit-ring.r3 { border-color: rgba(255,255,255,0.09); }
.orbit-rotor .speck, .orbit-rotor .speck.s2, .orbit-rotor .speck.s3 {
  background: #fff; box-shadow: 0 0 12px rgba(255,255,255,0.9);
}
.orbit-svg .arc, .orbit-svg .arc.a-xetf, .orbit-svg .arc.a-eratra, .orbit-svg .arc.a-indeone { stroke: rgba(255,255,255,0.4); }
/* orbit product chips on dark */
.eco-hero .orbit-node {
  background: linear-gradient(180deg, rgba(20,21,24,0.82), rgba(12,12,14,0.7));
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--cream-on-deep);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 24px 50px -26px rgba(0,0,0,0.9);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
}
.eco-hero .orbit-node .tag { color: rgba(245,246,248,0.5); }
.eco-hero .orbit-node .desc { color: rgba(245,246,248,0.6); }
.eco-hero .orbit-node .nm em { color: #fff; }
.eco-hero .orbit-node .dot { background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,0.12); }
.eco-hero .orbit-node .arrow-mini { color: rgba(245,246,248,0.85); }
.eco-hero .tick-frame { --tk-col: rgba(255,255,255,0.4); }

/* prompt bar on the dark hero */
.eco-hero .prompt-bar {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.eco-hero .pb-field, .eco-hero .pb-text { color: var(--cream-on-deep); }
.eco-hero .pb-spark { color: #fff; background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.2); }
.eco-hero .pb-send { background: var(--paper); color: var(--ink); }
.eco-hero .pb-send:hover { background: #ECECEE; }
.eco-hero .pb-caret { background: #fff; }

/* Hero · AI-first command element */
.hero-ai { margin-top: 30px; max-width: 580px; }
.hero-ai-label {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(245,246,248,0.62);
  margin-bottom: 12px;
}
.hero-ai-label .dot { width: 6px; height: 6px; border-radius: 50%; background: #4ADE80; box-shadow: 0 0 8px rgba(74,222,128,0.8); }

/* "Soon" pill on the dark nav */
.nav-soon .soon-pill {
  color: var(--cream-on-deep);
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.2);
}
.nav-soon .soon-pill::before { background: #fff; box-shadow: 0 0 0 0 rgba(255,255,255,0.5); }
@keyframes soonpulse {
  0% { box-shadow: 0 0 0 0 rgba(255,255,255,0.45); }
  70% { box-shadow: 0 0 0 7px rgba(255,255,255,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); }
}

/* hero photonic beams — faint travelling light hairlines */
.eco-hero .beam[data-beam] { opacity: .4; overflow: visible; }
.eco-hero .beam[data-beam]::after {
  content: ""; position: absolute; top: -1px; height: 3px; width: 22%; left: -22%;
  background: linear-gradient(90deg, transparent, #fff, var(--spark), transparent);
  filter: blur(.4px);
  animation: beamTravel 6s cubic-bezier(.5,0,.5,1) infinite;
}
.eco-hero .beam[data-beam]:nth-of-type(2)::after { animation-delay: 3s; animation-duration: 7s; }
@keyframes beamTravel { 0% { left: -22%; opacity: 0; } 12% { opacity: 1; } 88% { opacity: 1; } 100% { left: 100%; opacity: 0; } }

/* ============================================================
   STORY · problem (light) → shift (dark) + real market asset
   ============================================================ */
.story { padding-top: clamp(80px, 11vw, 150px); }
.story-head { max-width: 920px; }
.story-claim { margin-top: 16px; font-size: clamp(34px, 5.4vw, 76px); line-height: 0.98; }
.story .lead { max-width: 640px; color: var(--ink-2); }

.pain-row {
  margin-top: clamp(40px, 5vw, 64px);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.pain {
  position: relative;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  padding: 30px 28px 30px;
  overflow: hidden;
  transition: transform .4s var(--ease-out), box-shadow .4s var(--ease-out), border-color .3s;
}
.pain:hover { transform: translateY(-4px); border-color: transparent; box-shadow: 0 30px 60px -34px rgba(11,11,13,0.4); }
.pain-no {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.2em;
  color: var(--ink-4);
}
.pain-ic { width: 30px; height: 30px; color: var(--ink); margin: 18px 0 16px; display: block; }
.pain h3 { margin: 0 0 8px; }
.pain p { font-size: 14.5px; line-height: 1.55; color: var(--ink-3); }

/* ---- shift (dark) ---- */
.story-solve { overflow: hidden; }
.solve-grid {
  display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(40px, 5vw, 76px);
  align-items: center;
}
.solve-copy .lead { color: rgba(245,246,248,0.7); max-width: 560px; }
.solve-stats { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
.solve-stats .stat {
  flex: 1; min-width: 120px;
  border-left: 1px solid rgba(255,255,255,0.14); padding-left: 16px;
}
.solve-stats .num {
  display: block; font-family: 'Sora', sans-serif; font-weight: 600;
  font-size: clamp(30px, 3.4vw, 46px); line-height: 1;
  background: var(--platinum); -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
}
.solve-stats .lbl {
  display: block; margin-top: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgba(245,246,248,0.5);
}

/* ---- real market panel ---- */
.mkt-panel {
  position: relative; padding: 22px 22px 18px; border-radius: var(--r-4);
  color: var(--cream-on-deep);
}
.mkt-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.mkt-name { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 18px; letter-spacing: -0.01em; }
.mkt-sub { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.06em; color: rgba(245,246,248,0.45); margin-top: 5px; }
.mkt-live { font-family: 'JetBrains Mono', monospace; font-size: 9.5px; letter-spacing: 0.18em; color: rgba(245,246,248,0.7); display: inline-flex; align-items: center; gap: 7px; }
.mkt-live .ld { width: 6px; height: 6px; border-radius: 50%; background: #fff; box-shadow: 0 0 10px #fff; animation: pulse 1.6s ease-in-out infinite; }
.mkt-figs { display: flex; align-items: baseline; gap: 14px; margin: 18px 0 12px; }
.mkt-val { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(30px, 3.6vw, 44px); letter-spacing: -0.02em; }
.mkt-val .cents { color: rgba(245,246,248,0.4); font-size: 0.6em; }
.mkt-delta { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--cream-on-deep); }
.mkt-delta span { color: rgba(245,246,248,0.4); }
.mkt-chart { width: 100%; height: 200px; }
.mkt-chart svg { width: 100%; height: 100%; display: block; overflow: visible; }
.mk-line { filter: drop-shadow(0 0 6px rgba(255,255,255,0.35)); }
.mk-dot { filter: drop-shadow(0 0 8px #fff); }
.mkt-foot {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
  margin-top: 14px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.1);
}
.mkt-foot .k { display: block; font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,246,248,0.45); }
.mkt-foot .v { display: block; font-family: 'Sora', sans-serif; font-weight: 600; font-size: 18px; margin-top: 4px; }

@media (max-width: 1024px) {
  .solve-grid { grid-template-columns: 1fr; gap: 40px; }
  .pain-row { grid-template-columns: 1fr; }
}

/* ============================================================
   DARK-SECTION ACCENT FIXES (monochrome)
   On black surfaces, accent/ember/moss/gold flip to light so
   labels, bars, em-words and dots stay visible. Solid buttons
   are forced to brushed platinum (dark text).
   ============================================================ */
.section-deep, .pz-deep, .story-solve, .partner-cta, .ticker, .footer,
.platform-block, .trap-section, .ucits-cmp, .px-foot-cta {
  --ember: var(--cream-on-deep);  --ember-2: #ffffff;
  --moss:  var(--cream-on-deep);  --moss-2:  #ffffff;
  --gold:  var(--cream-on-deep);  --gold-2:  #ffffff;
  --accent: var(--cream-on-deep); --accent-2: #ffffff;
}
/* solid buttons on dark sections → flat white pill (no metal) */
.section-deep .btn-accent, .pz-deep .btn-accent,
.section-deep .btn-ember, .partner-cta .btn-ember, .pz-deep .btn-ember {
  background: var(--paper); color: var(--ink); border: 1px solid var(--paper);
}
.section-deep .btn-accent:hover, .pz-deep .btn-accent:hover,
.section-deep .btn-ember:hover, .partner-cta .btn-ember:hover, .pz-deep .btn-ember:hover {
  background: #ECECEE; transform: translateY(-1px);
}
/* metal gradient numerals/names already handled; keep pz-tag bar visible */
.pz-deep .pz-tag::before, .section-deep .pz-tag::before { background: rgba(245,246,248,0.55); }
.ticker .dot { color: rgba(245,246,248,0.55); }

/* photographic backdrops → full monochrome, etched into the black */
.photo-bd::before { filter: grayscale(1) contrast(1.1) brightness(0.4); opacity: 0.4; }

/* hero headline — pure white for punch (metal word keeps the chrome) */
.eco-hero .eco-headline { color: #FFFFFF; font-weight: 600; }
.eco-hero .eco-headline .gradient { font-weight: 600; }
/* section-deep big headings → bright white (metal words still chrome) */
.section-deep .h-section, .pz-deep .pz-name, .story-solve .h-section { color: #FFFFFF; }

/* ============================================================
   ============================================================
   inde ONE · v8 COMPONENT LAYER  (overrides everything above)
   Light-primary · one graphite accent · dark contrast bands.
   Sharp flat cards (ElevenLabs) · public.com asset strip ·
   adaptive submerged nav · mega-menu · three.js stage.
   Scope: body.io
   ============================================================
   ============================================================ */

body.io { background: var(--bg); color: var(--ink); }
body.io main, body.io section, body.io footer { position: relative; }

/* tighten display headings a touch, classic + sharp */
.io .h-section { font-size: clamp(30px, 4vw, 58px); letter-spacing: -0.035em; line-height: 1.02; }
.io .h-card { font-size: 19px; }

/* ----- Dark contrast band ----- */
.io .section-dark { background: #060607; color: var(--cream-on-deep); overflow: hidden; }
.io .section-dark .eyebrow { color: rgba(245,246,248,0.58); }
.io .section-dark .eyebrow::before { background: rgba(245,246,248,0.5); }
.io .section-dark .h-section, .io .section-dark h2, .io .section-dark h3 { color: #fff; }
.io .section-dark .lead { color: rgba(245,246,248,0.7); }

/* ============================================================
   NAV — fixed, submerged by default, glass once scrolled, adaptive
   ============================================================ */
.io .nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  background: transparent; border-bottom: 1px solid transparent; box-shadow: none;
  transition: background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.io .nav-inner { gap: 16px; padding: 13px var(--pad); }
.io .nav-links { display: flex; gap: 2px; align-items: center; font-size: 14px; }

/* brand + link colours adapt to the section behind the bar */
.io .nav .brand-word { color: var(--ink); }
.io .nav .nav-links { color: var(--ink-2); }
.io .nav .brand-mark--light { display: none; }
.io .nav .brand-mark--dark { display: block; }
.io .nav--on-dark .brand-word { color: var(--cream-on-deep); }
.io .nav--on-dark .nav-links { color: rgba(245,246,248,0.84); }
.io .nav--on-dark .brand-mark--light { display: block; }
.io .nav--on-dark .brand-mark--dark { display: none; }
.io .nav--on-dark .btn-primary { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.io .nav--on-dark .btn-primary:hover { background: #E9E9EC; }
.io .nav--on-light .btn-primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* glass appears only after scrolling away from the very top */
.io .nav--scrolled.nav--on-light {
  background: rgba(255,255,255,0.82);
  -webkit-backdrop-filter: blur(24px) saturate(1.8); backdrop-filter: blur(24px) saturate(1.8);
  border-bottom: 1px solid var(--line);
}
.io .nav--scrolled.nav--on-dark {
  background: rgba(10,11,14,0.7);
  -webkit-backdrop-filter: blur(26px) saturate(1.5); backdrop-filter: blur(26px) saturate(1.5);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* adaptive glass controls (lang switch / mobile toggle) */
.io .nav--on-dark .lang-switch { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.2); box-shadow: none; }
.io .nav--on-dark .lang-switch button { color: rgba(245,246,248,0.7); }
.io .nav--on-dark .lang-switch button + button { border-left-color: rgba(255,255,255,0.16); }
.io .nav--on-dark .lang-switch button.active { background: var(--paper); color: var(--ink); }
.io .nav--on-dark .nav-toggle { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.2); color: var(--cream-on-deep); box-shadow: none; }
.io .nav--on-light .lang-switch { background: rgba(255,255,255,0.5); border-color: var(--line-2); }
.io .nav--on-light .lang-switch button { color: var(--ink-3); }
.io .nav--on-light .lang-switch button.active { background: var(--ink); color: var(--paper); }

/* group trigger + chevron */
.io .nav-group { position: relative; }
.io .nav-group > a, .io .nav-links > a.nav-flat {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 13px; border-radius: 11px; color: inherit; cursor: pointer;
  transition: background .2s var(--ease), color .2s var(--ease);
}
.io .nav-group > a .chev {
  width: 6px; height: 6px; border-right: 1.6px solid currentColor; border-bottom: 1.6px solid currentColor;
  transform: rotate(45deg); margin-top: -2px; opacity: .5;
  transition: transform .3s var(--ease), opacity .2s var(--ease);
}
.io .nav-group:hover > a, .io .nav-group:focus-within > a,
.io .nav-links > a.nav-flat:hover { background: rgba(11,11,13,0.06); }
.io .nav--on-dark .nav-group:hover > a, .io .nav--on-dark .nav-group:focus-within > a,
.io .nav--on-dark .nav-links > a.nav-flat:hover { background: rgba(255,255,255,0.12); color: #fff; }
.io .nav-group:hover > a .chev, .io .nav-group:focus-within > a .chev { transform: rotate(225deg); opacity: .85; margin-top: 2px; }

/* ===== MEGA-MENU · two-pane (products | page sections) ===== */
.io .mega {
  position: absolute; top: 100%; left: 0;
  padding-top: 12px;
  width: min(720px, 92vw);
  opacity: 0; visibility: hidden; pointer-events: none;
  transform: translateY(4px);
  transition: opacity .2s var(--ease), transform .2s var(--ease);
}
.io .nav-group--right .mega { left: auto; right: 0; }
.io .nav-group:hover .mega, .io .nav-group:focus-within .mega { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
.io .mega-card {
  display: flex; overflow: hidden;
  background: rgba(255,255,255,0.98);
  -webkit-backdrop-filter: blur(30px) saturate(1.7); backdrop-filter: blur(30px) saturate(1.7);
  border: 1px solid var(--line); border-radius: 20px;
  box-shadow: 0 40px 90px -36px rgba(11,11,13,0.45), 0 2px 8px rgba(11,11,13,0.06);
}
.io .mega-list { flex: 0 0 320px; padding: 10px; display: flex; flex-direction: column; gap: 2px; }
.io .mega-item {
  display: flex; gap: 13px; align-items: center; padding: 12px 13px; border-radius: 13px;
  text-decoration: none; color: var(--ink); transition: background .18s var(--ease);
}
.io .mega-item:hover, .io .mega-item.active { background: rgba(11,11,13,0.05); }
.io .mega-item .mi-ic { flex: none; width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; background: var(--ink); color: #fff; }
.io .mega-item .mi-ic svg { width: 18px; height: 18px; }
.io .mega-item .mi-tx { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.io .mega-item .mi-t { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 14.5px; letter-spacing: -0.01em; }
.io .mega-item .mi-d { font-size: 12px; color: var(--ink-3); line-height: 1.35; margin-top: 2px; }
.io .mega-item .mi-go { color: var(--ink-4); font-size: 19px; transition: transform .2s var(--ease), color .2s; }
.io .mega-item:hover .mi-go, .io .mega-item.active .mi-go { color: var(--ink); transform: translateX(3px); }
/* keep product title/desc dark + legible on hover (never washes lighter) */
.io .mega-item:hover .mi-t, .io .mega-item.active .mi-t, .io .mega-item:focus .mi-t { color: var(--ink); }
.io .mega-item:hover .mi-d, .io .mega-item.active .mi-d { color: var(--ink-2); }
.io .mega-pane { flex: 1; border-left: 1px solid var(--line); background: rgba(244,244,247,0.7); padding: 22px; display: flex; flex-direction: column; justify-content: center; }
.io .mp-h { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 12px; display: block; }
.io .mp-default { color: var(--ink-3); }
.io .mp-default p { margin: 0; font-size: 13.5px; line-height: 1.5; max-width: 24ch; }
.io .mega-pane.has-active .mp-default { display: none; }
.io .mp-sec { display: none; flex-direction: column; gap: 2px; }
.io .mp-sec.active { display: flex; }
.io .mp-sec a { display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 9px; font-size: 14px; color: var(--ink-2); transition: background .18s var(--ease), color .18s; }
.io .mp-sec a:hover { background: #fff; color: var(--ink); }
.io .mp-sec .mps-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--ink-4); flex: none; transition: background .18s; }
.io .mp-sec a:hover .mps-dot { background: var(--ink); }

/* ============================================================
   HERO — dark cinematic video, submerged nav over the top
   ============================================================ */
.io .eco-hero { padding: clamp(150px, 22vh, 260px) 0 clamp(80px, 12vh, 150px); }
.io .eco-hero .hero-veil {
  background:
    linear-gradient(180deg, rgba(6,6,9,0.82) 0%, rgba(6,6,9,0.46) 16%, rgba(6,6,9,0.34) 40%, rgba(6,6,9,0.48) 68%, rgba(6,6,9,0.94) 100%);
}
/* dedicated scrim behind the submerged nav so light text never washes out */
.io .eco-hero::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 140px; z-index: 1;
  background: linear-gradient(180deg, rgba(6,6,9,0.55), rgba(6,6,9,0));
  pointer-events: none;
}
.io .eco-hero .wrap { z-index: 2; }
.io .eco-hero .eco-headline { color: #fff; font-weight: 600; font-size: clamp(40px, 6vw, 84px); letter-spacing: -0.045em; line-height: 0.98; }
.io .eco-hero .eco-sub { color: rgba(245,246,248,0.78); max-width: 600px; margin-top: 26px; font-size: clamp(16px,1.5vw,20px); }
.io .eco-hero .eyebrow { color: rgba(245,246,248,0.72); }
.io .eco-hero .eyebrow::before { background: rgba(245,246,248,0.5); }
.io .hero-trust { display: flex; flex-wrap: wrap; gap: 10px 26px; margin-top: 34px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,246,248,0.6); }
.io .hero-trust span { display: inline-flex; align-items: center; gap: 8px; }
.io .hero-trust span::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: rgba(245,246,248,0.5); }

/* AI prompt bar on hero (glass over video) */
.io .hero-ai { margin-top: 38px; max-width: 600px; }
.io .hero-ai-label { display: inline-flex; align-items: center; gap: 9px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.08em; color: rgba(245,246,248,0.7); margin-bottom: 12px; }
.io .hero-ai-label .dot { width: 7px; height: 7px; border-radius: 50%; background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,0.16); animation: pulse 1.8s ease-in-out infinite; }
.io .prompt-bar {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.1);
  -webkit-backdrop-filter: blur(20px) saturate(1.4); backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.2); border-radius: 999px;
  padding: 8px 8px 8px 18px;
}
.io .prompt-bar .pb-spark { color: rgba(255,255,255,0.8); display: grid; place-items: center; }
.io .prompt-bar .pb-spark svg { width: 18px; height: 18px; }
.io .prompt-bar .pb-field { flex: 1; min-width: 0; overflow: hidden; display: flex; align-items: center; white-space: nowrap; color: #fff; font-size: 14.5px; font-family: 'Space Grotesk', sans-serif; -webkit-mask-image: linear-gradient(90deg, #000 calc(100% - 16px), transparent); mask-image: linear-gradient(90deg, #000 calc(100% - 16px), transparent); }
.io .prompt-bar .pb-caret { width: 2px; height: 16px; background: #fff; margin-left: 2px; animation: blink 1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }
.io .prompt-bar .pb-send { flex: none; display: inline-flex; align-items: center; gap: 7px; background: #fff; color: var(--ink); border: 0; border-radius: 999px; padding: 9px 16px; font-family: 'Space Grotesk', sans-serif; font-size: 13px; font-weight: 500; cursor: pointer; white-space: nowrap; transition: transform .2s var(--ease); }
.io .prompt-bar .pb-send:hover { transform: translateY(-1px); }
/* Mobile: full prompt text on its own row, CTA on a second row — never squeeze
   the button or push it off-centre when the (animated) prompt grows. */
@media (max-width: 680px) {
  .io .prompt-bar {
    display: grid; grid-template-columns: auto 1fr;
    grid-template-areas: "spark field" "send send";
    align-items: start; column-gap: 11px; row-gap: 12px;
    border-radius: 20px; padding: 14px 16px;
  }
  .io .prompt-bar .pb-spark { grid-area: spark; align-self: start; }
  .io .prompt-bar .pb-field { grid-area: field; display: block; overflow: visible; white-space: normal; }
  .io .prompt-bar .pb-field .pb-text { white-space: normal; overflow-wrap: anywhere; }
  .io .prompt-bar .pb-send { grid-area: send; justify-self: stretch; justify-content: center; padding: 11px 16px; }
}

/* ============================================================
   INNER-PAGE HERO — clean light (or dark) headline hero
   ============================================================ */
.io .page-hero { padding: clamp(130px, 18vh, 200px) 0 clamp(54px, 8vh, 90px); position: relative; overflow: hidden; }
.io .page-hero .ph-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px,5vw,64px); align-items: center; }
.io .page-hero .ph-eyebrow { display: inline-flex; align-items: center; gap: 9px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); }
.io .page-hero .ph-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--ink); box-shadow: 0 0 0 4px rgba(11,11,13,0.08); }
.io .page-hero h1 { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(38px, 5.4vw, 76px); line-height: 0.98; letter-spacing: -0.045em; margin: 20px 0 0; }
.io .page-hero .ph-sub { margin: 22px 0 0; font-size: clamp(16px,1.5vw,20px); line-height: 1.55; color: var(--ink-2); max-width: 520px; }
.io .page-hero .h7-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.io .page-hero .ph-stats { display: flex; flex-wrap: wrap; gap: 18px 40px; margin-top: 38px; }
.io .page-hero .ph-stats .st .num { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(26px,3vw,38px); letter-spacing: -0.03em; display: block; }
.io .page-hero .ph-stats .st .lbl { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
/* dark hero variant */
.io .page-hero.dark { background: #060607; color: var(--cream-on-deep); }
.io .page-hero.dark h1 { color: #fff; }
.io .page-hero.dark .ph-sub { color: rgba(245,246,248,0.72); }
.io .page-hero.dark .ph-eyebrow { color: rgba(245,246,248,0.6); }
.io .page-hero.dark .ph-eyebrow .dot { background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,0.14); }
.io .page-hero.dark .ph-stats .st .num { color: #fff; }
.io .page-hero.dark .ph-stats .st .lbl { color: rgba(245,246,248,0.55); }
.io .page-hero.dark .ph-bd { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; filter: grayscale(1) contrast(1.05) brightness(0.4); opacity: 0.5; }
.io .page-hero.dark .wrap { position: relative; z-index: 2; }
.io .page-hero.dark::after { content:""; position:absolute; inset:0; z-index:1; background: linear-gradient(180deg, rgba(6,6,9,0.5), rgba(6,6,9,0.9)); pointer-events:none; }

/* simple CTA strip */
.io .cta-strip { text-align: center; }
.io .cta-strip h2 { margin-bottom: 26px; }

/* feature list (checks) */
.io .flist { list-style: none; margin: 22px 0 0; padding: 0; }
.io .flist li { display: flex; gap: 12px; align-items: flex-start; padding: 12px 0; border-top: 1px solid var(--line); font-size: 15px; color: var(--ink-2); }
.io .flist li::before { content: "→"; font-family: 'JetBrains Mono', monospace; color: var(--ink); flex: none; }
.io .section-dark .flist li { border-top-color: rgba(255,255,255,0.1); color: rgba(245,246,248,0.78); }
.io .section-dark .flist li::before { color: #fff; }

@media (max-width: 1000px) { .io .page-hero .ph-grid { grid-template-columns: 1fr; } }

/* ============================================================
   ASSET-CLASS STRIP — public.com style serif marquee
   ============================================================ */
.io .assets { padding: clamp(54px, 8vw, 96px) 0; border-bottom: 1px solid var(--line); background: var(--paper); }
.io .assets-head { text-align: center; max-width: 720px; margin: 0 auto clamp(34px,5vw,56px); }
.io .assets-head .eyebrow { justify-content: center; }
.io .assets-head h2 { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(26px,3.2vw,42px); letter-spacing: -0.03em; margin-top: 16px; }
.io .assets-cloud { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 8px 4px; max-width: 1000px; margin: 0 auto; }
.io .asset-word {
  font-family: 'Sora', sans-serif; font-weight: 600; letter-spacing: -0.02em;
  font-size: clamp(22px, 3.4vw, 44px); color: var(--ink); line-height: 1.25;
  padding: 2px 12px; display: inline-flex; align-items: center; gap: 10px;
}
.io .asset-word .pill { font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 400; letter-spacing: 0.04em; background: var(--ink); color: #fff; padding: 3px 8px; border-radius: 6px; transform: translateY(-6px); }
.io .asset-word .pill.soft { background: var(--bg-2); color: var(--ink-2); }
.io .asset-sep { color: var(--ink-4); font-size: clamp(18px,2vw,28px); }
.io .asset-word.muted { color: var(--ink-4); }

/* ============================================================
   SHARP FLAT CARDS — ElevenLabs style (non-clickable, no lift)
   ============================================================ */
.io .scard {
  background: #F6F6F8; border: 1px solid transparent; border-radius: 18px;
  padding: 26px 26px 28px; position: relative; min-height: 200px;
  display: flex; flex-direction: column;
}
.io .scard .sc-ic { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; background: #fff; border: 1px solid var(--line); color: var(--ink); margin-bottom: auto; }
.io .scard .sc-ic svg { width: 18px; height: 18px; }
.io .scard .sc-t { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 16px; letter-spacing: -0.01em; margin-top: 56px; }
.io .scard .sc-d { font-size: 14px; color: var(--ink-3); line-height: 1.5; margin-top: 9px; }
.io .scard.tall { min-height: 280px; }
/* dark variant */
.io .section-dark .scard { background: rgba(255,255,255,0.045); border-color: rgba(255,255,255,0.07); }
.io .section-dark .scard .sc-ic { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); color: #fff; }
.io .section-dark .scard .sc-t { color: #fff; }
.io .section-dark .scard .sc-d { color: rgba(245,246,248,0.62); }
/* feature image card (rich gradient/photo top) */
.io .scard.media { padding: 0; overflow: hidden; min-height: 320px; }
.io .scard.media .sc-media { height: 190px; background-size: cover; background-position: center; position: relative; }
.io .scard.media .sc-body { padding: 22px 24px 26px; }
.io .scard.media .sc-t { margin-top: 0; }

.io .scard-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.io .scard-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.io .scard-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ============================================================
   SWIM LANES — 2 rows (Individuals / Institutions), 2 cards each
   ============================================================ */
.io .lanes { display: flex; flex-direction: column; gap: 14px; }
.io .lane-row { display: grid; grid-template-columns: 200px 1fr 1fr; gap: 16px; align-items: stretch; }
.io .lane-label { display: flex; flex-direction: column; justify-content: center; gap: 8px; }
.io .lane-label .lr-k { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-4); }
.io .lane-label .lr-t { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(20px,2vw,26px); letter-spacing: -0.025em; line-height: 1.05; }
.io .lane {
  display: flex; flex-direction: column; text-decoration: none; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line); border-radius: 18px;
  padding: 26px 26px 24px; position: relative; overflow: hidden;
  transition: border-color .3s var(--ease), box-shadow .35s var(--ease-out), transform .35s var(--ease-out);
}
.io .lane:hover { border-color: var(--ink-4); box-shadow: 0 26px 54px -34px rgba(11,11,13,0.3); transform: translateY(-3px); }
.io .lane .ln-tag { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); display: inline-flex; align-items: center; gap: 8px; }
.io .lane .ln-tag .geo { background: var(--bg-2); padding: 3px 8px; border-radius: 5px; }
.io .lane h3 { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(22px,2.2vw,28px); letter-spacing: -0.025em; margin: 16px 0 10px; line-height: 1.06; }
.io .lane p { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; margin: 0; }
.io .lane .ln-feats { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; }
.io .lane .ln-feats span { font-size: 12px; padding: 5px 11px; border-radius: 999px; background: var(--bg-2); color: var(--ink-2); }
.io .lane .ln-go { margin-top: 20px; display: inline-flex; align-items: center; gap: 7px; font-weight: 500; font-size: 14px; color: var(--ink); }
.io .lane .ln-go .arrow { transition: transform .25s var(--ease); }
.io .lane:hover .ln-go .arrow { transform: translateX(4px); }
/* institutional row = darker cards for separation */
.io .lane-row.inst .lane { background: #0b0c0f; border-color: #1a1c20; color: var(--cream-on-deep); }
.io .lane-row.inst .lane:hover { border-color: #34373d; box-shadow: 0 26px 60px -34px rgba(0,0,0,0.7); }
.io .lane-row.inst .lane h3 { color: #fff; }
.io .lane-row.inst .lane p { color: rgba(245,246,248,0.66); }
.io .lane-row.inst .lane .ln-tag { color: rgba(245,246,248,0.6); }
.io .lane-row.inst .lane .ln-tag .geo { background: rgba(255,255,255,0.08); }
.io .lane-row.inst .lane .ln-feats span { background: rgba(255,255,255,0.07); color: rgba(245,246,248,0.8); }
.io .lane-row.inst .lane .ln-go { color: #fff; }
.io .lane-row.inst .lane-label .lr-t { color: var(--ink); }

/* ============================================================
   STORY — narrative two-column blocks
   ============================================================ */
.io .story7 { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(36px,5vw,72px); align-items: center; }
.io .story7.flip .st-media { order: -1; }
.io .story7 .st-copy .eyebrow { margin-bottom: 18px; }
.io .story7 .st-copy h2 { margin-bottom: 20px; }
.io .story7 .st-media { position: relative; }
.io .media-frame { position: relative; border-radius: var(--r-4); overflow: hidden; border: 1px solid var(--line); box-shadow: 0 40px 90px -44px rgba(11,11,13,0.4); background: #000; aspect-ratio: 4/3; }
.io .media-frame img, .io .media-frame video { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.02) contrast(1.03); }
.io .section-dark .media-frame { border-color: rgba(255,255,255,0.1); }

/* 3D three.js stage */
.io .scene-stage { position: relative; aspect-ratio: 1/1; min-height: 360px; }
.io .scene-canvas { width: 100%; height: 100%; display: block; }
.io .scene-stage::after { content: ""; position: absolute; inset: 0; background: radial-gradient(closest-side, rgba(255,255,255,0.05), transparent 72%); pointer-events: none; }

/* big stat row */
.io .statline { display: flex; flex-wrap: wrap; gap: 14px 48px; margin-top: 34px; }
.io .statline .st { display: flex; flex-direction: column; gap: 4px; }
.io .statline .st .num { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(28px,3vw,40px); letter-spacing: -0.03em; }
.io .statline .st .lbl { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.io .section-dark .statline .st .lbl { color: rgba(245,246,248,0.55); }

/* ============================================================
   WHY-INDIA explainer (EU institutions)
   ============================================================ */
.io .why-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.io .why-item { display: flex; gap: 16px; padding: 24px 24px; background: rgba(255,255,255,0.045); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; }
.io .why-item .wi-fig { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 24px; letter-spacing: -0.02em; color: #fff; flex: none; min-width: 92px; }
.io .why-item .wi-tx strong { display: block; font-family: 'Sora', sans-serif; font-weight: 600; font-size: 15px; color: #fff; margin-bottom: 5px; }
.io .why-item .wi-tx p { font-size: 13.5px; color: rgba(245,246,248,0.62); line-height: 1.5; }

/* ============================================================
   ETF STUDIO — filterable ETF cards (monochrome, dark band)
   ============================================================ */
.io .fomo-line { display: inline-flex; align-items: center; gap: 10px; font-size: 14px; color: rgba(245,246,248,0.7); margin-bottom: 22px; }
.io .fomo-line .pulse { width: 8px; height: 8px; border-radius: 50%; background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,0.12); animation: pulse 1.8s ease-in-out infinite; flex: none; }
.io .fomo-line strong { color: #fff; }

.io .etf-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 26px; }
.io .etf-filter { appearance: none; cursor: pointer; font-family: 'Space Grotesk', sans-serif; font-size: 13px; padding: 8px 15px; border-radius: 999px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); color: rgba(245,246,248,0.78); transition: background .2s, color .2s, border-color .2s; }
.io .etf-filter:hover { background: rgba(255,255,255,0.1); color: #fff; }
.io .etf-filter.active { background: #fff; color: #0b0b0d; border-color: #fff; }

/* scoped to #etfGrid so it never collides with the UCITS shelf .etf-card */
.io #etfGrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.io #etfGrid .etf-card { display: flex; flex-direction: column; text-decoration: none; border-radius: 16px; overflow: hidden; border: 1px solid rgba(255,255,255,0.1); background: #0d0e11; transition: border-color .3s var(--ease), transform .35s var(--ease-out), box-shadow .35s var(--ease-out); }
.io #etfGrid .etf-card:hover { border-color: rgba(255,255,255,0.28); transform: translateY(-3px); box-shadow: 0 26px 54px -34px rgba(0,0,0,0.8); }
.io #etfGrid .etf-card.hide { display: none; }
.io #etfGrid .etf-card.clip { display: none; }
.io #etfGrid .etf-cover { position: relative; padding: 16px; min-height: 92px; display: flex; flex-direction: column; justify-content: space-between; background: linear-gradient(150deg, rgba(255,255,255,0.1), rgba(255,255,255,0.02) 60%), #16181c; overflow: hidden; }
.io #etfGrid .etf-cover-glyph { position: absolute; right: -14px; top: -10px; width: 78px; height: 78px; color: rgba(255,255,255,0.06); }
.io #etfGrid .etf-logo { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 13px; color: #fff; width: 30px; height: 30px; border-radius: 8px; background: rgba(255,255,255,0.1); display: grid; place-items: center; border: 1px solid rgba(255,255,255,0.14); overflow: hidden; }
.io #etfGrid .etf-logo:has(img) { background: #fff; border-color: rgba(0,0,0,0.08); padding: 4px; }
.io #etfGrid .etf-logo img { width: 100%; height: 100%; object-fit: contain; display: block; }
.io #etfGrid .etf-dom { position: absolute; top: 16px; right: 16px; font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(245,246,248,0.7); border: 1px solid rgba(255,255,255,0.18); border-radius: 5px; padding: 3px 7px; }
/* subtle, classic colour-coding of the wrapper */
.io #etfGrid .etf-dom.us { color: #8fb6e0; border-color: rgba(143,182,224,0.4); }
.io #etfGrid .etf-dom.uc { color: #9ec9a6; border-color: rgba(158,201,166,0.4); }
.io #etfGrid .etf-cover-foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 8px; position: relative; z-index: 1; }
.io #etfGrid .etf-theme { font-family: 'JetBrains Mono', monospace; font-weight: 500; font-size: 13px; color: #fff; letter-spacing: 0.06em; line-height: 1.1; }
.io #etfGrid .etf-perf { font-family: 'JetBrains Mono', monospace; font-size: 14px; color: #6fc189; white-space: nowrap; }
.io #etfGrid .etf-perf small { font-size: 9px; color: rgba(245,246,248,0.5); margin-left: 3px; }
.io #etfGrid .etf-body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 9px; }
.io #etfGrid .etf-id { display: flex; flex-direction: column; align-items: flex-start; gap: 3px; }
.io #etfGrid .etf-tk { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 14.5px; color: #fff; line-height: 1.2; letter-spacing: -0.01em; }
.io #etfGrid .etf-issuer { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(245,246,248,0.45); }
.io #etfGrid .etf-name { font-size: 13px; color: rgba(245,246,248,0.72); line-height: 1.35; }
.io #etfGrid .etf-isin { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: rgba(245,246,248,0.4); border: 1px solid rgba(255,255,255,0.08); border-radius: 5px; padding: 3px 7px; align-self: flex-start; }
.io #etfGrid .etf-holds { display: flex; gap: 6px; flex-wrap: wrap; }
.io #etfGrid .etf-holds .hld { display: inline-flex; align-items: center; gap: 5px; font-family: 'JetBrains Mono', monospace; font-size: 10px; color: rgba(245,246,248,0.78); background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); border-radius: 999px; padding: 3px 8px 3px 3px; }
.io #etfGrid .etf-holds .hld i { width: 16px; height: 16px; border-radius: 50%; background: rgba(255,255,255,0.12); display: grid; place-items: center; font-size: 8px; font-style: normal; color: #fff; overflow: hidden; }
.io #etfGrid .etf-holds .hld i:has(img) { background: #fff; }
.io #etfGrid .etf-holds .hld i img { width: 100%; height: 100%; object-fit: contain; padding: 1.5px; box-sizing: border-box; }
.io #etfGrid .etf-holds .hld.more { background: transparent; color: rgba(245,246,248,0.5); padding: 3px 8px; }
.io #etfGrid .etf-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,0.08); }
.io #etfGrid .etf-stats div { display: flex; flex-direction: column; gap: 2px; }
.io #etfGrid .etf-stats .sv { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 13px; color: #fff; }
.io #etfGrid .etf-stats .sl { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,246,248,0.45); }
.io #etfGrid .etf-empty { display: none; grid-column: 1/-1; text-align: center; color: rgba(245,246,248,0.5); padding: 40px 0; }
.io .etf-more-row { display: flex; justify-content: center; margin-top: 26px; }
/* the [hidden] attribute must win over the explicit display below */
.io .etf-more[hidden] { display: none; }
.io .etf-more { display: inline-flex; align-items: center; gap: 9px; cursor: pointer; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14); color: #fff; border-radius: 999px; padding: 11px 20px; font-family: 'Space Grotesk', sans-serif; font-size: 13.5px; transition: background .2s; }
.io .etf-more:hover { background: rgba(255,255,255,0.1); }
.io .etf-more .ec { font-family: 'JetBrains Mono', monospace; color: rgba(245,246,248,0.6); font-size: 12px; }
.io .etf-more.open .ea { transform: rotate(180deg); }
.io .etf-more .ea { transition: transform .25s; }

@media (max-width: 900px) { .io #etfGrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .io #etfGrid { grid-template-columns: 1fr; } }

/* ============================================================
   CUSTOM BUILDER — basket composer mock (light card)
   ============================================================ */
.io .builder { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px,5vw,64px); align-items: center; }
.io .builder-panel { background: #0c0d10; border: 1px solid #1a1c20; border-radius: var(--r-4); padding: 26px; box-shadow: 0 40px 90px -44px rgba(0,0,0,0.5); }
.io .builder-panel .bp-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,0.08); margin-bottom: 16px; }
.io .builder-panel .bp-title { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 15px; color: #fff; }
.io .builder-panel .bp-tag { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,246,248,0.5); }
.io .bp-row { display: grid; grid-template-columns: 86px 1fr 46px; gap: 12px; align-items: center; padding: 9px 0; }
.io .bp-row .bp-name { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: rgba(245,246,248,0.85); }
.io .bp-row .bp-bar { height: 8px; border-radius: 999px; background: rgba(255,255,255,0.08); overflow: hidden; }
.io .bp-row .bp-bar span { display: block; height: 100%; background: linear-gradient(90deg, #8c909a, #fff); border-radius: 999px; }
.io .bp-row .bp-pct { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: #fff; text-align: right; }
.io .bp-foot { display: flex; align-items: center; gap: 10px; margin-top: 16px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.08); font-family: 'JetBrains Mono', monospace; font-size: 11px; color: rgba(245,246,248,0.6); }
.io .bp-foot .ok { color: #fff; }
@media (max-width: 1000px) { .io .builder { grid-template-columns: 1fr; } }

/* ============================================================
   AGENT RUNTIME block (monochrome terminal) — used on xETF
   ============================================================ */
.io .agent-rt { background: #0c0d10; border: 1px solid #1a1c20; border-radius: var(--r-4); padding: 26px 28px; box-shadow: 0 40px 90px -44px rgba(0,0,0,0.5); }
.io .agent-rt .art-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,0.08); margin-bottom: 18px; }
.io .agent-rt .art-dots { display: flex; gap: 6px; }
.io .agent-rt .art-dots i { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,0.18); }
.io .agent-rt .art-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,246,248,0.5); }
.io .agent-rt .art-q { font-family: 'Sora', sans-serif; font-style: italic; font-size: 17px; line-height: 1.4; color: #fff; border-left: 2px solid rgba(255,255,255,0.4); padding-left: 14px; margin-bottom: 18px; }
.io .agent-rt .art-step { font-family: 'JetBrains Mono', monospace; font-size: 13px; line-height: 1.7; color: rgba(245,246,248,0.85); }
.io .agent-rt .art-step .mut { color: rgba(245,246,248,0.5); }
.io .agent-rt .art-step .gd { color: #fff; }
.io .agent-rt .art-step::before { content: "› "; color: rgba(245,246,248,0.4); }
.io .agent-rt .art-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,0.08); }
.io .agent-rt .art-tags span { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: rgba(245,246,248,0.7); background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: 999px; padding: 4px 11px; }

/* ============================================================
   Form inputs on dark bands (waitlist) — dark glass, readable
   ============================================================ */
.io .section-dark input[type="email"],
.io .section-dark input[type="text"],
.io .section-dark select {
  background: rgba(255,255,255,0.07);
  -webkit-backdrop-filter: blur(14px) saturate(1.3); backdrop-filter: blur(14px) saturate(1.3);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 999px;
  box-shadow: none;
  color: #fff;
  padding: 14px 20px;
  font-family: 'Space Grotesk', sans-serif; font-size: 15px;
}
.io .section-dark input::placeholder { color: rgba(245,246,248,0.5); }
.io .section-dark select { color: #fff; }
.io .section-dark input:focus,
.io .section-dark select:focus {
  outline: none;
  border-color: rgba(255,255,255,0.55);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.12);
}

/* ============================================================
   Currency display helper (EUR default DE / USD EN)
   ============================================================ */
.io [data-cur] .cur-usd { display: none; }
.io[data-currency="USD"] [data-cur] .cur-usd { display: inline; }
.io[data-currency="USD"] [data-cur] .cur-eur { display: none; }

/* ============================================================
   FINAL CTA band (image)
   ============================================================ */
.io .foot-hero { position: relative; min-height: clamp(300px,40vw,460px); display: flex; align-items: flex-end; overflow: hidden; background: #060607; }
.io .foot-hero .fh-img { position: absolute; inset: 0; background-size: cover; background-position: center; filter: grayscale(1) contrast(1.05) brightness(0.6); transform: scale(1.04); }
.io .foot-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(6,6,8,0.4), rgba(6,6,8,0.85)); }
.io .foot-hero .wrap { position: relative; z-index: 2; padding: 70px var(--pad); }
.io .foot-hero .fh-tag { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(40px,7vw,96px); letter-spacing: -0.04em; line-height: 0.96; color: #fff; }
.io .foot-hero .fh-tag .sl { color: rgba(255,255,255,0.5); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1000px) {
  .io .story7 { grid-template-columns: 1fr; }
  .io .story7.flip .st-media { order: 0; }
  .io .scene-stage { min-height: 300px; }
}
@media (max-width: 900px) {
  .io .nav-links { display: none; }
  .io .scard-grid, .io .scard-grid.cols-4 { grid-template-columns: 1fr 1fr; }
  .io .lane-row { grid-template-columns: 1fr; }
  .io .lane-label { padding-bottom: 4px; }
}
@media (max-width: 560px) {
  .io .scard-grid, .io .scard-grid.cols-2, .io .scard-grid.cols-4 { grid-template-columns: 1fr; }
  .io .why-grid { grid-template-columns: 1fr; }
  /* declutter mobile nav — in-hero CTA covers "Get started" */
  .io .nav .btn-primary { display: none; }
  .io .nav-inner { padding: 12px var(--pad); }
}

/* ============================================================
   v8 ADDENDUM — ported components (monochrome) + fixes
   ============================================================ */

/* --- nav-flat link adapts to background (fix: AI Studio stayed white on light) --- */
.io .nav--on-light .nav-links > a.nav-flat { color: var(--ink-2); }
.io .nav--on-light .nav-links > a.nav-flat:hover { color: var(--ink); background: rgba(11,11,13,0.06); }
.io .nav--on-dark .nav-links > a.nav-flat { color: rgba(245,246,248,0.84); }
.io .nav-links > a.nav-flat.current { color: var(--ink); }
.io .nav--on-dark .nav-links > a.nav-flat.current { color: #fff; }

/* --- Mobile menu button: always visible, adapts to background --- */
.io .nav-toggle { display: none; border-radius: 999px; }
.io .nav--on-light .nav-toggle { color: var(--ink); background: rgba(255,255,255,0.55); border-color: var(--line-2); box-shadow: inset 0 1px 0 rgba(255,255,255,0.7), 0 2px 6px rgba(16,16,19,0.08); }
.io .nav--on-dark .nav-toggle { color: var(--cream-on-deep); background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.25); box-shadow: none; }

/* --- Mobile mega-menu accordion + dropdown panel --- */
@media (max-width: 900px) {
  .io .nav-toggle { display: inline-flex; align-items: center; gap: 6px; padding: 9px 16px; }

  /* the open dropdown panel */
  .io .nav-links.open {
    display: flex; flex-direction: column; gap: 0; align-items: stretch;
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--paper);
    border-bottom: 1px solid var(--line);
    box-shadow: 0 24px 50px -28px rgba(11,11,13,0.3);
    padding: 8px var(--pad) 18px;
    max-height: calc(100vh - 58px); overflow-y: auto;
  }
  .io .nav-links.open .nav-group { display: block; border-top: 1px solid var(--line); }
  .io .nav-links.open .nav-group:first-child { border-top: none; }
  .io .nav-links.open .nav-group > a { display: flex; justify-content: space-between; align-items: center; padding: 16px 0; color: var(--ink); font-size: 16px; font-family: 'Sora', sans-serif; font-weight: 600; }
  .io .nav-links.open .nav-group > a .chev { border-color: var(--ink); opacity: .55; }
  .io .nav-links.open .nav-flat { font-size: 16px; font-family: 'Sora', sans-serif; font-weight: 600; }
  .io .nav-links.open .mega { position: static; transform: none; opacity: 1; visibility: visible; pointer-events: auto; width: 100%; padding: 0 0 14px; }
  .io .nav-links.open .nav-group:not(.open-sub) .mega { display: none !important; }
  .io .nav-links.open .nav-group.open-sub .mega { display: block !important; }
  .io .nav-links.open .mega-card { flex-direction: column; box-shadow: none; border: 1px solid var(--line); border-radius: 16px; background: var(--bg-2); }
  .io .nav-links.open .mega-list { flex: none; padding: 8px; }
  .io .nav-links.open .mega-pane { display: none; }
  .io .nav-links.open .nav-group.open-sub > a .chev { transform: rotate(225deg); }

  /* nav bar itself flips to solid light while the menu is open, so brand + controls stay readable */
  .io .nav.nav--menu-open { background: var(--paper); border-bottom: 1px solid var(--line); -webkit-backdrop-filter: none; backdrop-filter: none; }
  .io .nav.nav--menu-open .brand-word { color: var(--ink); }
  .io .nav.nav--menu-open .brand-mark--light { display: none; }
  .io .nav.nav--menu-open .brand-mark--dark { display: block; }
  .io .nav.nav--menu-open .nav-toggle { color: var(--ink); background: rgba(11,11,13,0.05); border-color: var(--line-2); box-shadow: none; }
  .io .nav.nav--menu-open .lang-switch { background: rgba(255,255,255,0.6); border-color: var(--line-2); }
  .io .nav.nav--menu-open .lang-switch button { color: var(--ink-3); }
  .io .nav.nav--menu-open .lang-switch button.active { background: var(--ink); color: var(--paper); }
}

/* ============================================================
   FnO / OPTIONS DESK (monochrome) — app.html, studio.html
   ============================================================ */
.io .fno-desk { background: #0c0d10; border: 1px solid #1a1c20; border-radius: var(--r-4); padding: 24px; box-shadow: 0 40px 90px -44px rgba(0,0,0,0.5); }
.io .fno-top { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 12px; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,0.08); margin-bottom: 18px; }
.io .fno-sym { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.io .fno-sym .mkt { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(245,246,248,0.7); border: 1px solid rgba(255,255,255,0.18); border-radius: 5px; padding: 4px 8px; }
.io .fno-sym .mkt.us { border-style: dashed; color: rgba(245,246,248,0.5); }
.io .fno-sym .nm { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 20px; color: #fff; letter-spacing: -0.01em; }
.io .fno-sym .px { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: rgba(245,246,248,0.65); }
.io .fno-bias { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: #fff; border: 1px solid rgba(255,255,255,0.22); border-radius: 999px; padding: 6px 13px; }
.io .fno-metrics { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.io .fno-metrics .fm { border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 14px; background: rgba(255,255,255,0.02); }
.io .fno-metrics .fm .l { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(245,246,248,0.45); }
.io .fno-metrics .fm .v { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 26px; color: #fff; letter-spacing: -0.02em; margin: 8px 0 4px; }
.io .fno-metrics .fm .v.sm { font-size: 16px; }
.io .fno-metrics .fm .s { font-size: 11px; color: rgba(245,246,248,0.55); }
.io .fno-agents { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 18px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,0.08); }
.io .fno-agents .lab { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,246,248,0.4); margin-right: 4px; }
.io .fno-agents .agent { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: rgba(245,246,248,0.82); border: 1px solid rgba(255,255,255,0.1); border-radius: 999px; padding: 5px 12px 5px 5px; }
.io .fno-agents .agent i { width: 18px; height: 18px; border-radius: 50%; background: rgba(255,255,255,0.1); display: grid; place-items: center; font-style: normal; font-size: 9px; font-weight: 600; color: #fff; }
.io .fno-agents .agent small { color: rgba(245,246,248,0.45); font-size: 10px; }
.io .fno-agents .agent.lead { border-color: rgba(255,255,255,0.4); }
.io .fno-agents .agent.lead i { background: #fff; color: #000; }
@media (max-width: 760px) { .io .fno-metrics { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   DEV SURFACES — REST / MCP / SDK code cards (studio.html)
   ============================================================ */
.io .surfaces { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.io .surface { background: var(--paper); border: 1px solid var(--line); border-radius: 18px; padding: 26px 24px; display: flex; flex-direction: column; }
.io .surface .sf-k { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); }
.io .surface h4 { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 19px; letter-spacing: -0.015em; margin: 12px 0 8px; }
.io .surface > p { font-size: 13.5px; color: var(--ink-3); line-height: 1.5; margin-bottom: 16px; flex: 1; }
.io .code-block { background: #0c0d10; border-radius: 12px; padding: 16px 18px; font-family: 'JetBrains Mono', monospace; font-size: 12px; line-height: 1.65; color: rgba(245,246,248,0.82); white-space: pre; overflow-x: auto; }
.io .code-block .k { color: #fff; font-weight: 500; }
.io .code-block .s { color: #9aa0aa; }
.io .code-block .c { color: rgba(245,246,248,0.4); }
.io .section-dark .surface { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.08); }
.io .section-dark .surface h4 { color: #fff; }
.io .section-dark .surface .sf-k { color: rgba(245,246,248,0.5); }
.io .section-dark .surface > p { color: rgba(245,246,248,0.6); }
.io .section-dark .code-block { background: rgba(0,0,0,0.35); border: 1px solid rgba(255,255,255,0.06); }
@media (max-width: 900px) { .io .surfaces { grid-template-columns: 1fr; } }

/* ============================================================
   BROKER LEDGER (monochrome) — app.html
   ============================================================ */
.io .ledger { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-4); padding: 22px; box-shadow: 0 30px 70px -44px rgba(11,11,13,0.3); }
.io .ledger .lg-h { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 16px; }
.io .lg-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 16px; border-radius: 12px; background: var(--bg-2); margin-bottom: 8px; }
.io .lg-row.primary { background: #0c0d10; }
.io .lg-row.primary .lg-name, .io .lg-row.primary .lg-val { color: #fff; }
.io .lg-row.primary .lg-sub { color: rgba(245,246,248,0.55); }
.io .lg-name { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 15px; color: var(--ink); }
.io .lg-sub { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.06em; color: var(--ink-3); margin-top: 3px; }
.io .lg-val { font-family: 'JetBrains Mono', monospace; font-size: 14px; color: var(--ink); white-space: nowrap; }
.io .lg-mid { text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; color: var(--ink-4); padding: 8px 0; }
.io .lg-total { background: #0c0d10; border-radius: 14px; padding: 18px 20px; margin-top: 6px; }
.io .lg-total .lt-k { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,246,248,0.5); }
.io .lg-total .lt-v { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 30px; color: #fff; letter-spacing: -0.02em; margin: 6px 0 12px; }
.io .lg-total .lt-row { display: flex; justify-content: space-between; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: rgba(245,246,248,0.6); padding: 4px 0; }
.io .lg-total .lt-row .hl { color: #fff; }

/* ============================================================
   MODEL LOGOS — "your model, our markets" (studio.html)
   ============================================================ */
.io .models { display: flex; flex-wrap: wrap; gap: 12px; }
.io .model-chip { display: inline-flex; align-items: center; gap: 10px; padding: 11px 16px 11px 12px; border-radius: 14px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); }
.io .model-chip .mc-ic { width: 26px; height: 26px; border-radius: 7px; background: rgba(255,255,255,0.9); display: grid; place-items: center; overflow: hidden; }
.io .model-chip .mc-ic img { width: 100%; height: 100%; object-fit: contain; padding: 3px; }
.io .model-chip .mc-n { font-family: 'Space Grotesk', sans-serif; font-size: 14px; color: #fff; }
.io .model-chip .mc-t { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,246,248,0.45); }
.io .models-stage { position: relative; display: flex; flex-direction: column; gap: 14px; align-items: center; justify-content: center; padding: 30px; background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--r-4); min-height: 320px; }
.io .models-hub { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 16px; color: #000; background: #fff; padding: 12px 20px; border-radius: 999px; }
.io .models-conn { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,246,248,0.4); }

/* ============================================================
   PROPS HERO IMAGE — make it actually read (fix: invisible)
   ============================================================ */
.io .page-hero.dark .ph-bd { opacity: 0.62; filter: grayscale(1) contrast(1.06) brightness(0.62); }
.io .page-hero.dark::after { background: linear-gradient(180deg, rgba(6,6,9,0.42) 0%, rgba(6,6,9,0.62) 60%, rgba(6,6,9,0.88) 100%); }

/* light prompt bar variant (for light hero sections) */
.io .prompt-bar.light { background: rgba(11,11,13,0.05); border-color: rgba(11,11,13,0.12); }
.io .prompt-bar.light .pb-spark { color: var(--ink-2); }
.io .prompt-bar.light .pb-field { color: var(--ink); }
.io .prompt-bar.light .pb-caret { background: var(--ink); }
.io .prompt-bar.light .pb-send { background: var(--ink); color: #fff; }

/* --- Rich ETF builder asset (named holdings, monochrome) --- */
.io .xbuild { background: #0c0d10; border: 1px solid #1a1c20; border-radius: var(--r-4); padding: 22px; box-shadow: 0 40px 90px -44px rgba(0,0,0,0.5); }
.io .xbuild .xb-head { display: flex; align-items: flex-start; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,0.08); margin-bottom: 12px; }
.io .xbuild .xb-title { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 16px; color: #fff; }
.io .xbuild .xb-sub { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; color: rgba(245,246,248,0.45); margin-top: 4px; }
.io .xbuild .xb-live { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.06em; color: #fff; display: inline-flex; align-items: center; gap: 6px; border: 1px solid rgba(255,255,255,0.18); border-radius: 999px; padding: 5px 10px; }
.io .xbuild .xb-live::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #fff; animation: pulse 1.6s infinite; }
.io .xbuild .xb-row { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 9px 0; }
.io .xbuild .xb-row .nm { font-size: 13.5px; color: rgba(245,246,248,0.9); }
.io .xbuild .xb-row .nm small { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: rgba(245,246,248,0.4); margin-left: 6px; }
.io .xbuild .xb-row .w { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: #fff; }
.io .xbuild .xb-row .cm { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: 0.1em; color: rgba(245,246,248,0.6); border: 1px solid rgba(255,255,255,0.15); border-radius: 5px; padding: 3px 7px; }
.io .xbuild .xb-bar { display: flex; height: 8px; border-radius: 999px; overflow: hidden; margin-top: 12px; background: rgba(255,255,255,0.06); }
.io .xbuild .xb-bar span { display: block; height: 100%; }
.io .xbuild .xb-foot { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 16px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.08); }
.io .xbuild .xb-foot .v { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 18px; color: #fff; }
.io .xbuild .xb-foot small { display: block; font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(245,246,248,0.45); margin-top: 4px; }

/* --- US -> UCITS pivot strip --- */
.io .pivot { display: grid; grid-template-columns: 1fr auto; gap: 30px; align-items: center; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-4); padding: clamp(28px,4vw,44px); }
.io .pivot h3 { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(22px,2.6vw,32px); letter-spacing: -0.025em; line-height: 1.08; }
.io .pivot p { color: var(--ink-2); font-size: 15px; line-height: 1.55; margin-top: 12px; max-width: 60ch; }
@media (max-width: 760px) { .io .pivot { grid-template-columns: 1fr; } }

/* ============================================================
   v8 ADDENDUM 2 — tasteful colour coding + ucits heading fix
   ============================================================ */

/* trading colour tokens (used sparingly) */
.io { --pos: #6fc189; --neg: #d8745f; }

/* ucits section headings were using .h-display (huge) — bring down */
.io .h-display { font-size: clamp(28px, 3.6vw, 46px); line-height: 1.04; letter-spacing: -0.03em; }

/* --- FnO desk colour coding (bias / move / deltas) --- */
.io .fno-sym .px { color: var(--pos); }
.io .fno-bias { color: var(--pos); border-color: rgba(111,193,137,0.4); }
.io .fno-metrics .fm .v.pos { color: var(--pos); }
.io .fno-metrics .fm .v.neg { color: var(--neg); }
.io .fno-metrics .fm .s .dn { color: var(--neg); }
.io .fno-metrics .fm .s .up { color: var(--pos); }

/* --- Code-block syntax highlighting (REST / MCP / SDK) --- */
.io .code-block { color: #c9cdd4; }
.io .code-block .k  { color: #7aa6d6; font-weight: 500; }  /* keyword / method */
.io .code-block .s  { color: #b5c79a; }                     /* string */
.io .code-block .n  { color: #8fbcc7; }                     /* number */
.io .code-block .fn { color: #d8c98a; }                     /* function / tool */
.io .code-block .p  { color: #9cc4e0; }                     /* property / param */
.io .code-block .c  { color: rgba(245,246,248,0.4); }       /* comment */
.io .code-block .ar { color: var(--pos); }                  /* response arrow */

/* ============================================================
   v8 ADDENDUM 3 — glass inputs, timeline, pricing, use-cases
   ============================================================ */

/* --- Glass, curved inputs everywhere --- */
.io input[type="email"], .io input[type="text"], .io input[type="search"], .io select, .io textarea {
  border-radius: 999px;
  background: rgba(255,255,255,0.55);
  -webkit-backdrop-filter: blur(16px) saturate(1.5); backdrop-filter: blur(16px) saturate(1.5);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow: 0 0 0 1px var(--hair), inset 0 1px 0 rgba(255,255,255,0.8);
  color: var(--ink); padding: 14px 20px;
  font-family: 'Space Grotesk', sans-serif; font-size: 15px;
}
.io textarea { border-radius: var(--r-3); }
.io input::placeholder { color: var(--ink-4); }
.io input:focus, .io select:focus, .io textarea:focus {
  outline: none; border-color: rgba(11,11,13,0.3);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 0 0 3px rgba(11,11,13,0.08);
}
/* dark band: glass goes dark + curved */
.io .section-dark input[type="email"], .io .section-dark input[type="text"], .io .section-dark select {
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  -webkit-backdrop-filter: blur(16px) saturate(1.3); backdrop-filter: blur(16px) saturate(1.3);
  border: 1px solid rgba(255,255,255,0.2); box-shadow: none; color: #fff;
}
.io .section-dark input::placeholder { color: rgba(245,246,248,0.5); }
.io .section-dark input:focus, .io .section-dark select:focus {
  border-color: rgba(255,255,255,0.55); box-shadow: 0 0 0 3px rgba(255,255,255,0.12);
}
/* Custom select: kill the native arrow, draw a consistent chevron on the right.
   Light surfaces use a dark chevron, dark bands a light one. */
.io select {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  cursor: pointer; padding-right: 44px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230B0B0D' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 18px center; background-size: 13px;
}
.io select::-ms-expand { display: none; }
.io .section-dark select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 18px center; background-size: 13px;
}

/* ============================================================
   INTEGRATION TIMELINE — stepper
   ============================================================ */
.io .steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; position: relative; }
.io .step { position: relative; padding: 0 22px 0 0; }
.io .step .st-node { display: flex; align-items: center; gap: 0; margin-bottom: 18px; }
.io .step .st-dot { width: 34px; height: 34px; border-radius: 50%; flex: none; display: grid; place-items: center; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; background: var(--ink); color: #fff; z-index: 2; }
.io .step .st-line { flex: 1; height: 1px; background: var(--line-2); }
.io .step:last-child .st-line { display: none; }
.io .step .st-t { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 17px; letter-spacing: -0.015em; }
.io .step .st-d { font-size: 14px; color: var(--ink-3); line-height: 1.5; margin-top: 8px; }
.io .step .st-when { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-4); margin-top: 10px; display: inline-block; }
/* dark variant */
.io .section-dark .step .st-dot { background: #fff; color: #000; }
.io .section-dark .step .st-line { background: rgba(255,255,255,0.14); }
.io .section-dark .step .st-t { color: #fff; }
.io .section-dark .step .st-d { color: rgba(245,246,248,0.62); }
.io .section-dark .step .st-when { color: rgba(245,246,248,0.5); }
/* the headline time-saving stat next to the timeline */
.io .timeline-lead { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px 18px; margin-bottom: 8px; }
.io .timeline-lead .big { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(30px,3.4vw,44px); letter-spacing: -0.03em; }
.io .timeline-lead .big .pos { color: var(--pos); }
@media (max-width: 820px) {
  .io .steps { grid-template-columns: 1fr; gap: 22px; }
  .io .step { padding: 0 0 0 0; }
  .io .step .st-line { display: none; }
}

/* ============================================================
   USE-CASES — quote-style demand cards
   ============================================================ */
.io .uses { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.io .use { background: var(--paper); border: 1px solid var(--line); border-radius: 18px; padding: 26px; }
.io .use .uq { font-family: 'Sora', sans-serif; font-weight: 600; font-size: 18px; letter-spacing: -0.015em; line-height: 1.3; }
.io .use .uq::before { content: "“"; color: var(--ink-4); margin-right: 2px; }
.io .use .ub { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--line); font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.io .section-dark .use { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.io .section-dark .use .uq { color: #fff; }
.io .section-dark .use .ub { color: rgba(245,246,248,0.55); border-top-color: rgba(255,255,255,0.1); }
@media (max-width: 820px) { .io .uses { grid-template-columns: 1fr; } }

/* ============================================================
   PRICING TEASER — factors, not numbers
   ============================================================ */
.io .pricing { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.io .price-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-4); padding: 32px; position: relative; overflow: hidden; }
.io .price-card.feature { background: #0c0d10; border-color: #1a1c20; color: var(--cream-on-deep); }
.io .price-card .pc-k { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); }
.io .price-card.feature .pc-k { color: rgba(245,246,248,0.55); }
.io .price-card h3 { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(22px,2.4vw,28px); letter-spacing: -0.02em; margin: 12px 0 6px; }
.io .price-card.feature h3 { color: #fff; }
.io .price-card .pc-sub { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; }
.io .price-card.feature .pc-sub { color: rgba(245,246,248,0.68); }
.io .price-card .pc-list { list-style: none; margin: 18px 0 0; padding: 0; }
.io .price-card .pc-list li { display: flex; gap: 10px; padding: 9px 0; border-top: 1px solid var(--line); font-size: 14px; color: var(--ink-2); }
.io .price-card.feature .pc-list li { border-top-color: rgba(255,255,255,0.1); color: rgba(245,246,248,0.78); }
.io .price-card .pc-list li::before { content: "→"; font-family: 'JetBrains Mono', monospace; color: var(--ink); flex: none; }
.io .price-card.feature .pc-list li::before { color: #fff; }
.io .price-card .pc-tag { display: inline-block; margin-top: 18px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em; padding: 7px 14px; border-radius: 999px; background: var(--bg-2); color: var(--ink-2); }
.io .price-card.feature .pc-tag { background: rgba(255,255,255,0.1); color: #fff; }
@media (max-width: 820px) { .io .pricing { grid-template-columns: 1fr; } }

/* ============================================================
   HOMEPAGE HERO v2 — public.com layout (text above, video below)
   ============================================================ */
.io .hero-pub { padding: clamp(108px, 15vh, 168px) 0 clamp(40px, 5vw, 68px); background: var(--paper); position: relative; }
.io .hp-eyebrow { margin-bottom: 22px; }
.io .hp-headline {
  font-family: 'Sora', sans-serif; font-weight: 600;
  font-size: clamp(40px, 6.4vw, 92px); line-height: 0.96; letter-spacing: -0.045em;
  max-width: 15ch; color: var(--ink);
}
.io .hp-sub { margin-top: 22px; font-size: clamp(16px, 1.5vw, 20px); line-height: 1.5; color: var(--ink-2); max-width: 600px; }
.io .hp-meta { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px 24px; margin-top: clamp(28px, 3.5vw, 40px); }
.io .hp-tags { display: flex; flex-wrap: wrap; gap: 10px 26px; font-family: 'JetBrains Mono', monospace; font-size: 12.5px; letter-spacing: 0.02em; color: var(--ink-2); }
.io .hp-tags span { display: inline-flex; align-items: center; gap: 9px; }
.io .hp-tags svg { width: 16px; height: 16px; color: var(--ink-3); flex: none; }

.io .hp-aud { display: flex; flex-wrap: wrap; align-items: center; gap: 4px 14px; margin-bottom: 24px; font-family: 'JetBrains Mono', monospace; font-size: 12.5px; letter-spacing: 0.06em; text-transform: uppercase; }
.io .hp-aud a { color: var(--ink-3); padding: 3px 0; position: relative; transition: color .2s var(--ease); }
.io .hp-aud a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 0; height: 1px; background: var(--ink); transition: right .25s var(--ease); }
.io .hp-aud a:hover { color: var(--ink); }
.io .hp-aud a:hover::after { right: 0; }
.io .hp-aud .sep { color: var(--ink-4); }
.io .hp-meta { align-items: flex-end; }
.io .hp-meta .hp-trust { margin: 0; }
.io .hp-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: clamp(28px, 3.5vw, 40px); }
.io .hp-trust { display: flex; flex-wrap: wrap; gap: 10px 24px; margin: 22px 0 0; padding: 0; list-style: none; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.io .hp-trust li { display: inline-flex; align-items: center; gap: 9px; }
.io .hp-trust li svg { width: 17px; height: 17px; color: var(--ink); flex: none; }

.io .hp-video {
  margin-top: clamp(26px, 3.5vw, 44px); position: relative; border-radius: var(--r-4);
  overflow: hidden; aspect-ratio: 12 / 5; max-height: 500px; background: #06060a;
  box-shadow: 0 50px 100px -54px rgba(11,11,13,0.45), 0 0 0 1px var(--hair);
}
.io .hp-video video { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.02) contrast(1.03); pointer-events: none; }
.io .hp-veil { position: absolute; inset: 0; pointer-events: none; z-index: 1;
  background: linear-gradient(180deg, rgba(6,6,10,0.40) 0%, rgba(6,6,10,0.06) 26%, rgba(6,6,10,0.10) 52%, rgba(6,6,10,0.86) 100%); }
.io .hp-vo { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: clamp(20px, 3vw, 40px); }
.io .hp-vlabel { display: inline-flex; align-items: center; gap: 9px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.08em; color: rgba(245,246,248,0.82); margin-bottom: 14px; }
.io .hp-vlabel .dot { width: 7px; height: 7px; border-radius: 50%; background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,0.16); animation: pulse 1.8s ease-in-out infinite; }
.io .hp-vo .prompt-bar { max-width: 600px; }
.io .hp-vtop { position: absolute; top: 0; left: 0; right: 0; z-index: 2; padding: clamp(18px,2.5vw,30px); display: flex; justify-content: space-between; align-items: center; }
.io .hp-vtop .hp-live { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(245,246,248,0.85); display: inline-flex; align-items: center; gap: 7px; border: 1px solid rgba(255,255,255,0.22); border-radius: 999px; padding: 6px 12px; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); }
.io .hp-vtop .hp-live::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #6fc189; }

@media (max-width: 760px) {
  .io .hero-pub { padding-top: 96px; }
  .io .hp-video { aspect-ratio: 4 / 5; max-height: none; }
  .io .hp-meta .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   BRAND — separate mark + wordmark, sized independently, adaptive
   ============================================================ */
.io .brand { display: flex; align-items: center; gap: 5px; }
.io .brand-mk { height: 30px; width: auto; display: block; }
.io .brand-wm { height: 20px; width: auto; display: block; }
.io .brand-div { width: 1px; height: 22px; flex: none; background: rgba(128,128,128,0.4); }
/* default: hide dark variant; nav modes flip */
.io .brand-mk--dark, .io .brand-wm--dark { display: none; }
.io .nav--on-dark .brand-mk--light, .io .nav--on-dark .brand-wm--light { display: block; }
.io .nav--on-dark .brand-mk--dark, .io .nav--on-dark .brand-wm--dark { display: none; }
.io .nav--on-dark .brand-div { background: rgba(255,255,255,0.3); }
.io .nav--on-light .brand-mk--light, .io .nav--on-light .brand-wm--light { display: none; }
.io .nav--on-light .brand-mk--dark, .io .nav--on-light .brand-wm--dark { display: block; }
.io .nav--on-light .brand-div { background: rgba(11,11,13,0.2); }
@media (max-width: 900px) {
  .io .nav.nav--menu-open .brand-mk--light, .io .nav.nav--menu-open .brand-wm--light { display: none; }
  .io .nav.nav--menu-open .brand-mk--dark, .io .nav.nav--menu-open .brand-wm--dark { display: block; }
  .io .nav.nav--menu-open .brand-div { background: rgba(11,11,13,0.2); }
}
/* footer: platinum mark + wordmark on dark */
.io .footer .brand-mk--foot { height: 34px; width: auto; display: block; }
.io .footer .brand-wm--foot { height: 22px; width: auto; display: block; }
.io .footer .brand-div--foot { background: rgba(255,255,255,0.28); height: 26px; }

/* fix: micro-sign uppercasing to "M" (looked like milliseconds) — keep unit lowercase */
.io .hp-trust .unit, .io .lbl .unit { text-transform: none; }

/* ============================================================
   inde ONE · v8.1 — pre-launch pills, disclaimers, legal,
   contact, content/blog, personas, cookie banner
   ============================================================ */

/* ---- Brand "Pre-launch" pill (in nav, beside wordmark) ---- */
.io .brand-pill {
  display: inline-flex; align-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 0.12em; text-transform: uppercase;
  line-height: 1; padding: 4px 6px; border-radius: 999px; margin-left: 4px;
  border: 1px solid currentColor; opacity: 0.62; white-space: nowrap;
  font-weight: 500;
}
.io .nav--on-dark .brand-pill { color: var(--cream-on-deep); }
.io .nav--on-light .brand-pill { color: var(--ink); }
@media (max-width: 520px) { .io .brand-pill { display: none; } }

/* ---- Mega-menu item pills (Launching Soon · India) ---- */
.io .mi-pill {
  display: inline-block; vertical-align: middle;
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 0.1em; text-transform: uppercase;
  line-height: 1; padding: 3px 5px; border-radius: 999px; margin-left: 5px;
  background: var(--ember); color: #fff; font-weight: 500;
}
.io .mi-pill.soft { background: transparent; color: var(--ember); border: 1px solid color-mix(in srgb, var(--ember) 35%, transparent); }

/* ---- Disclaimer / capability band (foot of pages) ---- */
.io .disc-band { background: var(--paper); border-top: 1px solid var(--line); padding: 40px 0; }
.io .disc-band.dark { background: var(--deep); border-top-color: rgba(255,255,255,0.08); }
.io .disc-wrap { max-width: 920px; margin: 0 auto; }
.io .disc-k {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ember);
  margin-bottom: 12px;
}
.io .disc-band.dark .disc-k { color: rgba(245,246,248,0.6); }
.io .disc-k::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.io .disc-band p {
  font-size: 13px; line-height: 1.65; color: var(--mute, #5b5d63);
  margin: 0 0 10px; max-width: 920px;
}
.io .disc-band.dark p { color: rgba(245,246,248,0.62); }
.io .disc-band .exch {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px;
}
.io .disc-band .exch span {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.08em;
  padding: 6px 11px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.18);
  color: rgba(245,246,248,0.85);
}
.io .disc-band:not(.dark) .exch span { border-color: var(--line); color: var(--ink); }

/* ---- Footer disclaimer (common, small) ---- */
.io .footer-disc {
  margin-top: 26px; padding-top: 0; border-top: none;
  max-width: 1000px;
}
.io .footer-disc p { font-size: 11.5px; line-height: 1.65; color: rgba(233,236,241,0.42); margin: 0 0 10px; }
.io .footer-disc p:last-child { margin-bottom: 0; }
.io .footer-grid { grid-template-columns: 1.7fr repeat(4, 1fr); gap: 32px; }
.io .footer-grid .footer-brand { grid-column: 1 / 2; }
@media (max-width: 1024px) { .io .footer-grid { grid-template-columns: 1fr 1fr 1fr; } .io .footer-grid .footer-brand { grid-column: 1 / -1; } }
@media (max-width: 560px) { .io .footer-grid { grid-template-columns: 1fr 1fr; } }
.io .foot-connect { margin-top: 18px; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: 13.5px; }
.io .foot-connect .fc-link { color: rgba(233,236,241,0.8); }
.io .foot-connect .fc-link:hover { color: var(--ember); }
.io .foot-connect .fc-sep { color: rgba(233,236,241,0.3); }
.io .foot-social { margin-top: 16px; display: flex; gap: 10px; }
.io .foot-social a { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; border: 1px solid rgba(233,236,241,0.16); color: rgba(233,236,241,0.78); transition: border-color .2s, color .2s, background .2s; }
.io .foot-social a:hover { color: #fff; border-color: rgba(233,236,241,0.4); background: rgba(255,255,255,0.05); }
.io .foot-social svg { width: 17px; height: 17px; }

/* ---- Props hero: exchange connectivity chips ---- */
.io .ph-exch { margin-top: 26px; display: flex; flex-direction: column; gap: 10px; }
.io .ph-exch .px-k {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgba(245,246,248,0.62);
}
.io .ph-exch .px-live { width: 8px; height: 8px; border-radius: 50%; background: #19c37d; box-shadow: 0 0 0 4px rgba(25,195,125,0.18); flex: none; }
.io .ph-exch .px-rows { display: flex; flex-wrap: wrap; gap: 8px; }
.io .ph-exch .px-c {
  font-family: 'JetBrains Mono', monospace; font-size: 11.5px; letter-spacing: 0.08em;
  padding: 7px 13px; border-radius: 999px; border: 1px solid rgba(245,246,248,0.18);
  color: rgba(245,246,248,0.9);
}
/* Inquiry-form capability disclaimer (under request-access forms) */
.io .inq-disc {
  margin: 26px auto 0; max-width: 660px; font-size: 12.5px; line-height: 1.65;
  color: rgba(245,246,248,0.5); text-align: center;
}
.io .section-paper .inq-disc { color: #7a7c82; }

/* ---- Data & capabilities (app + studio) ---- */
.io .cap-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 0 48px; }
@media (max-width: 680px) { .io .cap-cols { grid-template-columns: 1fr; gap: 0; } }

/* ---- Persona (Investor / Trader) on the app page ---- */
.io .persona-band { padding: clamp(40px,5vw,64px) 0; }
.io .persona-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 28px; }
@media (max-width: 760px) { .io .persona-grid { grid-template-columns: 1fr; } }
.io .persona-card {
  position: relative; border: 1px solid var(--line); border-radius: 18px;
  padding: 28px 26px; background: var(--paper); transition: border-color .2s, transform .2s, box-shadow .2s;
  display: block; cursor: pointer; text-align: left;
}
.io .persona-card:hover { border-color: var(--ember); transform: translateY(-2px); box-shadow: 0 16px 40px rgba(0,0,0,0.07); }
.io .persona-card .pc-k {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ember); display: block; margin-bottom: 10px;
}
.io .persona-card h3 { font-family: 'Sora', sans-serif; font-size: 24px; margin: 0 0 8px; letter-spacing: -0.01em; }
.io .persona-card p { font-size: 14.5px; line-height: 1.6; color: #5b5d63; margin: 0 0 16px; }
.io .persona-card .pc-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.io .persona-card .pc-tags span {
  font-size: 11px; padding: 4px 9px; border-radius: 999px; background: #f3f4f6; color: #33353b;
}
.io .persona-card .pc-go { font-size: 13px; font-weight: 600; color: var(--ember); margin-top: 14px; display: inline-block; }

/* Persona chip on each section */
.io .pchip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px; letter-spacing: 0.12em;
  text-transform: uppercase; padding: 4px 9px; border-radius: 999px; margin-bottom: 14px;
  border: 1px solid var(--line); color: #6b6d73;
}
.io .pchip::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #19c37d; }
.io .pchip.trader::before { background: #ff7849; }
.io .pchip.both::before { background: linear-gradient(90deg,#19c37d,#ff7849); }
.io .section-dark .pchip { border-color: rgba(255,255,255,0.18); color: rgba(245,246,248,0.7); }

/* Persona filter toggle */
.io .persona-toggle {
  display: inline-flex; gap: 4px; padding: 4px; border-radius: 999px;
  border: 1px solid var(--line); background: var(--paper); margin-top: 22px;
}
.io .persona-toggle button {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em;
  padding: 8px 16px; border-radius: 999px; border: none; background: transparent;
  color: #6b6d73; cursor: pointer; transition: background .2s, color .2s;
}
.io .persona-toggle button.active { background: var(--ember); color: #fff; }
/* Filtering: dim non-matching sections */
.io[data-persona="investor"] section[data-persona="trader"],
.io[data-persona="trader"] section[data-persona="investor"] {
  opacity: 0.32; filter: grayscale(0.4); transition: opacity .3s, filter .3s;
}

/* ---- Legal / policy document pages ---- */
.io .legal-hero { padding: clamp(110px,13vw,160px) 0 clamp(30px,4vw,46px); }
.io .legal-hero .eyebrow { margin-bottom: 14px; }
.io .legal-hero h1 { font-family: 'Sora', sans-serif; font-size: clamp(32px,5vw,52px); letter-spacing: -0.02em; line-height: 1.04; margin: 0; max-width: 18ch; }
.io .legal-hero .sub { margin-top: 16px; font-size: 16px; color: #5b5d63; max-width: 680px; }
/* Centered variant for the legal/policy pages */
.io .legal-hero.centered { text-align: center; }
.io .legal-hero.centered .eyebrow { justify-content: center; }
.io .legal-hero.centered h1 { max-width: 22ch; margin-left: auto; margin-right: auto; }
.io .legal-hero.centered .sub { margin-left: auto; margin-right: auto; }
.io .legal-updated { margin-top: 18px; font-family: 'JetBrains Mono', monospace; font-size: 11.5px; letter-spacing: 0.06em; color: #8a8c92; }
.io .legal-hero.centered .legal-updated { text-align: center; }
.io .legal-doc { padding: 10px 0 90px; }
.io .legal-doc .wrap { max-width: 820px; }
.io .legal-doc h2 {
  font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ember); margin: 44px 0 10px;
}
.io .legal-doc h3 { font-family: 'Sora', sans-serif; font-size: 20px; margin: 28px 0 8px; letter-spacing: -0.01em; }
.io .legal-doc p, .io .legal-doc li { font-size: 15px; line-height: 1.72; color: #2c2e33; }
.io .legal-doc p { margin: 0 0 14px; }
.io .legal-doc ul { margin: 0 0 16px; padding-left: 20px; }
.io .legal-doc li { margin-bottom: 8px; }
.io .legal-doc a { color: var(--ember); text-decoration: underline; text-underline-offset: 3px; }
.io .legal-doc strong { font-weight: 600; }
.io .legal-note {
  margin: 22px 0; padding: 16px 18px; border-radius: 12px;
  background: #f6f7f9; border: 1px solid var(--line); font-size: 13.5px; color: #5b5d63;
}
.io .legal-note strong { color: var(--ink); }
.io .legal-doc .lead-date { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: #8a8c92; margin-bottom: 8px; }

/* ---- About: team cards ---- */
.io .team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 26px; }
@media (max-width: 860px) { .io .team-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .io .team-grid { grid-template-columns: 1fr; } }
.io .team-card {
  border: 1px solid var(--line); border-radius: 16px; padding: 24px 22px; background: var(--paper);
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.io .team-card:hover { border-color: var(--ember); transform: translateY(-2px); box-shadow: 0 14px 36px rgba(0,0,0,0.06); }
.io .team-card .tc-av {
  width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center;
  font-family: 'Sora', sans-serif; font-weight: 600; font-size: 17px; color: #fff;
  background: linear-gradient(135deg, #1a1c22, #43454d); margin-bottom: 16px; letter-spacing: 0.02em;
}
.io .team-card h3 { font-family: 'Sora', sans-serif; font-size: 18px; margin: 0 0 3px; letter-spacing: -0.01em; }
.io .team-card .tc-role { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ember); display: block; margin-bottom: 10px; }
.io .team-card p { font-size: 13.5px; line-height: 1.55; color: #5b5d63; margin: 0; }

/* ---- Contact: info + form two-column ---- */
.io .contact-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(28px,4vw,56px); align-items: start; }
@media (max-width: 860px) { .io .contact-grid { grid-template-columns: 1fr; } }
.io .contact-info .ci-item { padding: 16px 0; border-top: 1px solid var(--line); }
.io .contact-info .ci-item:first-of-type { border-top: none; }
.io .contact-info .ci-k { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: #8a8c92; display: block; margin-bottom: 6px; }
.io .contact-info .ci-v { font-size: 16px; color: var(--ink); }
.io .contact-info .ci-v a { color: var(--ember); text-decoration: underline; text-underline-offset: 3px; }
.io .form-card { margin: 0; }

/* ---- Blog index: article cards ---- */
.io .post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 900px) { .io .post-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .io .post-grid { grid-template-columns: 1fr; } }
.io .post-card {
  display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 16px;
  overflow: hidden; background: var(--paper); transition: transform .2s, box-shadow .2s, border-color .2s;
}
.io .post-card:hover { transform: translateY(-3px); box-shadow: 0 18px 44px rgba(0,0,0,0.08); border-color: #d9dade; }
.io .post-card .pc-cover { aspect-ratio: 16/10; background: #0d0d10 center/cover no-repeat; }
.io .post-card .pc-body { padding: 20px 20px 22px; display: flex; flex-direction: column; flex: 1; }
.io .post-card .pc-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.io .post-card .pc-tag { font-family: 'JetBrains Mono', monospace; font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ember); border: 1px solid color-mix(in srgb, var(--ember) 25%, transparent); border-radius: 999px; padding: 4px 8px; }
.io .post-card h3 { font-family: 'Sora', sans-serif; font-size: 19px; line-height: 1.25; letter-spacing: -0.01em; margin: 0 0 8px; }
.io .post-card p { font-size: 14px; line-height: 1.55; color: #5b5d63; margin: 0 0 16px; }
.io .post-card .pc-meta { margin-top: auto; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #8a8c92; letter-spacing: 0.03em; display: flex; gap: 8px; align-items: center; }
.io .blog-sub { margin-top: 70px; }

/* ---- Issuer trust marquee (xETF) ---- */
.io .issuer-band { padding: 44px 0 36px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); overflow: hidden; }
.io .issuer-cap { text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: #8a8c92; margin: 0 0 24px; }
.io .marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.io .marquee-track { display: flex; gap: 52px; width: max-content; animation: marq 40s linear infinite; }
.io .marquee-track span { font-family: 'Sora', sans-serif; font-weight: 600; font-size: clamp(20px, 2.4vw, 30px); color: #c5c7cd; white-space: nowrap; }
.io .issuer-band:hover .marquee-track { animation-play-state: paused; }
@keyframes marq { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .io .marquee-track { animation: none; } }

/* ---- xETF hero background watermark (partially covered by the builder card) ---- */
.io .page-hero { position: relative; overflow: hidden; }
.io .xetf-wm {
  position: absolute; z-index: 0; right: -1.5vw; bottom: -3.5vw; pointer-events: none; user-select: none;
  font-family: 'Sora', sans-serif; font-weight: 800; font-size: clamp(200px, 30vw, 520px);
  line-height: 0.78; letter-spacing: -0.045em; white-space: nowrap; color: rgba(11,11,13,0.045);
}
@media (max-width: 900px) { .io .xetf-wm { display: none; } }

/* ---- Highlight tag pills (e.g. UCITS pivot) ---- */
.io .hl-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.io .hl-tag { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.04em; padding: 6px 11px; border-radius: 999px; border: 1px solid var(--line); background: #f6f7f9; color: var(--ink); }
.io .section-dark .hl-tag { border-color: rgba(255,255,255,0.16); background: rgba(255,255,255,0.05); color: var(--cream-on-deep); }

/* ---- Blog: reads + videos split (desktop) / tabs (mobile) ---- */
.io .blog-tabs { display: none; }
.io .blog-split { display: grid; grid-template-columns: 1.7fr 1fr; gap: 0; }
.io .bs-reads { padding-right: 44px; }
.io .bs-videos { border-left: 1px solid var(--line); padding-left: 44px; }
.io .bs-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 22px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.io .bs-head h2 { font-family: 'Sora', sans-serif; font-size: 22px; letter-spacing: -0.01em; margin: 0; }
.io .bs-head .bs-meta { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em; color: #8a8c92; }
.io .bs-head .bs-meta a { color: var(--ember); }
.io .bs-reads .post-grid { grid-template-columns: 1fr 1fr; gap: 18px; }
.io .bs-videos .content-grid { grid-template-columns: 1fr; gap: 16px; margin-top: 0; }
.io .blog-more { margin-top: 22px; }
.io .blog-more .btn { width: 100%; justify-content: center; }
@media (max-width: 860px) {
  .io .blog-tabs { display: inline-flex; gap: 4px; padding: 4px; border-radius: 999px; border: 1px solid var(--line); background: var(--paper); margin-bottom: 26px; }
  .io .blog-tabs button { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.04em; padding: 9px 20px; border-radius: 999px; border: none; background: transparent; color: #6b6d73; cursor: pointer; }
  .io .blog-tabs button.active { background: var(--ember); color: #fff; }
  .io .blog-split { grid-template-columns: 1fr; }
  .io .bs-reads { padding-right: 0; }
  .io .bs-videos { border-left: none; padding-left: 0; }
  .io .blog-split[data-tab="reads"] .bs-videos { display: none; }
  .io .blog-split[data-tab="videos"] .bs-reads { display: none; }
}
@media (max-width: 480px) { .io .bs-reads .post-grid { grid-template-columns: 1fr; } }

/* ---- Blog post (article) page ---- */
.io .article-hero { padding: clamp(110px,13vw,150px) 0 0; }
.io .article-hero .wrap { max-width: 780px; }
.io .article-hero .a-tags { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 16px; }
.io .article-hero .a-tag { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ember); border: 1px solid color-mix(in srgb, var(--ember) 25%, transparent); border-radius: 999px; padding: 4px 9px; }
.io .article-hero h1 { font-family: 'Sora', sans-serif; font-size: clamp(30px,4.6vw,48px); line-height: 1.06; letter-spacing: -0.02em; margin: 0; }
.io .article-hero .a-meta { margin-top: 18px; font-family: 'JetBrains Mono', monospace; font-size: 12px; color: #8a8c92; letter-spacing: 0.04em; }
.io .article-cover { max-width: 980px; margin: 36px auto 0; padding: 0 var(--pad); }
.io .article-cover img { width: 100%; border-radius: 16px; display: block; }
.io .article-body { padding: 40px 0 90px; }
.io .article-body .wrap { max-width: 720px; }
.io .article-body p, .io .article-body li { font-size: 16.5px; line-height: 1.75; color: #2c2e33; }
.io .article-body p { margin: 0 0 20px; }
.io .article-body h2 { font-family: 'Sora', sans-serif; font-size: 26px; letter-spacing: -0.015em; margin: 40px 0 12px; }
.io .article-body h3 { font-family: 'Sora', sans-serif; font-size: 20px; margin: 30px 0 8px; }
.io .article-body ul, .io .article-body ol { margin: 0 0 20px; padding-left: 22px; }
.io .article-body li { margin-bottom: 8px; }
.io .article-body a { color: var(--ember); text-decoration: underline; text-underline-offset: 3px; }
.io .article-body blockquote { margin: 24px 0; padding: 4px 0 4px 20px; border-left: 3px solid var(--ember); font-size: 19px; line-height: 1.5; color: var(--ink); font-family: 'Sora', sans-serif; }
.io .article-body img { max-width: 100%; border-radius: 12px; margin: 12px 0; }
.io .article-back { margin-bottom: 28px; }
.io .article-back a { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: #8a8c92; letter-spacing: 0.04em; }
.io .article-back a:hover { color: var(--ember); }

/* ---- About: team table (legacy, unused) ---- */
.io .team-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.io .team-table th, .io .team-table td { text-align: left; padding: 14px 12px; border-bottom: 1px solid var(--line); font-size: 15px; vertical-align: top; }
.io .team-table th { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: #8a8c92; font-weight: 400; }
.io .team-table td:first-child { font-family: 'Sora', sans-serif; font-weight: 600; }
@media (max-width: 600px) { .io .team-table thead { display: none; } .io .team-table td { display: block; border: none; padding: 2px 0; } .io .team-table tr { display: block; padding: 14px 0; border-bottom: 1px solid var(--line); } }

/* ---- Contact form ---- */
.io .form-card { max-width: 620px; border: 1px solid var(--line); border-radius: 18px; padding: clamp(24px,4vw,36px); background: var(--paper); }
.io .field { margin-bottom: 18px; }
.io .field label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 7px; color: var(--ink); }
.io .field input, .io .field select, .io .field textarea {
  width: 100%; font: inherit; font-size: 15px; padding: 12px 14px; border-radius: 10px;
  border: 1px solid var(--line); background: #fff; color: var(--ink);
}
.io .field textarea { min-height: 130px; resize: vertical; }
.io .field input:focus, .io .field select:focus, .io .field textarea:focus { outline: none; border-color: var(--ember); box-shadow: 0 0 0 3px color-mix(in srgb, var(--ember) 14%, transparent); }
.io .field-check { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: #5b5d63; }
.io .field-check input { width: auto; margin-top: 2px; }

/* ---- Waitlist consent checkbox (injected by main.js) ---- */
.io .form-consent {
  flex-basis: 100%; margin: 4px auto 0; max-width: 520px;
  font-size: 12px; line-height: 1.5; text-align: center;
  color: inherit; opacity: 0.7;
}
.io .form-consent a { text-decoration: underline; text-underline-offset: 2px; color: inherit; }
.io .section-dark .form-consent, .io .cta-strip.section-dark .form-consent { color: rgba(245,246,248,0.62); }

/* ---- Content / blog (Instagram reels gallery) ---- */
.io .content-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; margin-top: 8px; }
.io .ig-card {
  border: 1px solid var(--line); border-radius: 16px; overflow: hidden; background: var(--paper);
  transition: transform .2s, box-shadow .2s; display: flex; flex-direction: column;
}
.io .ig-card:hover { transform: translateY(-3px); box-shadow: 0 18px 44px rgba(0,0,0,0.08); }
.io .ig-thumb { position: relative; aspect-ratio: 4/5; background: #0d0d10 center/cover no-repeat; cursor: pointer; }
.io .ig-thumb::after {
  content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.45));
}
.io .ig-play {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 2;
  width: 56px; height: 56px; border-radius: 50%; background: rgba(255,255,255,0.92);
  display: grid; place-items: center; transition: transform .2s;
}
.io .ig-card:hover .ig-play { transform: translate(-50%,-50%) scale(1.08); }
.io .ig-play svg { width: 22px; height: 22px; margin-left: 3px; fill: #0b0b0d; }
.io .ig-meta { padding: 14px 16px 16px; }
.io .ig-meta .ig-cap { font-size: 14px; line-height: 1.5; color: var(--ink); margin: 0 0 8px; font-weight: 500; }
.io .ig-meta .ig-handle { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #8a8c92; letter-spacing: 0.04em; }
/* Lightbox */
.io .ig-lb { position: fixed; inset: 0; z-index: 1200; background: rgba(6,6,7,0.9); display: none; align-items: center; justify-content: center; padding: 24px; }
.io .ig-lb.open { display: flex; }
.io .ig-lb-inner { width: min(420px, 92vw); max-height: 92vh; overflow: auto; border-radius: 14px; background: #fff; }
.io .ig-lb-close { position: absolute; top: 18px; right: 22px; font-size: 30px; line-height: 1; color: #fff; background: none; border: none; cursor: pointer; }
.io .content-cta { margin-top: 40px; text-align: center; }

/* ---- Cookie consent banner ---- */
.io .cookie-banner {
  position: fixed; right: 20px; left: auto; bottom: 20px; z-index: 1300;
  width: 360px; max-width: calc(100vw - 32px); margin: 0;
  background: var(--deep); color: var(--cream-on-deep);
  border: 1px solid rgba(255,255,255,0.12); border-radius: 14px; padding: 18px 18px 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.4); display: none;
}
@media (max-width: 480px) { .io .cookie-banner { left: 16px; right: 16px; width: auto; bottom: 16px; } }
.io .cookie-banner.show { display: block; animation: ckUp .4s var(--ease-out, ease) both; }
@keyframes ckUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
.io .cookie-banner p { font-size: 13px; line-height: 1.55; margin: 0 0 14px; color: rgba(245,246,248,0.82); }
.io .cookie-banner a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }
/* Reject and Agree share equal width/prominence (reject as easy as accept). */
.io .cookie-actions { display: flex; gap: 8px; }
.io .cookie-actions .btn { flex: 1; justify-content: center; gap: 6px; font-size: 13px; padding: 9px 12px; }
.io .cookie-actions .btn-ghost { color: #fff; border-color: rgba(255,255,255,0.3); }
.io .cookie-actions .btn-primary { background: #fff; color: #000; border-color: #fff; }
