/* ============================================================
   Bond Market Dashboard · page.css
   Self-contained (nav + footer included — no site.css dependency)
   Template: Options page design system + bond-specific accents
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:16px;scroll-behavior:smooth}

:root{
  --bg:#0b1220;
  --surface:rgba(255,255,255,.03);--surface2:rgba(255,255,255,.05);
  --border:#243246;--border2:#334155;
  --text:#e6edf3;--text-muted:#9fb2c9;--text-dim:#9fb2c9;
  --blue:#3b82f6;--blue2:#60a5fa;--blue3:#93c5fd;
  --green:#10b981;--green2:#34d399;
  --yellow:#f59e0b;--yellow2:#fbbf24;
  --red:#ef4444;--red2:#f87171;
  --purple:#8b5cf6;--purple2:#a78bfa;
  /* Bond-dashboard accent */
  --accent:#8cbc57;
  --font:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif;
  --font-humanist:'Nunito Sans','Segoe UI','Gill Sans',Arial,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
}

body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.5;min-height:100vh}
a{color:var(--blue2);text-decoration:none}
a:hover{color:var(--blue3)}

/* ================================================================
   NAV (self-contained)
   ================================================================ */
.site-nav{
  position:sticky;top:0;z-index:200;
  background:rgba(11,18,32,0.88);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:1200px;margin:0 auto;height:68px;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:800;color:var(--text);letter-spacing:.02em}
.nav-logo:hover{color:var(--text)}
.nav-logo-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:transparent;border-radius:8px;border:none;box-shadow:none}
.nav-logo-img{width:38px;height:38px;display:block}
.nav-logo-text{position:relative;top:0.5px}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{font-size:15px;font-weight:600;color:var(--text-muted);padding:8px 12px;border-radius:8px;transition:color .15s,background .15s}
.nav-links a:hover{color:var(--text);background:var(--surface)}
.nav-links a.active{color:var(--text)}
.nav-link-muted{opacity:.8}

.nav-toggle{display:none;align-items:center;justify-content:center;width:48px;height:44px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}
.nav-toggle:hover{border-color:var(--border2);background:var(--surface2)}
.nav-toggle-bars{position:relative;display:block;width:18px;height:2px;background:currentColor;border-radius:2px}
.nav-toggle-bars::before,.nav-toggle-bars::after{content:"";position:absolute;left:0;width:18px;height:2px;background:currentColor;border-radius:2px}
.nav-toggle-bars::before{top:-6px}
.nav-toggle-bars::after{top:6px}
.nav-drawer{max-width:1200px;margin:0 auto;padding:10px 24px 14px;border-top:1px solid var(--border)}
.nav-drawer a{display:block;font-size:14px;padding:16px 14px;border-radius:12px;color:var(--text);font-weight:700}
.nav-drawer a:hover{background:var(--surface2)}

/* ================================================================
   PAGE SHELL
   ================================================================ */
.page{max-width:1200px;margin:0 auto;padding:0 24px 110px}

/* ---- Page Header (Options-style) ---- */
.page-header{margin-bottom:28px;padding-top:36px}
.page-header-inner{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;flex-wrap:wrap;padding-bottom:24px;
  border-bottom:1px solid var(--border);
}
.page-header-eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue2);margin-bottom:10px;opacity:.8;
}
.page-header h1{
  font-family:var(--font-humanist);
  font-size:clamp(30px,4.2vw,48px);font-weight:800;
  color:var(--text);letter-spacing:-.02em;line-height:1.1;
}
.page-header p{font-size:16px;color:var(--text-muted);margin-top:8px;font-weight:500;max-width:560px}
.stat-row{display:flex;gap:24px;flex-shrink:0}
.stat{text-align:right}
.stat-val{font-family:var(--font-humanist);font-weight:800;font-size:26px;color:var(--text);line-height:1}
.stat-label{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-top:4px}

