/* ═══════════════════════════════════════════════════════════════
   Skale Capital — Website layer (extends colors_and_type.css)
   Marketing-scale typography + page sections.
   ═══════════════════════════════════════════════════════════════ */

html { scroll-behavior: smooth; }
body { overflow-x: hidden; }

/* Page renders at native 100% — no CSS zoom (it blurs text + backdrop-filters
   on large/low-density screens). Sizing is handled by clamp() type + capped
   .wrap widths; users on very large displays can use native browser zoom. */

/* Marketing display scale (clamp-based, brand families) */
.disp-1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(40px, 5.6vw, 84px);
  line-height: 1.0; letter-spacing: -0.015em;
  color: var(--fg1); margin: 0;
  text-wrap: balance;
}
.disp-2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(32px, 3.7vw, 60px);
  line-height: 1.04; letter-spacing: -0.01em;
  color: var(--fg1); margin: 0; text-wrap: balance;
}
.disp-3 {
  font-family: var(--font-body); font-weight: 700;
  font-size: clamp(24px, 2.6vw, 34px);
  line-height: 1.15; letter-spacing: 0; color: var(--fg1); margin: 0;
}
.lead {
  font-family: var(--font-body); font-weight: 400;
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.6; color: var(--fg2); margin: 0;
  max-width: 60ch; text-wrap: pretty;
}
.eyebrow {
  font-family: var(--font-display); font-weight: 700;
  font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--cream); display: inline-flex; align-items: center; gap: 12px;
}
.eyebrow::before {
  content: ''; width: 28px; height: 1px; background: var(--cream);
  opacity: 0.6; display: inline-block;
}
.eyebrow.center::after {
  content: ''; width: 28px; height: 1px; background: var(--cream);
  opacity: 0.6; display: inline-block;
}

/* Layout shell */
.wrap { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 32px; }
.wrap-wide { max-width: 1400px; }
section { position: relative; }
.sec-pad { padding: clamp(64px, 8.2vw, 160px) 0; }
.divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(222,201,180,0.22), transparent); }

/* Buttons — larger marketing sizes */
a.btn, .btn { text-decoration: none; border-radius: var(--r-md); }
.btn-xl {
  height: 54px; padding: 0 28px; font-size: 15px; border-radius: var(--r-md);
  letter-spacing: 0.02em;
}
.btn .arr { transition: transform var(--d-normal) var(--ease-premium); }
.btn:hover .arr { transform: translateX(3px); }

/* CTA hover — illumination only, no movement */
[data-magnetic] { transition: box-shadow 220ms var(--ease-premium); }
.btn-primary:hover {
  transform: none;
  box-shadow: 0 0 18px rgba(222,201,180,0.50), 0 0 44px rgba(222,201,180,0.22), 0 8px 24px rgba(0,0,0,0.25);
}

/* ═══════════════ NAV ═══════════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: 72px; display: flex; align-items: center;
  transition: background var(--d-slow) var(--ease-premium),
              backdrop-filter var(--d-slow), border-color var(--d-slow), height var(--d-slow);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  height: 64px;
  background: rgba(20,33,36,0.72);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--glass-border);
}
.nav .wrap { display: flex; align-items: center; justify-content: space-between; gap: 24px; position: relative; }
.nav-logo { height: 26px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 4px; position: absolute; left: 50%; transform: translateX(-50%); }
.nav-link {
  font-family: var(--font-body); font-weight: 600; font-size: 14px;
  color: var(--fg2); text-decoration: none; padding: 8px 14px; border-radius: var(--r-md);
  transition: color var(--d-fast), background var(--d-fast); letter-spacing: 0.01em;
}
.nav-link:hover { color: var(--fg1); background: rgba(255,255,255,0.04); }
.nav-link.active { color: var(--cream); }
.nav-right { display: flex; align-items: center; gap: 12px; }
.nav-toggle {
  display: none; width: 40px; height: 40px; align-items: center; justify-content: center;
  background: rgba(52,77,82,0.30); border: 1px solid var(--glass-border); border-radius: var(--r-sm);
  color: var(--fg1); cursor: pointer; padding: 0;
  transition: border-color var(--d-normal), color var(--d-normal);
}
.nav-toggle:hover { color: var(--cream); border-color: var(--glass-border-cream); }
.nav-menu {
  display: none; flex-direction: column;
  position: absolute; top: 100%; left: 0; right: 0;
  background: var(--glass-bg-deep); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--glass-border);
  padding: 8px 20px 16px;
}
.nav-menu a {
  display: block; padding: 14px 4px; text-decoration: none;
  font-family: var(--font-display); font-weight: 700; font-size: 16px; letter-spacing: 0.02em;
  color: var(--fg1); border-bottom: 1px solid var(--glass-border);
}
.nav-menu a:last-child { border-bottom: none; }
.nav-menu-portal { color: var(--cream) !important; }
.nav-menu a:active { color: var(--cream); }
.nav.menu-open .nav-menu { display: flex; }
.soon {
  font-family: var(--font-display); font-size: 9px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--cream-dim);
  border: 1px solid var(--glass-border-cream); border-radius: var(--r-pill);
  padding: 2px 7px; margin-left: 7px;
}
.nav-login {
  display: inline-flex; align-items: center;
  font-family: var(--font-body); font-weight: 600; font-size: 14px;
  color: var(--fg3); text-decoration: none; padding: 8px 12px; cursor: default;
}
.nav-login-live { cursor: pointer; transition: color var(--d-normal) var(--ease-premium); }
.nav-login-live:hover { color: var(--cream); }
.nav-cta { height: 42px; padding: 0 18px; font-size: 14px; }
.nav-soon-btn { cursor: default; color: var(--fg3); border-color: var(--glass-border); }
.nav-soon-btn:hover { background: transparent; border-color: var(--glass-border); }
.nav-soon-btn .soon { margin-left: 8px; }
.nav-toggle { display: none; }

/* ═══════════════ HERO ═══════════════ */
.hero {
  position: relative; min-height: 100vh; min-height: 100svh;
  display: flex; flex-direction: column; overflow: hidden;
  text-align: center;
  padding: 104px 24px 44px;
}
.hero-bg { position: absolute; inset: 0; z-index: 0; will-change: transform; }
.hero-bg img {
  width: 100%; height: 108%; object-fit: cover; object-position: center 44%;
  filter: saturate(0.85) brightness(0.78) contrast(1.02);
  transform-origin: center center;
  will-change: transform;
}
html:not(.intro):not(.intro-done) .hero-bg img { animation: heroSettle 7s var(--ease-premium) forwards; }
@keyframes heroSettle {
  from { transform: scale(1.06); }
  to   { transform: scale(1.0); }
}
/* cool teal duotone wash over the skyline — a real overlay div (reliable) */
.hero-duo {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(rgba(20,38,42,0.30), rgba(20,38,42,0.30)),
    radial-gradient(80% 64% at 50% 56%, rgba(20,33,36,0.14), transparent 76%),
    linear-gradient(180deg, rgba(20,33,36,0.82) 0%, rgba(20,33,36,0.22) 26%, rgba(20,33,36,0.20) 54%, rgba(20,33,36,0.66) 84%, var(--deep-teal) 100%);
}
.hero-grain { position: absolute; inset: 0; z-index: 1; opacity: 0.05; background-image: var(--noise-svg); background-size: 256px; pointer-events: none; }
.hero-chevron {
  position: absolute; z-index: 1; top: 50%; right: -6%; transform: translateY(-50%);
  width: min(58vw, 720px); opacity: 0.05; pointer-events: none;
}
/* Section watermark — fills deadspace, bleeds off-page like the IM cover */
.sec-chevron {
  position: absolute; z-index: 0; pointer-events: none; opacity: 0.03;
  width: min(140vw, 1760px); user-select: none;
}
.proc { position: relative; }
.proc-clip { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.proc .sec-chevron { right: -38%; top: 64%; transform: translateY(-50%); }
.proc .wrap { position: relative; z-index: 1; }
.hero-content { position: relative; z-index: 3; width: 100%; flex: 1 1 auto; display: flex; flex-direction: column; }
.hero-inner { flex: 1 1 auto; display: flex; flex-direction: column; align-items: center; justify-content: center; max-width: 900px; margin: 0 auto; }
.hero-tagline {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(34px, 5vw, 78px); line-height: 1.0; letter-spacing: -0.01em;
  color: var(--cream); margin: 0;
  white-space: nowrap;
}
.hero-tagline .iv { color: var(--ivory); }
.hero-sub {
  font-family: var(--font-body); font-weight: 400;
  font-size: clamp(16px, 1.5vw, 20px); line-height: 1.6;
  color: var(--fg1); margin: 24px auto 0; max-width: 48ch;
}
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 38px; justify-content: center; }

