
/* ════════════════════════════════════════════
   TOKEN SYSTEM
════════════════════════════════════════════ */
:root {
  --base:        #060D1A;
  --surface:     #0A1628;
  --surface-2:   #0F1E35;
  --surface-3:   #162640;
  --border:      #1A3A5C;
  --border-dim:  #0F2238;
  --accent:      #F5C542;   /* Plus91 signal yellow */
  --accent-dim:  rgba(245,197,66,.09);
  --accent-glow: rgba(245,197,66,.20);
  --text:        #E8EEF5;
  --text-2:      #7A94B0;
  --text-3:      #3D5570;
  --red:         #FF4D6A;
  --amber:       #FFB000;
  --blue-mid:    #0070C0;
  --mono:        'JetBrains Mono', monospace;
  --display:     'Manrope', sans-serif;
  --body:        'Lato', sans-serif;
  --max:         1280px;
  --pad:         48px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  background: var(--base);
  color: var(--text);
  font-family: var(--body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
}

/* Scan-line texture — always present */
body::before {
  content: '';
  position: fixed; inset: 0;
  background-image: repeating-linear-gradient(
    0deg, transparent, transparent 3px,
    rgba(255,255,255,.011) 3px, rgba(255,255,255,.011) 4px
  );
  pointer-events: none;
  z-index: 0;
}

/* ════════════════════════════════════════════
   SHARED UTILITIES
════════════════════════════════════════════ */
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }

.mono { font-family: var(--mono); }

.sec-label {
  font-family: var(--mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 14px;
  display: flex; align-items: center; gap: 12px;
}
.sec-label::before { content:''; width:20px; height:1px; background:var(--accent); flex-shrink:0; }

.sec-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(32px, 4vw, 54px);
  letter-spacing: -.055em; line-height: 1.02;
  color: var(--text); margin-bottom: 18px;
}
.sec-title .a { color: var(--accent); }

.sec-body {
  font-family: var(--body);
  font-weight: 300; font-size: 17px;
  line-height: 1.8; color: var(--text-2);
  max-width: 560px;
}

/* section divider rule */
.rule {
  display: flex; align-items: center; gap: 16px;
  padding: 32px 0;
}
.rule-label {
  font-family: var(--mono);
  font-size: 9px; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--text-3); white-space: nowrap;
}
.rule-line { flex:1; height:1px; background: var(--border-dim); }

/* panel base */
.panel {
  border: 1px solid var(--border);
  background: var(--surface);
  position: relative; overflow: hidden;
}
.panel::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse 90% 50% at 50% 0%, rgba(245,197,66,.03), transparent);
  pointer-events:none;
}
.panel-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
}
.panel-title {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
}
.panel-meta {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .08em; color: var(--accent);
}

/* metric row */
.mrow {
  display: flex; align-items: baseline;
  justify-content: space-between;
  padding: 7px 0;
}
.mkey {
  font-family: var(--mono); font-size: 11px;
  color: var(--text-3);
  display: flex; align-items: center; gap: 8px;
}
.mkey::before { content:''; width:4px; height:4px; border-radius:50%; background:var(--border); flex-shrink:0; }
.mval {
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  color: var(--text);
  display: flex; align-items: center; gap: 7px;
}
.mval.a { color: var(--accent); }
.mval.r { color: var(--red); }
.mval.am{ color: var(--amber); }

.badge {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: .08em; padding: 2px 7px; text-transform: uppercase;
}
.bg { background: rgba(245,197,66,.12); color: var(--accent); }
.br { background: rgba(255,77,106,.12); color: var(--red); }
.ba { background: rgba(245,166,35,.12); color: var(--amber); }

/* msec = metric section inside panel */
.msec {
  padding: 14px 20px;
  border-bottom: 1px solid var(--border-dim);
}
.msec:last-child { border-bottom: none; }
.msec-label {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase; color: var(--text-3);
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
}
.msec-label::after { content:''; flex:1; height:1px; background:var(--border-dim); }

/* status dot */
.sdot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); flex-shrink: 0;
  animation: sdotPulse 2s ease-in-out infinite;
}
@keyframes sdotPulse { 0%,100%{opacity:1} 50%{opacity:.35} }

/* buttons */
.btn-p {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--base); background: var(--accent);
  border: none; padding: 13px 26px; cursor: pointer;
  text-decoration: none; display: inline-flex;
  align-items: center; gap: 9px; transition: opacity .15s;
}
.btn-p:hover { opacity: .86; }
.btn-p .arr { transition: transform .18s; }
.btn-p:hover .arr { transform: translateX(4px); }

.btn-s {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-2); background: transparent;
  border: 1px solid var(--border); padding: 12px 26px;
  cursor: pointer; text-decoration: none;
  transition: border-color .15s, color .15s; display: inline-block;
}
.btn-s:hover { border-color: var(--text-3); color: var(--text); }

/* reveal animation */
.rv {
  opacity: 0; transform: translateY(20px);
  transition: opacity .65s ease, transform .65s ease;
}
.rv.in { opacity: 1; transform: translateY(0); }
.rv.d1 { transition-delay: .1s; }
.rv.d2 { transition-delay: .2s; }
.rv.d3 { transition-delay: .3s; }
.rv.d4 { transition-delay: .4s; }

