/* ================================================================
   PURAHU+ — NAVIGATION SYSTEM (SINGLE SOURCE OF TRUTH)
   One nav. One set of rules. No duplicates. No overrides.
   ================================================================ */
/* ── GLOBAL LINK RESET — bulletproof, no blue/purple EVER ──────── */
/* Use currentColor so links always match their context text color  */
a, a:link, a:visited, a:hover, a:active, a:focus {
  color: currentColor !important;
  text-decoration: none !important;
}
/* Ensure body always has an explicit color for links to inherit    */
html { color: #F5F0E8; }
body { color: rgba(255,255,255,0.75); }


/* ── Variables (if not already defined) ─────────────────────── */

/* ================================================================
   NUCLEAR LINK RESET — no blue/purple ANYWHERE on the platform
   This covers every <a> tag regardless of class or inline style
   ================================================================ */
*, *::before, *::after { box-sizing: border-box; }

a                 { color: inherit !important; text-decoration: none !important; }
a:link            { color: inherit !important; text-decoration: none !important; }
a:visited         { color: inherit !important; text-decoration: none !important; }
a:hover           { text-decoration: none !important; }
a:active          { color: inherit !important; text-decoration: none !important; }
a:focus           { outline: none; }

/* ── Ensure nav drawer never shows unless .open ──────────────── */



/* ── Prevent any overflow ghost content ─────────────────────── */
body { overflow-x: hidden; }

:root {
  --gold:        #D4A843;
  --gold-light:  #F0C85A;
  --gold-dim:    rgba(212,168,67,0.12);
  --dark:        #0D0603;
  --dark2:       #1A0A06;
  --white:       #F5F0E8;
  --border:      rgba(212,168,67,0.2);
  --nav-h:       58px;
}

/* ── Base reset ───────────────────────────────────────────────── */
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; background:var(--dark); }
body {
  padding-top: var(--nav-h);
  font-family: 'Barlow', sans-serif;
  background: var(--dark);
  color: var(--white);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color:inherit; text-decoration:none; }

/* ── Navigation ───────────────────────────────────────────────── */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-h);
  background: rgba(13,6,3,0.97);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

nav a, nav a:link, nav a:visited, nav a:active, nav a:hover {
  color: inherit;
  text-decoration: none;
}

/* ── Brand logo ───────────────────────────────────────────────── */
.nav-brand {
  display: flex;
  align-items: center;
  gap: 9px;
  text-decoration: none;
  flex-shrink: 0;
}

.nav-brand img, nav > a > img, nav img {
  width: 32px;
  height: 32px;
  max-width: 32px;
  max-height: 32px;
  border-radius: 50%;
  object-fit: cover;
  border: 1.5px solid rgba(212,168,67,0.35);
  display: block;
  flex-shrink: 0;
}

.nav-brand span {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: 0.88rem;
  letter-spacing: 2.5px;
  color: var(--gold);
  text-transform: uppercase;
  white-space: nowrap;
}

/* ── Nav links strip ──────────────────────────────────────────── */
.nav-links {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.nav-links::-webkit-scrollbar { display: none; }

/* ── Single nav link ──────────────────────────────────────────── */
.nav-link {
  display: inline-flex;
  align-items: center;
  height: var(--nav-h);
  padding: 0 13px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  text-decoration: none !important;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color 0.18s, border-color 0.18s;
  flex-shrink: 0;
}

.nav-link:hover {
  color: rgba(255,255,255,0.82);
  border-bottom-color: rgba(212,168,67,0.4);
}

.nav-link.active {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

/* ── Right side ───────────────────────────────────────────────── */
.nav-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ── CTA button ───────────────────────────────────────────────── */
.btn-nav-cta {
  display: inline-flex;
  align-items: center;
  padding: 8px 18px;
  background: var(--gold);
  color: var(--dark);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: 0.65rem;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  text-decoration: none !important;
  border-radius: 2px;
  white-space: nowrap;
  transition: background 0.18s;
  border: none;
  cursor: pointer;
}
.btn-nav-cta:hover { background: var(--gold-light); }
.btn-nav-cta.active { outline: 2px solid var(--gold); outline-offset: 2px; }

.btn-nav-outline {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  border: 1px solid rgba(212,168,67,0.35);
  color: rgba(255,255,255,0.55);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  white-space: nowrap;
  transition: all 0.18s;
}
.btn-nav-outline:hover { border-color: var(--gold); color: var(--gold); }

/* ── Mobile breakpoints ────────────────────────────────────────── */
@media (max-width: 900px) {
  nav { padding: 0 16px; }
  .nav-link { padding: 0 10px; font-size: 0.62rem; letter-spacing: 1.4px; }
  .btn-nav-cta { padding: 7px 13px; font-size: 0.62rem; }
}

@media (max-width: 640px) {
  :root { --nav-h: 52px; }
  nav { padding: 0 12px; gap: 6px; }
  .nav-brand span { display: none; }
  .nav-right { display: none; }
  .nav-brand img, nav img {
    width: 26px;
    height: 26px;
    max-width: 26px;
    max-height: 26px;
  }
  .nav-link { height: 52px; padding: 0 8px; font-size: 0.58rem; letter-spacing: 1.1px; }
}

@media (max-width: 380px) {
  nav { padding: 0 8px; gap: 4px; }
  .nav-link { padding: 0 6px; font-size: 0.55rem; letter-spacing: 0.9px; }
}


/* PURAHU+ MASTER STYLESHEET — DO NOT ADD INLINE STYLES TO HTML */

/* ── Brand / Logo ─────────────────────────────────────────────── */

/* ── Right side CTA ───────────────────────────────────────────── */

body { padding-top: 58px; }

/* ── MOBILE RESPONSIVE — Complete breakpoints ─────────────────── */

/* Tablet: hide brand text, shrink links */





/* Small mobile: even more compact */



/* ================================================================
   PURAHU+ PLATFORM — MASTER CSS
   Single source of truth for all platform styling.
   Generated: 2026-Q2
   
   RULES:
   - This is the ONLY stylesheet. No inline <style> blocks.
   - All components, pages, admin use ONLY this file.
   - Edit here. Deploy. Done.
   ================================================================ */

/* ────────────────────────────────────────────────────────────
   VARIABLES & RESET
   ──────────────────────────────────────────────────────────── */

/* ================================================================
   PURAHU PLATFORM — main.css
  
 Universal styles. All pages load ONLY this file.
   Last built: 2026-Q2
   ================================================================ */

:root{
  --gold:#D4A843;--gold-light:#F0C85A;--blue:#1A5F9E;--blue-mid:#1A3A5C;
  --red:#D94040;--green:#4CAF50;--white:#FFFFFF;
  --dark:#0F0603;--dark2:#1A0A06;--dark3:#2A1208;--dark4:#3A1A0A;
  --border:rgba(212,168,67,0.2);
}

/* HERO */

/* LIVE SIGNAL CARD */

/* SECTION STYLES */

/* WHY NOW */

/* WHAT YOU GET */

/* WHO ITS FOR */

/* RTU IN NUMBERS */

/* QUOTE */

/* PRICING STRIP */

/* CTA BLOCK */

/* FOOTER */

/* Daily RTU Feed */

/* ── Additional shared components ──────────────────────────────── */

/* ── Toast system ──────────────────────────────────────────────── */

/* ── Modal system ──────────────────────────────────────────────── */

/* ── Logo universal sizing ─────────────────────────────────────── */

/* ── Link resets ───────────────────────────────────────────────── */

/* STAT STRIP */

/* CONTROLS */

/* ALERT STRIP */

/* GRID */

/* EMPTY STATE */

/* RESULTS COUNT */

/* MAIN CHART */

/* STRESS BANDS LEGEND */

/* EVENTS TIMELINE */

/* SNAPSHOT TABLE */

/* ANALYSIS CARDS */

/* CTA */

/* HERO RIGHT — LIVE SIGNAL CARD */

/* SECTION */

/* WHO SECTION */

/* SIGNAL EXAMPLES */

/* PRICING */

/* NDA FORM */

/* QUOTE STRIP */

/* PROCESS STEPS */

/* PRICING GRID */

/* COMPARISON TABLE */

/* FAQ */

/* SIGNAL SUB */

/* CONTACT CTA */

/* LAYOUT */

/* MAIN CONTENT */

/* SIDEBAR */

/* PROGRESS BAR */

/* STEP PANELS */

/* STEP HEADINGS */

/* TIER CARDS */

/* FORM */

/* BUTTONS */

/* CONFIRMATION */

/* TIMELINE */

.tl-body h5{font-family:Barlow Condensed,sans-serif;font-size:0.82rem;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:4px;}

.tl-body p{font-size:0.8rem;color:rgba(255,255,255,0.5);line-height:1.6;}

/* KEY ENTRY PANEL */

/* CLIENT DASHBOARD */

/* SIDEBAR CONTENT */

/* DIVIDER */

/* ────────────────────────────────────────────────────────────
   COMPONENTS — Buttons, Cards, Forms
   ──────────────────────────────────────────────────────────── */

.btn-primary{padding:13px 28px;background:var(--gold);color:var(--dark);font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:0.8rem;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;border-radius:2px;}

.btn-primary:hover{background:var(--gold-light);}

.btn-secondary{padding:14px 24px;background:transparent;color:rgba(255,255,255,0.55);border:1px solid rgba(255,255,255,0.15);font-family:Barlow Condensed,sans-serif;font-weight:600;font-size:0.78rem;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:all .2s;}

.btn-secondary:hover{border-color:rgba(255,255,255,0.4);color:var(--white);}

.proof-label{font-size:0.72rem;color:rgba(255,255,255,0.35);margin-top:4px;letter-spacing:1px;text-transform:uppercase;font-family:'Barlow Condensed',sans-serif;}

.number-label{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:6px;}

.sig-label{font-size:0.65rem;letter-spacing:3px;text-transform:uppercase;
  color:rgba(91,163,217,0.8);margin-bottom:8px;}

.stat-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--border2);border:1px solid var(--border2);}

.stat-cell{padding:18px 20px;background:var(--d2);}

.stat-val{font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:600;color:var(--gold);line-height:1;}

.stat-lbl{font-size:0.62rem;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,0.35);margin-top:4px;}

.search-input{width:100%;padding:9px 14px 9px 34px;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);color:var(--white);font-size:0.82rem;
  font-family:'Barlow Condensed',sans-serif;border-radius:2px;outline:none;
  transition:border-color .2s;}

.search-input:focus{border-color:rgba(212,168,67,0.4);}

.search-input::placeholder{color:rgba(255,255,255,0.25);}

.sort-label{font-size:0.62rem;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(255,255,255,0.3);}

.sort-select{padding:7px 12px;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);color:var(--white);
  font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;border-radius:2px;
  cursor:pointer;outline:none;}

.section-label{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--gold);margin-bottom:12px;}

.ctrl-label{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:1.5px;
  text-transform:uppercase;color:rgba(255,255,255,0.45);margin-bottom:6px;}

.sl-label{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:1px;
  text-transform:uppercase;color:rgba(255,255,255,0.45);}

.ac-peak-label{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:1.5px;
  text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:4px;}

.ac-curr-label{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:1px;
  text-transform:uppercase;color:rgba(255,255,255,0.3);}

.btn-gold{background:var(--gold);color:var(--dark);}

.btn-outline{padding:14px 32px;background:transparent;color:var(--white);border:1px solid rgba(255,255,255,0.3);font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:0.82rem;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:all .2s;text-decoration:none;display:inline-block;}

.btn-gold:hover{background:var(--gold-light);}

.btn-outline:hover{border-color:var(--gold);color:var(--gold);}

.sec-label{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}

.tag-high{background:rgba(217,64,64,0.2);color:#D94040;}

.tag-med{background:rgba(212,168,67,0.2);color:var(--gold);}

.tag-fair{background:rgba(76,175,80,0.2);color:#4CAF50;}

.btn-fill{background:var(--gold);color:var(--dark);}

.btn-fill:hover{background:var(--gold-light);}

.btn-border{background:transparent;color:var(--gold);border:1px solid var(--border);}

.btn-border:hover{background:var(--gold-dim);border-color:var(--gold);}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}

.field{display:flex;flex-direction:column;gap:5px;}

.field label{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.45);}

.field input,.field select,.field textarea{padding:11px 14px;background:var(--dark3);border:1px solid rgba(212,168,67,0.25);color:var(--white);font-family:Barlow,sans-serif;font-size:0.88rem;outline:none;border-radius:2px;transition:border-color .2s;}

.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);}

.field select option{background:#1A2030;}

.field textarea{resize:vertical;min-height:80px;}

.btn-lg{padding:16px 36px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.85rem;letter-spacing:2px;text-transform:uppercase;border-radius:2px;text-decoration:none;display:inline-block;transition:all .2s;}

.btn-lg-gold{background:var(--gold);color:var(--dark);border:none;cursor:pointer;}

.btn-lg-gold:hover{background:var(--gold-light);}

.btn-lg-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,0.3);}

.btn-lg-outline:hover{border-color:var(--gold);color:var(--gold);}

.prog-label{font-family:Barlow Condensed,sans-serif;font-size:0.62rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.3);text-align:center;}

.prog-label.active{color:var(--gold);}

.prog-label.done{color:rgba(255,255,255,0.5);}

.tier-opt.selected{border-color:var(--gold);background:rgba(212,168,67,0.06);}

.tier-opt.selected::before{content:'✓';position:absolute;top:12px;right:14px;width:22px;height:22px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:700;color:var(--dark);line-height:22px;text-align:center;}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}

.field input::placeholder{color:rgba(255,255,255,0.25);}

.field-note{font-size:0.72rem;color:rgba(255,255,255,0.3);margin-top:3px;}

.btn-row{display:flex;gap:12px;align-items:center;margin-top:28px;flex-wrap:wrap;}

.btn-note{font-size:0.75rem;color:rgba(255,255,255,0.3);line-height:1.5;}

.status-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite;}

.status-label{font-family:Barlow Condensed,sans-serif;font-size:0.7rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);}

.key-input-row{display:flex;gap:10px;}

.key-input{flex:1;padding:12px 14px;background:var(--dark3);border:1px solid rgba(212,168,67,0.25);color:var(--white);font-family:Barlow,monospace;font-size:0.85rem;outline:none;border-radius:2px;letter-spacing:1px;}

.key-input:focus{border-color:var(--gold);}

.dash-stat-label{font-size:0.7rem;color:rgba(255,255,255,0.4);margin-top:4px;letter-spacing:1px;text-transform:uppercase;font-family:Barlow Condensed,sans-serif;}

.sidebar-label{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}

.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1px;border:1px solid var(--border);margin-bottom:28px;}

.stat-block{background:var(--dark);padding:32px 24px;text-align:center;}

.stat-label{font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:5px;font-family:Barlow Condensed,sans-serif;}

.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin:40px 0;}