/* hero credibility band — sits at the bottom of the hero */
.hero-stats {
  flex: none; width: min(940px, 92%); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr);
  padding-top: 22px; border-top: 1px solid var(--glass-border-hi);
}
.hero-stat { padding: 0 12px; border-right: 1px solid var(--glass-border); text-align: center; }
.hero-stat:last-child { border-right: none; }
.hero-stat .num {
  font-family: var(--font-display); font-weight: 700;
  font-variant-numeric: tabular-nums; color: var(--ivory);
  font-size: clamp(24px, 2.6vw, 36px); line-height: 1; letter-spacing: -0.01em;
}
.hero-stat .num .unit { color: var(--cream); }
.hero-stat .cap {
  margin-top: 10px; font-family: var(--font-display); font-weight: 700;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg3);
}
.scroll-hint {
  position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  font-family: var(--font-display); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--fg3);
}
.scroll-hint .line { width: 1px; height: 40px; background: linear-gradient(var(--cream), transparent); animation: scrollLine 2.2s var(--ease-premium) infinite; }
@keyframes scrollLine { 0% { transform: scaleY(0); transform-origin: top; } 45% { transform: scaleY(1); transform-origin: top; } 55% { transform: scaleY(1); transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* ═══════════════ MARQUEE / TRUST ═══════════════ */
.trust { border-top: 1px solid var(--glass-border); border-bottom: 1px solid var(--glass-border); background: rgba(26,47,51,0.4); overflow: hidden; }
.marquee { display: flex; gap: 0; white-space: nowrap; padding: 22px 0; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee-track { display: flex; align-items: center; gap: 56px; padding-right: 56px; animation: marquee 38s linear infinite; }
.marquee-track .item { display: inline-flex; align-items: center; gap: 14px; font-family: var(--font-display); font-weight: 600; font-size: 15px; letter-spacing: 0.02em; color: var(--fg2); }
.marquee-track .item svg { color: var(--cream); flex: none; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ═══════════════ SECTION HEADERS ═══════════════ */
.sec-head { max-width: 760px; }
.sec-head .disp-2 { margin-top: 18px; }
.sec-head .lead { margin-top: 18px; }
.sec-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.sec-head.center .lead { margin-left: auto; margin-right: auto; }

/* ═══════════════ FACILITIES ═══════════════ */
.fac-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 56px; }
.fac-card { padding: 40px; transition: transform var(--d-normal) var(--ease-premium), border-color var(--d-normal), box-shadow var(--d-normal); }
.fac-card:hover { transform: translateY(-3px); border-color: var(--glass-border-cream); box-shadow: var(--shadow-card-hover); }
.fac-ico { width: 52px; height: 52px; border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; background: rgba(222,201,180,0.10); border: 1px solid var(--glass-border-cream); color: var(--cream); margin-bottom: 28px; }
.fac-card h3 { margin-bottom: 12px; }
.fac-card .meta { margin-top: 26px; display: flex; gap: 28px; flex-wrap: wrap; }
.fac-meta-item .k { font-family: var(--font-display); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg3); }
.fac-meta-item .v { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--ivory); margin-top: 4px; font-variant-numeric: tabular-nums; white-space: nowrap; }

/* LVR ladder — asset classes & ceilings */
/* facilities hero — intro left, 2×2 fact cards right */
.fac-hero { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.fac-hero .sec-head { margin: 0; max-width: none; }
.fac-strip { margin-top: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.fac-strip .fac-meta-item {
  position: relative; overflow: hidden; text-align: center;
  padding: 26px 20px; border: 1px solid var(--glass-border); border-radius: var(--r-lg);
  background: rgba(20,33,36,0.45);
  transition: transform var(--d-normal) var(--ease-premium), border-color var(--d-normal) var(--ease-premium), box-shadow var(--d-slow) var(--ease-premium);
}
.fac-strip .fac-meta-item::before {
  content: ''; position: absolute; inset: 0; z-index: 0; border-radius: var(--r-lg); pointer-events: none;
  background: linear-gradient(105deg, transparent 40%, rgba(222,201,180,0.14) 50%, transparent 60%);
  background-size: 240% 100%; background-position: 170% 0;
  transition: background-position 1100ms var(--ease-premium);
}
.fac-strip .fac-meta-item:hover { transform: translateY(-3px); border-color: var(--glass-border-cream); box-shadow: var(--shadow-card-hover); }
.fac-strip .fac-meta-item:hover::before { background-position: -70% 0; }
.fac-strip .k { display: block; position: relative; z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg3); padding-bottom: 0; margin-bottom: 14px; }
.fac-strip .v { display: block; position: relative; z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: clamp(18px, 1.6vw, 22px); color: var(--ivory); margin-top: 0; white-space: normal; letter-spacing: 0.01em; }

.lvr-ladder { margin-top: 56px; }
/* LVR ring-gauge cards */
.lvr-rings { margin-top: 56px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.ring-card { position: relative; cursor: pointer; text-align: center; padding: 32px 20px 26px; border: 1px solid var(--glass-border); border-radius: var(--r-lg); background: rgba(20,33,36,0.45); transition: transform var(--d-normal) var(--ease-premium), border-color var(--d-normal) var(--ease-premium), box-shadow var(--d-slow) var(--ease-premium); }
.ring-card:hover, .ring-card:focus-visible { transform: translateY(-3px); border-color: var(--glass-border-cream); box-shadow: var(--shadow-card-hover); outline: none; }
.ring-card:focus-visible { box-shadow: var(--shadow-card-hover), 0 0 0 2px var(--cream); }
.ring-gauge { position: relative; width: 128px; height: 128px; margin: 0 auto 18px; }
.ring-gauge svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.ring-track { fill: none; stroke: rgba(255,255,255,0.08); stroke-width: 7; }
.lvr-arc { fill: none; stroke: var(--cream); stroke-width: 7; stroke-linecap: round; stroke-dasharray: 263.9; stroke-dashoffset: 263.9; filter: drop-shadow(0 0 6px rgba(222,201,180,0.45)); transition: stroke-dashoffset 1100ms var(--ease-premium); }
.ring-card .lvr-pct { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 30px; color: var(--ivory); font-variant-numeric: tabular-nums; }
.ring-name { font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--fg1); letter-spacing: 0.01em; transition: color var(--d-normal) var(--ease-premium); }
.ring-card:hover .ring-name, .ring-card:focus-visible .ring-name { color: var(--cream); }
.ring-desc { font-size: 13px; line-height: 1.45; color: var(--fg3); margin-top: 8px; }
.lvr-residual { margin-top: 16px; position: relative; display: flex; justify-content: center; align-items: center; gap: 28px; padding: 26px 30px; border: 1px solid var(--glass-border); border-radius: var(--r-lg); background: rgba(20,33,36,0.45); transition: border-color var(--d-normal) var(--ease-premium), box-shadow var(--d-slow) var(--ease-premium); cursor: pointer; }
.lvr-residual:hover, .lvr-residual:focus-visible { border-color: var(--glass-border-cream); box-shadow: var(--shadow-card-hover); outline: none; }
.lr-gauge { width: 92px; height: 92px; flex: none; margin: 0; position: absolute; right: 30px; top: 50%; transform: translateY(-50%); }
.res-arc { stroke-dashoffset: 66; }
.lr-gauge .lvr-pct { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--ivory); font-variant-numeric: tabular-nums; }
.lr-text { text-align: center; max-width: 60ch; }
.lvr-residual .ring-name { font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--fg1); letter-spacing: 0.01em; transition: color var(--d-normal) var(--ease-premium); }
.lvr-residual:hover .ring-name { color: var(--cream); }
.lvr-residual .ring-desc { font-size: 13px; line-height: 1.5; color: var(--fg3); margin: 6px auto 0; max-width: 64ch; }
.lvr-row {
  display: grid; grid-template-columns: 168px 1fr 280px; gap: 28px; align-items: center;
  padding: 16px 12px; margin: 0 -12px; border-radius: var(--r-lg);
  position: relative;
  transition: background var(--d-normal) var(--ease-premium);
}
.lvr-row:not(.static) { cursor: pointer; }
/* mirror sheen removed from LVR rows */
.lvr-name, .lvr-track, .lvr-desc { position: relative; z-index: 1; }
.lvr-row:not(.static):hover, .lvr-row:not(.static):focus-visible { background: rgba(255,255,255,0.035); }
.lvr-row:not(.static):focus-visible { outline: 2px solid var(--cream); outline-offset: 2px; }
.lvr-name { font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--fg1); letter-spacing: 0.01em; transition: color var(--d-normal), text-shadow 350ms var(--ease-premium); }
.lvr-row:not(.static):hover .lvr-name {
  color: var(--cream);
  text-shadow: 0 0 12px rgba(222,201,180,0.85), 0 0 28px rgba(222,201,180,0.45), 0 0 56px rgba(222,201,180,0.25);
}
.lvr-track {
  position: relative; height: 38px; border-radius: var(--r-md); overflow: hidden;
  background: rgba(255,255,255,0.07); border: 1px solid var(--glass-border);
}
.lvr-fill {
  position: absolute; inset: 0 auto 0 0; width: var(--w, 0%); border-radius: var(--r-md);
  background: linear-gradient(90deg, rgba(222,201,180,0.55), var(--cream));
  display: flex; align-items: center; justify-content: flex-end; padding-right: 12px;
  transition: width 1200ms var(--ease-premium), box-shadow var(--d-normal);
}
.js .lvr-fill { width: 0; }
.lvr-row:not(.static):hover .lvr-fill { box-shadow: var(--cream-glow-strong); }
.lvr-pct { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--deep-teal); font-variant-numeric: tabular-nums; white-space: nowrap; }
.lvr-note { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.04em; color: var(--cream); white-space: nowrap; transition: color 400ms var(--ease-premium) 250ms; }

/* Residual stock row — hover glow + bar sweep (no click action) */
.lvr-row.static:hover { background: rgba(255,255,255,0.035); }
.lvr-row.static .lvr-fill { width: 0; transition: width 900ms var(--ease-premium); }
.lvr-row.static:hover .lvr-fill { width: 75%; }
.lvr-row.static:hover .lvr-note { color: var(--deep-teal); }
.lvr-row.static:hover .lvr-name {
  color: var(--cream);
  text-shadow: 0 0 12px rgba(222,201,180,0.85), 0 0 28px rgba(222,201,180,0.45), 0 0 56px rgba(222,201,180,0.25);
}
.lvr-row.static:hover .lvr-desc {
  color: var(--cream);
  text-shadow: 0 0 10px rgba(222,201,180,0.75), 0 0 24px rgba(222,201,180,0.40), 0 0 48px rgba(222,201,180,0.22);
}
.lvr-desc { font-size: 13px; line-height: 1.45; color: var(--fg3); transition: color var(--d-normal), text-shadow 350ms var(--ease-premium); }
.lvr-row:not(.static):hover .lvr-desc {
  color: var(--cream);
  text-shadow: 0 0 10px rgba(222,201,180,0.75), 0 0 24px rgba(222,201,180,0.40), 0 0 48px rgba(222,201,180,0.22);
}
.lvr-hint { margin-top: 18px; padding: 0 12px; font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cream-dim); }
.disclaimer { margin-top: 24px; font-size: 13px; color: var(--fg3); display: flex; gap: 10px; align-items: flex-start; max-width: 70ch; }
.disclaimer svg { flex: none; color: var(--cream-dim); margin-top: 2px; }