/* grid columns */
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.g3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; }
.g4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; }
.g5 { display: grid; grid-template-columns: repeat(5,1fr); gap: 1px; }

/* ════════════════════════════════════════════
   NAV
════════════════════════════════════════════ */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  height: 64px; display: flex; align-items: center;
  justify-content: space-between; padding: 0 var(--pad);
  border-bottom: 1px solid var(--border-dim);
  background: rgba(6,13,26,.88);
  backdrop-filter: blur(18px);
  transition: border-color .3s;
}
#nav.scrolled { border-bottom-color: var(--border); }

.nav-brand { display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav-mark {
  width:36px; height:36px; border:1px solid var(--accent);
  display:grid; place-items:center;
  font-family:var(--mono); font-size:11px; font-weight:600;
  color:var(--accent); letter-spacing:-.02em;
}
.nav-name { font-family:var(--display); font-weight:800; font-size:17px; color:var(--text); letter-spacing:-.04em; }
.nav-sub { font-family:var(--mono); font-size:9px; font-weight:500; color:var(--text-3); letter-spacing:.14em; text-transform:uppercase; }

.nav-links { display:flex; gap:28px; list-style:none; }
.nav-links a {
  font-family:var(--mono); font-size:11px; font-weight:500;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-2); text-decoration:none; transition:color .15s;
}
.nav-links a:hover { color:var(--text); }

.nav-right { display:flex; align-items:center; gap:16px; }
.status-pill {
  display:flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:10px; font-weight:500;
  letter-spacing:.08em; color:var(--accent);
  border:1px solid rgba(245,197,66,.2); padding:5px 12px;
  background:var(--accent-dim);
}

/* ════════════════════════════════════════════
   HERO
════════════════════════════════════════════ */
#hero {
  position: relative; min-height: 100vh;
  display: flex; align-items: center;
  padding: 100px var(--pad) 64px;
  overflow: hidden;
}
#hero::before {
  content:''; position:absolute; inset:0;
  background-image: repeating-linear-gradient(
    90deg, transparent, transparent 119px,
    var(--border-dim) 119px, var(--border-dim) 120px
  );
  pointer-events:none; opacity:.5;
}
#hero::after {
  content:''; position:absolute; top:-100px; right:-60px;
  width:560px; height:560px;
  background: radial-gradient(circle, rgba(245,197,66,.055) 0%, transparent 65%);
  pointer-events:none;
}
.hero-bg-num {
  position:absolute; right:-10px; top:50%; transform:translateY(-52%);
  font-family:var(--display); font-weight:900;
  font-size:clamp(160px,22vw,280px); line-height:1; letter-spacing:-.06em;
  color:transparent; -webkit-text-stroke:1px rgba(245,197,66,.065);
  pointer-events:none; user-select:none; white-space:nowrap;
}
.hero-inner {
  position:relative; z-index:2; width:100%;
  display:grid; grid-template-columns:1fr 1fr;
  gap:60px; align-items:center;
  max-width:var(--max); margin:0 auto;
}
.hero-eyebrow {
  display:flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:10px; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--text-3);
  margin-bottom:26px;
}
.hero-eyebrow::before { content:''; width:24px; height:1px; background:var(--accent); }
.hero-eyebrow span { color:var(--accent); }
.hero-h1 {
  font-family:var(--display); font-weight:900;
  font-size:clamp(46px,5.8vw,82px);
  line-height:.95; letter-spacing:-.055em;
  color:var(--text); margin-bottom:28px;
}
.hero-h1 .ha { color:var(--accent); display:block; }
.hero-h1 .hd { color:var(--text-2); }
.h-rule { width:48px; height:1px; background:var(--border); margin-bottom:22px; }
.hero-copy {
  font-family:var(--body); font-weight:300; font-size:17px;
  line-height:1.75; color:var(--text-2); max-width:480px; margin-bottom:38px;
}
.hero-acts { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.hero-proof {
  margin-top:36px; padding-top:28px;
  border-top:1px solid var(--border-dim);
  display:flex; gap:28px; flex-wrap:wrap;
}
.pf-num {
  font-family:var(--display); font-weight:900;
  font-size:26px; letter-spacing:-.04em; color:var(--text); line-height:1; margin-bottom:3px;
}
.pf-num .pa { color:var(--accent); }
.pf-lbl {
  font-family:var(--mono); font-size:9px; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase; color:var(--text-3);
}
/* hero left children stagger */
.hero-left > * { animation: fadeUp .6s ease both; }
.hero-eyebrow { animation-delay:.04s; }
.hero-h1      { animation-delay:.1s; }
.h-rule       { animation-delay:.16s; }
.hero-copy    { animation-delay:.2s; }
.hero-acts    { animation-delay:.26s; }
.hero-proof   { animation-delay:.32s; }
.terminal-panel { animation: fadeUp .7s .18s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }

/* ── terminal panel (hero right) ── */
.terminal-panel { border:1px solid var(--border); background:var(--surface); position:relative; overflow:hidden; }
.terminal-panel::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 55% at 50% 0%,rgba(245,197,66,.04),transparent);
  pointer-events:none;
}
.t-bar {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 16px; border-bottom:1px solid var(--border); background:var(--surface-2);
}
.t-title { font-family:var(--mono); font-size:10px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); }
.t-clock { font-family:var(--mono); font-size:9px; letter-spacing:.08em; color:var(--accent); }

