/* Pakistan Investment Advisor — professional dashboard system.
   Uses Proxima Nova when available, with Inter as the web fallback. */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap");

/* ── Tokens ─────────────────────────────────────────────── */
:root{
  --paper:#F5F7FA;
  --paper2:#FFFFFF;
  --paper3:#EEF2F6;
  --ink:#111827;
  --ink2:#374151;
  --green:#075E4B;
  --green2:#0B755F;
  --green3:#12A87D;
  --green-light:#E6F6F0;
  --gold:#F2B94B;
  --gold2:#B7791F;
  --gold-light:#FFF7E6;
  --gold-pale:#F8D98A;
  --navy:#2854C5;
  --navy-light:#E9EEFF;
  --red:#C24132;
  --red-light:#FDEBE8;
  --bg:var(--paper);
  --card:var(--paper2);
  --border:#DDE3EA;
  --border2:#C8D1DC;
  --muted:#667085;
  --radius:8px;
  --shadow:0 1px 2px rgba(16,24,40,.05),0 10px 28px -18px rgba(16,24,40,.35);
  --shadow-lg:0 8px 22px -16px rgba(16,24,40,.45),0 20px 48px -28px rgba(16,24,40,.38);
  --serif:'Proxima Nova','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --display:'Proxima Nova','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'IBM Plex Mono','SF Mono',Menlo,monospace;
  --site-header-height:64px;
}