/* ═══════════════ PROCESS (scroll timeline) ═══════════════ */
.proc { position: relative; }
.proc-grid { display: grid; grid-template-columns: 1fr; gap: 0; margin-top: 40px; position: relative; }
.proc-rail { position: absolute; left: 27px; top: 12px; bottom: 12px; width: 2px; background: var(--glass-border-hi); }
.proc-rail .fill { position: absolute; top: 0; left: 0; width: 100%; height: 0%; background: linear-gradient(var(--cream), var(--cream-soft)); box-shadow: var(--cream-glow); transition: height 120ms linear; }
.proc-step { display: grid; grid-template-columns: 56px 1fr; gap: 28px; padding: 15px 0; position: relative; }
.proc-dot {
  width: 14px; height: 14px; margin-left: 21px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: var(--deep-teal); border: 2px solid var(--glass-border-hi);
  font-size: 0; color: transparent;
  z-index: 2; transition: border-color var(--d-slow) var(--ease-premium), background var(--d-slow) var(--ease-premium), box-shadow var(--d-slow) var(--ease-premium);
}
.proc-step.on .proc-dot { border-color: var(--cream); background: var(--cream); box-shadow: var(--cream-glow-strong); }
.proc-body { padding-top: 4px; }
.proc-body .day { display: none; }
/* dot sits on the rail line, optically centred on the stage heading */
.proc-dot { margin-top: 23px; align-self: start; }
.proc-body .day { font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cream); }
.proc-body h3 { margin: 6px 0 6px; transition: color var(--d-slow); }
.proc-step.on .proc-body h3 { color: var(--cream); }
.proc-body p { max-width: 64ch; }

/* ═══════════════ WHY — editorial edge list + sticky readout ═══════════════ */
.why-split { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: 72px; align-items: start; margin-top: 56px; }
.edge-list { border-top: 1px solid var(--glass-border-hi); }
.edge-item { position: relative; display: grid; grid-template-columns: 86px 1fr; gap: 28px; padding: 44px 0 44px 30px; border-bottom: 1px solid var(--glass-border); align-items: start; cursor: default; }
.edge-item::before {
  content: ''; position: absolute; left: 0; top: 26%; bottom: 26%; width: 2px;
  background: var(--cream); box-shadow: var(--cream-glow-strong); border-radius: 2px;
  transform: scaleY(0); transition: transform 500ms var(--ease-premium);
}
.edge-item.on::before { transform: scaleY(1); }
.edge-n { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--fg3); letter-spacing: 0.14em; padding-top: 12px; transition: color var(--d-normal); }
.edge-item.on .edge-n { color: var(--cream); }
.edge-item h3 { font-family: var(--font-body); font-weight: 700; font-size: clamp(21px, 2.3vw, 30px); line-height: 1.18; letter-spacing: 0; color: var(--fg2); margin: 0 0 14px; transition: color var(--d-slow) var(--ease-premium), text-shadow 450ms var(--ease-premium); text-wrap: balance; }
.edge-item.on h3 { color: var(--ivory); }
.edge-item:hover h3 { color: var(--cream); text-shadow: 0 0 14px rgba(222,201,180,0.4), 0 0 36px rgba(222,201,180,0.18); }
.edge-item p { max-width: 56ch; color: var(--fg3); transition: color var(--d-normal); }
.edge-item.on p { color: var(--fg2); }
.edge-stat { display: none; }

/* floating readout — aligns to the illuminated item */
.why-side { position: relative; min-width: 0; align-self: stretch; }
.why-sticky { position: absolute; top: 0; left: 0; right: 0; will-change: transform; text-align: center; }
.ws-num {
  display: block; font-family: var(--font-display); font-weight: 700;
  font-size: clamp(48px, 4.9vw, 76px); line-height: 0.92; letter-spacing: -0.02em;
  color: transparent; -webkit-text-stroke: 2px rgba(222,201,180,0.9);
  font-variant-numeric: tabular-nums; white-space: nowrap;
}
.ws-num.long, .ws-num.xlong { font-size: clamp(48px, 4.9vw, 76px); }
.ws-num.swap { animation: wsRise 560ms var(--ease-premium); }
@keyframes wsRise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

/* ═══════════════ PLATFORM ═══════════════ */
.plat { position: relative; overflow: hidden; }
.plat-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 64px; align-items: center; }
.plat-feats { margin-top: 32px; display: flex; flex-direction: column; gap: 4px; }
.plat-feat { display: grid; grid-template-columns: 40px 1fr; gap: 16px; padding: 18px 0; border-top: 1px solid var(--glass-border); }
.plat-feat:last-child { border-bottom: 1px solid var(--glass-border); }
.plat-feat .pf-ico { color: var(--cream); }
.plat-feat h4 { font-size: 16px; margin-bottom: 4px; }
.plat-mock { position: relative; perspective: 1600px; }
.plat-card { transform: rotateY(-9deg) rotateX(4deg); transform-style: preserve-3d; transition: transform 600ms var(--ease-premium); padding: 0; overflow: hidden; }
.plat-mock:hover .plat-card { transform: rotateY(-4deg) rotateX(2deg); }
.mock-bar { display: flex; align-items: center; gap: 8px; padding: 14px 18px; border-bottom: 1px solid var(--glass-border); background: rgba(26,47,51,0.6); }
.mock-dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,0.14); }
.mock-title { margin-left: 10px; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.06em; color: var(--fg2); white-space: nowrap; }
.mock-body { padding: 22px; display: flex; flex-direction: column; gap: 16px; }
.mock-kpis { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.mock-kpi { padding: 16px; border-radius: var(--r-lg); background: rgba(52,77,82,0.4); border: 1px solid var(--glass-border); }
.mock-kpi .k { font-family: var(--font-display); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg3); }
.mock-kpi .v { font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--ivory); margin-top: 6px; font-variant-numeric: tabular-nums; }
.mock-kpi .v.cream { color: var(--cream); }
.mock-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 14px; padding: 14px 16px; border-radius: var(--r-lg); background: rgba(52,77,82,0.3); border: 1px solid var(--glass-border); }
.mock-row .left { display: flex; align-items: center; gap: 12px; }
.mock-row .addr { font-family: var(--font-body); font-weight: 600; font-size: 13px; color: var(--fg1); text-align: left; }
.mock-row .amt { font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--ivory); font-variant-numeric: tabular-nums; }
.mock-stage { display: flex; align-items: center; gap: 6px; }
.mock-stage .seg { width: 22px; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.12); }
.mock-stage .seg.done { background: var(--cream); }
.mock-prog { height: 6px; border-radius: 3px; background: rgba(255,255,255,0.1); overflow: hidden; }
.mock-prog .pf { height: 100%; background: linear-gradient(90deg, var(--cream), var(--cream-soft)); border-radius: 3px; }

/* ═══════════════ ABOUT / FOUNDER ═══════════════ */
.about-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 64px; align-items: center; }
.about-portrait { position: relative; }
.about-portrait .frame { position: relative; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--glass-border-hi); }
.about-portrait img { width: 100%; height: auto; display: block; filter: saturate(0.85) contrast(1.02); }
.about-portrait .frame::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(20,33,36,0.55)); }
.about-portrait .name-plate { position: absolute; left: 24px; bottom: 24px; z-index: 2; }
.about-portrait .name-plate .nm { font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--ivory); letter-spacing: 0.01em; }
.about-portrait .name-plate .ti { font-family: var(--font-display); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cream); margin-top: 4px; }
.about-portrait .badge-float { position: absolute; top: -18px; right: -18px; z-index: 3; }
.about-quote { font-family: var(--font-display); font-weight: 700; font-size: clamp(22px, 2.4vw, 30px); line-height: 1.3; color: var(--ivory); letter-spacing: -0.005em; text-wrap: pretty; }
.about-body { margin-top: 24px; display: flex; flex-direction: column; gap: 16px; }
.about-stats { display: flex; gap: 40px; margin-top: 34px; flex-wrap: wrap; }
.about-stat .v { font-family: var(--font-display); font-weight: 700; font-size: 34px; color: var(--ivory); font-variant-numeric: tabular-nums; line-height: 1; }
.about-stat .v .unit { color: var(--cream); }
.about-stat .k { margin-top: 8px; font-family: var(--font-display); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg3); }

/* tag chips for complex deals */
.deal-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.deal-tag { font-family: var(--font-body); font-weight: 600; font-size: 13px; color: var(--fg2); padding: 8px 16px; border-radius: var(--r-pill); background: rgba(52,77,82,0.4); border: 1px solid var(--glass-border); transition: color var(--d-normal) var(--ease-premium), background var(--d-normal) var(--ease-premium), border-color var(--d-normal) var(--ease-premium), box-shadow var(--d-normal) var(--ease-premium), transform var(--d-normal) var(--ease-premium); }
.deal-tag:hover { color: var(--ivory); border-color: rgba(222,201,180,0.45); box-shadow: var(--cream-glow); transform: translateY(-2px); }