/* alert feed */
.a-feed { padding:14px 20px; border-bottom:1px solid var(--border-dim); }
.a-item {
  display:flex; align-items:flex-start; gap:9px; padding:5px 0;
  font-family:var(--mono); font-size:10px; line-height:1.45; color:var(--text-2);
  border-bottom:1px solid var(--border-dim);
  opacity:0; transform:translateX(-8px);
  transition:opacity .35s ease, transform .35s ease;
}
.a-item.in { opacity:1; transform:translateX(0); }
.a-item:last-child { border-bottom:none; }
.a-sev { width:6px; height:6px; border-radius:50%; flex-shrink:0; margin-top:3px; }
.sc { background:var(--red); box-shadow:0 0 6px rgba(255,77,106,.5); }
.sw { background:var(--amber); }
.si { background:var(--accent); }
.a-time { color:var(--text-3); flex-shrink:0; }

/* t-footer */
.t-footer {
  display:flex; align-items:center; flex-wrap:wrap; gap:14px;
  padding:9px 20px; border-top:1px solid var(--border-dim);
  background:var(--surface-2);
}
.t-foot-item {
  font-family:var(--mono); font-size:9px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--text-3);
  display:flex; align-items:center; gap:6px;
}
.t-foot-item strong { color:var(--text-2); font-weight:600; }

/* sparkline */
.spark-wrap { padding:14px 20px 16px; border-bottom:1px solid var(--border-dim); }
.spark-lbl {
  font-family:var(--mono); font-size:9px; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--text-3);
  margin-bottom:10px; display:flex; align-items:center; gap:8px;
}
.spark-lbl::after { content:''; flex:1; height:1px; background:var(--border-dim); }

/* scroll hint */
.scroll-hint {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--mono); font-size:9px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--text-3); z-index:5;
}
.scroll-line { width:1px; height:40px; background:linear-gradient(to bottom,var(--border),transparent); animation:scrollDrop 2s ease-in-out infinite; }
@keyframes scrollDrop { 0%{transform:scaleY(0);transform-origin:top;opacity:0} 40%{transform:scaleY(1);transform-origin:top;opacity:1} 80%{transform:scaleY(1);transform-origin:bottom;opacity:1} 100%{transform:scaleY(0);transform-origin:bottom;opacity:0} }

/* ════════════════════════════════════════════
   TRUST STRIP
════════════════════════════════════════════ */
#trust { position:relative; z-index:2; }
.trust-grid { background:var(--border-dim); border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim); }
.t-cell {
  background:var(--surface); padding:24px var(--pad);
  transition:background .2s;
}
.t-cell:hover { background:var(--surface-2); }
.t-big {
  font-family:var(--display); font-weight:900;
  font-size:clamp(26px,2.8vw,38px); letter-spacing:-.05em;
  color:var(--text); line-height:1; margin-bottom:5px;
}
.t-big .ta { color:var(--accent); }
.t-desc {
  font-family:var(--mono); font-size:9px; font-weight:500;
  letter-spacing:.1em; text-transform:uppercase; color:var(--text-3);
  line-height:1.6;
}