.card{background:rgba(255,255,255,0.03);border:1px solid rgba(212,168,67,0.15);border-radius:2px;padding:28px;}

.card-title{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:12px;}

.card-body{font-size:0.9rem;color:rgba(245,240,232,0.65);line-height:1.7;}

.btn{display:inline-block;padding:14px 32px;background:var(--gold);color:var(--dark);font-family:'Barlow Condensed',sans-serif;font-size:0.75rem;letter-spacing:3px;text-decoration:none;text-transform:uppercase;font-weight:600;}

.login-field label{display:block;font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:5px;text-align:left;}

.login-input{width:100%;padding:12px 14px;background:var(--dark4);border:1px solid rgba(212,168,67,0.25);color:var(--white);font-family:Barlow,monospace;font-size:0.88rem;outline:none;border-radius:2px;}

.login-input:focus{border-color:var(--gold);}

.db-label{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.4);}

.tb-db-label{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1px;color:rgba(255,255,255,0.35);text-transform:uppercase;}

.tab-badge{position:absolute;top:8px;right:4px;min-width:16px;height:16px;background:var(--red);border-radius:8px;font-size:0.6rem;font-weight:700;color:var(--white);display:flex;align-items:center;justify-content:center;padding:0 4px;}

.stat-box{background:var(--dark3);padding:20px;text-align:center;}

.status-pill{padding:3px 10px;border-radius:2px;font-family:Barlow Condensed,sans-serif;font-size:0.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;}

.modal{background:var(--dark3);border:1px solid var(--border);border-radius:4px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;}

.modal-header{padding:22px 28px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--dark3);}

.modal-title{font-family:Barlow Condensed,sans-serif;font-size:0.85rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);}

.modal-close{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,0.06);border:none;color:rgba(255,255,255,0.5);cursor:pointer;font-size:1rem;}

.modal-body{padding:28px;}

.detail-label{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.35);min-width:120px;flex-shrink:0;padding-top:2px;}

.modal-actions{padding:20px 28px;border-top:1px solid var(--border);display:flex;gap:10px;flex-wrap:wrap;}

.fi label{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.4);}

.fi input,.fi select,.fi textarea{padding:11px 14px;background:var(--dark4);border:1px solid rgba(212,168,67,0.2);color:var(--white);font-family:Barlow,sans-serif;font-size:0.88rem;outline:none;border-radius:2px;}

.fi input:focus,.fi select:focus{border-color:var(--gold);}

.fi select option{background:#1A2030;}

.btn-sm{padding:5px 12px;font-family:Barlow Condensed,sans-serif;font-size:0.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:2px;border:1px solid;background:transparent;}

.btn-sm-gold{border-color:var(--gold);color:var(--gold);}

.btn-sm-red{border-color:var(--red);color:var(--red);}

.rev-label{font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:6px;font-family:Barlow Condensed,sans-serif;}

.geo-label{font-family:Barlow Condensed,sans-serif;font-size:0.72rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.6);width:60px;flex-shrink:0;}

.kpi-label{font-size:0.62rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-top:4px;font-family:Barlow Condensed,sans-serif;}

/* ────────────────────────────────────────────────────────────
   LAYOUT — Hero, Sections, Grid
   ──────────────────────────────────────────────────────────── */

.hero{padding:80px 24px 60px;max-width:900px;margin:0 auto;text-align:center;}

.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 0% 50%,rgba(26,95,158,0.14) 0%,transparent 60%),radial-gradient(ellipse 50% 70% at 100% 20%,rgba(212,168,67,0.07) 0%,transparent 50%);}

.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(212,168,67,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(212,168,67,0.03) 1px,transparent 1px);background-size:64px 64px;}

.hero-inner{max-width:1100px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 420px;gap:80px;align-items:center;position:relative;}

.hero-eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--gold);margin-bottom:16px;}

.hero-eyebrow::before{content:'';width:32px;height:1px;background:var(--gold);}

.hero-desc{font-size:1.05rem;color:rgba(255,255,255,0.65);line-height:1.8;max-width:540px;margin-bottom:36px;}

.hero-btns{display:flex;gap:12px;flex-wrap:wrap;}

.hero-proof{display:flex;gap:32px;margin-top:40px;flex-wrap:wrap;}

.section{max-width:900px;margin:0 auto;padding:60px 24px;}

/* FOOTER */

footer{background:#110604;border-top:1px solid var(--border);padding:36px 40px;text-align:center;}

footer p{font-size:0.75rem;color:rgba(255,255,255,0.3);line-height:1.8;}

footer strong{color:var(--gold);}

.footer-links{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-top:12px;}

.footer-links a{font-size:0.75rem;color:rgba(255,255,255,0.3);text-decoration:none;}

.footer-links a:hover{color:var(--gold);}

.sig-footer{padding:28px 40px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  color:rgba(255,255,255,0.25);font-size:0.72rem;flex-wrap:wrap;gap:12px;}

.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,5vw,4.2rem);font-weight:300;line-height:1.1;color:var(--white);margin-bottom:24px;}

.hero h1 em{color:var(--gold);font-style:italic;}

.hero-sub{font-size:1.1rem;color:rgba(245,240,232,0.6);max-width:600px;margin:0 auto;}

.wrap{max-width:1100px;margin:0 auto;padding:72px 40px;}

.section-label{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--gold);margin-bottom:12px;}

.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:300;color:var(--white);margin-bottom:8px;}

.section-title em{color:var(--gold);font-style:italic;}

.hero-content{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:80px 40px;display:grid;grid-template-columns:1.1fr 0.9fr;gap:80px;align-items:center;}

.hero-badge{display:inline-block;padding:6px 16px;border:1px solid var(--gold);font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:28px;border-radius:2px;}

.signal-footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);font-size:0.72rem;color:#AAAAAA;line-height:1.6;}

.compare-table .row-section td{background:rgba(26,95,158,0.1);font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.35);padding:10px 16px;}

.page{min-height:100vh;padding-top:66px;display:grid;grid-template-columns:1fr 420px;max-width:1200px;margin:0 auto;}

.main{padding:56px 48px 80px;border-right:1px solid var(--border2);}

.section h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:300;margin-bottom:24px;}

.section h2 em{color:var(--gold);font-style:italic;}

.section p{font-size:1rem;color:rgba(245,240,232,0.75);margin-bottom:20px;line-height:1.8;}

/* ────────────────────────────────────────────────────────────
   PLATFORM — Signals, RTU, Corridors, Tiers
   ──────────────────────────────────────────────────────────── */

.pricing-strip{grid-template-columns:1fr;}

.rtu-daily-feed{background:rgba(0,0,0,0.3);border:1px solid rgba(212,168,67,0.15);border-radius:3px;padding:24px 28px;margin:40px 0;}

.rtu-daily-header{font-family:'Barlow Condensed',sans-serif;font-size:0.58rem;letter-spacing:4px;color:#D4A843;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:8px;}

.rtu-daily-header::before{content:'';display:inline-block;width:6px;height:6px;background:#22C55E;border-radius:50%;animation:pulse 2s infinite;}

.rtu-daily-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04);}

.rtu-daily-item:last-child{border-bottom:none;}

.rtu-daily-sov{font-family:'Barlow Condensed',sans-serif;font-size:0.8rem;color:rgba(255,255,255,0.7);display:flex;align-items:center;gap:8px;}

.rtu-daily-score{font-family:'JetBrains Mono',monospace;font-size:0.75rem;font-weight:600;}

.rtu-daily-trend{font-size:0.65rem;padding:2px 8px;border-radius:2px;font-family:'Barlow Condensed',sans-serif;letter-spacing:1px;}

.sig-hero{padding:52px 40px 36px;border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,rgba(13,42,69,0.2) 0%,transparent 100%);}

.sig-hero-top{display:flex;justify-content:space-between;align-items:flex-start;
  gap:24px;flex-wrap:wrap;margin-bottom:28px;}

.sig-label{font-size:0.65rem;letter-spacing:3px;text-transform:uppercase;
  color:rgba(91,163,217,0.8);margin-bottom:8px;}

.sig-title{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;
  color:var(--white);line-height:1.1;}

.sig-title span{color:var(--gold);}

.sig-version{font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,0.3);margin-top:6px;}

.sig-grid{padding:24px 40px;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;}

.sov-card{background:var(--d2);border:1px solid var(--border2);
  border-radius:2px;padding:14px 16px;cursor:pointer;
  transition:border-color .2s,background .2s;position:relative;}

.sov-card:hover{border-color:rgba(212,168,67,0.25);background:rgba(255,255,255,0.02);}

.sov-card.critical{border-left:3px solid #FF5252;}

.sov-card.severe{border-left:3px solid #D94040;}

.sov-card.stressed{border-left:3px solid #FF9800;}

.sov-card:hover .sc-rtu-link{border-color:var(--gold);color:var(--gold);}

.sig-footer{padding:28px 40px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  color:rgba(255,255,255,0.25);font-size:0.72rem;flex-wrap:wrap;gap:12px;}

.watchlist-btn { background:transparent; border:1px solid rgba(212,168,67,0.3);
    color:#D4A843; font-family:'Barlow Condensed',sans-serif; font-size:0.58rem;
    letter-spacing:1px; padding:3px 8px; cursor:pointer; border-radius:2px; margin-left:8px; }

.watchlist-btn.added { background:rgba(212,168,67,0.1); }

.sovereign-toggles{display:flex;gap:8px;flex-wrap:wrap;}

.sov-toggle{padding:5px 12px;border-radius:20px;border:1px solid rgba(255,255,255,0.15);
  background:transparent;color:rgba(255,255,255,0.4);font-family:'Barlow Condensed',sans-serif;
  font-size:0.72rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .2s;}

.sov-toggle.active{border-color:var(--color);color:var(--color);background:rgba(255,255,255,0.05);}

.signal-card{background:var(--dark2);border:1px solid var(--border);border-radius:4px;padding:28px;}

.signal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border);}

.signal-header span{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);}

.signal-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.05);}

.signal-row:last-child{border-bottom:none;}

.sig-name{font-size:0.88rem;color:var(--white);font-weight:500;}

.sig-curr{font-size:0.72rem;color:#AAAAAA;margin-top:2px;}

.sig-val{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:700;}

.sig-index{font-size:0.72rem;color:#AAAAAA;text-align:right;margin-top:2px;}

.signal-footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);font-size:0.72rem;color:#AAAAAA;line-height:1.6;}

.signals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;border:1px solid var(--border);margin:48px 0;}

.sig-card{padding:24px;background:var(--dark2);}

.sig-tag{display:inline-block;padding:3px 10px;font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:1.5px;text-transform:uppercase;border-radius:2px;margin-bottom:14px;font-weight:700;}

.sig-headline{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--white);font-weight:600;margin-bottom:8px;line-height:1.3;}

.sig-body{font-size:0.82rem;color:rgba(255,255,255,0.6);line-height:1.6;}

.sig-meta{margin-top:14px;font-size:0.7rem;color:#AAAAAA;font-family:'Barlow Condensed',sans-serif;letter-spacing:1px;text-transform:uppercase;}

.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1px;border:1px solid var(--border);margin:48px 0;}

.price-card{background:var(--d2);padding:0;position:relative;transition:background .2s;display:flex;flex-direction:column;}

.price-card:hover{background:rgba(42,18,8,0.9);}

.price-card.featured{background:#1A2A0A;border:1px solid var(--gold);margin:-1px;}

.price-badge{position:absolute;top:0;right:0;padding:5px 14px;background:var(--gold);font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:2px;color:var(--dark);font-weight:700;text-transform:uppercase;}

.price-header{padding:28px 24px 20px;}

.price-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1rem;letter-spacing:1px;color:var(--white);text-transform:uppercase;margin-bottom:8px;}

.price-amount{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:600;color:var(--gold);line-height:1;}

.price-amount sub{font-size:1rem;color:rgba(255,255,255,0.4);}

.price-desc{font-size:0.8rem;color:rgba(255,255,255,0.45);margin-top:6px;}

.price-features{padding:0 24px 24px;list-style:none;}

.price-features li{font-size:0.85rem;color:rgba(255,255,255,0.7);padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.05);display:flex;gap:10px;align-items:flex-start;}

.price-btn{display:block;width:100%;padding:14px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.78rem;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;transition:all .2s;text-align:center;}

.signal-strip{background:var(--blue-mid);border:1px solid rgba(91,163,217,0.25);padding:40px;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center;margin:48px 0;}

.signal-strip h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;color:var(--white);margin-bottom:8px;}

.signal-strip p{font-size:0.88rem;color:rgba(255,255,255,0.6);line-height:1.6;}

.tiers{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:32px;}

.tier-opt{border:2px solid var(--border2);background:var(--dark2);padding:24px;border-radius:4px;cursor:pointer;transition:all .2s;position:relative;}

.tier-opt:hover{border-color:rgba(212,168,67,0.5);}

.tier-opt.selected{border-color:var(--gold);background:rgba(212,168,67,0.06);}

.tier-opt.selected::before{content:'✓';position:absolute;top:12px;right:14px;width:22px;height:22px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:700;color:var(--dark);line-height:22px;text-align:center;}

.tier-name{font-family:Barlow Condensed,sans-serif;font-size:0.78rem;letter-spacing:2px;text-transform:uppercase;color:var(--white);font-weight:700;margin-bottom:6px;}

.tier-price{font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:10px;}

.tier-price sub{font-size:0.9rem;color:rgba(255,255,255,0.4);}

.tier-features-list{list-style:none;}

.tier-features-list li{font-size:0.8rem;color:rgba(255,255,255,0.58);padding:4px 0;display:flex;gap:7px;}

.tier-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);padding:3px 12px;background:var(--gold);font-family:Barlow Condensed,sans-serif;font-size:0.6rem;letter-spacing:2px;font-weight:700;color:var(--dark);text-transform:uppercase;border-radius:0 0 4px 4px;}

.signal-mini{background:var(--dark2);border:1px solid var(--border);border-radius:4px;padding:20px;margin-top:28px;}

.tier-pill{padding:2px 8px;border-radius:2px;font-family:Barlow Condensed,sans-serif;font-size:0.62rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;}

/* ────────────────────────────────────────────────────────────
   ADMIN CONSOLE
   ──────────────────────────────────────────────────────────── */

.stat-val{font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:600;color:var(--gold);line-height:1;}

.stat-label{font-size:0.68rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:5px;font-family:Barlow Condensed,sans-serif;}

#login-gate{position:fixed;inset:0;background:var(--dark);z-index:999;display:flex;align-items:center;justify-content:center;}

.panel{display:none;padding:28px;}

.panel.active{display:block;}

.stat-box{background:var(--dark3);padding:20px;text-align:center;}

/* ────────────────────────────────────────────────────────────
   ANIMATIONS & MEDIA QUERIES
   ──────────────────────────────────────────────────────────── */

@media(max-width:900px){.page{grid-template-columns:1fr;}.sidebar{display:none;}}