/* ═══════════════ VOICES — editorial quote spread ═══════════════ */
.vq-grid { display: grid; grid-template-columns: 0.9fr 1.35fr; gap: 72px; align-items: start; }
.vq-rail .disp-2 { margin-top: 18px; }
.vq-controls { display: flex; align-items: center; gap: 12px; margin-top: 40px; }
.vq-arrow {
  width: 52px; height: 52px; border-radius: 50%; border: 1px solid rgba(26,47,51,0.28);
  background: transparent; color: var(--fg-on-cream-1); display: flex; align-items: center; justify-content: center;
  cursor: pointer; padding: 0; transition: background var(--d-normal) var(--ease-premium), color var(--d-normal), border-color var(--d-normal), transform var(--d-normal) var(--ease-premium);
}
.vq-arrow:hover { background: var(--deep-teal); color: var(--cream); border-color: var(--deep-teal); transform: translateY(-2px); }
.vq-arrow:active { transform: scale(0.97); }
.vq-count { margin-left: 12px; font-family: var(--font-display); font-weight: 700; font-size: 13px; color: var(--fg-on-cream-3); font-variant-numeric: tabular-nums; letter-spacing: 0.1em; }
.vq-count #vqIdx { font-size: 19px; color: var(--fg-on-cream-1); }
.vq-count .sep { opacity: 0.5; margin: 0 5px; }
/* story-style segmented progress — beneath the quote panel */
.vq-segs { display: flex; gap: 10px; margin-top: 20px; width: min(340px, 100%); margin-left: auto; margin-right: auto; }
.vq-seg {
  flex: 1; height: 6px; border-radius: var(--r-pill); border: none; padding: 0; cursor: pointer;
  background: rgba(26,47,51,0.12); overflow: hidden; position: relative;
  transition: background var(--d-normal);
}
.vq-seg:hover { background: rgba(26,47,51,0.22); }
.vq-seg .fill { display: block; height: 100%; width: 0%; background: #C9A87E; border-radius: inherit; }
.vq-seg.active .fill { box-shadow: 0 0 12px rgba(201,168,126,0.9); }

.vq-stage { position: relative; min-height: 380px; }
.vq-ghost {
  position: absolute; top: -64px; right: -8px;
  font-family: var(--font-display); font-weight: 700; font-size: clamp(170px, 20vw, 280px); line-height: 1;
  color: var(--deep-teal); opacity: 0.05; user-select: none; pointer-events: none;
  font-variant-numeric: tabular-nums; letter-spacing: -0.04em;
}
.voice { position: absolute; inset: 0; opacity: 0; transform: translateY(18px); transition: opacity 700ms var(--ease-premium), transform 700ms var(--ease-premium); pointer-events: none; }
.voice.on { opacity: 1; transform: none; pointer-events: auto; }
.voice blockquote { margin: 0; font-family: var(--font-body); font-weight: 400; font-size: clamp(20px, 2.2vw, 30px); line-height: 1.42; color: var(--fg-on-cream-1); letter-spacing: 0; text-wrap: pretty; }
.voice .who { margin-top: 36px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.voice .who .rule { width: 44px; height: 2px; background: var(--deep-teal); opacity: 0.55; }
.voice .who .nm { font-family: var(--font-body); font-weight: 700; font-size: 16px; color: var(--fg-on-cream-1); }
.voice .who .co { font-size: 14px; color: var(--fg-on-cream-3); }
.voice .who .tag { font-family: var(--font-display); font-weight: 700; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-on-cream-2); border: 1px solid rgba(26,47,51,0.22); border-radius: var(--r-pill); padding: 6px 13px; }

/* ═══════════════ CONTACT ═══════════════ */
.contact-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 64px; }
.form { padding: 40px; }
.field { margin-bottom: 18px; }
.field label { display: block; font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg3); margin-bottom: 8px; }
.field input, .field select, .field textarea { width: 100%; height: 48px; font-size: 15px; background: rgba(26,47,51,0.5); }
.field textarea { height: 120px; }
@media (max-width: 760px) {
  .form { padding: 26px 22px; }
  .field { margin-bottom: 14px; }
  .field input, .field select, .field textarea { height: 46px; }
  .field textarea { height: 96px; }
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-info { display: flex; flex-direction: column; gap: 4px; }
.ci-item { display: grid; grid-template-columns: 44px 1fr; gap: 18px; padding: 26px 0; border-bottom: 1px solid var(--glass-border); align-items: center; }
.ci-item:first-of-type { border-top: 1px solid var(--glass-border); }
.ci-ico { width: 44px; height: 44px; border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; background: rgba(222,201,180,0.08); border: 1px solid var(--glass-border-cream); color: var(--cream); }
.ci-item .k { font-family: var(--font-display); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg3); }
.ci-item .v { font-family: var(--font-body); font-weight: 600; font-size: 17px; color: var(--fg1); margin-top: 4px; text-decoration: none; display: block; }
a.ci-link:hover .v, .ci-item a:hover .v { color: var(--cream); }

/* ═══════════════ TONAL BAND — raised dark panel ═══════════════ */
.band { background: rgba(42,66,71,0.32); border-top: 1px solid var(--glass-border); border-bottom: 1px solid var(--glass-border); }

/* ═══════════════ VOICES — cream variant ═══════════════ */
.voices-cream { background: var(--cream); position: relative; overflow: hidden; }
.voices-quote {
  position: absolute; pointer-events: none; user-select: none; display: block; opacity: 0.55;
}
.voices-cream .wrap { position: relative; z-index: 1; }
.voices-cream .eyebrow { color: var(--fg-on-cream-2); }
.voices-cream .eyebrow::before, .voices-cream .eyebrow.center::after { background: var(--fg-on-cream-2); opacity: 0.5; }
.voices-cream .disp-2 { color: var(--fg-on-cream-1); }

/* ═══════════════ CONTACT — photographic bookend ═══════════════ */
.contact-sec { position: relative; overflow: hidden; }
.contact-bg { position: absolute; inset: 0; z-index: 0; }
.contact-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 62%; filter: saturate(0.45) brightness(0.52); }
.contact-duo { position: absolute; inset: 0; background: linear-gradient(rgba(20,38,42,0.55), rgba(20,38,42,0.55)), linear-gradient(180deg, var(--deep-teal) 0%, rgba(20,33,36,0.78) 26%, rgba(20,33,36,0.80) 72%, var(--deep-teal) 100%); }
.contact-sec .wrap { position: relative; z-index: 1; }

/* hero credibility marker */
.hero-marker { font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--cream); margin-bottom: 26px; display: inline-flex; align-items: center; gap: 16px; }
.hero-marker::before, .hero-marker::after { content: ''; width: 36px; height: 1px; background: var(--cream); opacity: 0.5; }

/* styled select */
.field select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23DEC9B4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 42px; cursor: pointer; }

/* form submit → success state */
.form { position: relative; }
.form .form-fields { transition: opacity 400ms var(--ease-premium), transform 400ms var(--ease-premium); }
.form.sent .form-fields { opacity: 0; pointer-events: none; transform: translateY(-8px); }
.form-success { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 40px; opacity: 0; pointer-events: none; transform: translateY(12px); transition: opacity 500ms var(--ease-premium) 250ms, transform 500ms var(--ease-premium) 250ms; }
.form.sent .form-success { opacity: 1; pointer-events: auto; transform: none; }
.form-success .ok-ico { width: 64px; height: 64px; border-radius: 50%; background: rgba(222,201,180,0.12); border: 1px solid var(--glass-border-cream); display: flex; align-items: center; justify-content: center; color: var(--cream); margin-bottom: 22px; }
.form-success p { margin-top: 12px; max-width: 38ch; color: var(--fg2); }
/* brief highlight when the Sizer pre-fills the form */
@keyframes formPulse {
  0%   { box-shadow: 0 0 0 0 rgba(222,201,180,0); }
  28%  { box-shadow: 0 0 0 3px rgba(222,201,180,0.38), 0 0 44px rgba(222,201,180,0.18); }
  100% { box-shadow: 0 0 0 0 rgba(222,201,180,0); }
}
.form.prefilled { animation: formPulse 1500ms var(--ease-premium); }
@media (prefers-reduced-motion: reduce) { .form.prefilled { animation: none; } }

/* ═══════════════ FOOTER ═══════════════ */
.footer { border-top: 1px solid var(--glass-border); background: rgba(20,33,36,0.6); padding: 72px 0 40px; }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.footer-logo { height: 28px; margin-bottom: 20px; }
.footer-col h5 { font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cream); margin: 0 0 18px; }
.footer-col a { display: flex; align-items: center; font-family: var(--font-body); font-size: 14px; color: var(--fg2); text-decoration: none; padding: 7px 0; transition: color var(--d-fast); }
.footer-col a:hover { color: var(--fg1); }
.footer-desc { font-size: 14px; color: var(--fg3); max-width: 34ch; line-height: 1.6; }
.footer-bottom { margin-top: 56px; padding-top: 28px; border-top: 1px solid var(--glass-border); display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.footer-bottom .copy { font-size: 13px; color: var(--fg3); }
.footer-compliance { margin-top: 16px; font-size: 12px; color: var(--fg3); line-height: 1.6; max-width: 90ch; }

/* ═══════════════ SCROLL PROGRESS HAIRLINE ═══════════════ */
.scroll-bar {
  position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 200;
  transform: scaleX(0); transform-origin: 0 50%;
  background: linear-gradient(90deg, var(--cream), var(--cream-soft));
  box-shadow: var(--cream-glow);
}

/* ═══════════════ HERO CURSOR LIGHT ═══════════════ */
.hero-light { position: absolute; inset: 0; z-index: 3; pointer-events: none; mix-blend-mode: screen; opacity: 0; transition: opacity 400ms ease; }

/* ═══════════════ SCENARIO SIZER ═══════════════ */
.sizer { margin-top: 28px; padding: 44px 44px 40px; overflow: hidden; position: relative; transition: transform var(--d-normal) var(--ease-premium), border-color var(--d-normal), box-shadow 450ms var(--ease-premium); }
.sizer:hover {
  transform: translateY(-3px);
  border-color: rgba(222,201,180,0.45);
  box-shadow:
    0 12px 32px rgba(0,0,0,0.25),
    0 0 0 1px rgba(222,201,180,0.30),
    0 0 28px rgba(222,201,180,0.22),
    0 0 64px rgba(222,201,180,0.12);
}
/* ── console layout ── */
.sizer-console { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: clamp(28px, 3.4vw, 48px); align-items: stretch; }
.sizer-inputs { display: flex; flex-direction: column; justify-content: center; gap: 52px; min-width: 0; }
.sz-block { display: flex; flex-direction: column; }
.sz-block .sizer-step { margin-bottom: 16px; }
.sz-block .sizer-value { margin: 0 0 18px; }
.sz-block .sizer-scale { margin-top: 12px; }
.term-scale { position: relative; }
.term-scale .t12 { position: absolute; left: 66.6%; transform: translateX(-50%); }

/* ── asset cards ── */
.asset-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 22px; }
.sizer-tab {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 20px 10px 18px; cursor: pointer; text-align: center; position: relative;
  background: rgba(20,33,36,0.45); border: 1px solid var(--glass-border); border-radius: var(--r-lg);
  transition: transform var(--d-normal) var(--ease-premium), border-color var(--d-normal), background var(--d-normal), box-shadow 400ms var(--ease-premium);
}
.sizer-tab {
  background: rgba(20,33,36,0.45); border: 1px solid var(--glass-border); border-radius: var(--r-lg);
  transition: border-color var(--d-normal) var(--ease-premium), background var(--d-normal) var(--ease-premium);
}
.sizer-tab .ac-ico, .sizer-tab .ac-name { position: relative; z-index: 1; }
.sizer-tab:active { transform: scale(0.97); }
.ac-ico {
  width: 44px; height: 44px; display: grid; place-items: center;
  color: rgba(255,255,255,0.55); position: relative;
  transition: color 400ms var(--ease-premium), filter 400ms var(--ease-premium), transform 400ms var(--ease-premium);
}
.ac-ico svg { width: 38px; height: 38px; }
.sizer-tab .ac-name { font-family: var(--font-display); font-weight: 700; font-size: 14px; letter-spacing: 0.02em; color: var(--fg2); white-space: nowrap; transition: color var(--d-normal), text-shadow 400ms var(--ease-premium); }
.sizer-tab:hover { border-color: rgba(222,201,180,0.35); }
.sizer-tab:hover .ac-ico { color: var(--cream); }
.sizer-tab:hover .ac-name { color: var(--fg1); }
/* illuminated — the button lights up */
.sizer-tab.on {
  border-color: rgba(222,201,180,0.55);
  background: radial-gradient(120% 90% at 50% 0%, rgba(222,201,180,0.12), rgba(222,201,180,0.03) 60%), rgba(20,33,36,0.45);
  box-shadow: 0 0 0 1px rgba(222,201,180,0.22), 0 0 22px rgba(222,201,180,0.12);
}
.sizer-tab.on .ac-ico {
  color: var(--cream);
  filter: drop-shadow(0 0 6px rgba(222,201,180,0.5));
}
.sizer-tab.on .ac-name { color: var(--cream); }
@keyframes acIgnite {
  0% { transform: scale(0.88); }
  55% { transform: scale(1.1); }
  100% { transform: scale(1); }
}