/* ════════════════════════════════════════════
   PLATFORM SECTION
════════════════════════════════════════════ */
#platform { padding:100px 0; }
.plat-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border-dim);
  border:1px solid var(--border-dim);
  margin-top:56px;
}
.plat-card {
  background:var(--surface); padding:36px 32px;
  border:none; transition:background .22s; cursor:pointer;
  position:relative; overflow:hidden;
}
.plat-card::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:2px; background:var(--accent);
  transition:width .35s ease;
}
.plat-card:hover { background:var(--surface-2); }
.plat-card:hover::after { width:100%; }
.plat-card.featured {
  background:var(--surface-2);
  border-left:2px solid var(--accent);
}
.plat-tag {
  font-family:var(--mono); font-size:9px; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase;
  padding:3px 9px; margin-bottom:18px; display:inline-block;
}
.pt-ehr  { background:rgba(26,96,144,.25); color:#60A5FA; }
.pt-ai   { background:var(--accent-dim); color:var(--accent); }
.pt-tele { background:rgba(245,166,35,.12); color:#FBB024; }
.pt-sec  { background:rgba(255,77,106,.1); color:#FF6B85; }
.pt-data { background:rgba(139,92,246,.12); color:#A78BFA; }
.plat-name {
  font-family:var(--display); font-weight:800;
  font-size:20px; letter-spacing:-.035em; color:var(--text);
  margin-bottom:10px;
}
.plat-desc { font-family:var(--body); font-weight:300; font-size:14px; color:var(--text-2); line-height:1.7; margin-bottom:20px; }
.plat-link {
  font-family:var(--mono); font-size:10px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--accent);
  text-decoration:none; display:inline-flex; align-items:center; gap:7px;
  transition:gap .18s;
}
.plat-link:hover { gap:12px; }

/* ════════════════════════════════════════════
   BHAIRAV AI SECTION
════════════════════════════════════════════ */
#ai { padding:100px 0; background:var(--surface); border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim); }
/* BHAIRAV banner */
.bh-banner {
  border:1px solid rgba(245,197,66,.2);
  background:linear-gradient(135deg,rgba(245,197,66,.04),rgba(245,197,66,.01));
  padding:36px 40px;
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  margin-bottom:64px; position:relative; overflow:hidden;
}
.bh-banner::before {
  content:'BHAIRAV'; position:absolute; right:-20px; top:50%; transform:translateY(-50%);
  font-family:var(--display); font-weight:900; font-size:120px; letter-spacing:-.06em;
  color:transparent; -webkit-text-stroke:1px rgba(245,197,66,.04);
  pointer-events:none; user-select:none;
}
.bh-badge {
  font-family:var(--mono); font-size:9px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  border:1px solid rgba(245,197,66,.3); padding:4px 12px;
  color:var(--accent); background:var(--accent-dim);
  display:inline-flex; align-items:center; gap:7px; margin-bottom:12px;
}
.bh-h { font-family:var(--display); font-weight:900; font-size:clamp(22px,3vw,34px); letter-spacing:-.05em; color:var(--text); margin-bottom:8px; }
.bh-p { font-family:var(--body); font-weight:300; font-size:15px; color:var(--text-2); max-width:520px; line-height:1.75; }
.bh-acts { display:flex; gap:12px; align-items:center; flex-shrink:0; }

/* AI mock terminal */
.ai-mock {
  border:1px solid var(--border); background:var(--base);
  position:relative; overflow:hidden;
}
.ai-mock::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 50% at 50% 0%, rgba(245,197,66,.025), transparent);
  pointer-events:none;
}
/* type lines */
.tl {
  display:block; overflow:hidden; white-space:nowrap; width:0;
  font-family:var(--mono); font-size:12px; color:var(--text-2); line-height:1.8;
}
.tl.typed { animation:typeReveal var(--d,1.2s) steps(var(--s,32),end) forwards; }
@keyframes typeReveal { from{width:0} to{width:100%} }
.tcursor { display:inline-block; width:2px; height:13px; background:var(--accent); margin-left:2px; vertical-align:middle; animation:cursorBlink .8s step-end infinite; }
@keyframes cursorBlink { 0%,100%{opacity:1} 50%{opacity:0} }
/* diag tags */
.dtag {
  display:inline-block; font-family:var(--mono); font-size:10px; font-weight:600;
  letter-spacing:.06em; padding:4px 11px;
  border:1px solid var(--border); color:var(--text-2);
  opacity:0; transform:translateY(5px);
  transition:opacity .3s ease, transform .3s ease;
  margin:3px 2px;
}
.dtag.in { opacity:1; transform:translateY(0); }
/* risk meter */
.risk-bar-track { height:6px; background:var(--border-dim); margin-top:12px; }
.risk-bar-fill { height:6px; width:0; background:linear-gradient(90deg,var(--accent),#D89400); transition:width 1.1s ease; }
.risk-bar-fill.full { width:68%; }
/* next step lines */
.ns-line { height:6px; background:var(--border-dim); margin-top:8px; width:0!important; transition:width .6s ease; }
.ns-line.go { width:84%!important; }
.ns-line.go.w2 { width:62%!important; }

/* AI capabilities mini cards */
.ai-caps { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--border-dim); margin-top:36px; }
.ai-cap {
  background:var(--surface); padding:20px 22px;
  transition:background .2s;
}
.ai-cap:hover { background:var(--surface-2); }
.ai-cap-icon { font-size:18px; margin-bottom:10px; }
.ai-cap-name { font-family:var(--display); font-weight:800; font-size:15px; letter-spacing:-.03em; color:var(--text); margin-bottom:5px; }
.ai-cap-desc { font-family:var(--body); font-weight:300; font-size:13px; color:var(--text-2); line-height:1.6; }

/* ════════════════════════════════════════════
   SOLUTIONS (AUDIENCE)
════════════════════════════════════════════ */
#solutions { padding:100px 0; }
.aud-tabs { display:flex; border-bottom:1px solid var(--border-dim); margin-bottom:48px; }
.aud-tab {
  font-family:var(--mono); font-size:10px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-3); background:transparent; border:none;
  padding:12px 22px; cursor:pointer;
  border-bottom:2px solid transparent; margin-bottom:-1px;
  transition:color .18s, border-color .18s;
}
.aud-tab:hover { color:var(--text-2); }
.aud-tab.on { color:var(--accent); border-bottom-color:var(--accent); }
.aud-pane { display:none; }
.aud-pane.on {
  display:grid; grid-template-columns:1fr 1fr;
  gap:64px; align-items:center;
}
.aud-h { font-family:var(--display); font-weight:900; font-size:clamp(26px,3.2vw,42px); letter-spacing:-.05em; color:var(--text); margin-bottom:16px; line-height:1.05; }
.aud-p { font-family:var(--body); font-weight:300; font-size:16px; color:var(--text-2); line-height:1.8; margin-bottom:24px; }
.feat-list { list-style:none; margin-bottom:32px; }
.feat-list li {
  font-family:var(--body); font-size:14px; color:var(--text-2);
  padding:9px 0; border-bottom:1px solid var(--border-dim);
  display:flex; align-items:flex-start; gap:10px; line-height:1.5;
}
.feat-list li:last-child { border-bottom:none; }
.feat-list li::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--accent); flex-shrink:0; margin-top:5px; }
/* audience code panel */
.aud-code {
  border:1px solid var(--border); background:var(--base); padding:0; overflow:hidden;
}
.aud-code .ac-bar {
  padding:9px 14px; border-bottom:1px solid var(--border); background:var(--surface-2);
  font-family:var(--mono); font-size:10px; color:var(--text-3); letter-spacing:.08em;
}
.aud-code .ac-body { padding:20px; font-family:var(--mono); font-size:12px; line-height:2; }
.ck { color:#60A5FA; } .cv { color:var(--accent); } .cs { color:#FBB024; } .cm { color:var(--text-3); } .cn { color:var(--text-2); }

/* ════════════════════════════════════════════
   DATA PIPELINE SECTION
════════════════════════════════════════════ */
#data { padding:100px 0; background:var(--surface); border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim); }
.pipe-wrap { position:relative; }
.pipe-dot {
  position:absolute; left:27px; width:10px; height:10px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 10px rgba(245,197,66,.6);
  z-index:10; transition:top .42s cubic-bezier(.4,0,.2,1), opacity .3s;
  pointer-events:none;
}
.pipe-step {
  display:flex; align-items:center; gap:14px;
  border:1px solid var(--border-dim); padding:16px 20px;
  margin-bottom:1px; background:var(--base);
  position:relative; overflow:hidden; transition:background .22s;
  cursor:default;
}
.pipe-step::after {
  content:''; position:absolute; left:0; bottom:0;
  height:2px; width:0; background:linear-gradient(90deg,var(--accent),transparent);
  transition:width .45s ease;
}
.pipe-step.ps-active { background:var(--surface-2); }
.pipe-step.ps-active::after { width:100%; }
.pipe-step.ps-done { background:var(--surface); }
.pipe-step.ps-done::after { width:100%; opacity:.25; }
.pipe-icon {
  width:40px; height:40px; border:1px solid var(--border); flex-shrink:0;
  display:grid; place-items:center; color:var(--text-3); font-size:16px;
  transition:background .2s, color .2s, border-color .2s;
}
.pipe-step.ps-active .pipe-icon { background:var(--accent-dim); color:var(--accent); border-color:rgba(245,197,66,.3); }
.pipe-step.ps-done .pipe-icon { border-color:var(--border-dim); color:var(--text-3); }
.pipe-name { font-family:var(--display); font-weight:700; font-size:15px; letter-spacing:-.03em; color:var(--text); }
.pipe-meta { font-family:var(--mono); font-size:11px; color:var(--text-3); }

/* ════════════════════════════════════════════
   PROOF / CASE STUDIES
════════════════════════════════════════════ */
#proof { padding:100px 0; }
.case-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border-dim); margin-top:56px; }
.case-card {
  background:var(--surface); padding:32px 28px;
  transition:background .22s; position:relative; overflow:hidden;
}
.case-card:hover { background:var(--surface-2); }
.case-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:transparent; transition:background .3s;
}
.case-card:hover::before { background:var(--accent); }
.case-geo {
  font-family:var(--mono); font-size:9px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase; color:var(--accent);
  margin-bottom:14px; display:flex; align-items:center; gap:8px;
}
.case-geo::before { content:'◉'; font-size:7px; }
.case-h { font-family:var(--display); font-weight:800; font-size:18px; letter-spacing:-.035em; color:var(--text); margin-bottom:10px; line-height:1.25; }
.case-p { font-family:var(--body); font-weight:300; font-size:13px; color:var(--text-2); line-height:1.7; }
.case-stat { margin-top:22px; padding-top:18px; border-top:1px solid var(--border-dim); }
.case-big { font-family:var(--display); font-weight:900; font-size:clamp(28px,3vw,38px); letter-spacing:-.05em; color:var(--text); line-height:1; margin-bottom:4px; }
.case-big .ca { color:var(--accent); }
.case-desc { font-family:var(--mono); font-size:10px; color:var(--text-3); letter-spacing:.06em; }