.hero-eyebrow::before{content:'';width:32px;height:1px;background:var(--gold);}

.btn-primary:hover{background:var(--gold-light);}

.btn-secondary:hover{border-color:rgba(255,255,255,0.4);color:var(--white);}

@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.3;}}

@media(max-width:600px){.form-grid{grid-template-columns:1fr;}}

@media(max-width:700px){.faq-grid{grid-template-columns:1fr;}}

.footer-links a:hover{color:var(--gold);}

.rtu-daily-header::before{content:'';display:inline-block;width:6px;height:6px;background:#22C55E;border-radius:50%;animation:pulse 2s infinite;}

.eng-sel:focus{outline:none;border-color:var(--gold);}

.calc-btn:hover{opacity:.88;}

@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}



.search-input:focus{border-color:rgba(212,168,67,0.4);}

.filter-btn:hover{border-color:rgba(212,168,67,0.4);color:var(--gold);}

.sov-card:hover{border-color:rgba(212,168,67,0.25);background:rgba(255,255,255,0.02);}

.sov-card:hover .sc-rtu-link{border-color:var(--gold);color:var(--gold);}

.event-card:hover{background:rgba(212,168,67,0.05);}

.event-factor::before{content:'→';position:absolute;left:0;color:var(--gold);}

.snapshot-table tr:hover td{background:rgba(212,168,67,0.03);}



.btn-gold:hover{background:var(--gold-light);}

.btn-outline:hover{border-color:var(--gold);color:var(--gold);}

.client-card:hover{background:rgba(212,168,67,0.06);}

.price-card:hover{background:rgba(42,18,8,0.9);}

.btn-fill:hover{background:var(--gold-light);}

.btn-border:hover{background:var(--gold-dim);border-color:var(--gold);}

@media(max-width:560px){.form-row{grid-template-columns:1fr;}}

.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);}

.compare-table tr:hover td{background:rgba(212,168,67,0.03);}

.btn-lg-gold:hover{background:var(--gold-light);}

.btn-lg-outline:hover{border-color:var(--gold);color:var(--gold);}

.prog-step::after{content:'';position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--border2);z-index:0;}

.prog-step:last-child::after{display:none;}

.tier-opt:hover{border-color:rgba(212,168,67,0.5);}

.tier-opt.selected::before{content:'✓';position:absolute;top:12px;right:14px;width:22px;height:22px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:700;color:var(--dark);line-height:22px;text-align:center;}

.key-input:focus{border-color:var(--gold);}

.dash-action:hover{background:rgba(212,168,67,0.06);}

.or-divider::before,.or-divider::after{content:'';flex:1;height:1px;background:var(--border2);}

.login-input:focus{border-color:var(--gold);}

@keyframes blink{0%,100%{opacity:1;}50%{opacity:.3;}}

.tb-logout:hover{color:var(--red);}

.tb-refresh:hover{background:rgba(212,168,67,0.2);}

.req-table tr:hover td{background:rgba(212,168,67,0.03);}

.act-approve:hover{background:rgba(76,175,80,0.15);}

.act-reject:hover{background:rgba(217,64,64,0.1);}

.act-view:hover{border-color:var(--gold);color:var(--gold);}

.act-email:hover{background:rgba(26,95,158,0.15);}

.fi input:focus,.fi select:focus{border-color:var(--gold);}

.mini-table tr:hover td{background:rgba(212,168,67,0.03);}

/* ────────────────────────────────────────────────────────────
   UTILITIES
   ──────────────────────────────────────────────────────────── */

.gold-line{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:0;}

.purahu-toast{padding:10px 18px;background:#1A0A06;border-left:3px solid var(--gold,#D4A843);color:rgba(255,255,255,0.85);font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;letter-spacing:1px;border-radius:2px;box-shadow:0 4px 20px rgba(0,0,0,0.4);animation:toastIn 0.2s ease;pointer-events:auto;}

.purahu-toast.success{border-left-color:#22C55E;}

.purahu-toast.error{border-left-color:#EF4444;}

/* ────────────────────────────────────────────────────────────
   ADDITIONAL RULES
   ──────────────────────────────────────────────────────────── */

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;background:var(--dark);}

body{padding-top:56px;background:var(--dark);color:var(--white);font-family:'Cormorant Garamond',serif;line-height:1.7;}

h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:300;line-height:1.15;margin-bottom:24px;}

h1 em{font-style:italic;color:var(--gold);}

.proof-item{display:flex;flex-direction:column;}

.proof-val{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:600;color:var(--gold);line-height:1;}

.live-card{background:var(--d2);border:1px solid var(--border);border-radius:4px;overflow:hidden;}

.lc-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}

.lc-title{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);}

.live-dot{display:flex;align-items:center;gap:6px;font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:1px;text-transform:uppercase;color:var(--green);}

.ld{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;}

.lc-row{display:flex;justify-content:space-between;align-items:center;padding:13px 18px;border-bottom:1px solid var(--border2);}

.lc-row:last-child{border-bottom:none;}

.lc-left{display:flex;flex-direction:column;gap:2px;}

.lc-name{font-size:0.85rem;font-weight:600;color:var(--white);}

.lc-curr{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:1px;color:rgba(255,255,255,0.35);text-transform:uppercase;}

.lc-right{text-align:right;}

.lc-idx{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;line-height:1;}

.lc-sig{font-family:'Barlow Condensed',sans-serif;font-size:0.62rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-top:2px;}

.c-vstrong{color:#4CAF50;}

.c-strong{color:#8BC34A;}

.c-mod{color:var(--gold);}

.c-stress{color:#FF9800;}

.c-severe{color:var(--red);}

.sec-eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}

.sec-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:300;color:var(--white);line-height:1.2;margin-bottom:16px;}

.sec-title em{color:var(--gold);font-style:italic;}

.sec-body{font-size:0.9rem;color:rgba(255,255,255,0.62);line-height:1.8;max-width:680px;margin-bottom:40px;}

.why-now{background:rgba(26,95,158,0.06);border:1px solid rgba(91,163,217,0.15);border-radius:4px;padding:48px;}

.why-now p{font-size:0.95rem;color:rgba(255,255,255,0.72);line-height:1.85;margin-bottom:20px;}

.why-now p:last-child{margin-bottom:0;}

.insight-strip{background:var(--blue-mid);border:1px solid rgba(91,163,217,0.2);padding:24px 28px;margin:28px 0;}

.insight-strip p{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-style:italic;color:var(--white);line-height:1.6;margin:0;}

.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;border:1px solid var(--border);margin-top:36px;}

.why-card{background:var(--d2);padding:28px;}

.why-icon{font-size:1.5rem;margin-bottom:14px;display:block;}

.why-title{font-family:'Barlow Condensed',sans-serif;font-size:0.82rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:8px;}

.why-body{font-size:0.82rem;color:rgba(255,255,255,0.55);line-height:1.6;}

.product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1px;border:1px solid var(--border);margin-top:40px;}

.product-card{background:var(--d2);padding:28px;}

.product-num{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}

.product-name{font-family:'Barlow Condensed',sans-serif;font-size:0.95rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:10px;}

.product-body{font-size:0.83rem;color:rgba(255,255,255,0.58);line-height:1.6;}

.who-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;border:1px solid var(--border);margin-top:40px;}

.who-card{background:var(--d2);padding:24px;}

.who-title{font-family:'Barlow Condensed',sans-serif;font-size:0.8rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:8px;}

.who-body{font-size:0.8rem;color:rgba(255,255,255,0.5);line-height:1.55;}

.numbers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;border:1px solid var(--border);margin-top:40px;}

.number-card{background:var(--d2);padding:28px;text-align:center;}

.number-val{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:600;color:var(--gold);line-height:1;}

.quote-block{background:var(--d2);border:1px solid var(--border);padding:48px;text-align:center;margin:48px 0;}

.quote-text{font-family:'Cormorant Garamond',serif;font-size:clamp(1.4rem,3vw,2.2rem);font-style:italic;color:var(--white);max-width:820px;margin:0 auto 16px;line-height:1.5;font-weight:300;}

.quote-attr{font-family:'Barlow Condensed',sans-serif;font-size:0.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);}

.ps-title{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;color:var(--white);margin-bottom:8px;}

.ps-body{font-size:0.88rem;color:rgba(255,255,255,0.55);line-height:1.6;}

.ps-tiers{display:flex;gap:20px;margin-top:16px;flex-wrap:wrap;}

.ps-tier{text-align:center;}

.ps-tier-price{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:600;color:var(--gold);}

.ps-tier-name{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-top:3px;}

.cta-block{text-align:center;padding:64px 40px;background:var(--d2);border:1px solid var(--border);border-radius:4px;margin-top:48px;}

.cta-block h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:300;color:var(--white);margin-bottom:12px;}

.cta-block h2 em{color:var(--gold);font-style:italic;}

.cta-block p{font-size:0.9rem;color:rgba(255,255,255,0.55);max-width:520px;margin:0 auto 28px;line-height:1.7;}

.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

.trend-worse{color:#EF4444;background:rgba(239,68,68,0.1);}

.trend-better{color:#22C55E;background:rgba(34,197,94,0.1);}

.trend-alert{color:#F59E0B;background:rgba(245,158,11,0.1);}

.eng-sel{width:100%;background:rgba(0,0,0,.4);border:1px solid var(--border);color:var(--white);padding:14px 16px;font-family:'Barlow Condensed',sans-serif;font-size:.95rem;border-radius:2px;cursor:pointer;-webkit-appearance:none;appearance:none;}

.calc-btn{width:100%;padding:18px;background:var(--gold);color:var(--dark);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.82rem;letter-spacing:3px;text-transform:uppercase;border:none;cursor:pointer;border-radius:2px;transition:opacity .2s;}

.chart-tab{background:transparent;border:none;border-bottom:2px solid transparent;padding:10px 20px;color:rgba(255,255,255,.4);font-family:'Barlow Condensed',sans-serif;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .2s;}

.chart-tab.active{color:var(--gold);border-bottom-color:var(--gold);}

.range-btn{background:transparent;border:1px solid var(--border);color:rgba(255,255,255,.4);padding:5px 12px;font-family:'Barlow Condensed',sans-serif;font-size:.65rem;cursor:pointer;border-radius:2px;}

.range-btn.active{background:rgba(212,168,67,.15);border-color:var(--gold);color:var(--gold);}

.canvas-wrap{position:relative;height:320px;padding:16px;}

.m-lbl{font-family:'Barlow Condensed',sans-serif;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:6px;}

.m-val{font-family:'JetBrains Mono',monospace;font-size:.95rem;font-weight:600;color:var(--white);}

#purahu-toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}

.p-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.85);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;}

.p-modal{background:#1A0A06;border:1px solid rgba(212,168,67,0.3);border-radius:4px;padding:36px;max-width:480px;width:100%;position:relative;}

.p-modal-close{position:absolute;top:12px;right:16px;background:transparent;border:none;color:rgba(255,255,255,0.4);font-size:1.2rem;cursor:pointer;}

a{color:inherit;text-decoration:none;}

0%,100%{opacity:1;}

50%{opacity:.35;}

.controls{background:var(--d3);border:1px solid var(--border);border-radius:4px;padding:20px 24px;margin-bottom:24px;}

.search-wrap{position:relative;flex:1;min-width:200px;max-width:320px;}

.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);
  color:rgba(255,255,255,0.3);font-size:0.85rem;}

.filter-btns{display:flex;gap:6px;flex-wrap:wrap;}

.filter-btn{padding:7px 14px;background:transparent;
  border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.45);
  font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:1.5px;
  text-transform:uppercase;cursor:pointer;border-radius:2px;transition:all .2s;}

.filter-btn.active{background:rgba(212,168,67,0.12);border-color:var(--gold);color:var(--gold);}

.sort-wrap{display:flex;gap:6px;align-items:center;margin-left:auto;}

.alert-strip{padding:14px 40px;background:rgba(217,64,64,0.08);
  border-bottom:1px solid rgba(217,64,64,0.2);
  display:flex;align-items:center;gap:12px;}

.alert-badge{padding:3px 10px;background:rgba(217,64,64,0.2);border:1px solid rgba(217,64,64,0.4);
  font-size:0.62rem;letter-spacing:2px;text-transform:uppercase;color:#FF5252;border-radius:2px;}

.alert-countries{font-size:0.8rem;color:rgba(255,255,255,0.7);}

.alert-countries strong{color:#FF9800;}

.sc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;}

.sc-flag{font-size:1.4rem;line-height:1;}

.sc-regime{font-size:0.58rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:2px 7px;border-radius:10px;font-weight:600;}

.sc-name{font-size:0.88rem;font-weight:600;color:var(--white);margin-bottom:2px;}

.sc-curr{font-size:0.65rem;letter-spacing:1px;text-transform:uppercase;
  color:rgba(255,255,255,0.35);}

.sc-index{font-family:'JetBrains Mono',monospace;font-size:1.5rem;font-weight:500;
  margin:8px 0 4px;}

.sc-trend{font-size:0.68rem;letter-spacing:1px;text-transform:uppercase;
  display:flex;align-items:center;gap:4px;margin-bottom:10px;}

.sc-spark{height:36px;position:relative;}

.sc-rtu-link{display:block;margin-top:10px;padding:6px;text-align:center;
  border:1px solid rgba(212,168,67,0.15);font-size:0.62rem;letter-spacing:1.5px;
  text-transform:uppercase;color:rgba(255,255,255,0.3);transition:all .2s;}

.empty-state{text-align:center;padding:60px 24px;color:rgba(255,255,255,0.25);}

.results-bar{padding:10px 40px;background:var(--d3);border-bottom:1px solid var(--border2);
  display:flex;justify-content:space-between;align-items:center;}

.results-count{font-size:0.72rem;color:rgba(255,255,255,0.3);letter-spacing:1px;}

.regime-legend{display:flex;gap:14px;}

.leg-item{display:flex;align-items:center;gap:5px;font-size:0.62rem;
  color:rgba(255,255,255,0.35);letter-spacing:1px;text-transform:uppercase;}

.leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}

.traj-up   { color:#EF4444; }

.traj-down { color:#22C55E; }

.traj-flat { color:#F59E0B; }

.disclaimer{padding:14px 20px;background:rgba(26,95,158,0.15);border-left:3px solid rgba(91,163,217,0.5);
  font-size:0.8rem;color:rgba(255,255,255,0.55);line-height:1.6;max-width:680px;}

.controls-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap;}

.chart-container{background:var(--d3);border:1px solid var(--border);border-radius:4px;
  padding:28px;margin-bottom:24px;}

.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:12px;}

.chart-title-block .chart-main-title{font-family:'Barlow Condensed',sans-serif;font-size:0.75rem;
  font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);}

.chart-title-block .chart-sub{font-size:0.78rem;color:rgba(255,255,255,0.4);margin-top:4px;}