/* ── Reset & base ───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--serif);
  font-size:1rem;
  background:var(--paper);
  background-image:linear-gradient(180deg,#F8FAFC 0%,#F4F7FA 48%,#EEF3F7 100%);
  color:var(--ink2);
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body::before{
  content:none;
}
img{max-width:100%}
a{color:var(--green);text-decoration:none}
a:hover{text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px}
::selection{background:var(--gold-pale);color:var(--ink)}

/* ── Typography ─────────────────────────────────────────── */
h1,h2{font-family:var(--display);letter-spacing:0}
h1{font-size:2.45rem;font-weight:800;color:var(--green);margin-bottom:12px;line-height:1.02}
h2{font-size:1.8rem;font-weight:750;color:var(--ink);margin:34px 0 12px;line-height:1.18}
h3{font-family:var(--display);font-size:1.08rem;font-weight:700;color:var(--green);margin:20px 0 6px}
p{line-height:1.72;color:var(--ink2);margin-bottom:15px}
ul,ol{margin:0 0 16px 24px;line-height:1.78;color:var(--ink2)}
li{margin-bottom:3px}
strong{color:var(--ink);font-weight:600}
.lead{font-size:1.08rem;color:var(--muted);margin-bottom:32px;line-height:1.7}
.subtitle{color:var(--muted);margin-bottom:36px;font-size:1rem}
.byline{font-family:var(--mono);font-size:.72rem;letter-spacing:0;text-transform:uppercase;color:var(--muted);margin-bottom:28px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.byline a{color:var(--green)}
.highlight{background:var(--green-light);border:1px solid var(--border);border-left:4px solid var(--green3);border-radius:var(--radius);padding:14px 18px;margin-bottom:14px;font-size:.95rem;color:var(--green);font-weight:600}

/* ── Layout ─────────────────────────────────────────────── */
.container{max-width:1040px;margin:0 auto;padding:0 20px}
.container-wide{max-width:1180px;margin:0 auto;padding:0 20px}
article .container,body>.container{padding-top:40px;padding-bottom:40px}

/* ── Site header ── one self-contained, robust component ──── */
/* Layout: brand on the left, primary nav + actions on the right.
   At <=900px the links collapse into a dropdown; the search and the
   menu toggle live in an always-visible actions group so the top bar
   can never lose them. Everything is scoped to .site-header. */
.site-header{
  position:sticky;top:0;z-index:300;
  background:linear-gradient(180deg,#0C4536 0%,#073729 100%);
  color:#fff;border-bottom:1px solid rgba(255,255,255,.09);
  box-shadow:0 12px 34px -24px rgba(0,0,0,.9);
}
.site-header .header-inner{
  position:relative;width:100%;max-width:1180px;margin:0 auto;padding:0 22px;
  min-height:var(--site-header-height);display:flex;align-items:center;gap:20px;
}

/* Brand */
.site-header .brand{display:inline-flex;align-items:center;gap:10px;min-width:0;margin-right:auto;color:#fff;font-family:var(--display);white-space:nowrap;flex:0 1 auto}
.site-header .brand:hover{text-decoration:none}
.site-header .brand-mark{display:block;flex:0 0 auto;width:28px;height:19px;border-radius:3px;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.site-header .brand-name{min-width:0;overflow:hidden;text-overflow:ellipsis;font-size:1.04rem;font-weight:800;letter-spacing:-.01em;color:#fff}
.site-header .brand-name span{color:var(--gold)}

/* Primary nav links */
.site-header .site-nav{display:flex;align-items:center;gap:2px}
.site-header .site-nav a{font-family:var(--display);font-size:.9rem;font-weight:700;color:rgba(255,255,255,.84);padding:9px 12px;border-radius:8px;line-height:1;white-space:nowrap;transition:background .15s,color .15s}
.site-header .site-nav a:hover{color:#fff;text-decoration:none;background:rgba(255,255,255,.1)}
.site-header .site-nav a.active{color:#0C4536;background:var(--gold)}

/* Actions group (search + menu toggle) — always visible */
.site-header .header-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}

.site-header .nav-search{
  appearance:none;display:inline-flex;align-items:center;gap:7px;
  font-family:var(--display);font-size:.84rem;font-weight:700;line-height:1;white-space:nowrap;
  color:rgba(255,255,255,.95);background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);border-radius:9px;padding:8px 12px;cursor:pointer;
  transition:background .15s,border-color .15s,color .15s;
}
.site-header .nav-search:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.38);color:#fff;text-decoration:none}
.site-header .nav-search svg{opacity:.9;flex:0 0 auto}
.site-header .nav-search kbd{font-family:var(--mono);font-size:.62rem;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:2px 5px;color:rgba(255,255,255,.78)}

.site-header .nav-toggle{
  display:none;align-items:center;justify-content:center;flex-direction:column;gap:4px;
  width:42px;height:40px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:9px;cursor:pointer;padding:0;flex:0 0 auto;
}
.site-header .nav-toggle span{display:block;width:18px;height:2px;background:#fff;border-radius:2px;transition:transform .2s,opacity .2s}
.site-header .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.site-header .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.site-header .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.data-age{font-family:var(--mono);font-size:.68rem;letter-spacing:0;opacity:.75;color:var(--muted)}
.site-header .data-age{color:rgba(255,255,255,.7)}

/* Collapse to mobile menu */
@media(max-width:900px){
  :root{--site-header-height:58px}
  .site-header .header-inner{padding:0 16px;gap:14px}
  .site-header .brand{max-width:calc(100vw - 130px)}
  .site-header .brand-name{font-size:.98rem}
  .site-header .nav-toggle{display:inline-flex}
  .site-header .site-nav{
    position:absolute;left:0;right:0;top:100%;
    display:none;flex-direction:column;align-items:stretch;gap:2px;
    background:#073729;border-top:1px solid rgba(255,255,255,.1);
    padding:10px 16px 16px;box-shadow:0 24px 34px -16px rgba(0,0,0,.8);
  }
  .site-header .site-nav.open{display:flex}
  .site-header .site-nav a{padding:13px 12px;font-size:.98rem;border-radius:8px}
  .site-header .nav-search span,
  .site-header .nav-search kbd{display:none}
  .site-header .nav-search{padding:9px}
}
@media(max-width:380px){
  .site-header .brand-name{font-size:.9rem}
}

/* ── Footer ─────────────────────────────────────────────── */
footer{
  background:#052E27;color:var(--paper2);text-align:center;
  padding:26px 18px;margin-top:56px;font-size:.82rem;
  border-top:3px solid var(--gold);
  font-family:var(--mono);letter-spacing:0;
}
footer a{color:var(--gold-pale);margin:0 10px}

/* ── Cards & panels ─────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:20px}
.card-sm{padding:16px}
.section-title{font-family:var(--display);font-size:1.85rem;font-weight:800;color:var(--ink);margin-bottom:6px}
.section-sub{color:var(--muted);font-size:.98rem;margin-bottom:20px;max-width:720px}
.section-kicker{font-family:var(--mono);font-size:.68rem;letter-spacing:0;text-transform:uppercase;font-weight:700;color:var(--green3);margin-bottom:7px}

/* ── Hero (homepage tool) ───────────────────────────────── */
.hero{
  background:#052E27;
  background-image:linear-gradient(135deg,#052E27 0%,#075E4B 54%,#1E4F8A 100%);
  color:var(--paper2);padding:64px 0 34px;text-align:left;
  border-bottom:1px solid rgba(255,255,255,.12);
  position:relative;
  overflow:hidden;
}
.hero::after{content:"";position:absolute;inset:auto -20% -42% 48%;height:360px;background:linear-gradient(135deg,rgba(242,185,75,.22),rgba(18,168,125,.1));transform:rotate(-8deg);pointer-events:none}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:34px;align-items:center}
.hero-copy{max-width:660px}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:0;text-transform:uppercase;color:var(--gold-pale);font-weight:700;margin-bottom:14px}
.hero h1{font-family:var(--display);font-size:3rem;font-weight:800;line-height:1;margin-bottom:18px;color:var(--paper2);max-width:760px}
.hero p{opacity:.88;font-size:1.12rem;max-width:610px;margin:0 0 24px;color:rgba(255,255,255,.86)}
.hero-proof{display:flex;flex-wrap:wrap;gap:10px}
.hero-proof span{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:rgba(255,255,255,.9);border-radius:999px;padding:7px 11px;font-size:.82rem;font-weight:700}
.amount-wrap{background:rgba(255,255,255,.94);border:1px solid rgba(255,255,255,.44);border-radius:8px;padding:22px;box-shadow:0 24px 60px -32px rgba(0,0,0,.45);backdrop-filter:blur(10px)}
.amount-label{font-family:var(--mono);font-size:.72rem;letter-spacing:0;text-transform:uppercase;font-weight:700;margin-bottom:10px;color:var(--muted)}
.amount-input-row{display:flex;align-items:center;background:#fff;border-radius:8px;overflow:hidden;border:1px solid var(--border2);box-shadow:inset 0 1px 0 rgba(16,24,40,.04)}
.pkr-prefix{padding:0 14px;font-family:var(--mono);font-weight:700;color:var(--green);font-size:.95rem;white-space:nowrap;border-right:1px solid var(--border);height:52px;display:flex;align-items:center;background:var(--green-light)}
#amount-input{border:none;outline:none;font-family:var(--mono);font-size:1.25rem;font-weight:700;padding:14px 12px;width:100%;color:var(--ink);background:transparent}
#amount-input{min-width:0}
.amount-error{display:none;margin-top:8px;color:var(--red);font-size:.82rem;font-weight:800}
.amount-error.visible{display:block}
.risk-toggle{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:12px 0}
.profile-option{border:1px solid var(--border);background:var(--paper3);color:var(--muted);border-radius:7px;padding:9px 8px;font-weight:800;font-size:.78rem;cursor:pointer;transition:background .2s,color .2s,border-color .2s,transform .2s}
.profile-option:hover{transform:translateY(-1px);border-color:var(--green3);color:var(--green)}
.profile-option.active{background:var(--green);color:#fff;border-color:var(--green)}
.btn-analyze{display:block;width:100%;margin-top:12px;padding:15px;background:var(--gold);color:var(--ink);font-family:var(--display);font-size:.95rem;font-weight:800;border:none;border-radius:8px;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s}
.btn-analyze:hover{background:var(--gold-pale);transform:translateY(-1px);box-shadow:0 16px 34px -22px rgba(183,121,31,.8)}
.mini-score{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-top:14px;padding-top:13px;border-top:1px solid var(--border);font-size:.82rem;color:var(--muted)}
.mini-score strong{font-family:var(--mono);color:var(--green);font-size:.9rem}
.hero-dashboard{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:32px}
.hero-metric{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:8px;padding:14px 16px;color:#fff}
.hero-metric span{display:block;font-family:var(--mono);font-size:.65rem;letter-spacing:0;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:7px}
.hero-metric strong{font-family:var(--mono);font-size:1.28rem;color:var(--gold-pale);font-variant-numeric:tabular-nums}

/* ── Hero card (guides hub) ─────────────────────────────── */
.hero-card{
  background:#052E27;
  background-image:linear-gradient(135deg,#052E27 0%,#075E4B 62%,#2854C5 100%);
  color:var(--paper2);border-radius:var(--radius);padding:40px 32px;margin-bottom:28px;
  border:1px solid rgba(255,255,255,.16);
}
.hero-card h1{color:var(--paper2);font-size:2.1rem}
.hero-card p{color:rgba(253,251,244,.85);margin:10px 0 0;font-size:1.02rem;line-height:1.7}

/* ── Progress bar & step nav (tool) ─────────────────────── */
.step-shell{background:rgba(255,255,255,.92);border-bottom:1px solid var(--border);position:sticky;top:var(--site-header-height);z-index:190;backdrop-filter:blur(12px)}
#progress-wrap{background:#E3E8EE;height:4px;overflow:hidden}
#progress-bar{height:4px;background:var(--gold);width:20%;transition:width .4s ease}
.step-nav{display:flex;gap:8px;padding:12px 0;overflow-x:auto;scrollbar-width:none}
.step-nav::-webkit-scrollbar{display:none}
.step-pill{flex-shrink:0;padding:8px 12px;border-radius:999px;font-family:var(--display);font-size:.78rem;font-weight:800;cursor:pointer;border:1px solid var(--border);background:var(--paper2);color:var(--muted);transition:all .2s;white-space:nowrap}
.step-pill.active{background:var(--green);color:var(--paper2);border-color:var(--green)}
.step-pill.done{background:var(--green-light);color:var(--green);border-color:var(--green3)}

/* ── Wizard pages ───────────────────────────────────────── */
.page{display:none;animation:fadeUp .35s ease}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* ── Macro pills ────────────────────────────────────────── */
.macro-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:24px}
.macro-pill{background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:left;box-shadow:var(--shadow);position:relative;overflow:hidden}
.macro-pill::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--gold)}
.macro-val{font-family:var(--mono);font-size:1.35rem;font-weight:700;color:var(--green);font-variant-numeric:tabular-nums}
.macro-lbl{font-family:var(--mono);font-size:.62rem;letter-spacing:0;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* ── Tables — ledger style ──────────────────────────────── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:.9rem}
th{background:var(--green);color:var(--paper2);padding:10px 13px;text-align:left;font-family:var(--mono);font-weight:500;font-size:.68rem;letter-spacing:0;text-transform:uppercase;white-space:nowrap}
td{padding:10px 13px;border-bottom:1px solid var(--border);vertical-align:middle;line-height:1.6}
tr:hover td{background:rgba(233,239,230,.5)}
tr.rec-row td{background:var(--green-light)}
.num{text-align:right;font-family:var(--mono);font-variant-numeric:tabular-nums;font-weight:500;font-size:.85rem}
.yield-hi{color:var(--green3);font-weight:700}
.chg-up{color:var(--green3)}
.chg-dn{color:var(--red)}

.comparison-table,.vs-table,.bank-table,.portfolio-table,.transmission-table{width:100%;border-collapse:collapse;margin:18px 0;font-size:.9rem}
.comparison-table th,.bank-table th,.portfolio-table th,.transmission-table th{background:var(--green);color:var(--paper2);padding:10px 14px;text-align:left}
.comparison-table td,.bank-table td,.portfolio-table td,.transmission-table td,.vs-table td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:top;line-height:1.65;color:var(--ink2)}
.comparison-table tr:nth-child(even) td,.bank-table tr:nth-child(even) td,.transmission-table tr:nth-child(even) td{background:rgba(239,232,216,.45)}
.portfolio-table tr:last-child td{border-bottom:none;font-weight:700;background:var(--paper3)}
.transmission-table tr:last-child td{border-bottom:none}
.vs-table th{padding:11px 14px;text-align:left;font-weight:500}
.vs-table th.ns{background:var(--green);color:var(--paper2)}
.vs-table th.mf{background:var(--navy);color:var(--paper2)}
.vs-table th:first-child{background:var(--paper3);color:var(--muted)}
.vs-table td:first-child{font-weight:600;background:rgba(239,232,216,.5);color:var(--ink);font-size:.82rem;white-space:nowrap}
.vs-table tr:last-child td{border-bottom:none}

/* ── Badges & chips ─────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:3px;font-family:var(--mono);font-size:.62rem;letter-spacing:0;text-transform:uppercase;font-weight:500}
.badge-green{background:var(--green-light);color:var(--green);border:1px solid #BFCFB8}
.badge-gold{background:var(--gold-light);color:var(--gold2);border:1px solid #E2CD96}
.badge-blue{background:var(--navy-light);color:var(--navy);border:1px solid #C3CEDC}
.badge-grey{background:var(--paper3);color:var(--muted);border:1px solid var(--border)}
.badge-red{background:var(--red-light);color:var(--red);border:1px solid #E0BFB2}
.stock-chip{background:var(--green-light);border:1px solid var(--border2);border-radius:3px;padding:4px 12px;font-family:var(--mono);font-size:.74rem;font-weight:600;color:var(--green)}
.bank-chip{background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center;font-size:.88rem;font-weight:600;box-shadow:var(--shadow)}
.bank-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:16px 0}
.read-time{font-family:var(--mono);font-size:.66rem;background:var(--paper3);color:var(--muted);padding:3px 9px;border-radius:3px;font-weight:500;letter-spacing:0}
.topic-tag{font-family:var(--mono);font-size:.64rem;background:var(--green-light);color:var(--green);padding:3px 9px;border-radius:3px;font-weight:500;border:1px solid var(--border2);letter-spacing:0;text-transform:uppercase}

/* ── Fund cards (tool) ──────────────────────────────────── */
.funds-grid{display:grid;grid-template-columns:1fr;gap:16px}
.fund-card{background:var(--paper2);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;border:1px solid var(--border);transition:box-shadow .2s,transform .2s}
.fund-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.fund-card.rec{border-color:var(--gold);outline:1px solid var(--gold);outline-offset:-4px}
.fund-name{font-family:var(--display);font-weight:600;font-size:1rem;margin-bottom:6px;color:var(--ink)}
.fund-mgr{font-family:var(--mono);font-size:.68rem;letter-spacing:0;color:var(--muted);margin-bottom:10px;text-transform:uppercase}
.fund-returns{display:flex;gap:8px;margin:12px 0}
.ret-box{flex:1;text-align:center;background:var(--paper3);border-radius:4px;padding:8px 4px}
.ret-box.best{background:var(--green-light);outline:1px solid var(--border2)}
.ret-val{font-family:var(--mono);font-size:.98rem;font-weight:600;color:var(--green);font-variant-numeric:tabular-nums}
.ret-lbl{font-family:var(--mono);font-size:.58rem;letter-spacing:0;color:var(--muted);margin-top:2px;text-transform:uppercase}
.fund-verdict{font-size:.86rem;color:var(--ink2);margin:8px 0;font-style:italic}
.fund-earn{font-family:var(--mono);font-size:.8rem;font-weight:600;color:var(--navy);background:var(--navy-light);padding:6px 10px;border-radius:4px;margin-top:8px}

/* ── Portfolio allocation (tool) ────────────────────────── */
.alloc-grid{display:grid;grid-template-columns:1fr;gap:16px}
.alloc-item{display:flex;align-items:center;gap:12px;padding:14px;background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.alloc-dot{width:13px;height:13px;border-radius:50%;flex-shrink:0;outline:2px solid var(--paper);outline-offset:1px}
.alloc-label{font-weight:600;font-size:.92rem;color:var(--ink)}
.alloc-sub{font-size:.78rem;color:var(--muted)}
.alloc-amount{margin-left:auto;text-align:right;font-family:var(--mono);font-weight:600;color:var(--green);white-space:nowrap;font-variant-numeric:tabular-nums}
.alloc-pct{font-family:var(--mono);font-size:.72rem;color:var(--muted)}

/* ── Summary stats ──────────────────────────────────────── */
.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}
.stat-card,.stat-box{background:var(--paper2);border:1px solid var(--border);border-top:3px solid var(--gold);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);text-align:center}
.stat-val{font-family:var(--mono);font-size:1.35rem;font-weight:600;color:var(--green);font-variant-numeric:tabular-nums}
.stat-lbl{font-family:var(--mono);font-size:.62rem;letter-spacing:0;text-transform:uppercase;color:var(--muted);margin-top:4px}
.stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}

/* ── Charts ─────────────────────────────────────────────── */
.chart-wrap{position:relative;height:260px;margin:16px 0}
.chart-wrap-sm{position:relative;height:200px;margin:12px 0}

/* ── CTA blocks & buttons ───────────────────────────────── */
.cta-block{background:var(--green-light);border:1px solid var(--border2);border-left:4px solid var(--green);border-radius:var(--radius);padding:18px;margin:18px 0}
.cta-title{font-family:var(--display);font-weight:600;color:var(--green);margin-bottom:10px;font-size:1rem}
.cta-btns{display:flex;flex-wrap:wrap;gap:8px}
.btn-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:4px;font-family:var(--mono);font-size:.72rem;letter-spacing:0;text-transform:uppercase;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-decoration:none;margin:2px 2px 2px 0;background:var(--green);color:var(--paper2)}
.btn-cta:hover{background:var(--green2);text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--green);color:var(--paper2)}
.btn-primary:hover{background:var(--green2)}
.btn-secondary{background:var(--paper2);color:var(--green);border:1px solid var(--green)}
.btn-secondary:hover{background:var(--green-light)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-pale)}
.btn-navy{background:var(--navy);color:var(--paper2)}
.btn-navy:hover{background:#2E5377}

/* ── Wizard nav buttons ─────────────────────────────────── */
.nav-row{display:flex;justify-content:space-between;align-items:center;margin-top:24px;gap:12px}
.btn-nav{padding:12px 24px;border-radius:4px;font-family:var(--mono);font-size:.78rem;letter-spacing:0;text-transform:uppercase;font-weight:600;cursor:pointer;border:none;transition:all .2s}
.btn-next{background:var(--green);color:var(--paper2);margin-left:auto}
.btn-next:hover{background:var(--green2)}
.btn-back{background:var(--paper2);color:var(--green);border:1px solid var(--green)}
.btn-back:hover{background:var(--green-light)}

/* ── Ad slots — collapse until filled ───────────────────── */
.ad-slot{text-align:center;margin:24px 0;position:relative}
.ad-label{display:none;font-family:var(--mono);font-size:.58rem;letter-spacing:0;text-transform:uppercase;color:var(--border2);position:absolute;top:-14px;left:50%;transform:translateX(-50%);white-space:nowrap}
.ad-slot:has(ins[data-ad-status="filled"]) .ad-label{display:block}
ins.adsbygoogle[data-ad-status="unfilled"]{display:none!important}

/* ── Disclaimers ────────────────────────────────────────── */
.disclaimer{font-size:.8rem;color:var(--muted);background:var(--gold-light);border:1px solid #E2CD96;border-left:4px solid var(--gold);border-radius:var(--radius);padding:12px 16px;margin-top:20px;line-height:1.7}
.disclaimer-box{background:var(--gold-light);border:1px solid #E2CD96;border-left:4px solid var(--gold);border-radius:var(--radius);padding:18px;margin-top:8px}

/* ── Guide article components ───────────────────────────── */
.breadcrumb{font-family:var(--mono);font-size:.68rem;letter-spacing:0;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.breadcrumb a{color:var(--green)}
.callout{border-radius:var(--radius);padding:18px 20px;margin:18px 0;border:1px solid var(--border)}
.callout-green{background:var(--green-light);border-left:4px solid var(--green)}
.callout-gold{background:var(--gold-light);border-left:4px solid var(--gold)}
.callout-blue{background:var(--navy-light);border-left:4px solid var(--navy)}
.sector-card{background:var(--paper2);border:1px solid var(--border);border-top:3px solid var(--gold);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;margin-bottom:18px}
.sector-card h3{margin-top:0;font-size:1.08rem}
.sector-stocks{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.step-block{background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;margin-bottom:14px;display:flex;gap:16px;align-items:flex-start}
.step-num{background:var(--green);color:var(--gold-pale);border-radius:3px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600;font-size:.95rem;flex-shrink:0;margin-top:2px}
.step-body h3{margin-top:0}
.step-body p{margin-bottom:0}
.rate-timeline{background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;margin:20px 0}
.rate-row{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--border)}
.rate-row:last-child{border-bottom:none}
.rate-date{font-family:var(--mono);font-size:.74rem;color:var(--muted);min-width:90px}
.rate-val{font-family:var(--mono);font-size:1.05rem;font-weight:600;color:var(--green);min-width:64px;font-variant-numeric:tabular-nums}
.rate-note{font-size:.86rem;color:var(--ink2)}
.impact-grid{display:grid;grid-template-columns:1fr;gap:14px;margin:18px 0}
.impact-card{background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;text-align:center}
.impact-icon{font-size:1.8rem;margin-bottom:8px}
.impact-title{font-family:var(--display);font-weight:600;font-size:.95rem;margin-bottom:6px;color:var(--ink)}
.impact-desc{font-size:.84rem;color:var(--muted);line-height:1.6}
.impact-up{color:var(--green3)}
.impact-dn{color:var(--red)}
.playbook-grid{display:grid;grid-template-columns:1fr;gap:14px;margin:18px 0}
.playbook-card{border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);border:1px solid var(--border)}
.playbook-card.high{background:#F4E7D4;border-top:4px solid var(--red)}
.playbook-card.mid{background:var(--green-light);border-top:4px solid var(--green)}
.playbook-card.low{background:var(--navy-light);border-top:4px solid var(--navy)}
.playbook-label{font-family:var(--mono);font-size:.64rem;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:0}
.playbook-rate{font-family:var(--mono);font-size:1.05rem;font-weight:600;margin-bottom:6px}
.playbook-actions{font-size:.84rem;color:var(--ink2);line-height:1.8}
.verdict-card{border-radius:var(--radius);padding:22px 24px;margin:20px 0;box-shadow:var(--shadow);border:1px solid var(--border)}
.verdict-ns{background:var(--green-light);border-left:4px solid var(--green)}
.verdict-mf{background:var(--navy-light);border-left:4px solid var(--navy)}
.verdict-title{font-family:var(--display);font-weight:700;font-size:1.05rem;margin-bottom:8px;color:var(--ink)}
.reasons-list{list-style:none;padding:0;margin:0 0 16px}
.reasons-list li{padding:10px 0;border-bottom:1px solid var(--border);font-size:.92rem;color:var(--ink2);display:flex;gap:10px}
.reasons-list li::before{content:"→";color:var(--gold2);font-weight:700;flex-shrink:0;font-family:var(--mono)}
.reasons-list li:last-child{border-bottom:none}
.data-source{display:flex;align-items:flex-start;gap:12px;padding:14px;border:1px solid var(--border);background:var(--paper2);border-radius:var(--radius);margin-bottom:12px}
.data-source-icon{width:36px;height:36px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;background:var(--green-light)}

/* ── FAQ ────────────────────────────────────────────────── */
.faq-section{margin:32px 0}
.faq-item{border:1px solid var(--border);background:var(--paper2);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}
.faq-question{font-family:var(--display);font-weight:600;font-size:1rem;padding:16px 20px;background:var(--paper2);color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-question::after{content:"+";font-family:var(--mono);font-size:1.1rem;color:var(--gold2);transition:transform .25s;flex-shrink:0}
details[open] .faq-question{border-bottom:1px solid var(--border);background:var(--green-light)}
details[open] .faq-question::after{transform:rotate(45deg)}
.faq-answer{padding:14px 20px 18px;font-size:.95rem;line-height:1.8;color:var(--ink2)}
.faq-q{font-family:var(--display);font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:8px}
.faq-a{font-size:.92rem;color:var(--ink2);line-height:1.75}

/* ── Related links ──────────────────────────────────────── */
.related-links{background:var(--paper2);border:1px solid var(--border);border-top:3px double var(--border2);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;margin-top:32px}
.related-links h3{margin-top:0;margin-bottom:12px;color:var(--ink)}
.related-links a{display:block;padding:8px 0;border-bottom:1px solid var(--border);font-size:.95rem}
.related-links a:last-child{border-bottom:none}

/* ── Author card ────────────────────────────────────────── */
.author-card{display:flex;gap:20px;align-items:flex-start;background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}
.author-avatar{width:68px;height:68px;border-radius:50%;background:var(--green);color:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:1.7rem;font-weight:700;flex-shrink:0;outline:2px solid var(--gold);outline-offset:2px}
.author-byline{margin-top:18px;padding-top:14px;border-top:1px solid var(--border2);font-family:var(--mono);font-size:.72rem;letter-spacing:0;color:var(--muted);line-height:1.7}
.author-byline a{color:var(--green);font-weight:600}

/* ── Guides hub ─────────────────────────────────────────── */
.hub-intro{background:var(--green-light);border-radius:var(--radius);padding:28px 32px;margin-bottom:32px;border:1px solid var(--border2)}
.hub-intro h2{font-size:1.3rem;margin:0 0 14px;color:var(--green)}
.hub-intro p{font-size:.98rem;line-height:1.8;margin-bottom:14px}
.hub-intro p:last-of-type{margin-bottom:0}
.hub-intro strong{color:var(--green)}
.hub-pillars{display:grid;grid-template-columns:1fr;gap:10px;margin:16px 0}
.pillar{background:var(--paper2);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:4px;padding:12px 14px;font-size:.9rem;color:var(--ink2);line-height:1.65}
.pillar strong{display:block;color:var(--green);font-size:.92rem;margin-bottom:4px;font-family:var(--display)}
.guides-grid{display:grid;grid-template-columns:1fr;gap:20px}
.guide-card{background:var(--paper2);border:1px solid var(--border);border-left:4px solid var(--green);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;transition:box-shadow .25s,transform .25s,border-color .25s;display:flex;flex-direction:column}
.guide-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-left-color:var(--gold)}
.guide-icon{font-size:1.9rem;margin-bottom:12px}
.guide-title{font-family:var(--display);font-size:1.12rem;font-weight:600;color:var(--ink);margin-bottom:8px;line-height:1.3}
.guide-desc{font-size:.9rem;color:var(--muted);line-height:1.7;margin-bottom:14px;flex:1}
.guide-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.guide-link{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:.72rem;letter-spacing:0;text-transform:uppercase;font-weight:600;color:var(--green)}

/* ── About / contact ────────────────────────────────────── */
.mission-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:16px}
.mission-item{background:rgba(253,251,244,.1);border:1px solid rgba(217,184,106,.35);border-radius:var(--radius);padding:18px}
.mission-item .icon{font-size:1.8rem;margin-bottom:8px}
.mission-item h3{color:var(--paper2);font-size:.98rem;margin-top:0}
.mission-item p{color:rgba(253,251,244,.8);font-size:.86rem;margin-bottom:0}
.invest-option{background:var(--paper2);border:1px solid var(--border);border-left:4px solid var(--green);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 22px;margin-bottom:14px}
.invest-option h3{margin-top:0;font-size:1.02rem}
.invest-option p{margin-bottom:0;font-size:.9rem}
.social-link{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:4px;font-family:var(--mono);font-size:.72rem;letter-spacing:0;text-transform:uppercase;font-weight:600;border:1px solid var(--border2);margin-right:8px;margin-top:8px;color:var(--ink2);background:var(--paper2)}
.social-link:hover{border-color:var(--green);color:var(--green);text-decoration:none}
.contact-method{display:flex;align-items:center;gap:14px;padding:16px;background:var(--paper2);border:1px solid var(--border);border-left:4px solid var(--gold);border-radius:var(--radius);margin-bottom:12px}
.contact-icon{font-size:1.5rem;flex-shrink:0}
.contact-label{font-family:var(--mono);font-size:.66rem;letter-spacing:0;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.contact-val{font-weight:700;color:var(--green);font-size:.95rem}

/* ── Load-in stagger ────────────────────────────────────── */
.card,.guide-card,.macro-pill,.sector-card,.step-block,.stat-card,.stat-box{animation:fadeUp .5s ease both}
.card:nth-child(2),.guide-card:nth-child(2),.macro-pill:nth-child(2){animation-delay:.05s}
.card:nth-child(3),.guide-card:nth-child(3),.macro-pill:nth-child(3){animation-delay:.1s}
.card:nth-child(4),.guide-card:nth-child(4),.macro-pill:nth-child(4){animation-delay:.15s}
.guide-card:nth-child(5){animation-delay:.2s}
.guide-card:nth-child(6){animation-delay:.25s}
.guide-card:nth-child(n+7){animation-delay:.3s}

/* ── Responsive ─────────────────────────────────────────── */
@media(min-width:600px){
  .macro-grid{grid-template-columns:repeat(4,1fr)}
  .funds-grid{grid-template-columns:repeat(2,1fr)}
  .summary-grid{grid-template-columns:repeat(4,1fr)}
  .hub-pillars{grid-template-columns:repeat(3,1fr)}
  .impact-grid{grid-template-columns:repeat(3,1fr)}
  .playbook-grid{grid-template-columns:repeat(3,1fr)}
  .bank-grid{grid-template-columns:repeat(3,1fr)}
  .stat-row{grid-template-columns:repeat(4,1fr)}
  .mission-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:640px){.guides-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:700px){.alloc-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.funds-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){
  .card{padding:18px}
  th,td{padding:8px 10px;font-size:.82rem}
  .section-title{font-size:1.25rem}
  .stat-val{font-size:1.15rem}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ── Declutter: clamp long card descriptions ────────────── */
.guide-desc{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.guide-card:hover .guide-desc{-webkit-line-clamp:unset}
summary{cursor:pointer}
summary::-webkit-details-marker{display:none}

/* ── Mini guide cards (homepage dashboard) ──────────────── */
.mini-card{display:flex;flex-direction:column;gap:6px;background:var(--paper2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 12px;font-family:var(--mono);font-size:.7rem;letter-spacing:0;text-transform:uppercase;font-weight:600;color:var(--ink);line-height:1.5;transition:transform .2s,box-shadow .2s,border-color .2s}
.mini-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--gold);text-decoration:none;color:var(--green)}
.mini-ico{font-size:1.4rem}
.insight-cell{background:var(--green);color:var(--paper2);border-radius:var(--radius);padding:16px;border:1px solid var(--green2);outline:1px solid rgba(217,184,106,.4);outline-offset:-5px}
.insight-num{font-family:var(--mono);font-size:1.5rem;font-weight:600;color:var(--gold-pale);font-variant-numeric:tabular-nums}
.insight-lbl{font-size:.78rem;opacity:.85;line-height:1.5;margin-top:4px}

/* ── Listing pages: ticker, chips, badges ───────────────── */
.ticker-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:8px;margin-top:20px}
.ticker-cell{background:rgba(253,251,244,.08);border:1px solid rgba(217,184,106,.35);border-radius:4px;padding:9px 6px;text-align:center}
.tk-val{display:block;font-family:var(--mono);font-weight:600;color:var(--gold-pale);font-size:1rem;font-variant-numeric:tabular-nums}
.tk-lbl{font-family:var(--mono);font-size:.56rem;letter-spacing:0;text-transform:uppercase;opacity:.7}
.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 22px}
.chip{font-family:var(--mono);font-size:.66rem;letter-spacing:0;text-transform:uppercase;padding:8px 14px;border-radius:3px;border:1px solid var(--border2);background:var(--paper2);color:var(--muted);cursor:pointer;transition:all .15s;font-weight:600}
.chip:hover{border-color:var(--gold);color:var(--green);transform:translateY(-1px)}
.chip.active{background:var(--green);color:var(--paper2);border-color:var(--green)}
.topic-tag.tag-new{background:var(--gold);color:#191D1A;border-color:var(--gold2)}
.pipeline-step{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--border)}
.pipeline-step:last-child{border-bottom:none}

/* ── 2026 professional revamp overrides ─────────────────── */
*,*::before,*::after{letter-spacing:0}
h1{font-size:2.45rem}
h2{font-size:1.8rem}
.hero h1{font-size:3rem}
.section-title{font-size:1.85rem}
.hero-card h1{font-size:2.1rem}

.news-strip{
  display:block;background:#FFF7E6;color:#7A4F0B;text-align:center;
  padding:10px 16px;font-weight:800;text-decoration:none;border-bottom:1px solid #F3DCA6;line-height:1.35;
}
.news-strip:hover{text-decoration:none;background:#FFEEC4;color:#5F3C07}

.dashboard-card,.chart-card{position:relative;overflow:hidden}
.dashboard-card::after,.chart-card::after{
  content:"";position:absolute;top:0;right:0;width:82px;height:3px;background:linear-gradient(90deg,var(--green3),var(--gold));
}
.chart-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:20px}
.chart-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:8px}
.chart-title{font-size:1.02rem;font-weight:800;color:var(--ink);margin-bottom:6px}
.chart-copy{font-size:.88rem;color:var(--muted);line-height:1.55;margin-bottom:10px}
.chart-badge,.status-pill{
  display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);
  background:var(--paper3);color:var(--green);border-radius:999px;padding:6px 10px;
  font-family:var(--mono);font-size:.68rem;font-weight:700;white-space:nowrap;
}
.chart-wrap{height:290px}
.chart-wrap-sm{height:230px}

table{border-collapse:separate;border-spacing:0;font-size:.88rem}
th{background:#073B31;color:#fff;padding:12px 13px;font-weight:700;border-bottom:1px solid rgba(255,255,255,.08)}
td{background:#fff;padding:12px 13px;border-bottom:1px solid var(--border);line-height:1.55}
tbody tr:last-child td{border-bottom:none}
tr:hover td{background:#F7FAFC}
tr.rec-row td{background:#F0FBF6}
.tbl-wrap{border:1px solid var(--border);border-radius:8px;overflow:auto}
.tbl-wrap table{border:0}

.badge{border-radius:999px;padding:4px 9px;font-weight:800}
.badge-gold{background:#FFF1C7;color:#7A4F0B;border-color:#F4D58C}
.badge-green{background:var(--green-light);color:var(--green);border-color:#BFE9DA}
.badge-blue{background:var(--navy-light);color:var(--navy);border-color:#C9D5FF}
.badge-grey{background:#F2F4F7;color:#475467;border-color:#D0D5DD}
.badge-red{background:var(--red-light);color:var(--red);border-color:#F5B9B1}

.fund-card,.guide-card,.sector-card,.step-block,.impact-card,.invest-option,.data-source,.contact-method,.author-card,.related-links{
  background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);
}
.fund-card,.guide-card{transition:transform .2s,box-shadow .2s,border-color .2s}
.fund-card:hover,.guide-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.fund-card.rec{border-color:#F2B94B;outline:none;box-shadow:0 0 0 3px rgba(242,185,75,.18),var(--shadow)}
.fund-name,.guide-title{font-family:var(--display);font-weight:800;color:var(--ink)}
.fund-verdict{font-style:normal;color:var(--muted);line-height:1.55}
.ret-box{background:#F7FAFC;border:1px solid var(--border);border-radius:8px}
.ret-box.best{background:var(--green-light);outline:none;border-color:#BFE9DA}

.alloc-item{background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:none;align-items:flex-start}
.alloc-item:hover{border-color:#B9C5D4;box-shadow:var(--shadow)}
.summary-grid{gap:14px}
.stat-card,.stat-box{
  background:#fff;border:1px solid var(--border);border-top:0;border-radius:8px;padding:18px;text-align:left;box-shadow:var(--shadow)
}
.stat-val{font-size:1.28rem;font-weight:800;color:var(--green)}
.stat-lbl{font-size:.66rem;color:var(--muted);font-weight:700}

.btn-cta,.btn-nav{
  border-radius:8px;font-family:var(--display);font-size:.82rem;font-weight:800;text-transform:none;
  padding:11px 18px;box-shadow:none;
}
.btn-cta:hover,.btn-nav:hover{transform:translateY(-1px);text-decoration:none}
.btn-next{background:var(--green);color:#fff}
.btn-back{background:#fff;color:var(--green);border:1px solid var(--border2)}
.btn-secondary{background:#fff;color:var(--green);border:1px solid var(--border2)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-navy{background:var(--navy);color:#fff}

.cta-block{background:#fff;border:1px solid var(--border);border-left:4px solid var(--green3);border-radius:8px;box-shadow:var(--shadow)}
.cta-strong{background:linear-gradient(180deg,#fff,#FFF9EA);border-color:#F3DCA6;border-left-color:var(--gold)}
.cta-title{font-weight:800;color:var(--ink)}
.disclaimer{background:#FFF7E6;border:1px solid #F3DCA6;border-left:4px solid var(--gold);border-radius:8px;color:#66512A}

.gamify-card{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;
  background:#052E27;color:#fff;border-radius:8px;padding:22px;margin-bottom:20px;
  box-shadow:0 24px 56px -34px rgba(5,46,39,.75);
}
.gamify-card p{color:rgba(255,255,255,.72);margin:0;line-height:1.55}
.score-title{font-family:var(--mono);font-size:2.2rem;font-weight:800;color:var(--gold-pale);line-height:1}
.badge-row{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;max-width:360px}
.score-badge{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:rgba(255,255,255,.68);border-radius:999px;padding:8px 10px;font-size:.8rem;font-weight:800}
.score-badge.unlocked{background:rgba(18,168,125,.18);border-color:rgba(18,168,125,.42);color:#E9FFF7}

.seo-section{background:#fff;border-top:1px solid var(--border);padding:54px 0}
.section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:14px}
.section-heading h2{margin:0}
.section-heading.compact{margin-top:34px}
.source-line{font-size:.9rem;color:var(--muted);margin:0 0 22px;line-height:1.6}
.source-line a,.text-link{font-weight:800;color:var(--green)}
.insight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:22px}
.insight-cell{background:#052E27;border:1px solid rgba(255,255,255,.08);outline:none;border-radius:8px;padding:18px}
.insight-num{font-size:1.55rem;font-weight:800;color:var(--gold-pale)}
.insight-lbl{font-size:.86rem;color:rgba(255,255,255,.78);opacity:1}
.mini-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px;margin-bottom:32px}
.mini-card{
  background:#fff;border:1px solid var(--border);border-radius:8px;padding:15px;
  font-family:var(--display);font-size:.86rem;text-transform:none;font-weight:800;color:var(--ink);line-height:1.35;
}
.mini-ico{
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  background:var(--green-light);color:var(--green);border-radius:8px;font-family:var(--mono);font-size:.72rem;font-weight:800;
}

.faq-section{margin:36px 0 8px}
.faq-section h2{margin-top:0}
.faq-item{border-radius:8px;box-shadow:none}
.faq-question{font-family:var(--display);font-size:1rem;font-weight:800}
.faq-answer{font-size:.92rem;color:var(--muted);line-height:1.65}

.guide-card{border-left:0;padding:22px}
.guide-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--green-light);font-size:1.25rem;margin-bottom:14px}
.guide-desc{font-size:.9rem;line-height:1.6}
.guide-link{text-transform:none;font-family:var(--display);font-size:.86rem;font-weight:800}
.chip{border-radius:999px;text-transform:none;font-family:var(--display);font-size:.82rem}
.ticker-cell{border-radius:8px;background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.16)}

@media(min-width:760px){
  .chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  #page-4 .chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  #page-4 .chart-grid .card:last-child{grid-column:1 / -1}
}
@media(min-width:900px){
  h1{font-size:3.1rem}
  h2{font-size:2rem}
  .hero h1{font-size:4.45rem}
  .section-title{font-size:2rem}
}
@media(max-width:760px){
  .data-age{margin-top:2px;white-space:normal}
  .step-shell{top:var(--site-header-height)}
  .hero{padding:44px 0 26px}
  .hero-grid{grid-template-columns:1fr}
  .hero h1{font-size:2.45rem;max-width:100%;overflow-wrap:break-word}
  .hero p{max-width:100%}
  .hero-dashboard{grid-template-columns:repeat(2,1fr)}
  .amount-wrap{max-width:100%}
  .gamify-card{grid-template-columns:1fr}
  .badge-row{justify-content:flex-start}
  .section-heading{align-items:flex-start;flex-direction:column}
}
@media(max-width:520px){
  .container,.container-wide{padding:0 16px}
  .hero h1{font-size:2rem}
  h1{font-size:2.1rem}
  h2{font-size:1.55rem}
  .hero-dashboard{grid-template-columns:1fr}
  .amount-wrap,.card{padding:18px}
  .mini-score{align-items:flex-start;flex-direction:column;gap:5px}
  .risk-toggle{grid-template-columns:1fr}
  .summary-grid,.macro-grid{grid-template-columns:1fr}
  .nav-row{flex-direction:column;align-items:stretch}
  .btn-next{margin-left:0}
}

/* ── Global search: command-palette overlay ────────────── */
.search-overlay{position:fixed;inset:0;background:rgba(17,24,39,.45);z-index:9999;display:none;align-items:flex-start;justify-content:center;padding:11vh 16px 16px}
.search-overlay.open{display:flex}
@supports(backdrop-filter:blur(3px)){.search-overlay{backdrop-filter:blur(3px)}}
.search-modal{width:100%;max-width:600px;background:var(--paper2);border-radius:14px;box-shadow:0 24px 70px rgba(0,0,0,.4);overflow:hidden;border:1px solid rgba(0,0,0,.08);animation:s-pop .14s ease-out}
@keyframes s-pop{from{transform:translateY(-8px);opacity:.4}to{transform:none;opacity:1}}
.search-box{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--paper3)}
.search-box .s-ic{font-size:1.05rem;opacity:.55}
.search-box input{flex:1;min-width:0;border:0;outline:0;background:transparent;font-size:1.06rem;color:var(--ink);font-family:var(--display)}
.search-box .s-esc{font-family:var(--mono);font-size:.58rem;color:var(--muted);border:1px solid rgba(0,0,0,.15);border-radius:4px;padding:2px 6px;flex-shrink:0}
.search-results{max-height:56vh;overflow:auto;padding:6px}
.search-item{display:flex;align-items:flex-start;gap:11px;padding:10px 12px;border-radius:9px;cursor:pointer;text-decoration:none}
.search-item.active{background:var(--green-light)}
.search-item .si-body{min-width:0;flex:1}
.search-item .si-title{display:block;font-family:var(--display);font-weight:700;color:var(--ink);font-size:.95rem;line-height:1.3}
.search-item .si-desc{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;color:var(--muted);font-size:.8rem;line-height:1.45;margin-top:2px}
.search-item mark{background:var(--gold-pale);color:inherit;padding:0 1px;border-radius:2px}
.s-badge{flex-shrink:0;font-family:var(--mono);font-size:.55rem;letter-spacing:.06em;text-transform:uppercase;padding:3px 7px;border-radius:5px;margin-top:3px;font-weight:600}
.s-badge.Guide{background:var(--green-light);color:var(--green)}
.s-badge.Blog{background:var(--gold-light);color:var(--gold2)}
.s-badge.Tool{background:#E8EDF3;color:#23415E}
.s-badge.Page{background:var(--paper3);color:var(--muted)}
.search-empty{padding:30px 18px;text-align:center;color:var(--muted);font-size:.92rem;line-height:1.6}
.search-foot{display:flex;gap:16px;padding:9px 16px;border-top:1px solid var(--paper3);font-family:var(--mono);font-size:.58rem;letter-spacing:.05em;color:var(--muted);text-transform:uppercase}
.search-foot b{color:var(--ink2);font-weight:600}
@media(max-width:520px){.search-foot{display:none}.search-overlay{padding:7vh 10px 10px}}

/* ── Inline listing filter (guides / blog) ─────────────── */
.list-search{position:relative;margin:0 0 22px}
.list-search input{width:100%;box-sizing:border-box;padding:13px 16px 13px 44px;border:1px solid var(--border);border-radius:10px;font-size:1rem;font-family:var(--display);color:var(--ink);background:var(--paper2)}
.list-search input:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px var(--green-light)}
.list-search input::placeholder{color:var(--muted)}
.list-search .ls-ic{position:absolute;left:16px;top:50%;transform:translateY(-50%);opacity:.45;font-size:1.02rem;pointer-events:none}
.filter-empty{display:none;padding:26px 18px;text-align:center;color:var(--muted);font-size:.95rem}