/* ════════════════════════════════════════════
   GOVERNMENT SECTION
════════════════════════════════════════════ */
#govt { padding:100px 0; background:var(--surface); border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim); }
.govt-visual {
  border:1px solid var(--border); background:var(--base);
  position:relative; min-height:380px; padding:24px; overflow:hidden;
}
.govt-blob {
  position:absolute; inset:60px; border-radius:45% 55% 50% 45%;
  border:1px solid rgba(245,197,66,.15);
  background:radial-gradient(circle,rgba(245,197,66,.05),transparent 65%);
  animation:blobPulse 5s ease-in-out infinite;
}
@keyframes blobPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.04)} }
.govt-card {
  position:absolute; border:1px solid var(--border);
  background:rgba(10,22,40,.85); backdrop-filter:blur(8px);
  padding:12px 16px; font-family:var(--mono); font-size:11px;
  color:var(--text-2); transition:.22s ease;
}
.govt-card:hover { background:var(--surface-2); border-color:rgba(245,197,66,.3); }
.gc1 { left:24px; top:36px; width:180px; }
.gc2 { right:32px; top:72px; width:200px; }
.gc3 { left:56px; bottom:52px; width:210px; }
.gc4 { right:40px; bottom:40px; width:195px; }
.gc-alert {
  display:inline-flex; align-items:center; gap:6px;
  border-radius:2px; background:rgba(255,77,106,.12); color:var(--red);
  border:1px solid rgba(255,77,106,.25); padding:3px 8px;
  font-size:9px; letter-spacing:.08em; text-transform:uppercase; margin-bottom:6px;
}
.gc-info { color:var(--accent); margin-right:5px; }

