/* ============================================================
   Percision v2 — The Strategic Intelligence Platform
   Cinematic dark UI · cyan/violet brand · product-led
   ============================================================ */

:root {
  --bg:        #02050E;
  --bg-1:      #060B1F;
  --bg-2:      #0A1230;
  --bg-3:      #0E1A40;
  --line:      rgba(140, 170, 255, 0.10);
  --line-2:    rgba(140, 170, 255, 0.20);
  --line-3:    rgba(140, 170, 255, 0.32);

  --text:      #EAF0FF;
  --text-dim:  #A8B2D1;
  --text-mute: #6E789B;

  --per:       #22D3EE;      /* cyan      → "Per"     */
  --cision:    #C084FC;      /* violet    → "cision"  */
  --accent:    #B8C5FF;
  --good:      #34D399;
  --warn:      #FBBF24;
  --bad:       #F87171;
  --rose:      #FB7185;
  --amber:     #F59E0B;
  --blue:      #60A5FA;
  --green:     #34D399;

  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --r-xl: 28px;

  --grad-cyan:    linear-gradient(135deg, #67E8F9, #22D3EE);
  --grad-violet:  linear-gradient(135deg, #C4B5FD, #A78BFA);
  --grad-brand:   linear-gradient(135deg, #22D3EE 0%, #818CF8 50%, #A78BFA 100%);
  --grad-edge:    linear-gradient(135deg, rgba(34,211,238,.45), rgba(167,139,250,.45));

  --shadow-soft:  0 30px 80px -30px rgba(34,211,238,.18), 0 10px 30px -10px rgba(167,139,250,.18);
  --shadow-deep:  0 50px 140px -40px rgba(34,211,238,.28), 0 20px 60px -20px rgba(167,139,250,.28);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

.wrap { max-width: 1240px; margin: 0 auto; padding: 0 28px; position: relative; }

/* Brand wordmark */
.brand-per    { color: var(--per);    font-weight: 700; }
.brand-cision { color: var(--cision); font-weight: 700; }
.grad-cyan   { background: var(--grad-cyan);   -webkit-background-clip: text; background-clip: text; color: transparent; }
.grad-violet { background: var(--grad-violet); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ============================== NAV =============================== */
.nav {
  position: sticky; top: 0; z-index: 60;
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  background: rgba(2, 5, 14, 0.72);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 28px;
}
.brand {
  display: flex; align-items: center; gap: 10px;
  font-family: "Space Grotesk", "Inter", sans-serif;
  font-size: 20px; letter-spacing: -0.01em;
}
.brand-mark { width: 30px; height: 30px; }
.nav-links { display: flex; gap: 30px; align-items: center; }
.nav-links a {
  color: var(--text-dim); font-size: 14px; font-weight: 500;
  transition: color .2s var(--ease);
}
.nav-links a:hover { color: var(--text); }

/* ============================== BUTTONS =========================== */
.btn {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 12px 20px; border-radius: 999px;
  font-weight: 600; font-size: 14px; line-height: 1;
  transition: transform .2s var(--ease), box-shadow .25s var(--ease), border-color .2s var(--ease), color .2s var(--ease);
  border: 1px solid transparent;
  white-space: nowrap;
}
.btn.big { padding: 16px 24px; font-size: 15px; }
.btn-cta {
  border: 1px solid var(--line-2);
  color: var(--text);
  background: rgba(140,170,255,.04);
}
.btn-cta:hover { border-color: var(--per); color: var(--per); }
.btn-primary {
  background: var(--grad-brand);
  color: #04081A;
  box-shadow: 0 12px 32px -10px rgba(34,211,238,.55), 0 8px 24px -10px rgba(167,139,250,.55);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 18px 44px -10px rgba(34,211,238,.7), 0 12px 32px -10px rgba(167,139,250,.7); }
.btn-ghost {
  border: 1px solid var(--line-2); color: var(--text);
}
.btn-ghost:hover { border-color: var(--cision); color: var(--cision); }

/* ============================== HERO ============================== */
.hero {
  position: relative;
  padding: 100px 0 90px;
  overflow: hidden;
  isolation: isolate;
}
.hero-bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(60% 50% at 80% 0%,  rgba(34,211,238,.20), transparent 65%),
    radial-gradient(60% 60% at 0%  20%, rgba(167,139,250,.20), transparent 65%),
    radial-gradient(80% 50% at 50% 100%, rgba(99,102,241,.14), transparent 60%);
}
.grid-floor {
  position: absolute; inset: 35% -10% -20% -10%;
  background-image:
    linear-gradient(rgba(34,211,238,.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,211,238,.10) 1px, transparent 1px);
  background-size: 60px 60px;
  transform: perspective(800px) rotateX(60deg);
  transform-origin: center top;
  mask-image: linear-gradient(to bottom, transparent 0%, black 25%, black 70%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 25%, black 70%, transparent 100%);
}
.orb {
  position: absolute; border-radius: 50%;
  filter: blur(60px);
  opacity: .55;
}
.orb-1 { width: 420px; height: 420px; top: -60px; right: -60px; background: rgba(34,211,238,.55); }
.orb-2 { width: 380px; height: 380px; bottom: -100px; left: 10%; background: rgba(167,139,250,.55); }
.orb-3 { width: 280px; height: 280px; top: 30%; left: 40%; background: rgba(96,165,250,.40); }
.scan-line {
  position: absolute; left: 0; right: 0; top: 30%; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(34,211,238,.6), transparent);
  animation: scan 6s var(--ease) infinite;
}
@keyframes scan {
  0%,100% { transform: translateY(-180px); opacity: 0; }
  50%     { transform: translateY( 180px); opacity: 1; }
}

.hero-inner {
  display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center;
}

.status-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(52,211,153,.08);
  border: 1px solid rgba(52,211,153,.30);
  color: #C7F9E1;
  font-size: 12px; font-weight: 600; letter-spacing: .04em;
  margin-bottom: 22px;
}
.pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--good);
  box-shadow: 0 0 0 0 rgba(52,211,153,.7);
  animation: pulse 1.6s ease-out infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(52,211,153,.7); }
  70%  { box-shadow: 0 0 0 12px rgba(52,211,153,0); }
  100% { box-shadow: 0 0 0 0 rgba(52,211,153,0); }
}