.sizer-step { display: block; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg3); }
.sizer-step strong { font-weight: 800; color: var(--cream); }
.sizer-value { display: block; font-family: var(--font-display); font-weight: 700; font-size: clamp(26px, 3vw, 36px); color: var(--ivory); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; margin: 22px 0 22px; line-height: 1; }

/* range input */
.sizer input[type="range"] {
  -webkit-appearance: none; appearance: none; width: 100%; height: 6px; padding: 0; border: none;
  border-radius: var(--r-pill); cursor: pointer; outline: none; accent-color: var(--cream);
  background: linear-gradient(90deg, var(--cream) 0%, var(--cream) var(--fill, 30%), rgba(255,255,255,0.12) var(--fill, 30%), rgba(255,255,255,0.12) 100%);
}
.sizer input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; width: 26px; height: 26px; border-radius: 50%;
  background: var(--ivory); border: 4px solid var(--cream); box-shadow: var(--cream-glow-strong), 0 2px 8px rgba(0,0,0,0.3);
  cursor: grab; transition: transform var(--d-fast) var(--ease-premium);
}
.sizer input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.12); }
.sizer input[type="range"]:active::-webkit-slider-thumb { cursor: grabbing; transform: scale(1.05); }
.sizer input[type="range"]::-moz-range-thumb {
  width: 22px; height: 22px; border-radius: 50%; background: var(--ivory); border: 4px solid var(--cream);
  box-shadow: var(--cream-glow-strong); cursor: grab;
}
.sizer-scale { display: flex; justify-content: space-between; margin-top: 12px; font-family: var(--font-display); font-size: 11px; letter-spacing: 0.08em; color: var(--fg3); font-variant-numeric: tabular-nums; position: relative; }
.sizer-scale .mid { position: absolute; left: 75%; transform: translateX(-50%); }

.sizer-bar-wrap { margin-top: 30px; }
.sizer-bar-labels { display: flex; justify-content: space-between; margin-bottom: 8px; font-family: var(--font-display); font-weight: 700; font-size: 12px; font-variant-numeric: tabular-nums; }
.sizer-bar-labels .ll { color: var(--cream); white-space: nowrap; }
.sizer-bar-labels .lr { color: var(--fg3); white-space: nowrap; }
.sizer-bar { height: 14px; border-radius: var(--r-pill); background: rgba(255,255,255,0.08); overflow: hidden; position: relative; }
.sizer-bar .fill { position: absolute; inset: 0 auto 0 0; height: 100%; border-radius: var(--r-pill); background: linear-gradient(90deg, var(--cream-soft), var(--cream)); box-shadow: var(--cream-glow); transition: width 500ms var(--ease-premium); }

/* ── term sheet — cream paper readout ── */
.termsheet {
  position: relative; isolation: isolate;
  background: var(--ivory);
  color: var(--fg-on-cream-1);
  border-radius: var(--r-xl);
  padding: 30px 34px 32px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.38), 0 0 0 1px rgba(222,201,180,0.35);
  display: flex; flex-direction: column;
}
.termsheet::before {
  content: ''; position: absolute; inset: 0; border-radius: inherit; z-index: -1;
  background-image: var(--noise-svg); background-size: 256px;
  opacity: 0.05; mix-blend-mode: multiply; pointer-events: none;
}
.termsheet.pulse { animation: pulseCream 600ms var(--ease-premium); }
.ts-head { display: flex; align-items: center; gap: 14px; padding-bottom: 18px; border-bottom: 1px solid rgba(26,47,51,0.18); }
/* chevron mark — top-right corner, illuminates on hover (matches deal cards) */
.ts-chev {
  position: absolute; top: 18px; right: 18px; width: 26px; z-index: 1;
  filter: brightness(0.28) saturate(0.6); opacity: 0.18;
  transition: opacity 450ms var(--ease-premium), filter 450ms var(--ease-premium);
}
.termsheet:hover .ts-chev {
  opacity: 1;
  filter: brightness(0.28) saturate(0.6) drop-shadow(0 0 5px rgba(26,47,51,0.45)) drop-shadow(0 0 14px rgba(26,47,51,0.22));
}
.ts-title { display: block; font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-on-cream-1); }
.ts-sub { display: block; margin-top: 3px; font-size: 12px; color: var(--fg-on-cream-3); }
.ts-loan { padding: 22px 0 20px; }
.ts-label { display: block; font-family: var(--font-display); font-weight: 700; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-on-cream-2); }
.termsheet .sizer-loan { color: var(--deep-teal); font-size: clamp(38px, 3.4vw, 52px); }
.sizer-loan { display: block; font-family: var(--font-display); font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: -0.02em; line-height: 1; margin: 10px 0 0; }
.sizer-loan.settle { animation: szSettle 760ms var(--ease-premium); }
@keyframes szSettle { 0% { text-shadow: none; transform: translateY(0); } 35% { text-shadow: 0 0 22px rgba(201,168,126,0.55); transform: translateY(-3px); } 100% { text-shadow: none; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) { .sizer-loan.settle { animation: none; } }
.ts-compliance { font-family: var(--font-body); font-size: 11.5px; line-height: 1.5; color: var(--fg-on-cream-3); margin: 14px 0 18px; }
.ts-rows { border-top: 1px solid rgba(26,47,51,0.18); }
.ts-row { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; padding: 13px 0; border-bottom: 1px solid rgba(26,47,51,0.12); }
.ts-row:last-child { border-bottom: none; }
.ts-rows { border-top: 1px solid rgba(26,47,51,0.18); border-bottom: 1px solid rgba(26,47,51,0.18); }
.ts-row .k { font-family: var(--font-display); font-weight: 700; font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-on-cream-2); }
.ts-row .v { font-family: var(--font-body); font-weight: 700; font-size: 15px; color: var(--fg-on-cream-1); font-variant-numeric: tabular-nums; text-align: right; white-space: nowrap; }
.termsheet .sizer-flag { margin: 16px 0 20px; color: var(--fg-on-cream-2); }
.termsheet .sizer-flag svg { color: var(--deep-teal); }
.termsheet .sizer-flag strong { color: var(--fg-on-cream-1); }
.termsheet .btn-primary { width: 100%; margin-top: auto; background: var(--deep-teal); color: var(--cream); border-color: var(--deep-teal); }
.termsheet .btn-primary:hover { box-shadow: 0 0 18px rgba(201,168,126,0.55), 0 0 40px rgba(201,168,126,0.25), 0 8px 24px rgba(26,47,51,0.30); }
.sizer-flag { display: flex; gap: 10px; align-items: flex-start; margin: 20px 0 24px; font-size: 13px; line-height: 1.5; color: var(--fg2); opacity: 0; transition: opacity var(--d-slow); }
.sizer-flag.show { opacity: 1; }
.sizer-flag svg { flex: none; margin-top: 1px; color: var(--cream); }
.sizer-flag.warn svg { color: var(--status-warning); }
.sizer-flag strong { color: var(--fg1); font-weight: 700; }
.sizer-readout .btn { width: 100%; }

/* collapse the centered nav to a menu before it can collide with the login buttons */
@media (max-width: 980px) {
  .nav-links { display: none; }
  .nav-toggle { display: inline-flex; }
}

@media (max-width: 820px) {
  .sizer-console { grid-template-columns: 1fr; gap: 36px; }
}

/* ═══════════════ CREAM TRACK-RECORD BAND ═══════════════ */
.track { background: var(--ivory); color: var(--fg-on-cream-1); position: relative; overflow: hidden; isolation: isolate; }
.track::before {
  content: ''; position: absolute; inset: 0; z-index: 0;
  background-image: var(--noise-svg); background-size: 256px;
  opacity: 0.05; mix-blend-mode: multiply; pointer-events: none;
}
/* ivory double-chevron — deliberate watermark on the cream band, hangs off the right edge */
.track .md-chev { position: absolute; right: -10%; top: 50%; transform: translateY(-50%); width: min(54vw, 720px); opacity: 0.55; pointer-events: none; user-select: none; }
.track .wrap { position: relative; z-index: 1; }
.track .eyebrow { color: var(--fg-on-cream-2); }
.track .eyebrow::before, .track .eyebrow.center::after { background: var(--fg-on-cream-2); opacity: 0.5; }
.track-head { max-width: 900px; }
.track-head h2 { color: var(--fg-on-cream-1); margin-top: 18px; font-size: clamp(38px, 5vw, 70px); line-height: 1.0; }
.track-head p { color: var(--fg-on-cream-2); margin-top: 18px; font-size: clamp(16px, 1.4vw, 20px); line-height: 1.6; max-width: 60ch; }
.track-grid { display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 64px; }
.track-grid.two { grid-template-columns: repeat(2, 1fr); max-width: 880px; }