.chart-wrap{position:relative;height:180px;}

.chart-note{font-size:0.72rem;color:rgba(255,255,255,0.3);margin-top:12px;line-height:1.5;}

.stress-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:20px;}

.sl-item{display:flex;align-items:center;gap:6px;}

.sl-dot{width:10px;height:10px;border-radius:2px;}

.events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1px;
  border:1px solid var(--border);margin-bottom:48px;}

.event-card{background:var(--d2);padding:24px;transition:background .2s;cursor:pointer;}

.event-card.critical .event-year-badge{background:rgba(217,64,64,0.2);color:var(--red);border-color:rgba(217,64,64,0.3);}

.event-card.high .event-year-badge{background:rgba(255,152,0,0.2);color:var(--amber);border-color:rgba(255,152,0,0.3);}

.event-card.baseline .event-year-badge{background:rgba(76,175,80,0.2);color:var(--green);border-color:rgba(76,175,80,0.3);}

.event-year-badge{display:inline-block;padding:3px 10px;border-radius:2px;border:1px solid;
  font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;}

.event-title{font-family:'Barlow Condensed',sans-serif;font-size:0.88rem;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:8px;}

.event-desc{font-size:0.82rem;color:rgba(255,255,255,0.65);line-height:1.6;margin-bottom:12px;}

.event-factors{display:flex;flex-direction:column;gap:4px;}

.event-factor{font-size:0.75rem;color:rgba(255,255,255,0.4);padding-left:12px;position:relative;}

.snapshot-wrap{overflow-x:auto;margin-bottom:48px;}

.snapshot-table{width:100%;border-collapse:collapse;min-width:700px;}

.snapshot-table th{padding:10px 14px;text-align:center;background:var(--blue-mid,#0D2A45);
  font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:2px;
  text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--border);}

.snapshot-table th:first-child{text-align:left;}

.snapshot-table td{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,0.04);
  font-family:'JetBrains Mono',monospace;font-size:0.8rem;text-align:center;}

.snapshot-table td:first-child{text-align:left;font-family:'Barlow Condensed',sans-serif;
  font-size:0.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white);}

.idx-cell{border-radius:2px;padding:4px 8px;display:inline-block;min-width:36px;text-align:center;}

.idx-vstrong{background:rgba(76,175,80,0.15);color:#4CAF50;}

.idx-strong{background:rgba(139,195,74,0.15);color:#8BC34A;}

.idx-mod{background:rgba(212,168,67,0.15);color:var(--gold);}

.idx-stress{background:rgba(255,152,0,0.15);color:#FF9800;}

.idx-severe{background:rgba(217,64,64,0.15);color:#D94040;}

.idx-crisis{background:rgba(217,64,64,0.3);color:#FF5252;font-weight:700;}

.analysis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:48px;}

.analysis-card{background:var(--d2);border:1px solid var(--border);padding:28px;border-radius:2px;}

.ac-sovereign{display:flex;align-items:center;gap:10px;margin-bottom:16px;}

.ac-flag{font-size:1.6rem;}

.ac-name{font-family:'Barlow Condensed',sans-serif;font-size:0.82rem;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;color:var(--white);}

.ac-curr{font-size:0.72rem;color:rgba(255,255,255,0.35);}

.ac-peak{font-family:'JetBrains Mono',monospace;font-size:1.8rem;font-weight:500;line-height:1;margin-bottom:4px;}

.ac-peak-year{font-size:0.75rem;color:rgba(255,255,255,0.4);margin-bottom:14px;}

.ac-narrative{font-size:0.82rem;color:rgba(255,255,255,0.65);line-height:1.6;}

.ac-current{display:flex;justify-content:space-between;align-items:center;
  margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,0.06);}

.ac-curr-val{font-family:'JetBrains Mono',monospace;font-size:0.9rem;color:var(--gold);}

.pulse-dot{width:8px;height:8px;border-radius:50%;background:#4CAF50;animation:pulse 2s infinite;}

.clients-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;margin:48px 0;border:1px solid var(--border);}

.client-card{padding:32px;background:var(--dark2);transition:background .2s;}

.client-icon{font-size:1.8rem;margin-bottom:16px;display:block;}

.client-type{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.9rem;letter-spacing:1px;color:var(--white);text-transform:uppercase;margin-bottom:8px;}

.client-desc{font-size:0.85rem;color:rgba(255,255,255,0.6);line-height:1.6;}

.delivers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin:48px 0;}

.deliver-card{border:1px solid var(--border);background:var(--dark2);padding:28px;border-radius:2px;}

.deliver-num{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:12px;}

.deliver-title{font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:10px;text-transform:uppercase;letter-spacing:1px;}

.deliver-body{font-size:0.85rem;color:rgba(255,255,255,0.65);line-height:1.7;}

.pf-check{color:var(--gold);flex-shrink:0;margin-top:1px;}

.nda-block{background:var(--dark2);border:1px solid var(--border);padding:48px;border-radius:4px;max-width:760px;}

.nda-block h3{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;color:var(--white);margin-bottom:8px;}

.nda-block p{font-size:0.88rem;color:rgba(255,255,255,0.65);line-height:1.7;margin-bottom:28px;}

.nda-note{padding:14px 18px;background:rgba(26,95,158,0.15);border-left:3px solid #5BA3D9;font-size:0.8rem;color:var(--white);line-height:1.6;margin-bottom:24px;}

.submit-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap;}

.submit-note{font-size:0.78rem;color:rgba(255,255,255,0.35);line-height:1.5;}

#inst-status{display:none;margin-top:20px;}

.success-box{padding:20px 24px;background:rgba(212,168,67,0.1);border:1px solid var(--gold);border-radius:2px;}

.success-box h4{font-family:'Barlow Condensed',sans-serif;font-size:0.9rem;letter-spacing:1px;color:var(--gold);margin-bottom:6px;}

.success-box p{font-size:0.85rem;color:rgba(255,255,255,0.75);line-height:1.6;}

.quote-strip{background:var(--blue-mid);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:64px 40px;text-align:center;}

.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0;margin:48px 0;position:relative;}

.step{padding:32px;background:var(--dark2);border:1px solid var(--border);border-right:none;position:relative;}

.step:last-child{border-right:1px solid var(--border);}

.step-num{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:700;color:var(--gold);opacity:.3;margin-bottom:12px;display:block;}

.step-title{font-family:Cormorant Garamond,serif;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:300;color:var(--white);line-height:1.15;margin-bottom:16px;}

.step-body{font-size:0.82rem;color:rgba(255,255,255,0.55);line-height:1.6;}

.h-badge{display:inline-block;padding:6px 18px;border:1px solid var(--gold);border-radius:2px;font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:28px;}

.h-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,5vw,4rem);font-weight:300;line-height:1.1;color:var(--white);margin-bottom:20px;}

.h-title em{color:var(--gold);font-style:italic;}

.h-sub{font-size:1rem;color:rgba(255,255,255,0.62);line-height:1.8;max-width:580px;margin:0 auto;}

.feat-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);padding:4px 14px;background:var(--gold);font-family:'Barlow Condensed',sans-serif;font-size:0.62rem;letter-spacing:2px;font-weight:700;color:var(--dark);text-transform:uppercase;border-radius:0 0 4px 4px;white-space:nowrap;}

.pc-top{padding:32px 28px 24px;border-bottom:1px solid var(--border);}

.pc-name{font-family:'Barlow Condensed',sans-serif;font-size:0.82rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:12px;}

.pc-price{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:4px;}

.pc-price sub{font-size:1.1rem;color:rgba(255,255,255,0.4);}

.pc-desc{font-size:0.82rem;color:rgba(255,255,255,0.45);margin-top:8px;line-height:1.5;}

.pc-features{padding:24px 28px;flex:1;list-style:none;}

.pc-features li{font-size:0.85rem;color:#EEEEEE;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.05);display:flex;gap:10px;align-items:flex-start;}

.pc-features li:last-child{border-bottom:none;}

.pc-btn{display:block;margin:0 28px 28px;padding:13px;text-align:center;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.78rem;letter-spacing:2px;text-transform:uppercase;border-radius:2px;text-decoration:none;transition:all .2s;border:none;cursor:pointer;}

.compare-table{width:100%;border-collapse:collapse;margin:40px 0;}

.compare-table th{padding:14px 16px;background:var(--blue-mid);font-family:'Barlow Condensed',sans-serif;font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--border);text-align:left;}

.compare-table th:not(:first-child){text-align:center;}

.compare-table td{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,0.05);font-size:0.85rem;color:#EEEEEE;}

.compare-table td:not(:first-child){text-align:center;}

.check{color:var(--green);font-size:1rem;}

.cross{color:rgba(255,255,255,0.2);font-size:1rem;}

.partial{color:var(--gold);font-size:0.75rem;font-family:'Barlow Condensed',sans-serif;letter-spacing:1px;}

.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin:40px 0;}

.faq-item h4{font-family:'Barlow Condensed',sans-serif;font-size:0.88rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:8px;}

.faq-item p{font-size:0.85rem;color:rgba(255,255,255,0.58);line-height:1.7;}

.contact-block{text-align:center;padding:72px 40px;border-top:1px solid var(--border);}

.contact-block h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.8rem);font-weight:300;color:var(--white);margin-bottom:16px;}

.contact-block h2 em{color:var(--gold);font-style:italic;}

.contact-block p{font-size:0.9rem;color:rgba(255,255,255,0.55);max-width:500px;margin:0 auto 32px;line-height:1.7;}

.contact-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

.sidebar{padding:56px 36px;background:var(--dark);}

.sidebar-sticky{position:sticky;top:90px;}

.progress-track{display:flex;gap:0;margin-bottom:48px;}

.prog-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;}

.prog-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:var(--dark);display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:0.75rem;font-weight:700;color:rgba(255,255,255,0.35);position:relative;z-index:1;transition:all .3s;}

.prog-dot.done{background:var(--gold);border-color:var(--gold);color:var(--dark);}

.prog-dot.active{border-color:var(--gold);color:var(--gold);background:rgba(212,168,67,0.1);}

.step-panel{display:none;}

.step-panel.active{display:block;}

.step-tag{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}

.step-title em{color:var(--gold);font-style:italic;}

.step-sub{font-size:0.9rem;color:rgba(255,255,255,0.6);line-height:1.7;margin-bottom:36px;max-width:560px;}

.tf-bullet{color:var(--gold);flex-shrink:0;}

.span2{grid-column:1/-1;}

.confirm-box{background:var(--dark2);border:1px solid var(--border);border-radius:4px;padding:36px;margin-bottom:32px;}

.confirm-id{font-family:Barlow Condensed,sans-serif;font-size:0.72rem;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:8px;}

.confirm-val{font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:600;color:var(--gold);margin-bottom:4px;}

.confirm-status{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:rgba(212,168,67,0.1);border:1px solid rgba(212,168,67,0.3);border-radius:20px;margin-bottom:24px;}

.confirm-detail{font-size:0.88rem;color:rgba(255,255,255,0.65);line-height:1.8;}

.confirm-detail strong{color:var(--white);}

.timeline-next{margin-top:32px;}

.tl-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--border2);}

.tl-item:last-child{border-bottom:none;}

.tl-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0;}

.tl-pending{background:rgba(212,168,67,0.1);border:1px solid var(--border);}

.key-entry{background:var(--dark2);border:1px solid var(--border);border-radius:4px;padding:28px;margin-bottom:24px;}

.key-entry h4{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:0.85rem;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:8px;}

.key-entry p{font-size:0.82rem;color:rgba(255,255,255,0.5);margin-bottom:16px;line-height:1.6;}

.key-btn{padding:12px 20px;background:var(--gold);color:var(--dark);font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:0.75rem;letter-spacing:1.5px;text-transform:uppercase;border:none;cursor:pointer;border-radius:2px;white-space:nowrap;}

.key-error{color:#D94040;font-size:0.78rem;margin-top:8px;display:none;}

.dash-header{background:var(--dark2);border:1px solid var(--border);padding:24px 28px;border-radius:4px 4px 0 0;display:flex;align-items:center;justify-content:space-between;margin-bottom:1px;}

.dash-plan{font-family:Barlow Condensed,sans-serif;font-size:0.72rem;letter-spacing:2px;text-transform:uppercase;}

.dash-name{font-size:0.95rem;font-weight:600;color:var(--white);}

.dash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-bottom:1px;}

.dash-stat{background:var(--dark2);padding:20px 24px;border:1px solid var(--border);}

.dash-stat-val{font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:600;color:var(--gold);line-height:1;}

.dash-actions{display:grid;grid-template-columns:1fr 1fr;gap:1px;}

.dash-action{background:var(--dark2);border:1px solid var(--border);padding:20px 24px;cursor:pointer;transition:background .2s;}

.dash-action-icon{font-size:1.4rem;margin-bottom:8px;}

.dash-action-title{font-family:Barlow Condensed,sans-serif;font-size:0.82rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:4px;}

.dash-action-desc{font-size:0.78rem;color:rgba(255,255,255,0.45);line-height:1.5;}

.trust-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border2);}

.trust-item:last-child{border-bottom:none;}

.trust-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px;}

.trust-title{font-family:Barlow Condensed,sans-serif;font-size:0.8rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;}

.trust-body{font-size:0.78rem;color:rgba(255,255,255,0.5);line-height:1.5;}

.sidebar-divider{height:1px;background:var(--border2);margin:28px 0;}

.sm-header{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;}

.sm-pulse{width:6px;height:6px;border-radius:50%;background:#4CAF50;animation:pulse 2s infinite;}

.sm-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.04);}

.sm-row:last-child{border-bottom:none;}

.sm-name{font-size:0.82rem;color:var(--white);}