/* ════════════════════════════════════════════
   STANDARDS / TRUST ARCHITECTURE
════════════════════════════════════════════ */
#standards { padding:80px 0; border-top:1px solid var(--border-dim); }
.std-grid { display:flex; flex-wrap:wrap; gap:8px; margin-top:36px; }
.std-tag {
  font-family:var(--mono); font-size:11px; font-weight:600;
  letter-spacing:.06em; padding:8px 14px;
  border:1px solid var(--border); color:var(--text-2);
  background:var(--surface); transition:.18s ease; cursor:default;
}
.std-tag:hover { border-color:rgba(245,197,66,.35); color:var(--accent); background:var(--accent-dim); }

/* ════════════════════════════════════════════
   WHY PLUS91
════════════════════════════════════════════ */
#why { padding:100px 0; background:var(--surface); border-top:1px solid var(--border-dim); border-bottom:1px solid var(--border-dim); }
.why-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--border-dim); margin-top:56px; }
.why-card {
  background:var(--surface); padding:32px 24px;
  transition:background .2s; position:relative; overflow:hidden;
}
.why-card:hover { background:var(--surface-2); }
.why-card::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:2px; background:var(--accent); transition:width .35s;
}
.why-card:hover::after { width:100%; }
.why-n {
  font-family:var(--mono); font-size:11px; font-weight:600;
  letter-spacing:.1em; color:var(--text-3); margin-bottom:16px;
}
.why-h { font-family:var(--display); font-weight:800; font-size:16px; letter-spacing:-.03em; color:var(--text); margin-bottom:10px; }
.why-p { font-family:var(--body); font-weight:300; font-size:13px; color:var(--text-2); line-height:1.65; }

/* ════════════════════════════════════════════
   CTA SECTION
════════════════════════════════════════════ */
#cta { padding:120px var(--pad); text-align:center; position:relative; overflow:hidden; }
#cta::before {
  content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:700px; height:700px;
  background:radial-gradient(circle, rgba(245,197,66,.06) 0%, transparent 65%);
  pointer-events:none;
}
#cta::after {
  content:''; position:absolute; inset:0;
  background-image:repeating-linear-gradient(
    90deg, transparent, transparent 119px,
    var(--border-dim) 119px, var(--border-dim) 120px
  );
  pointer-events:none; opacity:.4;
}
.cta-inner { position:relative; z-index:2; max-width:680px; margin:0 auto; }
.cta-h { font-family:var(--display); font-weight:900; font-size:clamp(30px,4vw,54px); letter-spacing:-.055em; line-height:1.04; color:var(--text); margin-bottom:18px; }
.cta-h .ca { color:var(--accent); }
.cta-p { font-family:var(--body); font-weight:300; font-size:17px; color:var(--text-2); line-height:1.8; margin-bottom:36px; }
.cta-acts { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════ */
footer {
  background:var(--surface); border-top:1px solid var(--border-dim);
  padding:64px var(--pad) 32px;
}
.foot-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.foot-brand { font-family:var(--display); font-weight:800; font-size:19px; letter-spacing:-.04em; color:var(--text); margin-bottom:10px; }
.foot-brand span { color:var(--accent); }
.foot-tag { font-family:var(--body); font-weight:300; font-size:14px; color:var(--text-2); line-height:1.7; }
.foot-since { font-family:var(--mono); font-size:10px; color:var(--text-3); letter-spacing:.08em; margin-top:14px; }
.foot-col h6 { font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--text-3); margin-bottom:16px; }
.foot-col a { display:block; font-family:var(--body); font-size:14px; color:var(--text-2); text-decoration:none; padding:5px 0; transition:color .15s, padding-left .15s; }
.foot-col a:hover { color:var(--text); padding-left:4px; }
.foot-col a.ac { color:var(--accent); }
.foot-bottom { border-top:1px solid var(--border-dim); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.foot-copy { font-family:var(--mono); font-size:10px; color:var(--text-3); letter-spacing:.04em; }
.foot-social { display:flex; gap:20px; }
.foot-social a { font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); text-decoration:none; transition:color .15s; }
.foot-social a:hover { color:var(--accent); }