.display {
  font-family: "Space Grotesk", "Inter", sans-serif;
  font-size: clamp(44px, 6.2vw, 86px);
  line-height: 1.0;
  letter-spacing: -0.025em;
  font-weight: 700;
  margin: 0 0 22px;
  color: var(--accent);
}
.lede {
  font-size: 19px;
  color: var(--text-dim);
  max-width: 56ch;
  margin: 0 0 32px;
  line-height: 1.55;
}
.cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 44px; }

.hero-meta {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 600px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
}
.hero-meta-num {
  font-family: "Space Grotesk", sans-serif;
  font-size: 32px; font-weight: 700; color: var(--text);
  line-height: 1;
}
.hero-meta-num span {
  font-size: 16px; color: var(--text-mute); font-weight: 500; margin-left: 2px;
}
.hero-meta-lbl { color: var(--text-mute); font-size: 12px; margin-top: 8px; line-height: 1.4; }

/* Two-phase strip in the hero (CREATE → EXECUTE) */
.lede-highlight {
  background: var(--grad-brand);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-weight: 700;
}
.hero-phases {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: stretch;
  gap: 14px;
  max-width: 680px;
  padding-top: 26px;
  border-top: 1px solid var(--line);
}
.phase {
  position: relative;
  padding: 16px 18px;
  background: linear-gradient(180deg, rgba(14,26,64,.6), rgba(6,11,31,.6));
  border: 1px solid var(--line);
  border-radius: 14px;
  backdrop-filter: blur(6px);
}
.phase-num {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: .14em; color: var(--text-mute);
  margin-bottom: 4px;
}
.phase-h {
  font-family: "Space Grotesk", sans-serif;
  font-size: 15px; font-weight: 700; color: var(--text);
  margin-bottom: 4px;
  letter-spacing: -0.005em;
}
.phase-x { color: var(--text-mute); font-size: 12px; line-height: 1.45; }
.phase-arrow {
  align-self: center;
  width: 30px; height: 14px;
  background: linear-gradient(90deg, var(--per), var(--cision));
  clip-path: polygon(0 40%, 70% 40%, 70% 0, 100% 50%, 70% 100%, 70% 60%, 0 60%);
  opacity: .85;
}

/* ----- Hero visual: stacked product screens ----- */
.hero-visual { position: relative; height: 540px; perspective: 1200px; }
.screen-stack { position: absolute; inset: 0; transform-style: preserve-3d; }
.screen {
  position: absolute;
  background: linear-gradient(180deg, rgba(14,26,64,.92), rgba(6,11,31,.92));
  border: 1px solid var(--line-2);
  border-radius: 14px;
  box-shadow: var(--shadow-deep);
  overflow: hidden;
  backdrop-filter: blur(8px);
}
.screen-back {
  width: 60%; height: 240px;
  top: 0; right: 0;
  transform: rotateY(-12deg) rotateX(6deg) translateZ(-40px);
  opacity: .92;
}
.screen-front {
  width: 92%; height: 380px;
  bottom: 0; left: 0;
  transform: rotateY(-6deg) rotateX(2deg);
}
.screen-chrome {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  background: rgba(2,5,14,.6);
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--text-mute); letter-spacing: .03em;
}
.screen-chrome span {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(140,170,255,.25);
}
.screen-chrome span:nth-child(2) { background: rgba(34,211,238,.5); }
.screen-chrome span:nth-child(3) { background: rgba(167,139,250,.5); }
.screen-chrome i { font-style: normal; margin-left: 8px; text-transform: uppercase; }

/* mini frameworks grid in back screen */
.frameworks-grid.mini {
  padding: 16px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
.fw-card {
  background: rgba(11,19,48,.6);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px 8px;
  text-align: center;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600; font-size: 12px;
  color: var(--text-dim);
}
.fw-card.active {
  background: rgba(34,211,238,.14);
  border-color: rgba(34,211,238,.5);
  color: var(--per);
  box-shadow: 0 0 24px -6px rgba(34,211,238,.6);
}

/* command center mock (front screen) */
.cc-head {
  padding: 14px 16px;
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--line);
}
.cc-title {
  font-family: "Space Grotesk", sans-serif;
  font-size: 18px; font-weight: 700; color: var(--text);
}
.cc-toggles { display: flex; gap: 10px; }
.toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 9px; border-radius: 8px;
  font-family: "JetBrains Mono", monospace;
  font-size: 9px; letter-spacing: .08em;
  border: 1px solid var(--line); color: var(--text-mute);
}
.toggle em.on {
  width: 22px; height: 11px; border-radius: 999px;
  background: linear-gradient(90deg, var(--per), var(--cision));
  position: relative; font-style: normal;
}
.toggle em.on::after {
  content: ""; position: absolute; right: 1px; top: 1px;
  width: 9px; height: 9px; border-radius: 50%; background: #02050E;
}

.cc-kpis {
  padding: 14px 16px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
}
.kpi {
  background: rgba(11,19,48,.6);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
}
.kpi-label {
  display: flex; justify-content: space-between; align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 9px; letter-spacing: .08em;
  color: var(--text-mute); margin-bottom: 6px;
}
.kpi-val { font-family: "Space Grotesk", sans-serif; font-weight: 700; font-size: 20px; color: var(--text); }
.kpi-tgt { font-size: 9px; color: var(--text-mute); margin-top: 4px; }
.behind { color: var(--bad); font-size: 9px; }
.ahead  { color: var(--good); font-size: 9px; }
.ontrack { color: var(--per); font-size: 9px; }