/* MD social links — icon buttons */
.md-links { display: flex; gap: 12px; margin-top: 26px; }
.md-icon-btn {
  width: 46px; height: 46px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--fg-on-cream-1); border: 1px solid rgba(26,47,51,0.28);
  transition: background var(--d-normal) var(--ease-premium), color var(--d-normal), border-color var(--d-normal), transform var(--d-normal) var(--ease-premium);
}
.md-icon-btn:hover { background: var(--deep-teal); color: var(--cream); border-color: var(--deep-teal); transform: translateY(-2px); }

/* MD profile spread */
.md-head { display: flex; align-items: flex-end; gap: 36px; max-width: none; }
.md-head > div { flex: none; }
.md-head::after { content: ''; flex: 1; height: 1px; background: rgba(26,47,51,0.18); margin-bottom: 20px; }

.md-photo { position: relative; }
.md-photo .frame { position: relative; z-index: 1; box-shadow: 0 24px 64px rgba(26,47,51,0.18); }

.md-stats { margin-top: 80px; padding-top: 48px; border-top: 1px solid rgba(26,47,51,0.16); display: grid; grid-template-columns: 1fr 1fr; gap: 44px; }
.md-stats .md-stat:nth-child(2) { border-left: 1px solid rgba(26,47,51,0.16); padding-left: 44px; }
.md-stat .v { font-family: var(--font-display); font-weight: 700; font-size: clamp(72px, 9vw, 132px); line-height: 0.95; letter-spacing: -0.02em; color: var(--fg-on-cream-1); font-variant-numeric: tabular-nums; white-space: nowrap; }
.md-stat .unit { color: var(--deep-teal); opacity: 0.5; }
.md-stat .k { margin-top: 16px; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-on-cream-2); }
.md-stat .d { margin-top: 7px; font-size: 13px; line-height: 1.5; color: var(--fg-on-cream-3); }

/* MD watermark metrics — superseded by md-stats */
.md-metrics { display: none; }
.track-stat { padding: 0 32px; border-left: 1px solid rgba(26,47,51,0.14); }
.track-stat:first-child { padding-left: 0; border-left: none; }
.track-stat .v { font-family: var(--font-display); font-weight: 700; font-size: clamp(48px, 6.4vw, 92px); line-height: 0.92; letter-spacing: -0.02em; color: var(--fg-on-cream-1); font-variant-numeric: tabular-nums; }
.track-stat .v .unit { color: var(--deep-teal); opacity: 0.55; }
.track-stat .k { margin-top: 16px; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-on-cream-2); }
.track-stat .d { margin-top: 8px; font-size: 13px; line-height: 1.5; color: var(--fg-on-cream-3); }
.track-line { margin-top: 64px; padding-top: 36px; border-top: 1px solid rgba(26,47,51,0.14); display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.track-line .statement { font-family: var(--font-display); font-weight: 700; font-size: clamp(20px, 2.2vw, 28px); color: var(--fg-on-cream-1); letter-spacing: -0.005em; max-width: 24ch; }
.track .btn-primary { background: var(--deep-teal); color: var(--cream); border-color: var(--deep-teal); }
.track .btn-primary:hover { box-shadow: 0 0 18px rgba(201,168,126,0.55), 0 0 40px rgba(201,168,126,0.25), 0 8px 24px rgba(26,47,51,0.25); }

/* founder header: title — rule — metrics (rule runs into the stats divider) */
.md-head2 { display: flex; align-items: flex-start; gap: 44px; }
.md-head-title { flex: none; }
.md-head-title .eyebrow { color: var(--fg-on-cream-2); }
.md-head-title .eyebrow::before { background: var(--fg-on-cream-2); opacity: 0.5; }
.md-head-title h2 { color: var(--fg-on-cream-1); margin-top: 14px; }
.md-head-rule { flex: 1; height: 1px; background: rgba(26,47,51,0.28); align-self: flex-end; margin-bottom: 20px; }
.md-head-stats { flex: none; display: flex; align-items: stretch; gap: 40px; }
.md-hstat + .md-hstat { border-left: 1px solid rgba(26,47,51,0.28); padding-left: 40px; }
.md-hstat .v { font-family: var(--font-display); font-weight: 700; font-size: clamp(38px, 3.4vw, 52px); line-height: 1; letter-spacing: -0.01em; color: var(--fg-on-cream-1); font-variant-numeric: tabular-nums; white-space: nowrap; }
.md-hstat .unit { color: var(--deep-teal); opacity: 0.5; }
.md-hstat .k { margin: 5px 0 25px; font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--fg-on-cream-2); }

/* founder body: photo | large quote | small text */
.md-body { display: grid; grid-template-columns: 1fr 2.08fr; gap: 52px; align-items: center; margin-top: 44px; }
.md-story p { font-size: 14px; line-height: 1.75; color: var(--fg-on-cream-2); margin: 0 0 16px; }
.md-story .story-quote { font-size: clamp(22px, 2.1vw, 30px); line-height: 1.4; margin: 28px 0; font-weight: 700; letter-spacing: -0.005em; text-wrap: pretty; }
.md-story .story-quote i, .md-story .story-quote em { font-style: normal; }
.md-story p:last-child { margin-bottom: 0; }
.md-quote .prin-quote { margin: 0; font-size: clamp(26px, 2.5vw, 36px); line-height: 1.34; }
.md-side p { font-size: 14px; line-height: 1.7; color: var(--fg-on-cream-2); margin: 0 0 14px; }
.md-extras { margin-top: 44px; display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.md-extras .deal-tags { margin: 0; }
.md-extras .md-links { margin: 0; }

/* founder spread — portrait | story | stats rail */
.md-grid { display: grid; grid-template-columns: 0.82fr 1.38fr 0.62fr; gap: 56px; align-items: center; margin-top: 56px; }
.md-rail { border-left: 1px solid rgba(26,47,51,0.16); padding-left: 48px; display: flex; flex-direction: column; gap: 40px; }
.md-rail .md-stat + .md-stat { border-top: 1px solid rgba(26,47,51,0.16); padding-top: 36px; }

/* principal-in-cream layout */
.prin-grid { display: grid; grid-template-columns: 0.78fr 1.22fr; gap: 56px; align-items: center; margin-top: 56px; }
.prin-quote { font-family: var(--font-display); font-weight: 700; font-size: clamp(25px, 2.8vw, 38px); line-height: 1.28; color: var(--fg-on-cream-1); margin: 0 0 22px; letter-spacing: -0.005em; text-wrap: pretty; }
.prin-body p { color: var(--fg-on-cream-2); }
.prin-body p + p { margin-top: 14px; }
.prin-body .deal-tags { margin-top: 26px; }
.track .deal-tag { color: var(--fg-on-cream-2); background: rgba(26,47,51,0.05); border: 1px solid rgba(26,47,51,0.18); }
.track .deal-tag:hover {
  color: var(--fg-on-cream-1); background: rgba(222,201,180,0.35); border-color: rgba(201,168,126,0.8);
  box-shadow: 0 0 16px rgba(201,168,126,0.45), 0 4px 12px rgba(26,47,51,0.10);
  transform: translateY(-2px);
}
.track .about-portrait { max-width: none; }
.track .about-portrait .frame { border: 1px solid rgba(26,47,51,0.18); box-shadow: 0 24px 64px rgba(26,47,51,0.18); }

/* ═══════════════ SELECTED TRANSACTIONS (tombstones) ═══════════════ */
.deals-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 56px; }
.deal-card { padding: 28px; position: relative; overflow: hidden; transition: transform var(--d-normal) var(--ease-premium), border-color var(--d-normal), box-shadow 450ms var(--ease-premium); }
.deal-card:hover {
  transform: translateY(-3px);
  border-color: rgba(222,201,180,0.45);
  box-shadow:
    0 12px 32px rgba(0,0,0,0.25),
    0 0 0 1px rgba(222,201,180,0.30),
    0 0 28px rgba(222,201,180,0.22),
    0 0 64px rgba(222,201,180,0.12);
}
.deal-card .chev { position: absolute; top: 18px; right: 18px; width: 26px; opacity: 0.12; transition: opacity 450ms var(--ease-premium), filter 450ms var(--ease-premium); }
.deal-card:hover .chev {
  opacity: 0.95;
  filter: drop-shadow(0 0 6px rgba(222,201,180,0.9)) drop-shadow(0 0 16px rgba(222,201,180,0.5)) drop-shadow(0 0 32px rgba(222,201,180,0.25));
}
.deal-top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.deal-amt { font-family: var(--font-display); font-weight: 700; font-size: 32px; color: var(--ivory); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; line-height: 1; }
.deal-status { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--status-success); }
.deal-status .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--status-success); box-shadow: 0 0 8px var(--status-success); }
.deal-scenario { margin: 20px 0 18px; font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--cream); letter-spacing: 0.01em; }
.deal-rows { border-top: 1px solid var(--glass-border); }
.deal-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 11px 0; border-bottom: 1px solid var(--glass-border); }
.deal-row .k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg3); white-space: nowrap; }
.deal-row .v { font-family: var(--font-mono); font-size: 12px; color: var(--fg1); font-variant-numeric: tabular-nums; text-align: right; white-space: nowrap; }
.deal-row .v.cream { color: var(--cream); }
.deals-note { margin-top: 26px; display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--fg3); max-width: 76ch; }
.deals-note svg { flex: none; color: var(--cream-dim); margin-top: 2px; }