.sm-curr{font-size:0.68rem;color:#AAAAAA;}

.sm-badge{font-family:Barlow Condensed,sans-serif;font-size:0.68rem;font-weight:700;padding:2px 8px;border-radius:2px;}

.s-vstrong{background:rgba(76,175,80,0.15);color:#4CAF50;}

.s-strong{background:rgba(139,195,74,0.15);color:#8BC34A;}

.s-mod{background:rgba(212,168,67,0.15);color:var(--gold);}

.s-stress{background:rgba(255,112,67,0.15);color:#FF7043;}

.s-severe{background:rgba(217,64,64,0.15);color:#D94040;}

.or-divider{display:flex;align-items:center;gap:12px;margin:28px 0;color:rgba(255,255,255,0.2);font-size:0.75rem;font-family:Barlow Condensed,sans-serif;letter-spacing:2px;text-transform:uppercase;}

<!-- Supabase client -->
  
  
  .db-status{position:fixed;bottom:16px;left:16px;padding:6px 14px;font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1px;text-transform:uppercase;border-radius:2px;display:none;z-index:500;}

.db-ok{background:rgba(76,175,80,0.15);border:1px solid rgba(76,175,80,0.3);color:#4CAF50;}

.db-err{background:rgba(217,64,64,0.15);border:1px solid rgba(217,64,64,0.3);color:#D94040;}

.eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:0.6rem;letter-spacing:4px;color:var(--gold);text-transform:uppercase;margin-bottom:16px;}

.divider{height:1px;background:rgba(212,168,67,0.15);margin:60px 0;}

.cta{text-align:center;padding:80px 24px;background:rgba(212,168,67,0.04);border-top:1px solid rgba(212,168,67,0.1);}

html,body{background:var(--dark);color:var(--white);font-family:Barlow,sans-serif;min-height:100vh;}

.login-box{background:var(--dark3);border:1px solid var(--border);padding:48px;border-radius:4px;width:100%;max-width:440px;text-align:center;}

.login-logo{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid rgba(212,168,67,0.4);margin-bottom:20px;}

.login-title{font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:300;margin-bottom:6px;}

.login-sub{font-size:0.82rem;color:rgba(255,255,255,0.4);margin-bottom:28px;line-height:1.5;}

.login-field{margin-bottom:12px;}

.login-btn{width:100%;padding:13px;background:var(--gold);color:var(--dark);font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:0.82rem;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;border-radius:2px;margin-top:4px;}

.login-err{color:var(--red);font-size:0.78rem;display:none;margin-top:8px;}

.login-hint{font-size:0.72rem;color:rgba(255,255,255,0.2);margin-top:16px;line-height:1.6;}

.db-indicator{display:inline-flex;align-items:center;gap:6px;margin-bottom:16px;}

.db-dot{width:8px;height:8px;border-radius:50%;}

.db-dot.connecting{background:#D4A843;animation:blink 1s infinite;}

.db-dot.connected{background:#4CAF50;}

.db-dot.error{background:var(--red);}

#app{display:none;}

.top-bar{background:rgba(15,6,3,0.98);border-bottom:1px solid var(--border);padding:12px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;backdrop-filter:blur(8px);}

.tb-brand{display:flex;align-items:center;gap:10px;}

.tb-brand img{width:30px;height:30px;border-radius:50%;object-fit:cover;border:1px solid rgba(212,168,67,0.3);}

.tb-brand span{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:0.88rem;letter-spacing:2px;color:var(--gold);}

.tb-badge{padding:3px 10px;background:rgba(217,64,64,0.2);border:1px solid var(--red);border-radius:2px;font-family:Barlow Condensed,sans-serif;font-size:0.65rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);}

.tb-right{display:flex;align-items:center;gap:16px;}

.tb-db{display:flex;align-items:center;gap:6px;}

.tb-db-dot{width:7px;height:7px;border-radius:50%;background:var(--green);}

.tb-clock{font-family:Barlow,monospace;font-size:0.75rem;color:rgba(255,255,255,0.3);}

.tb-logout{font-family:Barlow Condensed,sans-serif;font-size:0.72rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.3);cursor:pointer;}

.tb-refresh{padding:5px 12px;background:rgba(212,168,67,0.1);border:1px solid rgba(212,168,67,0.25);color:var(--gold);font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:2px;}

.req-filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;align-items:center;}

.rf-chip{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:rgba(255,255,255,0.4);font-family:Barlow Condensed,sans-serif;font-size:0.72rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .2s;}

.rf-chip.active{background:var(--blue-mid);border-color:var(--blue);color:var(--white);}

.rf-search{flex:1;min-width:200px;padding:8px 14px;background:var(--dark3);border:1px solid rgba(212,168,67,0.2);color:var(--white);font-family:Barlow,sans-serif;font-size:0.85rem;outline:none;border-radius:2px;}

.rf-search::placeholder{color:rgba(255,255,255,0.25);}

.req-table{width:100%;border-collapse:collapse;}

.req-table th{padding:11px 14px;text-align:left;background:var(--blue-mid);font-family:Barlow Condensed,sans-serif;font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--border);}

.req-table td{padding:13px 14px;border-bottom:1px solid rgba(255,255,255,0.04);font-size:0.83rem;color:rgba(255,255,255,0.8);vertical-align:top;}

.s-pending{background:rgba(212,168,67,0.15);color:var(--gold);}

.s-approved{background:rgba(76,175,80,0.15);color:var(--green);}

.s-rejected{background:rgba(217,64,64,0.15);color:var(--red);}

.t-brief{background:rgba(255,255,255,0.08);color:#CCCCCC;}

.t-corridor{background:rgba(26,95,158,0.2);color:#5BA3D9;}

.t-annual{background:rgba(212,168,67,0.2);color:var(--gold);}

.t-thematic{background:rgba(139,195,74,0.15);color:#8BC34A;}

.t-methodology{background:rgba(91,163,217,0.15);color:#5BA3D9;}

.action-btns{display:flex;gap:6px;flex-wrap:wrap;}

.act-btn{padding:5px 12px;border:1px solid;font-family:Barlow Condensed,sans-serif;font-size:0.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:2px;background:transparent;transition:all .2s;}

.act-approve{border-color:var(--green);color:var(--green);}

.act-reject{border-color:var(--red);color:var(--red);}

.act-view{border-color:rgba(255,255,255,0.2);color:rgba(255,255,255,0.55);}

.act-email{border-color:var(--blue);color:#5BA3D9;}

.empty-state h3{font-family:Cormorant Garamond,serif;font-size:1.4rem;font-weight:300;margin-bottom:8px;}

.empty-state p{font-size:0.82rem;line-height:1.6;}

#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:500;display:none;align-items:center;justify-content:center;padding:24px;}

#modal-overlay.open{display:flex;}

.detail-row{display:flex;gap:16px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.04);}

.detail-row:last-child{border-bottom:none;}

.detail-val{font-size:0.88rem;color:var(--white);line-height:1.6;word-break:break-word;}

.key-box{background:var(--dark4);border:1px solid rgba(212,168,67,0.2);padding:20px;border-radius:2px;margin-top:16px;}

.key-display{font-family:Barlow,monospace;font-size:0.85rem;color:var(--gold);background:var(--dark);padding:12px 16px;border:1px solid rgba(212,168,67,0.2);border-radius:2px;word-break:break-all;letter-spacing:1px;margin-bottom:10px;}

.key-warning{font-size:0.75rem;color:var(--red);line-height:1.5;}

.email-box{background:var(--dark4);border:1px solid rgba(91,163,217,0.2);padding:20px;border-radius:2px;margin-top:16px;}

.email-preview{background:var(--dark);padding:16px;border:1px solid rgba(255,255,255,0.06);border-radius:2px;font-size:0.8rem;color:rgba(255,255,255,0.7);line-height:1.8;white-space:pre-wrap;margin-bottom:10px;max-height:240px;overflow-y:auto;}

.fi{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;}

.copy-btn{padding:8px 18px;background:var(--blue-mid);border:1px solid rgba(91,163,217,0.3);color:#5BA3D9;font-family:Barlow Condensed,sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border-radius:2px;}

.rev-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;border:1px solid var(--border);margin-bottom:28px;}

.rev-card{background:var(--dark3);padding:24px;}

.rev-val{font-family:Cormorant Garamond,serif;font-size:2.2rem;font-weight:600;color:var(--gold);line-height:1;}

#toast{position:fixed;bottom:28px;right:28px;padding:14px 20px;background:var(--dark3);border:1px solid var(--border);border-radius:4px;font-size:0.85rem;color:var(--white);z-index:999;display:none;max-width:340px;box-shadow:0 8px 32px rgba(0,0,0,0.4);}

#toast.success{border-color:var(--green);color:var(--green);}

#toast.error{border-color:var(--red);color:var(--red);}

.loading{text-align:center;padding:40px;color:rgba(255,255,255,0.3);font-family:Barlow Condensed,sans-serif;font-size:0.8rem;letter-spacing:2px;text-transform:uppercase;}

.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px;margin-bottom:28px;}

.chart-card{background:var(--dark3);border:1px solid var(--border);padding:20px;border-radius:2px;}

.chart-title{font-family:Barlow Condensed,sans-serif;font-size:0.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}

.mini-table{width:100%;border-collapse:collapse;margin-top:12px;}

.mini-table th{font-family:Barlow Condensed,sans-serif;font-size:0.65rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.3);padding:6px 10px;text-align:left;border-bottom:1px solid rgba(255,255,255,0.06);}

.mini-table td{font-size:0.8rem;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.04);color:rgba(255,255,255,0.75);}

.geo-bar{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04);}

.geo-track{flex:1;height:6px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden;}

.geo-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .5s;}

.geo-count{font-size:0.78rem;color:rgba(255,255,255,0.4);width:40px;text-align:right;}

.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1px;border:1px solid var(--border);margin-bottom:28px;}

.kpi{background:var(--dark3);padding:16px;text-align:center;}

.kpi-val{font-family:Cormorant Garamond,serif;font-size:1.6rem;font-weight:600;color:var(--gold);line-height:1;}

.ua-list{margin-top:12px;}

.ua-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04);}

.ua-name{font-size:0.82rem;color:rgba(255,255,255,0.65);}