.cc-twins {
  padding: 12px 16px 14px;
  border-top: 1px solid var(--line);
}
.twin-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 9px; letter-spacing: .12em; color: var(--text-mute);
  margin-bottom: 10px; text-transform: uppercase;
}
.twins-row { display: flex; gap: 10px; }
.twin-av {
  flex: 1;
  height: 56px;
  border: 1px solid var(--line-2);
  border-radius: 50%;
  display: grid; place-items: center;
  position: relative;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700; font-size: 12px;
  color: var(--text);
  background: rgba(11,19,48,.7);
  max-width: 56px;
}
.twin-av::after {
  content: ""; position: absolute; right: 0; bottom: 0;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--good); border: 2px solid var(--bg-1);
}
.twin-av span {
  position: absolute; bottom: -16px; left: 50%; transform: translateX(-50%);
  font-family: "JetBrains Mono", monospace;
  font-size: 8px; letter-spacing: .08em; color: var(--text-mute);
  font-weight: 500;
}
.twin-av.cyan   { border-color: rgba(34,211,238,.6); box-shadow: 0 0 18px -4px rgba(34,211,238,.7); }
.twin-av.blue   { border-color: rgba(96,165,250,.6); box-shadow: 0 0 18px -4px rgba(96,165,250,.5); }
.twin-av.amber  { border-color: rgba(245,158,11,.6); box-shadow: 0 0 18px -4px rgba(245,158,11,.5); }
.twin-av.rose   { border-color: rgba(251,113,133,.6); box-shadow: 0 0 18px -4px rgba(251,113,133,.5); }
.twin-av.green  { border-color: rgba(52,211,153,.6); box-shadow: 0 0 18px -4px rgba(52,211,153,.5); }
.twin-av.violet { border-color: rgba(167,139,250,.6); box-shadow: 0 0 18px -4px rgba(167,139,250,.5); }

/* =========================== TICKER STRIP ========================= */
.ticker {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(6,11,31,.6);
  overflow: hidden;
  padding: 14px 0;
  position: relative;
}
.ticker::before, .ticker::after {
  content: ""; position: absolute; top: 0; bottom: 0; width: 120px; z-index: 2; pointer-events: none;
}
.ticker::before { left: 0; background: linear-gradient(90deg, var(--bg) 10%, transparent); }
.ticker::after  { right: 0; background: linear-gradient(-90deg, var(--bg) 10%, transparent); }
.ticker-track {
  display: flex; gap: 36px; width: max-content;
  animation: ticker 50s linear infinite;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px; letter-spacing: .04em; color: var(--text-mute);
  white-space: nowrap;
}
.ticker-track span:hover { color: var(--per); }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================== SECTIONS ========================== */
.section { padding: 110px 0; position: relative; }
.section-alt {
  background:
    radial-gradient(60% 40% at 50% 0%, rgba(34,211,238,.06), transparent 70%),
    linear-gradient(180deg, transparent, rgba(11,19,48,.45), transparent);
}

.section-head { max-width: 880px; margin-bottom: 48px; }
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }

.kicker {
  display: inline-block;
  padding: 6px 12px;
  background: rgba(34,211,238,.10);
  border: 1px solid rgba(34,211,238,.30);
  color: var(--per);
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  border-radius: 999px;
  margin-bottom: 20px;
}
.h2 {
  font-family: "Space Grotesk", "Inter", sans-serif;
  font-size: clamp(32px, 4.5vw, 56px);
  line-height: 1.05; letter-spacing: -0.022em; font-weight: 700;
  margin: 0 0 18px;
  color: var(--accent);
  max-width: 22ch;
}
.h2.huge { font-size: clamp(40px, 6vw, 72px); max-width: 18ch; margin-left: auto; margin-right: auto; }
.section-head.center .h2 { max-width: 26ch; margin-left: auto; margin-right: auto; }
.sub { color: var(--text-dim); font-size: 17px; max-width: 64ch; line-height: 1.55; }
.sub.center { margin-left: auto; margin-right: auto; }

/* ====================== DEVICE FRAME (BIG PRODUCT) ================ */
.device-frame {
  position: relative;
  border-radius: var(--r-xl);
  background: linear-gradient(180deg, rgba(14,26,64,.92), rgba(6,11,31,.92));
  border: 1px solid var(--line-2);
  box-shadow: var(--shadow-deep);
  overflow: hidden;
}
.device-frame::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(80% 40% at 50% -10%, rgba(34,211,238,.18), transparent 60%),
    radial-gradient(60% 30% at 0% 100%, rgba(167,139,250,.14), transparent 60%);
  z-index: 0;
}
.device-chrome {
  position: relative; z-index: 1;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 16px;
  background: rgba(2,5,14,.6);
}
.device-chrome .dots { display: flex; gap: 6px; }
.device-chrome .dots span {
  width: 11px; height: 11px; border-radius: 50%;
  background: rgba(140,170,255,.18);
}
.device-chrome .dots span:nth-child(2) { background: rgba(34,211,238,.4); }
.device-chrome .dots span:nth-child(3) { background: rgba(167,139,250,.4); }
.device-chrome .url-bar {
  flex: 1; max-width: 360px;
  background: rgba(11,19,48,.6);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 6px 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px; color: var(--text-dim);
}
.device-chrome .env-pill {
  margin-left: auto;
  padding: 4px 10px; border-radius: 6px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--good);
  border: 1px solid rgba(52,211,153,.4);
  background: rgba(52,211,153,.08);
  letter-spacing: .04em;
}
.device-screen { position: relative; z-index: 1; padding: 0; }

/* product nav */
.ecc-nav {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 30px;
  padding: 18px 28px;
  border-bottom: 1px solid var(--line);
  background: rgba(2,5,14,.5);
}
.ecc-logo {
  display: flex; align-items: center; gap: 10px;
  font-family: "Space Grotesk", sans-serif; font-weight: 700; font-size: 18px;
}
.ecc-logo em {
  font-family: "JetBrains Mono", monospace;
  font-style: normal; font-size: 9px; color: var(--text-mute);
  margin-left: 6px; letter-spacing: .12em; text-transform: uppercase;
}
.ecc-tabs { display: flex; gap: 8px; justify-content: center; }
.ecc-tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px; border-radius: 10px;
  border: 1px solid var(--line);
  font-size: 13px; color: var(--text-dim);
  font-weight: 500;
  background: rgba(11,19,48,.4);
}
.ecc-tab em {
  font-style: normal; font-family: "JetBrains Mono", monospace;
  font-size: 9px; color: var(--text-mute); letter-spacing: .1em;
  text-transform: uppercase;
}
.ecc-tab.active {
  border-color: rgba(34,211,238,.5);
  background: rgba(34,211,238,.10);
  color: var(--per);
  box-shadow: 0 0 28px -6px rgba(34,211,238,.5);
}
.ecc-tab.active em { color: var(--per); }
.ecc-actions { display: flex; gap: 8px; }
.ecc-pill {
  padding: 8px 12px; border-radius: 8px;
  border: 1px solid var(--line);
  font-size: 12px; color: var(--text-dim);
  background: rgba(11,19,48,.4);
}

