/* GraySwan Market Overview — web edition. Brand variables are injected from tokens.json by app.js
   (fallbacks below), so this matches the print + deck exactly. */
:root{
  --gold:#BAA786; --gold-dark:#8A7645; --ink:#231F20; --navy:#1F2837; --body:#2B2B2B;
  --grey:#797A85; --panel-grey:#60626B; --shade-grey:#F1F1F1; --view-box:#F3F1EA; --mute:#C9C9CC;
  --serif:"Libre Baskerville", Georgia, serif; --sans:"Inter", system-ui, sans-serif;
  --rail:260px; --col:820px;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);color:var(--body);background:#eceae6;line-height:1.6;-webkit-font-smoothing:antialiased}

/* ── control rail ─────────────────────────────────────────────── */
.rail{position:fixed;top:0;left:0;width:var(--rail);height:100vh;overflow-y:auto;background:var(--navy);color:#d7dade;padding:22px 20px 30px}
.rail-brand{font-family:var(--sans);font-weight:700;font-size:20px;letter-spacing:.06em}
.wm-gray{color:#aeb3bb}.wm-swan{color:#fff}
.rail-sub{color:var(--gold);font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin:2px 0 20px}
.btn{width:100%;border:1px solid var(--gold);background:transparent;color:var(--gold);font-family:var(--sans);
  font-weight:600;font-size:13px;padding:10px;border-radius:6px;cursor:pointer;transition:.15s}
.btn:hover{background:var(--gold);color:var(--navy)}
.menu-group{margin-top:22px}
.menu-title{color:#8b9099;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.rail label{display:flex;align-items:center;gap:9px;font-size:13.5px;color:#cdd1d6;padding:4px 0;cursor:pointer}
.rail input[type=checkbox]{accent-color:var(--gold);width:15px;height:15px}
.rail-foot{margin-top:28px;font-size:11px;color:#7d828b;line-height:1.5}
.rail-foot code{color:var(--gold);font-size:10.5px}

/* ── the page (document column) ───────────────────────────────── */
.page{margin-left:var(--rail);padding:42px 0 80px;display:flex;flex-direction:column;align-items:center}
.sheet{width:var(--col);max-width:92vw;background:#fff;padding:54px 60px;margin-bottom:26px;
  box-shadow:0 1px 3px rgba(0,0,0,.08),0 6px 24px rgba(0,0,0,.06);border-radius:2px}
.status{color:var(--grey);font-size:14px}

/* cover */
.cover{background:var(--navy);color:#fff;padding:90px 60px}
.cover .eyebrow{color:var(--gold);letter-spacing:.22em;text-transform:uppercase;font-size:12px}
.cover h1{font-family:var(--serif);font-weight:700;font-size:46px;line-height:1.1;margin:14px 0 6px}
.cover .date{color:#aeb3bb;font-size:16px;letter-spacing:.04em}
.cover .rule{height:1px;background:rgba(186,167,134,.5);margin:26px 0 0;width:64px}

/* intro / contents */
.intro p{font-size:16.5px;color:var(--body)}
.contents{border:1px solid #e7e5e0;background:#faf9f7;border-radius:3px;padding:18px 22px;margin-top:10px}
.contents h3{font-family:var(--serif);color:var(--ink);font-size:17px;margin:0 0 8px}
.contents ol{margin:0;padding-left:0;list-style:none;counter-reset:c}
.contents li{display:flex;justify-content:space-between;gap:12px;padding:5px 0;border-bottom:1px dotted #e3e1dc}
.contents li:last-child{border-bottom:0}
.contents .rn{color:var(--gold-dark);font-family:var(--serif);font-weight:700;min-width:30px}
.contents .nm{flex:1;font-family:var(--serif);color:var(--ink)}
.contents .pg{color:var(--grey);font-size:13px}

/* section divider */
.divider{border-top:2px solid var(--gold);padding-top:22px}
.divider h2{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:30px;margin:0}
.divider .tag{font-style:italic;color:var(--grey);font-size:17px;margin-top:4px}

/* topic block */
.block{padding-top:30px}
.block h3{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:23px;margin:0 0 3px}
.block .src{color:var(--grey);font-style:italic;font-size:12.5px;margin-bottom:14px}
.scoreboard{display:flex;border-top:1.5px solid var(--gold);border-bottom:1.5px solid var(--gold);margin:0 0 18px}
.kpi{flex:1;text-align:center;padding:11px 6px}
.kpi .v{font-family:var(--serif);font-weight:700;color:var(--navy);font-size:23px;line-height:1}
.kpi .l{color:var(--grey);font-size:11.5px;margin-top:5px;line-height:1.3}
.block p{margin:0 0 12px;text-align:justify}
.charts{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin:18px 0}
.charts img{max-width:100%;width:auto;max-height:430px;border:1px solid #efeee9;border-radius:2px}
.charts.two img{max-width:48%}
.imgmiss{color:var(--grey);font-size:12px;border:1px dashed #d8d6d0;padding:30px;border-radius:3px}

.gsview{border-left:3px solid var(--gold);background:var(--view-box);padding:13px 18px;margin:14px 0;border-radius:0 3px 3px 0}
.gsview .lbl{color:var(--gold-dark);font-weight:700;font-size:11px;letter-spacing:.13em;text-transform:uppercase}
.gsview p{margin:4px 0 0;font-style:italic;color:var(--navy);text-align:left}
.risk{background:var(--shade-grey);border-left:3px solid var(--panel-grey);padding:11px 18px;margin:12px 0;border-radius:0 3px 3px 0}
.risk .lbl{color:var(--panel-grey);font-weight:700;font-size:11px;letter-spacing:.13em;text-transform:uppercase}
.risk p{margin:3px 0 0;color:var(--panel-grey);font-size:14px;text-align:left}

/* sign-off */
.signoff{background:var(--navy);color:#fff;padding:70px 60px}
.signoff h2{font-family:var(--serif);font-weight:400;font-size:42px;line-height:1.15;margin:0 0 26px}
.signoff .find{color:var(--gold);letter-spacing:.04em;margin-bottom:18px}
.signoff .contacts{color:#aeb3bb;font-size:13.5px;line-height:1.8}
.signoff .disc{color:#7d828b;font-size:11px;margin-top:22px;max-width:520px}

/* ── print → clean PDF ────────────────────────────────────────── */
@media print{
  @page{size:A4;margin:16mm 15mm}
  body{background:#fff}
  .no-print{display:none!important}
  .page{margin:0;padding:0}
  .sheet{width:auto;max-width:none;box-shadow:none;border-radius:0;padding:0;margin:0 0 6mm;break-inside:avoid}
  .cover,.signoff{break-after:page}
  .divider{break-before:page}
  .block{break-inside:avoid}
}