/* ================================================================
   STATUS BANNER
   ================================================================ */
.bd-status{
  margin:10px 0 0;padding:10px 12px;border-radius:12px;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);
  color:var(--text);font-size:13px;
}
.bd-status[data-kind='error']{border-color:rgba(255,87,87,.35);background:rgba(255,87,87,.08)}

/* ================================================================
   PANELS
   ================================================================ */
.panel{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:18px 16px;margin-bottom:16px;
  box-shadow:0 4px 16px rgba(0,0,0,.25);
}
.panel h2{margin:0 0 8px;font-family:var(--font-humanist);font-size:18px;font-weight:800;color:var(--text)}
.panel h3{margin:0 0 8px;font-family:var(--font-humanist);font-size:16px;font-weight:700;color:var(--text)}
.panel h4{margin:12px 0 6px;font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.panel__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px;flex-wrap:wrap}
.stack-on-mobile{gap:8px}
.ctrls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.small{font-size:12px}
.muted{color:var(--text-muted)}

/* ================================================================
   FORM CONTROLS
   ================================================================ */
.input,.select{
  background:#0f1218;border:1px solid #2c3647;color:#cfe2ff;
  border-radius:8px;padding:6px 8px;font-size:12px;
  color-scheme:dark;
}
.select{cursor:pointer}
.input:focus,.select:focus{outline:none;border-color:rgba(59,130,246,.5);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.input option,.select option{background:#0f1218;color:#e6edf3}

/* ================================================================
   GRID
   ================================================================ */
.grid.two{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:960px){.grid.two{grid-template-columns:1fr 1fr}}

/* ================================================================
   MACRO SCORE
   ================================================================ */
.scorecard .score{display:flex;align-items:center;gap:16px;margin-top:10px;flex-wrap:wrap}
.score__value{font-family:var(--font-humanist);font-size:48px;font-weight:800;line-height:1}
.score__pill{padding:6px 10px;border-radius:999px;background:#243044;color:#cde3ff;border:1px solid #334257;font-size:13px}

/* ================================================================
   PILLS
   ================================================================ */
.pill{padding:6px 10px;border-radius:999px;background:#222c3b;border:1px solid #2c3647;font-size:12px}
.pill--pos{background:#1b2a1d;border-color:#284b2a;color:#bff0c1}
.pill--neu{background:#203046;border-color:#2c3e54;color:#d6ecff}
.pill--neg{background:#3a2b1f;border-color:#5a432a;color:#ffd9b8}
.legend-wrap{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}

/* ================================================================
   REGIME TEXT + NOTES
   ================================================================ */
.macro-regime-text{margin-top:8px;font-size:12px;line-height:1.4;color:#c5cfde}
.macro-regime-text strong{display:block;margin-bottom:3px}
.macro-regime-text.macro-pos strong{color:var(--accent)}
.macro-regime-text.macro-neutral strong{color:#e0b85a}
.macro-regime-text.macro-neg strong{color:#ff6b6b}

.horizon-note{margin-top:10px;line-height:1.5;font-size:12px;color:var(--text-muted)}
.regime-hint{margin:6px 0 0;font-size:12px;color:var(--text-muted)}
.tf-tip{margin-top:4px;color:var(--accent);font-size:12px}

.explain{margin-top:8px;line-height:1.5;color:var(--text-muted);font-size:13px}

/* Inline / static notes */
.inline-note{margin-top:8px;border:1px solid #2c3647;border-radius:8px;background:#0f1218;padding:10px}
.inline-note>div{color:#cfe2ff;opacity:.9}
.static-note{margin-top:8px;border:1px solid #2c3647;border-radius:8px;background:#0f1218;padding:10px;color:#cfe2ff}
.static-note strong{color:#cde3ff}

/* ================================================================
   ALLOCATION BAR
   ================================================================ */
.alloc__head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px}
#allocationBar{
  position:relative;height:14px;border-radius:8px;
  background:linear-gradient(to right,#ff4d4d,#ffa64d,#5aa9e6,#8cbc57);
  border:1px solid #2c3647;
}
#allocationMarker{position:absolute;top:-4px;width:2px;height:22px;background:#fff;left:50%;transition:left .6s ease}
.alloc__legend{display:flex;justify-content:space-between;gap:10px;margin-top:8px;flex-wrap:wrap}
.alloc__legend span{display:inline-block}

/* ================================================================
   TILES GRID (macro recession risk)
   ================================================================ */
.tiles-grid{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:1100px){.tiles-grid{grid-template-columns:repeat(4,1fr)}}

/* ================================================================
   TABLE
   ================================================================ */
.tbl-wrap{overflow:auto}
table.mini{width:100%;border-collapse:collapse;font-size:13px;color:var(--text-muted)}
table.mini th,table.mini td{border:1px solid #253046;padding:8px}
table.mini th{background:#0f1218;color:#cde3ff;text-align:left}

/* ================================================================
   BULLETS (footnote panels)
   ================================================================ */
ul.bullets{margin:8px 0 0 18px;display:flex;flex-direction:column;gap:4px}
ul.bullets li{line-height:1.5;color:var(--text-muted);font-size:13px}

/* ================================================================
   COLOUR HELPERS
   ================================================================ */
.t-green{color:var(--accent)}
.t-amber{color:#e0b85a}
.t-red{color:#ff6b6b}

/* ================================================================
   DISCLAIMER
   ================================================================ */
.disclaimer{
  margin-top:24px;padding:14px 18px;border-radius:10px;
  background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.18);
  font-size:12px;color:var(--text-muted);line-height:1.6;
}
.disclaimer strong{color:rgba(251,191,36,.9)}

/* ================================================================
   FOOTER
   ================================================================ */
footer{
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  margin-top:48px;padding:28px 24px;
  max-width:1200px;margin-left:auto;margin-right:auto;
}
.footer-left{font-size:14px;color:var(--text-dim)}
.footer-left a{color:var(--text-muted)}
.footer-left a:hover{color:var(--text)}
.footer-right{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.08em}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:820px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .page{padding:0 16px 96px}
  .page-header{padding-top:24px}
  .page-header-inner{flex-direction:column;align-items:flex-start}
  .stat-row{width:100%;justify-content:flex-start}
  .stat{text-align:left}
  .page-header h1{font-size:28px}
  footer{flex-direction:column;align-items:flex-start;gap:8px;padding:20px 16px}
}

@media(max-width:540px){
  .nav-inner{padding:0 16px}
  .score__value{font-size:36px}
  .panel__head{flex-direction:column;align-items:flex-start}
  .horizon-note{font-size:12px}
  .pill{font-size:11px}
  .input{width:100px}
}

/* ── tool-card + help accordion (added for consistency) ── */
.tool-card{
  background:rgba(255,255,255,.025);border:1px solid var(--border);
  border-radius:12px;padding:24px 28px;position:relative;overflow:hidden;margin-bottom:16px;
}
.tool-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blue2)}
.tool-card h2{font-family:var(--font-humanist);font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.01em;line-height:1.2}
details.help{margin-top:16px;border:1px dashed rgba(36,50,70,.8);border-radius:10px;padding:12px 16px}
details.help[open]{background:rgba(255,255,255,.015)}
details.help summary{font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px}
details.help summary::marker,details.help summary::-webkit-details-marker{display:none}
details.help summary::before{content:"▸";font-size:11px;transition:transform .15s;display:inline-block}
details.help[open] summary::before{transform:rotate(90deg)}
details.help .help-body{margin-top:12px;padding-left:4px}
details.help ul{margin:0;padding:0 0 0 18px;display:flex;flex-direction:column;gap:8px}
details.help li{font-size:14px;color:var(--text-muted);line-height:1.6}