.ecc-tabs-sub {
  display: flex; gap: 4px;
  padding: 0 28px;
  border-bottom: 1px solid var(--line);
}
.ecc-tabs-sub span {
  padding: 14px 18px;
  font-size: 13px; font-weight: 500;
  color: var(--text-mute);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.ecc-tabs-sub .active {
  color: var(--per);
  border-bottom-color: var(--per);
}

.ecc-body { padding: 28px 28px 32px; }

.ecc-title-row {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 24px;
  margin-bottom: 22px;
}
.ecc-title {
  font-family: "Space Grotesk", sans-serif;
  font-size: 30px; font-weight: 700;
  color: var(--text); letter-spacing: -0.015em;
}
.ecc-title em {
  font-style: normal;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; color: var(--per);
  letter-spacing: .14em; text-transform: uppercase;
  margin-left: 12px;
  border: 1px solid rgba(34,211,238,.3);
  padding: 4px 10px; border-radius: 6px;
  vertical-align: middle;
}
.ecc-sub { color: var(--text-dim); font-size: 14px; margin-top: 6px; }
.ecc-sub a { color: var(--per); text-decoration: underline; text-decoration-color: rgba(34,211,238,.4); text-underline-offset: 3px; }

.ecc-toggles { display: flex; gap: 10px; }
.ecc-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: 8px;
  border: 1px solid var(--line);
  background: rgba(11,19,48,.4);
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: .1em; color: var(--text-mute);
}
.ecc-toggle em.on {
  width: 28px; height: 14px; border-radius: 999px;
  background: linear-gradient(90deg, var(--per), var(--cision));
  position: relative;
}
.ecc-toggle em.on::after {
  content: ""; position: absolute; right: 2px; top: 2px;
  width: 10px; height: 10px; border-radius: 50%; background: #02050E;
}

.alert {
  margin-bottom: 26px;
  padding: 14px 18px; border-radius: 12px;
  background: rgba(248,113,113,.08);
  border: 1px solid rgba(248,113,113,.30);
  color: var(--text);
  font-size: 14px;
}
.alert .dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--bad); margin-right: 8px;
  box-shadow: 0 0 0 4px rgba(248,113,113,.18);
}
.alert b { color: var(--bad); font-weight: 700; }

.ecc-section { margin-bottom: 30px; }
.ecc-section-h {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 14px;
}
.ecc-section-h span {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: .14em; color: var(--text-dim);
  text-transform: uppercase;
}
.ecc-section-h em {
  font-style: normal;
  font-size: 11px; color: var(--text-mute);
  font-family: "JetBrains Mono", monospace;
}