/* ═══════════════ GOVERNANCE & STRUCTURE ═══════════════ */
.gov-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 56px; }
.gov-card { padding: 22px 24px; display: grid; grid-template-columns: 40px 1fr; column-gap: 14px; align-items: center; align-content: start; transition: transform var(--d-normal) var(--ease-premium), border-color var(--d-normal), box-shadow 450ms var(--ease-premium); }
.gov-card:hover {
  transform: translateY(-3px);
  border-color: rgba(222,201,180,0.45);
  box-shadow:
    0 12px 32px rgba(0,0,0,0.25),
    0 0 0 1px rgba(222,201,180,0.30),
    0 0 28px rgba(222,201,180,0.22),
    0 0 64px rgba(222,201,180,0.12);
}
.gov-ico { width: 44px; height: 44px; border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; background: rgba(222,201,180,0.08); border: 1px solid var(--glass-border-cream); color: var(--cream); margin-bottom: 22px; }
.gov-card .gov-ico { grid-column: 1; grid-row: 1; margin-bottom: 0; }
.gov-card h4 { grid-column: 2; grid-row: 1; font-family: var(--font-body); font-weight: 700; font-size: 17px; color: var(--ivory); letter-spacing: 0; margin: 0; text-wrap: balance; }
.gov-card p { grid-column: 1 / -1; grid-row: 2; margin-top: 10px; font-size: 13.5px; line-height: 1.5; color: var(--fg2); }
.gov-card .code { grid-column: 1 / -1; display: inline-block; padding-top: 10px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.02em; color: var(--cream); white-space: nowrap; }

.gov-invest {
  margin-top: 18px; padding: 38px 42px; border-radius: var(--r-xl);
  background: var(--cream);
  display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.gov-invest h3 { color: var(--fg-on-cream-1); }
.gov-invest p { margin-top: 8px; color: var(--fg-on-cream-2); max-width: 80ch; }
.gov-invest .btn-primary { background: var(--deep-teal); color: var(--cream); border-color: var(--deep-teal); flex: none; }
.gov-invest .btn-primary:hover { box-shadow: 0 0 18px rgba(201,168,126,0.55), 0 0 40px rgba(201,168,126,0.25), 0 8px 24px rgba(26,47,51,0.25); }

/* ═══════════════ REVEAL ═══════════════ */
.js .reveal { opacity: 0; transform: translateY(24px); transition: opacity 700ms var(--ease-premium), transform 700ms var(--ease-premium); }
.js .reveal[data-rv="left"] { transform: translateX(-30px); }
.js .reveal[data-rv="right"] { transform: translateX(30px); }
.js .reveal[data-rv="scale"] { transform: scale(0.95); }
.reveal[data-rv].in { transform: none; }
/* clip-path mask reveal for headline drama */
.js .rv-mask { clip-path: inset(0 0 102% 0); opacity: 0; transition: clip-path 1000ms var(--ease-premium), opacity 600ms ease; }
.rv-mask.in { clip-path: inset(0 0 -8% 0); opacity: 1; }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"] { transition-delay: 80ms; }
.reveal[data-d="2"] { transition-delay: 160ms; }
.reveal[data-d="3"] { transition-delay: 240ms; }
.reveal[data-d="4"] { transition-delay: 320ms; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero-bg { transform: none !important; }
  .hero-bg img { animation: none !important; transform: scale(1.0) !important; }
  html { scroll-behavior: auto; }
}

/* ═══════════════ RESPONSIVE ═══════════════ */
@media (max-width: 1080px) {
  .plat-grid, .about-grid, .contact-grid { grid-template-columns: 1fr; gap: 44px; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .about-portrait { max-width: 460px; }
  .sizer-body { grid-template-columns: 1fr; gap: 36px; }
  .track-grid { grid-template-columns: repeat(2, 1fr); gap: 48px 0; }
  .deals-grid { grid-template-columns: repeat(2, 1fr); }
  .gov-cards { grid-template-columns: 1fr 1fr; }
  .voice-stage-legacy { min-height: 340px; }
  .vq-grid { grid-template-columns: 1fr; gap: 44px; }
  .vq-stage { min-height: 420px; }
  .prin-grid { grid-template-columns: 1fr; gap: 40px; }
  .prin-grid .about-portrait { max-width: 460px; }
  .md-grid { grid-template-columns: 1fr; gap: 44px; }
  .md-grid .about-portrait { max-width: 460px; }
  .md-head2 { flex-wrap: wrap; gap: 28px; }
  .md-head-rule { display: none; }
  .md-head-stats { width: 100%; justify-content: flex-start; }
  .md-body { grid-template-columns: 1fr; gap: 44px; }
  .md-body .about-portrait { max-width: 460px; }
  .md-rail { border-left: none; padding-left: 0; border-top: 1px solid rgba(26,47,51,0.16); padding-top: 40px; flex-direction: row; gap: 44px; }
  .md-rail .md-stat { flex: 1; }
  .md-rail .md-stat + .md-stat { border-top: none; padding-top: 0; border-left: 1px solid rgba(26,47,51,0.16); padding-left: 44px; }
}
@media (max-width: 760px) {
  .wrap { padding: 0 20px; }
  .nav-links { display: none; }
  #about .md-head-stats { justify-content: center; text-align: center; }
  #about .md-portrait, #about .md-photo { margin-left: auto; margin-right: auto; }
  #about .md-story { text-align: center; }
  .nav-toggle { display: inline-flex; }
  .nav-login { display: none; }
  .nav-cta { display: none; }
  .nav-right .btn-primary { height: 40px; padding: 0 16px; font-size: 13px; white-space: nowrap; }
  .hero-stats { width: 100%; margin-top: 40px; grid-template-columns: 1fr 1fr; gap: 0; }
  .hero-stat { padding: 18px 12px; }
  .hero-stat:nth-child(2) { border-right: none; }
  .hero-stat:nth-child(1), .hero-stat:nth-child(2) { border-bottom: 1px solid var(--glass-border); }
  .fac-grid { grid-template-columns: 1fr; }
  .fac-hero { grid-template-columns: 1fr; gap: 32px; }
  .fac-strip { grid-template-columns: 1fr 1fr; gap: 12px; }
  .fac-strip .fac-meta-item { min-width: 0; padding: 22px 12px; }
  .fac-strip .v { white-space: normal; font-size: 16px; }
  .lvr-row { grid-template-columns: 1fr; gap: 10px; padding: 18px 12px; }
  .lvr-rings { grid-template-columns: 1fr 1fr; }
  .lvr-residual { gap: 20px; padding: 20px; }
  .lvr-desc { font-size: 12px; }
  .edge-item { grid-template-columns: 1fr; gap: 8px; padding: 32px 0 32px 22px; }
  .why-split { grid-template-columns: 1fr; gap: 0; }
  .why-side { display: none; }
  .edge-stat { display: block; margin-top: 18px; font-family: var(--font-display); font-weight: 700; font-size: 44px; line-height: 1; color: transparent; -webkit-text-stroke: 1.5px rgba(222,201,180,0.85); letter-spacing: -0.01em; opacity: 0; transform: translateY(8px); transition: opacity 500ms var(--ease-premium), transform 500ms var(--ease-premium); }
  .edge-item.on .edge-stat { opacity: 1; transform: none; }
  .voice-stage-legacy { min-height: 480px; }
  .vq-stage { min-height: 520px; }
  .vq-ghost { top: -40px; font-size: 140px; }
  .field-row { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 28px 24px; }
  .footer-top > div:first-child { grid-column: 1 / -1; }
  .about-stats { gap: 28px; }
  .hero-chevron { right: -20%; width: 90vw; }
  .sizer { padding: 26px; }
  .asset-cards { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .sizer-tab { padding: 16px 10px 14px; }
  .ring-gauge { width: 104px; height: 104px; margin-bottom: 14px; }
  .ring-card .lvr-pct { font-size: 24px; }
  .lr-gauge { display: none; }
  .lvr-residual { padding: 22px 24px; }
  .lvr-residual .ring-desc { max-width: none; }
  .termsheet .sizer-loan { font-size: 38px; }
  .ts-loan { padding: 18px 0 16px; }
  .sizer-value, .sz-block .sizer-value { font-size: 23px; }
  .sizer-inputs { gap: 36px; }
  .termsheet { padding: 24px; }
  .track-grid { grid-template-columns: 1fr; gap: 36px; }
  .track-stat { padding: 0 0 0 0; border-left: none; border-top: 1px solid rgba(26,47,51,0.14); padding-top: 28px; }
  .track-stat:first-child { border-top: none; padding-top: 0; }
  .track-line { flex-direction: column; align-items: flex-start; }
  .deals-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .deal-card { padding: 16px; }
  .deal-amt { font-size: 21px; }
  .deal-scenario { margin: 12px 0 10px; font-size: 13px; }
  .deal-row { flex-direction: column; align-items: flex-start; gap: 2px; padding: 8px 0; }
  .deal-row .v { text-align: left; white-space: normal; }
  .deal-card .chev { width: 20px; top: 14px; right: 14px; }
  .gov-cards { grid-template-columns: 1fr; }
  .gov-invest { padding: 28px 24px; }
}

@media (max-width: 480px) {
  /* hero: keep the tagline on one line, stack the CTAs full-width for big tap targets */
  .hero-tagline { font-size: clamp(30px, 11vw, 44px); }
  .hero { padding: 92px 20px 40px; }
  .hero-cta { flex-direction: column; width: 100%; max-width: 340px; margin-left: auto; margin-right: auto; }
  .hero-cta .btn { width: 100%; }
  .hero-sub { font-size: 15px; }
  /* founder stats: stack rather than cram side-by-side */
  .md-rail { flex-direction: column; gap: 24px; }
  .md-rail .md-stat + .md-stat { border-left: none; padding-left: 0; border-top: 1px solid rgba(26,47,51,0.16); padding-top: 24px; }
  /* testimonial quote marks: smaller so they don't crowd the panel */
  .vq-mark-open { bottom: 24px; left: 6%; width: 96px; }
  .vq-mark-close { top: 24px; right: 6%; width: 96px; }
  /* contact + governance headings breathe */
  .gov-invest { flex-direction: column; align-items: flex-start; gap: 20px; }
  .gov-invest .btn-primary { width: 100%; }
}


/* ═══════════════════════════════════════════════════════════════
   WORLD-CLASS LAYER — contour field · kinetic hero · ticker ·
   scrubbed process · spotlight glass · odometers · lux voices
   ═══════════════════════════════════════════════════════════════ */

/* ── Living contour field ── */
.contour-canvas { position: fixed; inset: 0; width: 100vw; height: 100vh; z-index: -1; pointer-events: none; }

/* ── Kinetic hero type — visible by default; animates only during the intro ── */
.hero-tagline .w { display: inline-block; vertical-align: bottom; }
.hero-tagline .wi { display: inline-block; opacity: 1; }
html.intro .hero-tagline .wi { opacity: 0; transform: translateY(0.22em); animation: wordUp 1150ms cubic-bezier(0.33, 0, 0.2, 1) forwards; }
html.intro .hero-tagline .w:nth-child(1) .wi { animation-delay: 0ms; }
html.intro .hero-tagline .w:nth-child(2) .wi { animation-delay: 120ms; }
html.intro .hero-tagline .w:nth-child(3) .wi { animation-delay: 240ms; }
@keyframes wordUp { to { opacity: 1; transform: translateY(0); } }

/* ── Landing intro — "Dawn" title sequence ── */
.intro-flip {
  position: absolute; inset: 0; z-index: 6; display: none;
  align-items: center; justify-content: center;
  pointer-events: none; perspective: 1200px;
}
html.intro .intro-flip { display: flex; }

/* composed logo mark — biased up to sit where the tagline will land (no jump on handoff) */
.intro-wm {
  display: flex; align-items: center; justify-content: center;
  transform: translateY(-37px);
  will-change: transform, opacity; backface-visibility: hidden;
}
.intro-mark { width: clamp(96px, 11vw, 168px); height: auto; display: block; }
.intro-mark .cv {
  opacity: 0;
  transition: opacity 1600ms cubic-bezier(0.45, 0.05, 0.25, 1);
}
/* fade in bottom-to-top: beige (lower) first, white (upper) after — no movement */
html.wm-in .intro-mark .cv-bot { opacity: 1; transition-delay: 0ms; }
html.wm-in .intro-mark .cv-top { opacity: 1; transition-delay: 600ms; }

/* night → dawn: a brand-gradient curtain hides the page until everything is ready,
   then fades to reveal the city — and the photo itself lifts from dark to lit (cinematic dawn) */
.intro-curtain { position: fixed; inset: 0; z-index: 5; background: var(--bg-gradient); opacity: 0; pointer-events: none; }
html.intro .intro-curtain { opacity: 1; }
html.intro.dawn .intro-curtain { opacity: 0; transition: opacity 1700ms cubic-bezier(0.45, 0.05, 0.25, 1); }
/* exposure lift + slow zoom-out on the skyline — the photo comes to life as the light comes up */
html.intro .hero-bg img { filter: saturate(0.42) brightness(0.30) contrast(1.06); transform: scale(1.07); transition: filter 4600ms cubic-bezier(0.45, 0.05, 0.25, 1), transform 5200ms cubic-bezier(0.33, 0, 0.2, 1); }
html.intro.dawn .hero-bg img { filter: saturate(0.85) brightness(0.78) contrast(1.02); transform: scale(1.0); }

/* the mark fades cleanly out as the tagline arrives */
html.wm-flip .intro-wm {
  opacity: 0; transform: translateY(-30px) scale(1.02);
  transition: opacity 650ms ease, transform 900ms cubic-bezier(0.45, 0.05, 0.25, 1);
}

/* hold the page back while the title sequence plays */
html.intro .nav { opacity: 0; visibility: hidden; }
.nav { transition: opacity 900ms var(--ease-premium), visibility 0s 900ms; }
html:not(.intro) .nav { visibility: visible; transition: opacity 900ms var(--ease-premium), visibility 0s; }
html.intro.nav-in .nav { opacity: 1; visibility: visible; transition: opacity 900ms var(--ease-premium), visibility 0s; }
html.intro .hero .reveal { opacity: 0 !important; transform: translateY(24px) !important; }
html.intro .scroll-bar { opacity: 0; }
html.intro-hold .hero-tagline .wi { animation-play-state: paused; }
/* staged hero entrance — visible by default; only animates as the intro hands off */
.hero-sub, .hero-cta { transition: opacity 900ms var(--ease-premium), transform 900ms var(--ease-premium); }
.hero-cta { transition-delay: 240ms; }
html.intro .hero-sub, html.intro .hero-cta { opacity: 0; transform: translateY(16px); }

/* one-time light sweep across the skyline — removed per client */

/* ── Settled-deals ticker ── */
.marquee-track .item {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-mono); font-weight: 400; font-size: 12.5px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg3);
}
.marquee-track .item .tk-tag { color: var(--cream); letter-spacing: 0.14em; }
.marquee-track .item .tk-amt { color: var(--ivory); }

/* ── Scroll-scrubbed process ── */
.proc-grid { grid-template-columns: 1fr 280px; gap: 56px; }
.proc-steps { position: relative; }
.proc-day-sticky { position: sticky; top: 30vh; text-align: right; }
.pd-label { display: block; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--cream); }
.pd-num {
  display: block; margin-top: 8px;
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(110px, 9.5vw, 170px); line-height: 0.9; letter-spacing: -0.02em;
  color: transparent; -webkit-text-stroke: 1.5px rgba(222,201,180,0.45);
  font-variant-numeric: tabular-nums;
}
.pd-of { display: block; margin-top: 10px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg3); }