.ua-count{font-family:Barlow Condensed,sans-serif;font-size:0.8rem;font-weight:700;color:var(--gold);}
/* ── Utility Classes — replaces repeated inline styles ────────────── */
.u-label { font-family:'Barlow Condensed',sans-serif;font-size:0.58rem;letter-spacing:3px;color:var(--gold,#D4A843);text-transform:uppercase; }
.u-label-sm { font-family:'Barlow Condensed',sans-serif;font-size:0.6rem;letter-spacing:2px;color:rgba(255,255,255,0.35);text-transform:uppercase; }
.u-label-white { font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:2px;color:rgba(255,255,255,0.5); }
.u-score-red { color:#EF4444;font-weight:600; }
.u-score-amber { color:#F59E0B;font-weight:600; }
.u-score-green { color:#22C55E;font-weight:600; }
.u-score-mono { font-family:'JetBrains Mono',monospace;font-weight:600; }
.u-card { background:rgba(0,0,0,0.2);border:1px solid rgba(212,168,67,0.12);border-radius:3px;padding:20px; }
.u-card-sm { padding:12px;background:rgba(212,168,67,0.05);border:1px solid rgba(212,168,67,0.1);border-radius:2px; }
.u-card-pad { background:var(--d2,#1A0A06);padding:16px 18px; }
.u-row-between { display:flex;justify-content:space-between;align-items:center; }
.u-row-center { display:flex;align-items:center;gap:10px; }
.u-text-muted { font-size:0.78rem;color:rgba(255,255,255,0.6);line-height:1.5; }
.u-text-body { font-size:0.85rem;color:rgba(255,255,255,0.65);line-height:1.6; }
.u-text-gold { color:var(--gold,#D4A843);font-size:0.8rem; }
.u-text-dim { color:rgba(255,255,255,0.3);text-decoration:none;font-size:0.75rem; }
.u-text-center { text-align:center; }
.u-text-right { text-align:right; }

/* ── Content sections ──────────────────────────────────────────── */
.p-section   { max-width:1100px; margin:0 auto; padding:48px 24px; }
.p-section-sm{ max-width:1100px; margin:0 auto; padding:24px; }
.p-hero      { max-width:1100px; margin:0 auto; padding:80px 24px 40px; }

/* ── Row/Col layout helpers ────────────────────────────────────── */
.p-row       { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.p-row-sb    { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.p-grid-2    { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.p-grid-3    { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.p-grid-auto { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:12px; }

/* ── Table/signal rows ─────────────────────────────────────────── */
.sig-row     { display:grid; grid-template-columns:1fr 80px 100px 120px; padding:13px 16px; align-items:center; border-bottom:1px solid rgba(255,255,255,0.04); }
.sig-row:last-child { border-bottom:none; }
.sig-row:hover { background:rgba(255,255,255,0.02); }
.sig-table   { border:1px solid rgba(212,168,67,0.12); border-radius:3px; overflow:hidden; }

/* ── Status badges ─────────────────────────────────────────────── */
.band-severe  { color:#EF4444; background:rgba(239,68,68,0.1);   padding:3px 10px; border-radius:2px; font-family:'Barlow Condensed',sans-serif; font-size:0.62rem; letter-spacing:1px; display:inline-block; }
.band-stress  { color:#F59E0B; background:rgba(245,158,11,0.1);  padding:3px 10px; border-radius:2px; font-family:'Barlow Condensed',sans-serif; font-size:0.62rem; letter-spacing:1px; display:inline-block; }
.band-mod     { color:#F59E0B; background:rgba(245,158,11,0.08); padding:3px 10px; border-radius:2px; font-family:'Barlow Condensed',sans-serif; font-size:0.62rem; letter-spacing:1px; display:inline-block; }
.band-strong  { color:#22C55E; background:rgba(34,197,94,0.1);   padding:3px 10px; border-radius:2px; font-family:'Barlow Condensed',sans-serif; font-size:0.62rem; letter-spacing:1px; display:inline-block; }

/* ── Status trends ─────────────────────────────────────────────── */
.trend-worse  { color:#EF4444; font-family:'Barlow Condensed',sans-serif; font-size:0.7rem; }
.trend-better { color:#22C55E; font-family:'Barlow Condensed',sans-serif; font-size:0.7rem; }
.trend-stable { color:rgba(255,255,255,0.4); font-family:'Barlow Condensed',sans-serif; font-size:0.7rem; }

/* ── CTA / Button system ───────────────────────────────────────── */
.btn-primary {
  display:inline-flex; align-items:center; padding:12px 28px;
  background:var(--gold,#D4A843); color:var(--dark,#0D0603);
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:0.7rem; letter-spacing:2px; text-transform:uppercase;
  text-decoration:none; border-radius:2px; border:none; cursor:pointer;
  transition:background 0.18s;
}
.btn-primary:hover { background:#F0C85A; }

.btn-ghost {
  display:inline-flex; align-items:center; padding:10px 20px;
  background:transparent; border:1px solid rgba(212,168,67,0.35);
  color:var(--gold,#D4A843);
  font-family:'Barlow Condensed',sans-serif; font-size:0.68rem;
  letter-spacing:1.5px; text-transform:uppercase;
  text-decoration:none; border-radius:2px; cursor:pointer;
  transition:all 0.18s;
}
.btn-ghost:hover { background:rgba(212,168,67,0.08); }

/* ── Input / Form ──────────────────────────────────────────────── */
.p-input {
  width:100%; padding:11px 14px;
  background:rgba(0,0,0,0.3);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:3px; color:rgba(255,255,255,0.85);
  font-family:'Barlow Condensed',sans-serif; font-size:0.82rem;
  transition:border-color 0.18s;
}
.p-input:focus { outline:none; border-color:rgba(212,168,67,0.4); }
.p-label {
  display:block; margin-bottom:6px;
  font-family:'Barlow Condensed',sans-serif; font-size:0.6rem;
  letter-spacing:2px; color:rgba(255,255,255,0.4); text-transform:uppercase;
}

/* ── Live indicator ────────────────────────────────────────────── */
.live-dot {
  display:inline-block; width:7px; height:7px;
  background:#22C55E; border-radius:50%;
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot { 0%,100%{opacity:1;} 50%{opacity:0.3;} }

/* ── Mobile responsive for content ────────────────────────────── */
@media (max-width:640px) {
  .p-section, .p-section-sm, .p-hero { padding-left:16px; padding-right:16px; }
  .p-grid-2, .p-grid-3 { grid-template-columns:1fr; }
  .sig-row { grid-template-columns:1fr 70px 90px; }
  .sig-row > *:last-child { display:none; }
}

/* ================================================================
   PURAHU+ — MOBILE RESPONSIVE + INTERACTION FIXES
   Fixes: pointer-events, z-index, hamburger nav, single-column
   ================================================================ */

/* ── Z-INDEX HIERARCHY (nothing sits above nav) ───────────────── */
nav                       { z-index: 9999 !important; }
.p-modal-overlay,
#p-upgrade-modal          { z-index: 9000; }
.purahu-toast,
#purahu-toast-container   { z-index: 8000; }

/* ── Decorative layers CANNOT intercept touch/click ──────────── */
.hero-grid,
.hero-bg,
.fx-grid,
.bg-grid,
.grid-overlay,
.hero-overlay,
.bg-pattern,
[class*="grid-bg"],
[class*="bg-lines"]       { pointer-events: none !important; z-index: 0; }

/* ── Hero section ─────────────────────────────────────────────── */
.hero                     { position:relative; z-index: 1; }
.hero-inner               { position:relative; z-index: 2; }

/* ── Background grid — subtle, not dominant ───────────────────── */
.hero-grid {
  opacity: 0.25;
  background-image:
    linear-gradient(rgba(212,168,67,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,168,67,0.015) 1px, transparent 1px);
}

/* ── HAMBURGER NAV — mobile only ──────────────────────────────── */






/* ── Mobile drawer ────────────────────────────────────────────── */






/* ── Show hamburger on mobile ─────────────────────────────────── */
@media (max-width: 900px) {
  
  .nav-links              { display: none !important; }
  .nav-right              { display: none !important; }
}

/* ── SINGLE COLUMN MOBILE LAYOUTS ────────────────────────────── */
@media (max-width: 768px) {
  /* Grid collapses */
  .hero-inner,
  .p-grid-2,
  .p-grid-3,
  .p-grid-auto,
  [class*="grid-2"],
  [class*="grid-3"]       { grid-template-columns: 1fr; }

  /* Width enforcement */
  .hero-copy,
  .hero-card,
  .signal-panel,
  .live-panel,
  .tier-card,
  .p-card,
  .u-card                 { width: 100%; max-width: 100%; }

  /* Typography on mobile */
  p, .hero-copy p         { font-size: 0.95rem; line-height: 1.7; max-width: 100%; }
  h1                      { font-size: clamp(1.8rem, 6vw, 3rem); }
  h2                      { font-size: clamp(1.4rem, 5vw, 2rem); }

  /* Padding */
  .p-section, .p-hero     { padding-left: 16px; padding-right: 16px; }

  /* Signal table — hide last column on mobile */
  .sig-row                { grid-template-columns: 1fr 65px 90px; }
  .sig-row > *:last-child { display: none; }
}

@media (max-width: 480px) {
  /* Very small screens */
  .p-grid-auto            { grid-template-columns: 1fr; }
  .p-row, .p-row-sb       { flex-direction: column; align-items: flex-start; }
  .btn-primary,
  .btn-ghost              { width: 100%; justify-content: center; }
}

/* ── Mobile drawer — refined ──────────────────────────────────── */







/* ── Hamburger animation ──────────────────────────────────────── */






@media (max-width: 900px) {
  
  .nav-links     { display: none !important; }
  .nav-right     { display: none !important; }
  
}

/* ── Decorative grids only — never intercept clicks ─────────────
   Earlier this used [class*="-grid"] which wrongly matched real
   layout grids (form-grid, pricing-grid, etc.) and disabled all
   form inputs and buttons inside them. Now scoped to decorative
   background layers only. */
.hero-grid, .hero-bg, .fx-grid, .bg-grid, .hero-overlay,
canvas.bg-canvas, [class*="bg-lines"] {
  pointer-events: none !important;
  z-index: 0;
}

/* ── Ensure page content is clickable above decorative layers ── */
.hero, .hero-inner, main, section, article,
.p-section, .p-hero, .sig-table, .u-card {
  position: relative;
  z-index: 1;
}

/* ── Hero text never overflows on mobile ──────────────────────── */
@media (max-width: 640px) {
  .hero h1, .sec-title { font-size: clamp(1.6rem, 7vw, 2.4rem); }
  .hero p, .sec-body   { font-size: 0.9rem; line-height: 1.7; }
  .hero-inner, .hero-copy { max-width: 100%; width: 100%; }
}

/* ================================================================
   RESPONSIVE TEXT & LAYOUT — all devices
   ================================================================ */

/* ── Base text legibility ─────────────────────────────────────── */
body {
  font-size:       16px;
  line-height:     1.6;
  overflow-x:      hidden;
  word-break:      break-word;
  -webkit-text-size-adjust: 100%;
}

p { line-height: 1.75; max-width: 68ch; }
h1,h2,h3,h4 { line-height: 1.2; }

/* ── Fluid heading sizes ──────────────────────────────────────── */
.sec-title  { font-size: clamp(1.5rem, 4vw, 2.8rem); }
.hero h1    { font-size: clamp(1.8rem, 5vw, 3.2rem); }

/* ── Responsive table — prevents overflow on mobile ──────────── */
.pricing-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 3px;
}
table {
  width: 100%;
  border-collapse: collapse;
  min-width: 480px;   /* forces scroll before breaking */
}
th, td {
  padding: 12px 16px;
  text-align: left;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  vertical-align: top;
}

/* ── Section containers — fluid, never overflow ──────────────── */
.p-section,
.p-hero,
[style*="max-width:1100px"],
[style*="max-width:900px"],
[style*="max-width:860px"] {
  box-sizing: border-box;
  width: 100%;
}

/* ── Cards never overflow viewport ───────────────────────────── */
.u-card, .p-card, .tier-card,
[style*="max-width:480px"],
[style*="max-width:520px"] {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/* ── MOBILE TEXT — 390px (iPhone) ────────────────────────────── */
@media (max-width: 640px) {
  body { font-size: 15px; }
  p    { font-size: 0.92rem; line-height: 1.7; max-width: 100%; }

  /* Headings clamp on small screens */
  h1   { font-size: clamp(1.5rem, 6.5vw, 2.2rem); }
  h2   { font-size: clamp(1.2rem, 5vw, 1.8rem); }
  h3   { font-size: clamp(1rem, 4vw, 1.4rem); }

  /* Barlow Condensed labels — keep readable */
  [style*="font-size:0.58rem"],
  [style*="font-size:0.6rem"],
  [style*="letter-spacing:3px"] {
    font-size: 0.62rem;
    letter-spacing: 2px;
  }

  /* Cormorant serif — slightly larger on small screens */
  [style*="font-family:'Cormorant Garamond'"],
  [style*="font-family: 'Cormorant Garamond'"] {
    font-size: clamp(1.1rem, 4.5vw, 1.6rem);
  }

  /* Padding reset on all containers */
  [style*="padding:80px"],
  [style*="padding: 80px"] {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  /* Signal table columns */
  .sig-row {
    grid-template-columns: 1fr 55px 75px !important;
    font-size: 0.7rem;
  }

  /* Pricing table scroll hint */
  .pricing-table-wrap::after {
    content: 'Scroll →';
    display: block;
    text-align: right;
    font-size: 0.6rem;
    color: rgba(255,255,255,0.25);
    padding-top: 6px;
    font-family: 'Barlow Condensed', sans-serif;
  }
}

@media (max-width: 390px) {
  body { font-size: 14px; }
  .nav-link { font-size: 0.52rem; padding: 0 5px; }
}

/* ── TABLET — 768px ──────────────────────────────────────────── */
@media (max-width: 768px) {
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:repeat(2"],
  [style*="grid-template-columns:repeat(3"] {
    grid-template-columns: 1fr;
  }

  /* Stack pricing cards */
  .tier-grid,
  [style*="grid-template-columns:repeat(auto-fit,minmax(280px"] {
    grid-template-columns: 1fr;
  }
}

/* ================================================================
   PURAHU+ — BLOOMBERG-GRADE POLISH
   Institutional intelligence terminal aesthetic
   ================================================================ */

/* ── Gold line separator ──────────────────────────────────────── */
.gold-rule {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(212,168,67,0.4), transparent);
  margin: 32px 0;
  border: none;
}

/* ── Intelligence terminal data rows ─────────────────────────── */
.data-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 11px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.78rem;
}
.data-row:last-child { border-bottom: none; }
.data-row .label { color: rgba(255,255,255,0.4); letter-spacing: 1px; }
.data-row .value { color: rgba(255,255,255,0.85); font-weight: 600; }

/* ── Ticker-style stat boxes ──────────────────────────────────── */
.stat-ticker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 1px;
  background: rgba(212,168,67,0.1);
  border: 1px solid rgba(212,168,67,0.15);
  border-radius: 3px;
  overflow: hidden;
}
.stat-ticker-item {
  background: var(--dark2, #1A0A06);
  padding: 14px 16px;
  text-align: center;
}
.stat-ticker-item .val {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.4rem;
  font-weight: 300;
  color: #D4A843;
  line-height: 1;
}
.stat-ticker-item .lbl {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.55rem;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.3);
  text-transform: uppercase;
  margin-top: 4px;
}

/* ── Intelligence brief header style ─────────────────────────── */
.intel-header {
  border-left: 3px solid var(--gold, #D4A843);
  padding-left: 16px;
  margin-bottom: 24px;
}
.intel-header .eyebrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.55rem;
  letter-spacing: 4px;
  color: var(--gold, #D4A843);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.intel-header h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 300;
  color: #F5F0E8;
  line-height: 1.25;
}

/* ── Section dividers ─────────────────────────────────────────── */
.section-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 4px;
  color: var(--gold, #D4A843);
  text-transform: uppercase;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(212,168,67,0.15);
}

/* ── Premium card with left accent ───────────────────────────── */
.card-accent {
  background: rgba(0,0,0,0.25);
  border: 1px solid rgba(212,168,67,0.1);
  border-left: 3px solid var(--gold, #D4A843);
  border-radius: 0 3px 3px 0;
  padding: 20px;
}

/* ── Stress indicator bars ────────────────────────────────────── */
.stress-bar {
  height: 3px;
  border-radius: 2px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
  margin-top: 6px;
}
.stress-bar-fill { height: 100%; border-radius: 2px; transition: width 0.6s ease; }
.stress-bar-fill.severe  { background: #EF4444; }
.stress-bar-fill.stress  { background: #F59E0B; }
.stress-bar-fill.stable  { background: #22C55E; }

/* ── Monospace data values ────────────────────────────────────── */
.mono { font-family: 'JetBrains Mono', 'Courier New', monospace; }

/* ── Hero gradient overlay (Bloomberg terminal feel) ─────────── */
.terminal-bg {
  background:
    radial-gradient(ellipse at 20% 50%, rgba(212,168,67,0.04) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(212,168,67,0.03) 0%, transparent 50%),
    #0D0603;
}

/* ── Footer ───────────────────────────────────────────────────── */
footer {
  border-top: 1px solid rgba(212,168,67,0.12);
  padding: 32px 24px;
  margin-top: 80px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,0.2);
  text-align: center;
}
footer a { color: rgba(255,255,255,0.3); }
footer a:hover { color: var(--gold, #D4A843); }

/* ── Mobile: full width containers on small screens ─────────── */
@media (max-width: 900px) {
  .stat-ticker           { grid-template-columns: 1fr 1fr; }
  .card-accent           { border-left-width: 2px; }
}

@media (max-width: 480px) {
  .stat-ticker           { grid-template-columns: 1fr; }
  .intel-header          { padding-left: 12px; }
  .section-label::after  { display: none; }
}

/* ── Ensure text never overflows on small screens ────────────── */
@media (max-width: 480px) {
  p, li, .sec-body {
    word-break: break-word;
    overflow-wrap: break-word;
    hyphens: none;
    max-width: 100%;
  }
  [style*="max-width"] {
    max-width: 100%;
  }
}

/* ================================================================
   PURAHU+ COMPONENT SYSTEM
   Replace all repeated inline styles with these classes
   Every pattern used 2+ times across pages is here
   ================================================================ */

/* ── Wrappers / containers ────────────────────────────────────── */
.p-wrap      { max-width:1100px; margin:0 auto; padding:0 24px; }
.p-wrap-hero { max-width:1100px; margin:0 auto; padding:80px 24px 48px; }
.p-wrap-md   { max-width:760px;  margin:0 auto; padding:0 24px; }
.p-wrap-sm   { max-width:560px;  margin:0 auto; padding:0 24px; }

/* ── Section spacing ──────────────────────────────────────────── */
.p-gap-xs  { margin-bottom:8px; }
.p-gap-sm  { margin-bottom:16px; }
.p-gap-md  { margin-bottom:24px; }
.p-gap-lg  { margin-bottom:48px; }
.p-gap-xl  { margin-bottom:80px; }

/* ── Text alignment ───────────────────────────────────────────── */
.t-center  { text-align:center; }
.t-right   { text-align:right; }
.t-left    { text-align:left; }

/* ── Barlow Condensed text styles ────────────────────────────── */
.t-label   {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.58rem; letter-spacing:4px;
  color:var(--gold,#D4A843); text-transform:uppercase;
}
.t-label-sm {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.55rem; letter-spacing:3px;
  color:var(--gold,#D4A843); text-transform:uppercase;
}
.t-label-dim {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.6rem; letter-spacing:2px;
  color:rgba(255,255,255,0.35); text-transform:uppercase;
}
.t-body-bc {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.85rem; color:rgba(255,255,255,0.65);
  line-height:1.6;
}
.t-body-sm {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.75rem; color:rgba(255,255,255,0.45);
  line-height:1.6;
}
.t-mono {
  font-family:'JetBrains Mono','Courier New',monospace;
  font-size:0.85rem; font-weight:600;
}

/* ── Cormorant Garamond serif headings ────────────────────────── */
.t-serif-xl {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.8rem,5vw,3rem);
  font-weight:300; line-height:1.2; color:#F5F0E8;
}
.t-serif-lg {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.4rem,4vw,2.2rem);
  font-weight:300; color:#F5F0E8; line-height:1.25;
}
.t-serif-md {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.1rem,3vw,1.6rem);
  font-weight:300; color:rgba(255,255,255,0.8);
}

/* ── Color utilities ──────────────────────────────────────────── */
.c-gold   { color:var(--gold,#D4A843); }
.c-white  { color:rgba(255,255,255,0.85); }
.c-dim    { color:rgba(255,255,255,0.45); }
.c-red    { color:#EF4444; }
.c-amber  { color:#F59E0B; }
.c-green  { color:#22C55E; }

/* ── Flex row helpers ─────────────────────────────────────────── */
.f-row         { display:flex; align-items:center; }
.f-row-gap     { display:flex; align-items:center; gap:10px; }
.f-row-between { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.f-row-center  { display:flex; align-items:center; justify-content:center; gap:12px; }

/* ── Signal table rows ────────────────────────────────────────── */
.sig-hdr {
  display:grid; grid-template-columns:1fr 80px 100px 120px;
  padding:10px 16px;
  background:rgba(212,168,67,0.05);
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.58rem; letter-spacing:3px;
  color:rgba(255,255,255,0.3);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.sig-r {
  display:grid; grid-template-columns:1fr 80px 100px 120px;
  padding:13px 16px; align-items:center;
  border-bottom:1px solid rgba(255,255,255,0.04);
  transition:background 0.15s;
}
.sig-r:hover { background:rgba(255,255,255,0.02); }
.sig-r:last-child { border-bottom:none; }

.sov-info  { display:flex; align-items:center; gap:10px; }
.sov-flag  { font-size:1.1rem; }
.sov-name  { font-family:'Barlow Condensed',sans-serif; font-size:0.85rem; color:rgba(255,255,255,0.85); }
.sov-curr  { font-family:'Barlow Condensed',sans-serif; font-size:0.6rem; color:rgba(255,255,255,0.3); margin-top:1px; }

/* ── Band badges ──────────────────────────────────────────────── */
.badge {
  display:inline-block; padding:3px 10px; border-radius:2px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.62rem; letter-spacing:1px; text-align:center;
}
.badge-severe { background:rgba(239,68,68,0.12);  color:#EF4444; }
.badge-stress { background:rgba(245,158,11,0.12); color:#F59E0B; }
.badge-mod    { background:rgba(245,158,11,0.08); color:#F59E0B; }
.badge-strong { background:rgba(34,197,94,0.12);  color:#22C55E; }

/* ── Trend indicators ─────────────────────────────────────────── */
.trend-w { font-family:'Barlow Condensed',sans-serif; font-size:0.7rem; color:#EF4444; text-align:right; }
.trend-i { font-family:'Barlow Condensed',sans-serif; font-size:0.7rem; color:#22C55E; text-align:right; }
.trend-s { font-family:'Barlow Condensed',sans-serif; font-size:0.7rem; color:rgba(255,255,255,0.35); text-align:right; }

/* ── Small card (teaser/locked items) ────────────────────────── */
.card-sm {
  padding:12px;
  background:rgba(212,168,67,0.05);
  border:1px solid rgba(212,168,67,0.1);
  border-radius:2px;
}
.card-locked {
  padding:14px;
  background:rgba(0,0,0,0.2);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:2px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.68rem; color:rgba(255,255,255,0.5);
}
.card-locked .lock-icon { margin-right:6px; opacity:0.4; }

/* ── CTA footnote ─────────────────────────────────────────────── */
.cta-note {
  margin-top:10px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.6rem; color:rgba(255,255,255,0.25);
  text-align:center;
}

/* ── Live indicator ───────────────────────────────────────────── */
.live-pill {
  display:inline-flex; align-items:center; gap:6px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.62rem; letter-spacing:2px;
  color:rgba(255,255,255,0.4);
}
.live-pill::before {
  content:'';
  display:inline-block; width:7px; height:7px;
  background:#22C55E; border-radius:50%;
  animation:pulse-dot 2s infinite;
}

/* ── Mobile component collapse ────────────────────────────────── */
@media (max-width: 640px) {
  .sig-hdr  { grid-template-columns:1fr 60px 80px; }
  .sig-r    { grid-template-columns:1fr 60px 80px; font-size:0.72rem; }
  .sig-r > *:last-child { display:none; }
  .p-wrap, .p-wrap-hero, .p-wrap-md { padding-left:14px; padding-right:14px; }
}

/* ── Additional component classes — extracted from inline styles ── */

/* From rtu.html */
.p-panel     { background:var(--d2,#1A0A06); padding:16px 18px; }
.p-panel-lg  { background:rgba(0,0,0,.3); border:1px solid var(--border,rgba(212,168,67,.2)); padding:20px; border-radius:3px; }
.p-panel-sm  { background:rgba(0,0,0,.3); padding:12px; border-radius:3px; }
.p-nowrap    { white-space:nowrap; }

/* From index.html */
.c-gold-d4   { color:var(--gold,#D4A843); }
.p-panel-28  { background:var(--d2,#1A0A06); padding:28px 24px; }
.t-stat-num  { font-size:1.8rem; margin-bottom:12px; font-family:'Barlow Condensed',sans-serif; font-weight:300; color:var(--gold,#D4A843); }
.t-bc-78     { font-family:'Barlow Condensed',sans-serif; font-size:0.78rem; font-weight:600; letter-spacing:1px; color:rgba(255,255,255,0.85); }
.t-bc-65     { font-family:'Barlow Condensed',sans-serif; font-size:0.65rem; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.45); }
.t-body-85   { font-size:0.85rem; color:rgba(255,255,255,0.55); line-height:1.75; }
.t-body-80   { font-size:0.8rem; color:rgba(255,255,255,0.5); line-height:1.6; }

/* From ai-labor.html */
.ai-score-row { display:flex; justify-content:space-between; font-family:'Barlow Condensed',sans-serif; font-size:0.72rem; align-items:center; }
.ai-col       { display:flex; flex-direction:column; gap:8px; }
.c-muted-7    { color:rgba(255,255,255,0.7); }
.c-muted-3    { color:rgba(255,255,255,0.3); }

/* From pricing.html */
.p-tier-card  { padding:28px; background:var(--d2,#1A0A06); border:1px solid rgba(212,168,67,.15); border-radius:3px; }
.t-price-link { color:var(--gold,#D4A843); font-size:0.8rem; }
.t-tier-feat  { font-family:'Barlow Condensed',sans-serif; font-size:0.75rem; letter-spacing:1px; color:rgba(255,255,255,.6); }
.p-m-48       { margin:48px 0; }

/* From historical.html */
.hist-factor  { padding:10px; background:rgba(245,158,11,.06); border-radius:2px; border:1px solid rgba(245,158,11,.15); }
.hist-factor .factor-name { font-family:'Barlow Condensed',sans-serif; font-size:0.62rem; color:#F59E0B; }
.hist-factor .factor-val  { font-family:'Barlow Condensed',sans-serif; font-size:0.7rem; color:rgba(255,255,255,.5); margin-top:2px; }

/* ================================================================
   EXTRACTED INLINE STYLE CLASSES
   Every pattern used 2+ times is here — use class instead of style
   ================================================================ */

/* ── Colour utilities ─────────────────────────────────────────── */
.c-dim3    { color:rgba(255,255,255,0.3); }
.c-dim4    { color:rgba(255,255,255,0.4); }
.c-dim5    { color:rgba(255,255,255,0.5); }
.c-dim55   { color:rgba(255,255,255,0.55); }
.c-gold-fw { color:var(--gold,#D4A843); font-weight:700; letter-spacing:2px; }
.c-gold-sm { color:var(--gold); font-size:0.8rem; }
.fw6       { font-weight:600; }
.fw7       { font-weight:700; }

/* ── Margin/padding shorthands ────────────────────────────────── */
.ml-16     { margin-left:16px; }
.mt-6      { margin-top:6px; }
.mb-0      { margin-bottom:0; }
.p-28      { padding:28px; background:var(--d2,#1A0A06); }

/* ── Flex layouts ─────────────────────────────────────────────── */
.f-footer  { max-width:1100px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; }
.f-links   { display:flex; gap:20px; flex-wrap:wrap; }
.f-sb-mb   { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; margin-bottom:12px; }

/* ── Typography — Barlow Condensed ───────────────────────────── */
.bc-label3 { font-family:'Barlow Condensed',sans-serif; font-size:0.58rem; color:rgba(255,255,255,0.35); letter-spacing:2px; text-transform:uppercase; }
.bc-sm     { font-family:'Barlow Condensed',sans-serif; font-size:0.6rem;  letter-spacing:2px; color:#D4A843; }
.bc-md     { font-family:'Barlow Condensed',sans-serif; font-size:0.65rem; letter-spacing:3px; text-transform:uppercase; }
.bc-body   { font-family:'Barlow Condensed',sans-serif; font-size:0.78rem; font-weight:700; letter-spacing:1px; }
.bc-68     { font-family:'Barlow Condensed',sans-serif; font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; }
.bc-70     { font-family:'Barlow Condensed',sans-serif; font-size:0.7rem;  color:rgba(255,255,255,0.5); margin-top:4px; }
.bc-link   { color:rgba(255,255,255,0.3); text-decoration:none; font-size:0.75rem; }

/* ── Typography — Cormorant Garamond ─────────────────────────── */
.cg-md     { font-family:'Cormorant Garamond',serif; font-size:1.2rem; color:rgba(255,255,255,0.8); font-weight:300; }
.cg-18     { font-size:1.8rem; margin-bottom:12px; }

/* ── Body text ────────────────────────────────────────────────── */
.body-lg   { font-size:0.9rem; color:rgba(255,255,255,0.4); }
.body-sm   { font-size:0.85rem; color:rgba(255,255,255,0.55); line-height:1.75; margin:0; }
.body-sm2  { font-size:0.8rem;  color:rgba(255,255,255,0.5);  line-height:1.6;  margin:0; }

/* ── Status cards (ai-labor, historical) ─────────────────────── */
.card-amber { padding:10px; background:rgba(245,158,11,0.06); border-radius:2px; border:1px solid rgba(245,158,11,0.15); }
.card-amber .lbl { font-family:'Barlow Condensed',sans-serif; font-size:0.62rem; color:#F59E0B; }

/* ── Row types ────────────────────────────────────────────────── */
.row-signal { display:flex; justify-content:space-between;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.72rem; color:rgba(255,255,255,0.6);
  padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.05); }

/* ── Display none (hidden by default) ────────────────────────── */
.d-none { display:none; }

/* ================================================================
   FINAL COMPONENT PASS — replaces remaining repeated inline patterns
   ================================================================ */

/* ── Page hero sections ───────────────────────────────────────── */
.page-hero {
  max-width:1100px; margin:0 auto;
  padding:72px 24px 48px;
}
.page-hero .eyebrow {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.58rem; letter-spacing:4px;
  color:var(--gold,#D4A843); text-transform:uppercase;
  margin-bottom:10px;
}
.page-hero h1 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.8rem,5vw,3rem);
  font-weight:300; color:#F5F0E8;
  line-height:1.2; margin-bottom:16px;
}
.page-hero .sub {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.85rem; color:rgba(255,255,255,0.45);
  max-width:580px; line-height:1.75;
}

/* ── Content blocks ───────────────────────────────────────────── */
.content-block {
  max-width:1100px; margin:0 auto; padding:0 24px 48px;
}
.content-block-lg {
  max-width:1100px; margin:0 auto; padding:0 24px 80px;
}

/* ── Pricing cards ────────────────────────────────────────────── */
.price-card {
  background:rgba(0,0,0,0.25);
  border:1px solid rgba(212,168,67,0.15);
  border-radius:3px; padding:32px;
}
.price-card.featured {
  border-color:rgba(212,168,67,0.4);
  background:rgba(212,168,67,0.03);
}
.price-val {
  font-family:'Barlow Condensed',sans-serif;
  font-size:2.4rem; font-weight:300;
  color:var(--gold,#D4A843); line-height:1;
}
.price-period {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.65rem; color:rgba(255,255,255,0.35);
  margin-top:4px;
}
.price-feature {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.72rem; color:rgba(255,255,255,0.55);
  padding:7px 0; border-bottom:1px solid rgba(255,255,255,0.05);
  display:flex; align-items:center; gap:8px;
}
.price-feature::before { content:'✓'; color:var(--gold,#D4A843); flex-shrink:0; }
.price-feature:last-child { border-bottom:none; }

/* ── AI Labor vulnerability index ────────────────────────────── */
.vuln-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:12px; margin:20px 0;
}
.vuln-card {
  background:rgba(0,0,0,0.2);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:3px; padding:14px;
}
.vuln-card.high   { border-color:rgba(239,68,68,0.2); }
.vuln-card.medium { border-color:rgba(245,158,11,0.2); }
.vuln-card.low    { border-color:rgba(34,197,94,0.2); }

.vuln-header {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.55rem; letter-spacing:2px;
  text-transform:uppercase; margin-bottom:10px;
}
.vuln-card.high   .vuln-header { color:#EF4444; }
.vuln-card.medium .vuln-header { color:#F59E0B; }
.vuln-card.low    .vuln-header { color:#22C55E; }

.vuln-row {
  display:flex; justify-content:space-between;
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.72rem; margin-bottom:7px;
  align-items:center;
}
.vuln-row .country { color:rgba(255,255,255,0.7); }
.vuln-row .score   { font-weight:600; }
.vuln-card.high   .vuln-row .score { color:#EF4444; }
.vuln-card.medium .vuln-row .score { color:#F59E0B; }
.vuln-card.low    .vuln-row .score { color:#22C55E; }

/* ── Metric stats (used in index + admin) ─────────────────────── */
.metric-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:12px; margin:24px 0;
}
.metric-box {
  background:rgba(0,0,0,0.2);
  border:1px solid rgba(212,168,67,0.1);
  border-radius:3px; padding:18px;
  text-align:center;
}
.metric-val {
  font-family:'Barlow Condensed',sans-serif;
  font-size:2rem; font-weight:300;
  color:var(--gold,#D4A843); line-height:1;
  margin-bottom:6px;
}
.metric-label {
  font-family:'Barlow Condensed',sans-serif;
  font-size:0.58rem; letter-spacing:2px;
  color:rgba(255,255,255,0.35); text-transform:uppercase;
}
.metric-sub {
  font-size:0.65rem; color:rgba(255,255,255,0.2);
  margin-top:3px; font-family:'Barlow Condensed',sans-serif;
}

/* ── Mobile responsive for new components ─────────────────────── */
@media (max-width:640px) {
  .page-hero            { padding:48px 16px 32px; }
  .content-block,
  .content-block-lg     { padding-left:16px; padding-right:16px; }
  .price-card           { padding:20px; }
  .metric-grid          { grid-template-columns:1fr 1fr; }
  .vuln-grid            { grid-template-columns:1fr; }
}

/* ================================================================
   MOBILE CARD + TEXT FIX — prevents word-by-word vertical wrapping
   ================================================================ */
@media (max-width: 768px) {

  /* Cards must be full width — no narrow columns */
  .p-card, .u-card, .card-accent, .card-sm, .price-card,
  .hero-card, .signal-card, .corridor-card, .tier-card,
  [style*="max-width:480px"], [style*="max-width:520px"],
  [style*="max-width:440px"] {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  /* Text wrapping — no aggressive hyphenation */
  p, li, h1, h2, h3, div {
    word-break: normal !important;
    overflow-wrap: break-word;
    hyphens: none !important;
  }

  /* Grid columns must collapse */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1fr 80px 100px 120px"] {
    grid-template-columns: 1fr !important;
  }

  /* Ensure text containers use full width */
  .t-body-bc, .t-body-sm, .sec-body {
    max-width: 100% !important;
    width: 100%;
  }
}

/* ── RTU Engine dropdowns — full width on mobile ──────────────── */
@media (max-width: 640px) {
  select, .sov-select {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 0.85rem;
  }
  .engine-row, .corridor-row {
    flex-direction: column !important;
    gap: 12px !important;
  }
}

/* ================================================================
   MOBILE FINAL — centralized responsive system
   ================================================================ */

/* ── Global hyphen kill — no word splitting anywhere ─────────── */
* {
  -webkit-hyphens: none !important;
  -ms-hyphens: none !important;
  hyphens: none !important;
}

/* ── All text: normal word break ────────────────────────────────*/
p, li, span, div, h1, h2, h3, h4, a, button, label {
  word-break: normal;
  overflow-wrap: break-word;
}

/* ── Mobile — containers & cards ────────────────────────────── */
@media (max-width: 768px) {

  /* Every card type becomes full width */
  .p-card, .u-card, .card-accent, .card-sm, .card-locked,
  .price-card, .tier-card, .hero-card, .signal-card,
  .corridor-card, .comparison-card, .vuln-card,
  .stat-ticker-item, .metric-box {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  /* All grids collapse */
  .p-grid-2, .p-grid-3, .p-grid-auto,
  .stat-ticker, .metric-grid, .vuln-grid,
  .tier-grid {
    grid-template-columns: 1fr !important;
  }

  /* Text containers fill width */
  p, .t-body-bc, .t-body-sm, .sec-body {
    max-width: 100% !important;
    width: 100%;
  }

  /* Remove fixed widths that cause narrow columns */
  [style*="max-width:480px"],
  [style*="max-width:520px"],
  [style*="max-width:440px"],
  [style*="max-width:400px"] {
    max-width: 100% !important;
  }
}

/* ── Small mobile ────────────────────────────────────────────── */
@media (max-width: 480px) {
  .btn-primary, .btn-ghost, .btn-nav-cta {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
  .f-row, .f-row-gap, .f-row-between {
    flex-wrap: wrap;
  }
}

/* ================================================================
   DEFINITIVE TEXT RENDERING — overrides everything above
   Applied LAST so it wins all specificity wars
   ================================================================ */

/* ── Kill ALL hyphenation everywhere, no exceptions ───────────── */
html, html * {
  -webkit-hyphens: none !important;
  -moz-hyphens:    none !important;
  -ms-hyphens:     none !important;
  hyphens:         none !important;
}

/* ── Normal word breaking for all body text ─────────────────────
   word-break:normal = only break at normal break points (spaces)
   overflow-wrap:break-word = only wrap if word TRULY won't fit   */
body, p, li, span, h1, h2, h3, h4, h5, h6,
div, section, article, aside, main,
a, button, label, td, th {
  word-break: normal;
  overflow-wrap: break-word;
}

/* ── Only break-word on truly long strings (URLs, codes) ────────*/
.key-display, code, pre, [class*="key"], [class*="code"] {
  word-break: break-all;
  overflow-wrap: anywhere;
}

/* ════════════════════════════════════════════════════════════════
   MOBILE TEXT — phones and small tablets
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── Text sizes: readable but not huge ──────────────────────── */
  p, li { font-size: 0.92rem; line-height: 1.75; }

  /* ── Containers: never let text get squeezed ────────────────── */
  p, .sec-body, .t-body-bc, .t-body-sm {
    max-width: 100% !important;
    width: 100% !important;
  }

  /* ── All cards: full viewport width ─────────────────────────── */
  .p-card, .u-card, .card-accent, .card-sm, .card-locked,
  .price-card, .tier-card, .hero-card, .signal-card,
  .corridor-card, .comparison-card, .vuln-card,
  .metric-box, .stat-ticker-item {
    width:     100% !important;
    max-width: 100% !important;
    min-width:  0   !important;
    box-sizing: border-box !important;
  }

  /* ── All grids collapse to single column ────────────────────── */
  .p-grid-2, .p-grid-3, .p-grid-auto,
  .stat-ticker, .metric-grid, .vuln-grid, .tier-grid,
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: repeat(2"],
  [style*="grid-template-columns: repeat(3"] {
    grid-template-columns: 1fr !important;
  }

  /* ── Flex: wrap and don't constrain children ─────────────────── */
  .f-row, .f-row-gap, .f-row-between, .f-row-center {
    flex-wrap: wrap !important;
  }
  .f-row > *, .f-row-gap > *, .f-row-between > * {
    min-width: 0;
    flex-shrink: 1;
  }

  /* ── Fix max-width on inline containers ─────────────────────── */
  [style*="max-width:480px"], [style*="max-width:520px"],
  [style*="max-width:440px"], [style*="max-width:400px"],
  [style*="max-width:360px"] {
    max-width: 100% !important;
    width: 100% !important;
  }

  /* ── Hero heading — clamp to viewport ───────────────────────── */
  h1 { font-size: clamp(1.5rem, 7vw, 2.4rem) !important; }
  h2 { font-size: clamp(1.2rem, 5.5vw, 1.8rem) !important; }
  h3 { font-size: clamp(1rem, 4.5vw, 1.4rem) !important; }

  /* ── Section padding ─────────────────────────────────────────── */
  .p-wrap, .p-wrap-hero, .p-hero, .p-section, .content-block,
  [style*="padding:80px"], [style*="padding: 80px"] {
    padding-left:  16px !important;
    padding-right: 16px !important;
  }
  .p-wrap-hero, .page-hero, [style*="padding:80px 24px"] {
    padding-top: 40px !important;
  }
}

/* ── 480px and below: very small phones ─────────────────────────*/
@media (max-width: 480px) {
  p, li    { font-size: 0.88rem; line-height: 1.7; }
  h1       { font-size: clamp(1.3rem, 8vw, 1.8rem) !important; }

  .btn-primary, .btn-ghost {
    width: 100%;
    justify-content: center;
  }

  /* Signal table: 2 columns only on tiny screens */
  .sig-hdr, .sig-r {
    grid-template-columns: 1fr 65px !important;
  }
  .sig-hdr > *:nth-child(3),
  .sig-hdr > *:nth-child(4),
  .sig-r > *:nth-child(3),
  .sig-r > *:nth-child(4) {
    display: none !important;
  }
}

/* ── Nav hamburger z-index fix ──────────────────────────────────*/
nav {
  z-index: 10000 !important;
}




body.menu-open { overflow: hidden; }

/* ================================================================
   FINAL LINK OVERRIDE — last rule in file, wins ALL conflicts
   Prevents blue/purple appearing anywhere in any context
   ================================================================ */
a, a:any-link, a:link, a:visited, a:active, a:hover, a:focus,
nav a, nav a:visited, footer a, footer a:visited,
.nav-link, .nav-link:visited, .btn-nav-cta, .btn-nav-cta:visited,
.btn-primary, .btn-primary:visited, .btn-ghost, .btn-ghost:visited {
  color: currentColor !important;
  text-decoration: none !important;
  -webkit-text-fill-color: currentColor !important;
}

/* ── Inline grid override — collapses ALL inline grid-template-columns on mobile */
@media (max-width: 768px) {
  [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:repeat(2"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns:repeat(auto-fit"] {
    grid-template-columns: 1fr !important;
  }
}


/* ================================================================
   ABSOLUTE FINAL TEXT OVERRIDE
   This is the LAST block in the CSS file.
   It wins every specificity war above.
   ================================================================ */

/* Base: normal word break everywhere, always */
html, html * {
  -webkit-hyphens: none !important;
  -moz-hyphens: none !important;
  hyphens: none !important;
  word-break:       normal !important;
  overflow-wrap:    normal !important;
}

/* Only allow breaking on genuinely unbreakable long strings */
code, pre, .key-display, [class*="api-key"], [class*="token"] {
  word-break:    break-all !important;
  overflow-wrap: anywhere !important;
}

/* Mobile — every container must be full width, no squeezing text */
@media (max-width: 768px) {

  /* Text nodes */
  p, li, span, h1, h2, h3, h4, h5, h6,
  .sec-body, .t-body-bc, .t-body-sm,
  .comparison-card p, .signal-card p,
  .case-card p, .card-accent p, .u-card p {
    word-break:    normal   !important;
    overflow-wrap: normal   !important;
    hyphens:       none     !important;
    line-height:   1.75     !important;
    max-width:     100%     !important;
  }

  /* All card types: full width, no min-width squeezing */
  .comparison-card, .signal-card, .case-card,
  .card-accent, .u-card, .p-card, .tier-card,
  .price-card, .hero-card, .metric-box,
  .vuln-card, .card-sm, .stat-ticker-item {
    width:     100% !important;
    max-width: 100% !important;
    min-width: 0    !important;
    box-sizing: border-box !important;
  }

  /* Grid collapse — every possible variant */
  .comparison-grid, .cards-grid, .insight-grid,
  .p-grid-2, .p-grid-3, .p-grid-auto,
  .tier-grid, .metric-grid, .vuln-grid,
  .stat-ticker {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* Historical/crisis cards — force flow layout */
  .crisis-card, .timeline-card, .historical-card,
  .event-card, .replay-card {
    position:      relative  !important;
    inset:         auto      !important;
    transform:     none      !important;
    width:         100%      !important;
    margin-bottom: 20px      !important;
  }
}

@media (max-width: 480px) {
  p, li {
    font-size: 0.88rem  !important;
    line-height: 1.7    !important;
  }
}

/* ── Mobile drawer: slide-in from right (smoother UX) ─────────── */
@media (max-width: 900px) {
  
  
  
  
  body.menu-open { overflow: hidden !important; }
}

/* ── Drawer links: no text elongation, full width ────────────── */

/* ================================================================
   NAVIGATION SYSTEM — SINGLE SOURCE (consolidated from 21 rules)
   nav + hamburger + drawer. No duplicates. No conflicts.
   ================================================================ */

/* Nav isolates its own stacking context so nothing traps taps */
nav {
  isolation: isolate;
  z-index: 99999 !important;
}

/* ── Hamburger button (mobile only) ──────────────────────────── */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 32px;
  height: 32px;
  padding: 5px;
  background: transparent;
  border: none;
  cursor: pointer;
  position: relative;
  z-index: 100000;
  margin-left: auto;
}
.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: rgba(255,255,255,0.7);
  border-radius: 2px;
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Mobile drawer — slides in from right ────────────────────── */
#nav-mobile-drawer {
  position: fixed;
  top: var(--nav-h, 58px);
  right: -100%;
  width: min(320px, 85vw);
  height: calc(100vh - var(--nav-h, 58px));
  background: #0A0502;
  border-left: 1px solid rgba(212,168,67,0.2);
  z-index: 99998;
  display: flex;
  flex-direction: column;
  transition: right 0.3s ease;
  overflow-y: auto;
  visibility: hidden;
}
#nav-mobile-drawer.open {
  right: 0;
  visibility: visible;
}
#nav-mobile-drawer .nav-link {
  display: block;
  width: 100%;
  height: auto;
  padding: 16px 24px;
  font-size: 0.78rem;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.65);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
#nav-mobile-drawer .nav-link:hover { color: #D4A843; }
#nav-mobile-drawer .btn-nav-cta {
  margin: 16px 24px;
  justify-content: center;
  text-align: center;
}

/* ── Show hamburger, hide desktop nav below 900px ───────────── */
@media (max-width: 900px) {
  .nav-hamburger { display: flex; }
  .nav-links     { display: none; }
  .nav-right     { display: none; }
}

body.menu-open { overflow: hidden; }

/* ================================================================
   DIVERGENCE SPOTLIGHT CARD (homepage)
   ================================================================ */
.div-spotlight {
  max-width: 420px;
  margin: 40px auto;
  background: linear-gradient(160deg, rgba(20,10,5,0.6), rgba(0,0,0,0.4));
  border: 1px solid rgba(212,168,67,0.25);
  border-radius: 4px;
  padding: 28px;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.ds-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 20px;
}
.ds-eyebrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.55rem; letter-spacing: 3px; text-transform: uppercase;
  color: #D4A843;
}
.live-pill-sm {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.5rem; letter-spacing: 2px;
  color: #EF4444; border: 1px solid rgba(239,68,68,0.4);
  padding: 2px 8px; border-radius: 10px;
  animation: dsPulse 2s infinite;
}
@keyframes dsPulse { 0%,100%{opacity:1;} 50%{opacity:0.4;} }
.ds-flag { font-size: 2.4rem; line-height: 1; margin-bottom: 8px; }
.ds-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.6rem; font-weight: 300; color: #F5F0E8;
}
.ds-curr {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.62rem; letter-spacing: 2px; text-transform: uppercase;
  color: rgba(255,255,255,0.35); margin-bottom: 22px;
}
.ds-split {
  display: grid; grid-template-columns: 1fr auto 1fr;
  gap: 12px; align-items: center; margin-bottom: 22px;
}
.ds-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.5rem; letter-spacing: 2px; text-transform: uppercase;
  color: rgba(255,255,255,0.3); margin-bottom: 6px;
}
.ds-val {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.82rem; line-height: 1.3; font-weight: 500;
}
.ds-market { color: rgba(255,255,255,0.55); }
.ds-rtu { color: #EF4444; }
.ds-arrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.6rem; color: rgba(212,168,67,0.5);
  letter-spacing: 1px;
}
.ds-score {
  border-top: 1px solid rgba(212,168,67,0.12);
  border-bottom: 1px solid rgba(212,168,67,0.12);
  padding: 16px 0; margin-bottom: 18px;
}
.ds-score-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 3rem; font-weight: 300; color: #EF4444; line-height: 1;
}
.ds-score-band {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.58rem; letter-spacing: 2px; color: rgba(239,68,68,0.7);
  margin-top: 4px;
}
.ds-note {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.72rem; line-height: 1.6; color: rgba(255,255,255,0.4);
  margin-bottom: 22px;
}
.ds-cta {
  display: inline-block;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.7rem; letter-spacing: 2px; text-transform: uppercase;
  background: #D4A843; color: #0D0603 !important;
  padding: 12px 28px; border-radius: 2px; font-weight: 600;
}
.ds-cta:hover { background: #E0B654; }

@media (max-width: 480px) {
  .div-spotlight { margin: 24px 16px; padding: 22px; }
  .ds-split { grid-template-columns: 1fr; gap: 14px; }
  .ds-arrow { display: none; }
}