/* ════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════ */
@media(max-width:1024px) {
  :root { --pad:28px; }
  .hero-inner,.g2,.aud-pane.on,.foot-grid { grid-template-columns:1fr; gap:40px; }
  .hero-bg-num { font-size:120px; right:-8px; top:auto; bottom:0; transform:none; }
  .plat-grid { grid-template-columns:1fr 1fr; }
  .case-grid { grid-template-columns:1fr 1fr; }
  .why-grid { grid-template-columns:repeat(3,1fr); }
  .g5 { grid-template-columns:repeat(3,1fr); }
  .bh-banner { flex-direction:column; }
  .ai-caps { grid-template-columns:1fr; }
}
@media(max-width:640px) {
  :root { --pad:20px; }
  #nav .nav-links { display:none; }
  .status-pill { display:none; }
  .plat-grid,.case-grid,.why-grid,.g5 { grid-template-columns:1fr; }
  .aud-tabs { overflow-x:auto; }
  .hero { padding:90px var(--pad) 48px; }
  .g4 { grid-template-columns:1fr 1fr; }
}
@media(prefers-reduced-motion:reduce) { *,*::before,*::after { animation:none!important; transition:none!important; } }


/* Plus91 blue/yellow refinements layered over the dashboard concept */
:root{
  --plus-blue:#0070C0;
  --plus-blue-2:#1595D3;
  --plus-yellow:#F5C542;
  --plus-orange:#F5A623;
  --signal-green:#21D07A;
}
.nav-mark{border-color:var(--plus-blue-2);color:var(--plus-blue-2)}
.nav-name span,.foot-brand span{color:var(--plus-yellow)}
.btn-p{background:linear-gradient(135deg,var(--plus-yellow),var(--plus-orange));color:#060D1A!important;}
.btn-p:hover{color:#060D1A!important;}
.status-pill{color:var(--plus-yellow);border-color:rgba(245,197,66,.26);background:rgba(245,197,66,.08)}
.sdot{background:var(--plus-yellow);box-shadow:0 0 0 6px rgba(245,197,66,.13),0 0 20px rgba(245,197,66,.55)}
.hero-eyebrow span,.sec-label,.plat-link,.aud-tab.on,.case-geo,.std-tag:hover,.foot-col a.ac,.foot-social a:hover{color:var(--plus-yellow)}
.hero-eyebrow::before,.sec-label::before,.plat-card::after,.aud-tab.on,.pipe-dot,.pipe-step::after,.case-card:hover::before,.why-card::after{background:var(--plus-yellow)}
.nav-mark,.pt-ehr{border-color:var(--plus-blue-2)}
.pt-ehr,.ck{color:var(--plus-blue-2)}
.route{background:linear-gradient(90deg,transparent,var(--plus-blue-2),var(--plus-yellow),transparent)}
.map-node i,.cv{color:var(--plus-blue-2)}
.core-node strong,.c1 strong,.hero-h1 .ha,.t-big .ta,.pf-num .pa,.sec-title .a,.cta-h .ca,.case-big .ca{color:var(--plus-yellow)}
.core-node{border-color:rgba(245,197,66,.35);background:radial-gradient(circle at 50% 0%,rgba(245,197,66,.15),rgba(0,112,192,.18)),rgba(10,22,40,.96)}
.sc{background:#FF4D6A;box-shadow:0 0 6px rgba(255,77,106,.5)}
.sw{background:var(--plus-yellow)}
.si{background:var(--plus-blue-2)}
.bg{background:rgba(245,197,66,.12);color:var(--plus-yellow)}
.ba{background:rgba(245,166,35,.12);color:var(--plus-orange)}
.br{background:rgba(255,77,106,.12);color:#FF4D6A}
.t-clock,.panel-meta,.mval.a{color:var(--plus-yellow)}
#hero::after,#cta::before{background:radial-gradient(circle,rgba(0,112,192,.08) 0%,rgba(245,197,66,.055) 38%,transparent 65%)}
.hero-bg-num{ -webkit-text-stroke-color: rgba(245,197,66,.09); }

/* ════════════════════════════════════════════
   CONTACT PAGE
════════════════════════════════════════════ */
.contact-page {
  position: relative;
  z-index: 1;
  background: var(--base);
  overflow: hidden;
}
.contact-page::before {
  content:'';
  position: fixed;
  inset: 0;
  background-image: repeating-linear-gradient(
    90deg,
    transparent,
    transparent 119px,
    var(--border-dim) 119px,
    var(--border-dim) 120px
  );
  opacity: .38;
  pointer-events: none;
}
.contact-hero {
  position: relative;
  padding: 132px 0 80px;
  border-bottom: 1px solid var(--border-dim);
}
.contact-hero::after {
  content:'CONTACT';
  position:absolute;
  right:-24px;
  top:120px;
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(90px,14vw,220px);
  letter-spacing:-.07em;
  line-height:1;
  color:transparent;
  -webkit-text-stroke:1px rgba(245,197,66,.045);
  pointer-events:none;
  user-select:none;
}
.contact-hero-grid,
.contact-form-grid {
  display:grid;
  grid-template-columns: 1fr 0.92fr;
  gap:64px;
  align-items:center;
  position:relative;
  z-index:2;
}
.contact-title {
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-.06em;
  color:var(--text);
  max-width:760px;
  margin:0 0 24px;
}
.contact-lead {
  font-family:var(--body);
  font-weight:300;
  color:var(--text-2);
  font-size:18px;
  line-height:1.8;
  max-width:640px;
  margin-bottom:36px;
}
.contact-quick-row {
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.contact-status-panel {
  min-height:360px;
}
.contact-routing-readout {
  position:relative;
  z-index:1;
}
.contact-routes,
.contact-form-section {
  position:relative;
  padding:96px 0;
}
.contact-form-section {
  background:var(--surface);
  border-top:1px solid var(--border-dim);
  border-bottom:1px solid var(--border-dim);
}
.contact-route-grid {
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:1px;
  background:var(--border-dim);
  border:1px solid var(--border-dim);
  margin-top:56px;
}
.contact-route-card {
  display:block;
  min-height:230px;
  background:var(--surface);
  padding:28px 24px;
  text-decoration:none;
  position:relative;
  overflow:hidden;
  transition:background .22s ease, transform .22s ease;
}
.contact-route-card::before {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 70% 45% at 50% 0%, rgba(245,197,66,.035), transparent);
  opacity:0;
  transition:opacity .22s ease;
}
.contact-route-card::after {
  content:'';
  position:absolute;
  left:0;
  bottom:0;
  width:0;
  height:2px;
  background:var(--accent);
  transition:width .35s ease;
}
.contact-route-card:hover {
  background:var(--surface-2);
}
.contact-route-card:hover::before { opacity:1; }
.contact-route-card:hover::after { width:100%; }
.route-code {
  display:inline-flex;
  font-family:var(--mono);
  font-size:9px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  border:1px solid rgba(245,197,66,.24);
  background:var(--accent-dim);
  padding:4px 9px;
  margin-bottom:18px;
}
.contact-route-card h3 {
  font-family:var(--display);
  font-weight:800;
  font-size:18px;
  line-height:1.22;
  letter-spacing:-.035em;
  color:var(--text);
  margin:0 0 10px;
  position:relative;
  z-index:1;
}
.contact-route-card p {
  font-family:var(--body);
  font-weight:300;
  font-size:14px;
  line-height:1.7;
  color:var(--text-2);
  margin:0;
  position:relative;
  z-index:1;
}
.contact-info-stack {
  margin-top:42px;
  border-top:1px solid var(--border-dim);
  max-width:560px;
}
.contact-info-item {
  display:flex;
  justify-content:space-between;
  gap:24px;
  padding:16px 0;
  border-bottom:1px solid var(--border-dim);
  color:var(--text-2);
}
.info-label {
  font-family:var(--mono);
  font-size:10px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-3);
  flex-shrink:0;
}
.contact-info-item a,
.contact-info-item strong {
  color:var(--text);
  text-decoration:none;
  font-family:var(--body);
  font-weight:700;
  text-align:right;
}
.contact-form-panel {
  align-self:start;
}
.contact-form-slot {
  padding:28px;
  position:relative;
  z-index:1;
}
.contact-form-content :is(input, textarea, select) {
  width:100%;
  background:var(--base);
  border:1px solid var(--border);
  color:var(--text);
  padding:12px 14px;
  font-family:var(--body);
  margin-bottom:14px;
}
.contact-form-content :is(input, textarea, select):focus {
  outline:none;
  border-color:rgba(245,197,66,.55);
  box-shadow:0 0 0 3px rgba(245,197,66,.08);
}
.contact-form-content :is(label) {
  color:var(--text-2);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.contact-form-content :is(button, input[type="submit"]) {
  font-family:var(--mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--base);
  background:var(--accent);
  border:0;
  padding:13px 26px;
  width:auto;
  cursor:pointer;
}
.contact-form-fallback {
  border:1px dashed var(--border);
  background:rgba(6,13,26,.55);
  padding:30px;
}
.fallback-kicker {
  font-family:var(--mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:12px;
}
.contact-form-fallback h3 {
  font-family:var(--display);
  font-weight:800;
  letter-spacing:-.04em;
  margin:0 0 10px;
  color:var(--text);
}
.contact-form-fallback p {
  color:var(--text-2);
  font-family:var(--body);
  font-weight:300;
  line-height:1.7;
  margin-bottom:22px;
}

@media(max-width:1024px) {
  .contact-hero-grid,
  .contact-form-grid { grid-template-columns:1fr; gap:40px; }
  .contact-route-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:640px) {
  .contact-hero { padding:104px 0 60px; }
  .contact-routes,
  .contact-form-section { padding:72px 0; }
  .contact-route-grid { grid-template-columns:1fr; }
  .contact-info-item { display:block; }
  .contact-info-item a,
  .contact-info-item strong { display:block; text-align:left; margin-top:6px; }
}

/* Final homepage hero headline stack */
.hero-h1-final {
  margin-bottom: 12px;
}
.hero-ambition {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(25px, 2.65vw, 39px);
  line-height: 1.1;
  letter-spacing: -0.05em;
  color: var(--text-2);
  margin: 0 0 34px;
}
.hero-subline {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.055em;
  color: var(--text);
  margin-bottom: 26px;
}
.hero-subline span { color: var(--accent); }

/* Expanded footer sitemap */
.foot-grid {
  grid-template-columns: 1.45fr repeat(5, minmax(0, 1fr));
  gap: 34px;
}
@media(max-width:1180px) {
  .foot-grid { grid-template-columns: repeat(3, 1fr); }
}
@media(max-width:640px) {
  .foot-grid { grid-template-columns: 1fr; }
}