/* ── Spotlight glass ── removed per client (tilt retained in JS) */

/* ── Odometer numerals ── */
.odo { display: inline-flex; line-height: 1; }
.odo .odo-d { display: inline-block; overflow: hidden; height: 1em; }
.odo .odo-strip { display: block; }
.odo .odo-strip span { display: block; height: 1em; line-height: 1; }

/* ── Lux voices — ivory ground, dark glass quote panel ── */
.voices-cream { background: var(--ivory); isolation: isolate; }
.voices-cream::before {
  content: ''; position: absolute; inset: 0; z-index: 0;
  background-image: var(--noise-svg); background-size: 256px;
  opacity: 0.05; mix-blend-mode: multiply; pointer-events: none;
}
/* comma-style marks — opening (66) bottom-left, closing (99) top-right */
.vq-mark-open { bottom: 52px; left: 4%; width: clamp(140px, 12vw, 190px); }
.vq-mark-close { top: 52px; right: 4%; width: clamp(140px, 12vw, 190px); }
.vq-stage::before { content: none; }

/* the quote panel — the page's dark surface language, inverted on cream */
.vq-stage {
  min-height: 440px;
  background: linear-gradient(160deg, var(--deep-teal) 0%, var(--mid-teal) 100%);
  border-radius: var(--r-2xl);
  border: 1px solid rgba(222,201,180,0.30);
  box-shadow: 0 30px 80px rgba(26,47,51,0.22), var(--cream-glow);
  overflow: hidden;
}
.vq-stage::after {
  content: ''; position: absolute; inset: 0; z-index: 0;
  background-image: var(--noise-svg); background-size: 256px;
  opacity: 0.035; pointer-events: none;
}
/* panel ornaments removed — backdrop chevron carries the brand */
.vq-stage .voice {
  padding: 56px 60px;
  display: flex; flex-direction: column; justify-content: center;
}
.vq-stage .voice blockquote { color: var(--ivory); font-size: clamp(21px, 2.2vw, 31px); max-width: 30ch; text-shadow: 0 1px 24px rgba(0,0,0,0.25); }
.vq-stage .voice .who .rule { background: var(--cream); opacity: 0.7; }
.vq-stage .voice .who .nm { color: var(--ivory); }
.vq-stage .voice .who .co { color: var(--fg2); }
.vq-stage .voice .who .tag { position: absolute; top: 28px; right: 32px; color: var(--cream); border-color: rgba(222,201,180,0.38); }

/* grain over the cream principal band too */
.track::before {
  content: ''; position: absolute; inset: 0;
  background-image: var(--noise-svg); background-size: 256px;
  opacity: 0.05; mix-blend-mode: multiply; pointer-events: none;
}
.track-stat .v { white-space: nowrap; font-size: clamp(44px, 4.9vw, 76px); }

@media (max-width: 1080px) {
  .proc-grid { grid-template-columns: 1fr; }
  .proc-side { display: none; }
}
@media (max-width: 760px) {
  .vq-ghost { font-size: 88px; top: 18px; right: 20px; }
  .vq-stage .voice { padding: 36px 28px; }
  .vq-stage .voice .who .tag { top: 22px; right: 24px; }
  .md-stats { grid-template-columns: 1fr; gap: 36px; }
  .md-stat:nth-child(2) { border-left: none; padding-left: 0; border-top: 1px solid rgba(26,47,51,0.16); padding-top: 32px; }
  .md-stat .v { font-size: clamp(60px, 16vw, 80px); }
  .md-rail { flex-direction: column; gap: 32px; }
  .md-rail .md-stat + .md-stat { border-left: none; padding-left: 0; border-top: 1px solid rgba(26,47,51,0.16); padding-top: 32px; }
  .contour-canvas { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .contour-canvas { display: none; }
  .hero-tagline .wi { transform: none !important; animation: none !important; opacity: 1 !important; }
}

/* ═══════════════ TOUCH: tap-to-illuminate (mirrors :hover on phones) ═══════════════ */
/* .tap-active is only ever added by site.js on touch devices, so these are safe ungated */
.gov-card.tap-active, .fac-card.tap-active, .fac-strip .fac-meta-item.tap-active,
.ring-card.tap-active, .deal-card.tap-active,
.inv-feat.tap-active, .inv-gov-card.tap-active, .setup-step.tap-active, .loop-step.tap-active,
.inv-elig-card.tap-active {
  transform: translateY(-3px);
  border-color: var(--glass-border-cream);
  box-shadow: var(--shadow-card-hover);
}
.gov-card.tap-active h4, .fac-card.tap-active h3, .ring-card.tap-active .ring-name,
.inv-feat.tap-active h3, .inv-gov-card.tap-active h3,
.setup-step.tap-active h4, .loop-step.tap-active h4 { color: var(--cream); }
.sizer-tab.tap-active { border-color: rgba(222,201,180,0.35); }
.sizer-tab.tap-active .ac-ico { color: var(--cream); }
.sizer-tab.tap-active .ac-name { color: var(--fg1); }
/* row-style elements: a subtle wash on tap */
.glance-cell.tap-active, .inv-step.tap-active, .inv-model-item.tap-active, .ledger-row.tap-active { background: rgba(222,201,180,0.06); }