/* KPI tiles */
.kpi-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px;
}
.kpi-tile {
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 14px 16px;
}
.kpi-tile-h {
  display: flex; justify-content: space-between; align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: .1em;
  color: var(--text-mute); margin-bottom: 8px;
}
.kpi-tile-h .tag { font-size: 10px; padding: 2px 6px; border-radius: 4px; letter-spacing: 0; }
.kpi-tile-h .tag.behind  { color: var(--bad); background: rgba(248,113,113,.10); border: 1px solid rgba(248,113,113,.3); }
.kpi-tile-h .tag.ahead   { color: var(--good); background: rgba(52,211,153,.10); border: 1px solid rgba(52,211,153,.3); }
.kpi-tile-h .tag.ontrack { color: var(--per); background: rgba(34,211,238,.08); border: 1px solid rgba(34,211,238,.3); }
.kpi-tile-v {
  font-family: "Space Grotesk", sans-serif;
  font-size: 28px; font-weight: 700; color: var(--text);
  line-height: 1; margin-bottom: 8px;
}
.kpi-tile-t { font-size: 11px; color: var(--text-dim); }
.kpi-tile-t em { font-style: normal; color: var(--text-mute); margin-left: 4px; }
.kpi-tile-x { font-size: 10px; color: var(--text-mute); margin-top: 2px; min-height: 14px; }
.kpi-bar {
  margin-top: 10px;
  height: 4px; border-radius: 999px; overflow: hidden;
  background: rgba(140,170,255,.10);
}
.kpi-bar i {
  display: block; height: 100%; width: var(--w);
  background: linear-gradient(90deg, var(--per), var(--cision));
  border-radius: 999px;
}
.kpi-bar.good i { background: linear-gradient(90deg, #34D399, #22D3EE); }

/* Goals */
.goals { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.goal {
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 18px;
}
.goal-h { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.goal-h span:first-child { font-family: "Space Grotesk", sans-serif; font-weight: 700; font-size: 15px; color: var(--text); }
.prio { font-family: "JetBrains Mono", monospace; font-size: 9px; padding: 3px 7px; border-radius: 4px; letter-spacing: .08em; }
.prio.crit { color: var(--bad);  background: rgba(248,113,113,.10); border: 1px solid rgba(248,113,113,.3); }
.prio.high { color: var(--amber); background: rgba(245,158,11,.10); border: 1px solid rgba(245,158,11,.3); }
.goal-meta {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--text-mute); margin: 6px 0 10px;
  letter-spacing: .08em;
}
.goal p { margin: 0 0 14px; font-size: 13px; color: var(--text-dim); line-height: 1.5; }
.goal-bar {
  display: flex; justify-content: space-between;
  font-size: 11px; color: var(--text-dim); margin-bottom: 6px;
}
.bar-rail { height: 4px; border-radius: 999px; background: rgba(140,170,255,.1); overflow: hidden; }
.bar-rail i {
  display: block; height: 100%; width: var(--w);
  background: linear-gradient(90deg, var(--amber), #F59E0B);
}
.bar-rail.good i { background: linear-gradient(90deg, #34D399, #22D3EE); }
.bar-rail.rose i { background: linear-gradient(90deg, #FB7185, #F87171); }

/* ===================== FINANCIAL MODULE SECTION =================== */
.fin-body { padding: 24px 28px 28px; }

/* Top row: Buffett gauge + DCF + Owner Earnings + MoS */
.fin-top {
  display: grid; grid-template-columns: 1.15fr 1fr 1fr 1fr; gap: 14px;
  margin-bottom: 16px;
}
.fin-card {
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px 18px;
  position: relative;
  overflow: hidden;
}
.fin-card.buffett {
  border-color: rgba(34,211,238,.35);
  background:
    radial-gradient(60% 80% at 0% 0%, rgba(34,211,238,.10), transparent 70%),
    linear-gradient(180deg, rgba(14,26,64,.85), rgba(6,11,31,.85));
}
.fin-card-h {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: .12em; color: var(--text-mute);
  text-transform: uppercase;
}
.fin-card-h em {
  font-style: normal;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--text-mute);
  text-transform: none; letter-spacing: .04em;
}
.fin-card-h .tag {
  font-size: 9px; padding: 2px 7px; border-radius: 4px;
  letter-spacing: .06em;
}
.fin-card-h .tag.good    { color: var(--good); background: rgba(52,211,153,.10); border: 1px solid rgba(52,211,153,.3); }
.fin-card-h .tag.ahead   { color: var(--good); background: rgba(52,211,153,.10); border: 1px solid rgba(52,211,153,.3); }
.fin-card-h .tag.ontrack { color: var(--per);  background: rgba(34,211,238,.10); border: 1px solid rgba(34,211,238,.3); }

.good-text { color: var(--good); }

/* Buffett gauge */
.gauge { position: relative; display: grid; place-items: center; margin: 4px 0 6px; }
.gauge-svg { width: 100%; max-width: 200px; height: auto; display: block; }
.gauge-num {
  position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%);
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700; font-size: 36px; line-height: 1;
  display: flex; align-items: baseline; gap: 4px;
}
.gauge-num em { font-style: normal; font-size: 12px; color: var(--text-mute); }
.gauge-meta {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 11px; color: var(--text-dim);
  padding-top: 10px; border-top: 1px solid var(--line);
}
.gauge-meta span { display: flex; justify-content: space-between; }
.gauge-meta b { color: var(--text); font-weight: 600; }

/* Big numeric cards */
.fin-big-num {
  font-family: "Space Grotesk", sans-serif;
  font-size: 38px; font-weight: 700; line-height: 1;
  color: var(--text);
  margin: 8px 0 6px;
}
.fin-big-num em { font-style: normal; font-size: 18px; color: var(--text-dim); margin-left: 2px; }
.fin-big-sub { color: var(--text-dim); font-size: 12px; }
.fin-big-sub b { color: var(--text); }

.fin-rows {
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid var(--line);
  display: grid; gap: 6px;
  font-size: 11px;
}
.fin-rows div { display: flex; justify-content: space-between; color: var(--text-dim); }
.fin-rows b { color: var(--text); font-weight: 600; }

/* Owner earnings bars */
.oe-bars {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px;
  height: 50px; align-items: end;
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid var(--line);
}
.oe-bars i {
  display: block; height: var(--h); min-height: 8px;
  background: rgba(140,170,255,.20);
  border-radius: 3px;
}
.oe-bars i.active {
  background: linear-gradient(180deg, var(--per), var(--cision));
  box-shadow: 0 -6px 12px -4px rgba(34,211,238,.6);
}

/* Margin of safety rail */
.mos-rail {
  position: relative;
  height: 14px; border-radius: 999px; overflow: hidden;
  margin: 14px 0 8px;
  display: flex;
  border: 1px solid var(--line);
}
.mos-zone { flex: 1; }
.mos-zone.red { background: linear-gradient(90deg, rgba(248,113,113,.4), rgba(248,113,113,.15)); }
.mos-zone.yel { background: linear-gradient(90deg, rgba(251,191,36,.3), rgba(251,191,36,.15)); }
.mos-zone.grn { background: linear-gradient(90deg, rgba(52,211,153,.3), rgba(52,211,153,.5)); }
.mos-mark {
  position: absolute; top: -3px; bottom: -3px; width: 3px;
  background: var(--per);
  box-shadow: 0 0 12px rgba(34,211,238,.8);
  border-radius: 2px;
}
.mos-legend {
  display: flex; justify-content: space-between;
  font-size: 10px; color: var(--text-mute);
  font-family: "JetBrains Mono", monospace;
  letter-spacing: .04em;
}

/* Mid row: Sankey + ratios + warnings */
.fin-mid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 14px;
}

.sankey-card .sankey {
  width: 100%; height: auto;
  margin-top: 6px;
}

/* Ratios */
.ratios { list-style: none; padding: 0; margin: 6px 0 0; display: grid; gap: 8px; }
.ratios li {
  display: grid;
  grid-template-columns: 1.3fr auto 1.5fr auto;
  gap: 10px;
  align-items: center;
  font-size: 11px;
}
.ratios .r-name { color: var(--text-dim); }
.ratios .r-val { color: var(--text); font-family: "Space Grotesk", sans-serif; font-weight: 700; min-width: 44px; text-align: right; }
.ratios .r-bar { display: block; height: 5px; background: rgba(140,170,255,.10); border-radius: 999px; overflow: hidden; }
.ratios .r-bar i {
  display: block; height: 100%; width: var(--w);
  background: linear-gradient(90deg, var(--per), var(--cision));
  border-radius: 999px;
}
.ratios .r-pct {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--per); letter-spacing: .04em;
  min-width: 30px;
}

/* Warnings */
.warnings { list-style: none; padding: 0; margin: 6px 0 10px; display: grid; gap: 8px; }
.warn-row {
  display: grid; grid-template-columns: 18px 1fr; gap: 10px;
  align-items: start;
  padding: 8px 10px; border-radius: 8px;
  border: 1px solid var(--line);
}
.warn-row b { display: block; font-size: 12px; color: var(--text); font-weight: 600; }
.warn-row em { display: block; font-size: 10px; color: var(--text-mute); font-style: normal; margin-top: 2px; line-height: 1.4; }
.warn-dot {
  width: 8px; height: 8px; border-radius: 50%;
  margin-top: 5px; align-self: start;
}
.warn-yellow { background: rgba(251,191,36,.06); border-color: rgba(251,191,36,.25); }
.warn-yellow .warn-dot { background: var(--warn); box-shadow: 0 0 0 3px rgba(251,191,36,.18); }
.warn-red { background: rgba(248,113,113,.06); border-color: rgba(248,113,113,.25); }
.warn-red .warn-dot { background: var(--bad); box-shadow: 0 0 0 3px rgba(248,113,113,.18); }
.warn-clear { opacity: .7; }
.warn-clear .warn-dot { background: var(--good); box-shadow: 0 0 0 3px rgba(52,211,153,.18); }
.warn-foot {
  margin-top: 8px;
  padding-top: 10px; border-top: 1px solid var(--line);
  font-size: 11px; color: var(--text-mute);
  font-family: "JetBrains Mono", monospace;
}
.warn-foot a { color: var(--per); text-decoration: underline; cursor: pointer; }

/* Trust strip below the financial frame */
.fin-trust {
  margin-top: 24px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: var(--r);
  background: rgba(11,19,48,.4);
}
.fin-trust-item {
  display: flex; flex-direction: column; gap: 6px;
  border-left: 2px solid rgba(34,211,238,.4);
  padding-left: 14px;
}
.fin-trust-item b {
  font-family: "Space Grotesk", sans-serif;
  font-size: 22px; color: var(--per); font-weight: 700;
  line-height: 1;
}
.fin-trust-item span { color: var(--text-dim); font-size: 12px; line-height: 1.4; }

/* ============================ TWINS SECTION ======================= */
.twins-stage {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 30px; align-items: stretch;
}

.twin-feature-card {
  background: linear-gradient(180deg, rgba(14,26,64,.85), rgba(6,11,31,.85));
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  padding: 28px;
  display: grid; grid-template-columns: 160px 1fr; gap: 24px;
  box-shadow: var(--shadow-soft);
  height: 100%;
}
.twin-photo { position: relative; }
.twin-photo-svg {
  width: 160px; height: 160px;
  border-radius: 50%;
  border: 2px solid rgba(34,211,238,.5);
  box-shadow: 0 0 32px -4px rgba(34,211,238,.6), 0 0 0 6px rgba(34,211,238,.08);
  background: var(--bg-1);
  overflow: hidden;
}
.live-badge {
  position: absolute; bottom: 8px; left: 8px;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 999px;
  background: rgba(2,5,14,.92);
  border: 1px solid rgba(52,211,153,.4);
  font-family: "JetBrains Mono", monospace;
  font-size: 9px; letter-spacing: .14em; color: var(--good);
}
.live-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--good);
  box-shadow: 0 0 0 0 rgba(52,211,153,.7);
  animation: pulse 1.6s ease-out infinite;
}
.twin-feature-name {
  font-family: "Space Grotesk", sans-serif;
  font-size: 20px; font-weight: 700; color: var(--per); margin-bottom: 4px;
}
.twin-feature-name .demo {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--cision);
  background: rgba(167,139,250,.10);
  border: 1px solid rgba(167,139,250,.3);
  padding: 2px 7px; border-radius: 4px;
  margin-left: 8px; vertical-align: middle;
  letter-spacing: .12em;
}
.twin-feature-role { color: var(--text-dim); font-size: 13px; margin-bottom: 8px; }
.twin-caps {
  display: flex; gap: 16px; margin-bottom: 16px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px; color: var(--text-mute); letter-spacing: .04em;
}
.twin-caps span { display: inline-flex; align-items: center; gap: 6px; }

.twin-chat-q {
  margin-left: auto; max-width: 80%;
  padding: 10px 14px; border-radius: 12px 12px 4px 12px;
  background: linear-gradient(135deg, rgba(34,211,238,.18), rgba(167,139,250,.18));
  border: 1px solid var(--line-2);
  font-size: 13px; color: var(--text);
  margin-bottom: 12px;
  width: fit-content;
}
.twin-chat-a {
  padding: 14px 16px; border-radius: 4px 12px 12px 12px;
  background: rgba(11,19,48,.7);
  border: 1px solid var(--line);
  font-size: 13px; color: var(--text-dim); line-height: 1.55;
  margin-bottom: 14px;
}
.twin-chat-a b { color: var(--text); }
.twin-chat-input {
  display: flex; gap: 8px;
  padding: 8px;
  background: rgba(11,19,48,.5);
  border: 1px solid var(--line);
  border-radius: 12px;
}
.twin-chat-input input {
  flex: 1;
  background: transparent; border: 0; outline: 0;
  color: var(--text); font-size: 13px;
  padding: 6px 10px;
}
.twin-chat-input button {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 8px;
  background: linear-gradient(135deg, rgba(245,158,11,.18), rgba(245,158,11,.10));
  border: 1px solid rgba(245,158,11,.3);
  color: var(--amber); font-weight: 600; font-size: 13px;
}

/* twin grid */
.twin-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.twin-card {
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px;
  position: relative;
  transition: transform .25s var(--ease), border-color .25s var(--ease);
}
.twin-card:hover { transform: translateY(-3px); border-color: var(--line-2); }
.twin-init {
  width: 44px; height: 44px; border-radius: 50%;
  display: grid; place-items: center;
  font-family: "Space Grotesk", sans-serif; font-weight: 700; font-size: 16px;
  background: rgba(11,19,48,.7); border: 1px solid currentColor;
  margin-bottom: 12px;
}
.twin-name { font-family: "Space Grotesk", sans-serif; font-weight: 700; font-size: 15px; color: var(--text); }
.twin-role { font-size: 12px; color: var(--text-mute); margin-bottom: 12px; }
.twin-stat {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 8px; border-radius: 6px;
  font-size: 11px; color: var(--text-dim);
  background: rgba(11,19,48,.6); border: 1px solid var(--line);
  font-family: "JetBrains Mono", monospace;
}
.twin-stat .dot { width: 6px; height: 6px; border-radius: 50%; }
.twin-stat .dot.live { background: var(--good); }
.twin-stat .dot.warn { background: var(--amber); }

.twin-card.cyan   { color: var(--per); }
.twin-card.blue   { color: var(--blue); }
.twin-card.amber  { color: var(--amber); }
.twin-card.rose   { color: var(--rose); }
.twin-card.green  { color: var(--green); }
.twin-card.violet { color: var(--cision); }

/* ============================ COMPUTE SECTION ===================== */
.compute { overflow: hidden; isolation: isolate; }
.compute-bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(60% 50% at 50% 50%, rgba(34,211,238,.12), transparent 70%),
    linear-gradient(180deg, rgba(2,5,14,.4), transparent 30%, transparent 70%, rgba(2,5,14,.4));
}
.rack-row {
  position: absolute; left: -10%; right: -10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(34,211,238,.35), rgba(167,139,250,.35), transparent);
  animation: rack-pulse 4s var(--ease) infinite;
}
.rack-row     { top: 12%; }
.rack-row.r2  { top: 28%; animation-delay: -1s; }
.rack-row.r3  { top: 50%; animation-delay: -2s; opacity: .7; }
.rack-row.r4  { top: 72%; animation-delay: -3s; opacity: .5; }
.rack-row.r5  { top: 90%; animation-delay: -1.5s; opacity: .6; }
@keyframes rack-pulse {
  0%,100% { transform: scaleX(.85); opacity: .35; }
  50%     { transform: scaleX(1); opacity: .8; }
}
.data-stream {
  position: absolute;
  width: 2px; height: 80px;
  background: linear-gradient(180deg, transparent, var(--per), transparent);
  animation: stream 3s linear infinite;
  filter: blur(1px);
}
.data-stream.s1 { left: 18%; animation-delay: 0s;   background: linear-gradient(180deg, transparent, var(--per), transparent); }
.data-stream.s2 { left: 52%; animation-delay: -1s;  background: linear-gradient(180deg, transparent, var(--cision), transparent); }
.data-stream.s3 { left: 82%; animation-delay: -2s;  background: linear-gradient(180deg, transparent, #818CF8, transparent); }
@keyframes stream {
  0%   { top: -10%; opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { top: 110%; opacity: 0; }
}

.compute-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
  margin-bottom: 60px;
}
.cg-card {
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cg-card::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(80% 60% at 50% 0%, rgba(34,211,238,.10), transparent 60%);
}
.cg-num {
  font-family: "Space Grotesk", sans-serif;
  font-size: 56px; font-weight: 700; line-height: 1;
  margin-bottom: 8px;
  position: relative;
}
.cg-num em { font-size: 24px; vertical-align: super; font-style: normal; font-weight: 600; }
.cg-lbl { font-family: "Space Grotesk", sans-serif; font-weight: 600; font-size: 14px; color: var(--text); margin-bottom: 6px; }
.cg-x { color: var(--text-mute); font-size: 12px; }

/* Pipeline */
.pipeline {
  display: flex; align-items: stretch; justify-content: center; gap: 18px;
  flex-wrap: wrap;
}
.pl-stage {
  flex: 1; min-width: 240px;
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  padding: 28px;
  position: relative;
  text-align: center;
}
.pl-stage.core {
  border-color: rgba(34,211,238,.45);
  background: linear-gradient(180deg, rgba(34,211,238,.10), rgba(167,139,250,.10));
  box-shadow: 0 0 50px -10px rgba(34,211,238,.4);
}
.pl-num {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: .14em; color: var(--text-mute);
  margin-bottom: 10px;
}
.pl-h {
  font-family: "Space Grotesk", sans-serif;
  font-size: 22px; font-weight: 700; color: var(--text);
  margin-bottom: 8px;
}
.pl-stage.core .pl-h { background: var(--grad-cyan); -webkit-background-clip: text; background-clip: text; color: transparent; }
.pl-x { color: var(--text-dim); font-size: 13px; line-height: 1.5; }

.pl-spinner {
  position: relative;
  width: 80px; height: 80px;
  margin: 16px auto 0;
}
.pl-spinner .ring {
  position: absolute; inset: 0;
  border: 1px solid rgba(34,211,238,.4);
  border-top-color: var(--per);
  border-radius: 50%;
  animation: spin 2s linear infinite;
}
.pl-spinner .ring.r2 { inset: 12px; border-color: rgba(167,139,250,.4); border-top-color: var(--cision); animation-duration: 3s; animation-direction: reverse; }
.pl-spinner .ring.r3 { inset: 24px; border-color: rgba(96,165,250,.4); border-top-color: var(--blue); animation-duration: 1.5s; }
@keyframes spin { to { transform: rotate(360deg); } }

.pl-arrow {
  align-self: center;
  width: 30px; height: 14px;
  background:
    linear-gradient(90deg, var(--per), var(--cision));
  clip-path: polygon(0 40%, 70% 40%, 70% 0, 100% 50%, 70% 100%, 70% 60%, 0 60%);
  opacity: .8;
}

/* ============================ FRAMEWORKS ========================== */
.fw-gallery {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 12px;
}
.fw-tile {
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 18px;
  text-align: center;
  position: relative;
  transition: transform .25s var(--ease), border-color .25s var(--ease);
}
.fw-tile:hover { transform: translateY(-4px); border-color: var(--line-2); }
.fw-tile-pip {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: 9px; letter-spacing: .1em;
  color: var(--per);
  background: rgba(34,211,238,.10);
  border: 1px solid rgba(34,211,238,.3);
  padding: 3px 7px; border-radius: 4px;
  margin-bottom: 10px;
}
.fw-tile-name {
  font-family: "Space Grotesk", sans-serif;
  font-size: 17px; font-weight: 700; color: var(--text);
  margin-bottom: 4px;
}
.fw-tile-x { font-size: 11px; color: var(--text-mute); line-height: 1.4; }
.fw-active {
  border-color: rgba(34,211,238,.5);
  background: linear-gradient(180deg, rgba(34,211,238,.18), rgba(34,211,238,.04));
  box-shadow: 0 0 36px -8px rgba(34,211,238,.5);
}
.fw-active .fw-tile-name { color: var(--per); }
.fw-investor {
  border-color: rgba(167,139,250,.4);
  background: linear-gradient(180deg, rgba(167,139,250,.18), rgba(167,139,250,.04));
}
.fw-investor .fw-tile-pip { color: var(--cision); background: rgba(167,139,250,.10); border-color: rgba(167,139,250,.3); }
.fw-investor .fw-tile-name { color: var(--cision); }

/* ============================ MARKET ============================== */
.market-grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 16px;
  margin-bottom: 40px;
}
.m-card {
  background: linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 32px;
}
.m-card.big {
  border-color: var(--line-2);
  background: linear-gradient(135deg, rgba(34,211,238,.08), rgba(167,139,250,.08)), linear-gradient(180deg, rgba(14,26,64,.7), rgba(6,11,31,.7));
}
.m-num {
  font-family: "Space Grotesk", sans-serif;
  font-size: 64px; font-weight: 700;
  line-height: 1; margin-bottom: 8px;
  color: var(--text);
}
.grad-cyan-bg {
  background: var(--grad-cyan);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.m-lbl { font-family: "Space Grotesk", sans-serif; font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 10px; }
.m-card p { color: var(--text-dim); font-size: 14px; line-height: 1.55; margin: 0; }

.quote {
  display: grid; grid-template-columns: 40px 1fr; gap: 18px; align-items: start;
  padding: 28px;
  border: 1px solid var(--line-2);
  border-radius: var(--r-lg);
  background: rgba(11,19,48,.4);
}
.quote svg { color: var(--per); }
.quote p { margin: 0; font-size: 17px; color: var(--text-dim); line-height: 1.5; }
.quote b { color: var(--text); }

/* ============================ CTA ================================ */
.cta { padding: 80px 0 110px; }
.cta-card {
  position: relative;
  border-radius: var(--r-xl);
  padding: 64px 48px;
  text-align: center;
  border: 1px solid var(--line-2);
  background: linear-gradient(180deg, rgba(14,26,64,.85), rgba(6,11,31,.85));
  overflow: hidden;
  box-shadow: var(--shadow-deep);
}
.cta-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(40% 60% at 20% 0%, rgba(34,211,238,.20), transparent 60%),
    radial-gradient(40% 60% at 80% 100%, rgba(167,139,250,.20), transparent 60%);
}
.cta-eyebrow {
  position: relative;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px; letter-spacing: .14em;
  color: var(--per); text-transform: uppercase;
  margin-bottom: 16px;
}
.cta-h {
  position: relative;
  font-family: "Space Grotesk", sans-serif;
  font-size: clamp(34px, 5vw, 60px);
  font-weight: 700; letter-spacing: -0.02em;
  color: var(--accent);
  margin: 0 0 14px;
}
.cta-sub {
  position: relative;
  font-size: 16px; color: var(--text-dim);
  max-width: 56ch; margin: 0 auto 32px;
}
.cta-actions { position: relative; display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ============================ FOOTER ============================== */
.foot {
  padding: 36px 0;
  border-top: 1px solid var(--line);
  background: var(--bg-1);
}
.foot-inner {
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
}
.foot-brand p { color: var(--text-mute); margin: 4px 0 0; font-size: 13px; }
.foot-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; color: var(--text-mute); font-size: 13px; }
.foot-meta a { color: var(--text); }
.foot-meta a:hover { color: var(--per); }

/* ============================ RESPONSIVE ========================== */
@media (max-width: 1100px) {
  .hero-inner { grid-template-columns: 1fr; gap: 50px; }
  .hero-visual { height: 460px; }
  .kpi-grid { grid-template-columns: repeat(3, 1fr); }
  .fw-gallery { grid-template-columns: repeat(4, 1fr); }
  .twins-stage { grid-template-columns: 1fr; }
  .fin-top { grid-template-columns: 1fr 1fr; }
  .fin-mid { grid-template-columns: 1fr; }
  .fin-trust { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 800px) {
  .nav-links { gap: 14px; }
  .nav-links a:not(.btn) { display: none; }
  .hero { padding: 60px 0 50px; }
  .hero-meta { grid-template-columns: 1fr 1fr; }
  .ecc-tabs { display: none; }
  .ecc-actions { display: none; }
  .ecc-nav { grid-template-columns: 1fr; gap: 10px; }
  .ecc-title { font-size: 22px; }
  .ecc-title-row { flex-direction: column; gap: 12px; }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .goals { grid-template-columns: 1fr; }
  .compute-grid { grid-template-columns: repeat(2, 1fr); }
  .pipeline { flex-direction: column; }
  .pl-arrow { transform: rotate(90deg); }
  .market-grid { grid-template-columns: 1fr; }
  .twin-grid { grid-template-columns: 1fr; }
  .twin-feature-card { grid-template-columns: 1fr; }
  .twin-photo-svg { width: 120px; height: 120px; margin: 0 auto; }
  .fw-gallery { grid-template-columns: repeat(2, 1fr); }
  .fin-top { grid-template-columns: 1fr; }
  .fin-trust { grid-template-columns: 1fr; }
  .section { padding: 70px 0; }
  .foot-inner { flex-direction: column; align-items: flex-start; }
  .foot-meta { align-items: flex-start; }
  .device-frame { border-radius: 16px; }
  .ecc-body { padding: 18px; }
}

@media (prefers-reduced-motion: reduce) {
  .ticker-track, .scan-line, .pl-spinner .ring, .data-stream, .rack-row, .pulse, .live-dot {
    animation: none !important;
  }
}
