/* ============================================================================
   editorial.css — shared styling for the Market Suite Library (/library/*)
   and Today's Read (/today). Extends the live terminal design language:
   JetBrains Mono throughout, #080808 ground, #f5c518 gold, hairline borders,
   uppercase letter-spaced labels. Long-form reading gets a measured column,
   roomy leading, and exactly one signature moment per page.
   ========================================================================== */

:root{
  --bg:#080808; --bg2:#0d0d0d; --bg3:#131313; --bg4:#191919;
  --border:#1f1f1f; --bhi:#2c2c2c;
  --text:#d4d4d4; --read:#dcdcdc; --dim:#757575; --dim2:#9a9a9a; --bright:#f0f0f0;
  --gold:#f5c518; --gold2:#c49a0f; --gold3:#5c4609;
  --bull:#00c97a; --bear:#ff3d3d; --neut:#8a8a8a; --session:#38bdf8;
  --bull-bg:rgba(0,201,122,.07); --bear-bg:rgba(255,61,61,.07); --neut-bg:rgba(138,138,138,.06);
  --f:'JetBrains Mono','Courier New',monospace;
  --measure:660px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--f);font-size:14px;line-height:1.65;
  -webkit-font-smoothing:antialiased;padding-top:60px;
}
a{color:inherit}
::selection{background:rgba(245,197,24,.22);color:#fff}
:focus-visible{outline:1px solid var(--gold);outline-offset:2px}

/* faint ground glow, same vocabulary as about.html */
.page-bg{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 38% at 15% 12%,rgba(245,197,24,.040),transparent),
    radial-gradient(ellipse 45% 35% at 85% 88%,rgba(245,197,24,.022),transparent);
}

/* ── NAV ─────────────────────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:60px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;background:rgba(8,8,8,.96);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.nav-brand{
  color:var(--gold);font-size:15px;font-weight:700;letter-spacing:3px;
  text-decoration:none;text-shadow:0 0 22px rgba(245,197,24,.28);white-space:nowrap;
}
.nav-brand em{color:#fff;font-style:normal}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{
  color:var(--dim2);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  text-decoration:none;padding:6px 16px;transition:color .2s;white-space:nowrap;
}
.nav-link:hover{color:var(--text)}
.nav-link.here{color:var(--gold)}
.nav-signin{
  color:var(--dim2);font-size:10px;letter-spacing:1.8px;text-transform:uppercase;
  text-decoration:none;transition:all .2s;border:1px solid var(--border);
  padding:7px 16px;margin-left:8px;white-space:nowrap;
}
.nav-signin:hover{color:var(--text);border-color:var(--bhi)}
/* triple-bar menu toggle — drawn from three lines, shown only on mobile */
.nav-toggle{
  display:none;flex-direction:column;justify-content:center;gap:4px;
  width:36px;height:32px;padding:7px 8px;background:transparent;
  border:1px solid var(--border);cursor:pointer;
}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--dim2);
  border-radius:1px;transition:transform .2s,opacity .2s,background .2s}
.nav-toggle:hover span{background:var(--text)}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.nav-toggle.open span{background:var(--gold)}

/* ── shared shell ────────────────────────────────────────────────────────── */
.wrap{max-width:var(--measure);margin:0 auto;padding:0 28px}
.eyebrow{
  font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);
  font-weight:600;display:flex;align-items:center;gap:10px;
}
.eyebrow .sep{color:var(--dim);font-weight:400}
.krule{height:1px;background:var(--border);border:0}

/* ── LIBRARY HUB (/library) ──────────────────────────────────────────────── */
.hub-head{max-width:760px;margin:0 auto;padding:64px 28px 8px}
.hub-title{
  font-size:38px;font-weight:700;line-height:1.08;letter-spacing:-.5px;
  color:var(--bright);margin:18px 0 16px;
}
.hub-title .gold{color:var(--gold);text-shadow:0 0 22px rgba(245,197,24,.2)}
.hub-dek{font-size:15px;color:var(--dim2);line-height:1.8;max-width:560px}
.hub-list{max-width:760px;margin:0 auto;padding:40px 28px 80px;display:flex;flex-direction:column;gap:0}
.card{
  display:block;text-decoration:none;border-top:1px solid var(--border);
  padding:30px 4px;transition:background .2s,padding .2s;position:relative;
}
.hub-list .card:last-child{border-bottom:1px solid var(--border)}
.card:hover{background:rgba(245,197,24,.018)}
.card-kicker{
  font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold2);
  display:flex;gap:10px;align-items:center;margin-bottom:12px;
}
.card-kicker .num{color:var(--dim);font-variant-numeric:tabular-nums}
.card-title{
  font-size:22px;font-weight:700;color:var(--bright);line-height:1.2;
  letter-spacing:-.2px;margin-bottom:10px;transition:color .2s;
}
.card:hover .card-title{color:var(--gold)}
.card-dek{font-size:13.5px;color:var(--dim2);line-height:1.75;max-width:600px}
.card-meta{
  margin-top:14px;font-size:10px;letter-spacing:1px;text-transform:uppercase;
  color:var(--dim);display:flex;align-items:center;gap:14px;
}
.card-arrow{color:var(--gold);opacity:0;transform:translateX(-4px);transition:all .2s}
.card:hover .card-arrow{opacity:1;transform:none}

/* ── ARTICLE (library long-form) ─────────────────────────────────────────── */
.art-head{max-width:var(--measure);margin:0 auto;padding:64px 28px 0}
.art-kicker{margin-bottom:22px}
.art-title{
  font-size:34px;font-weight:700;line-height:1.12;letter-spacing:-.5px;
  color:var(--bright);margin-bottom:20px;
}
.art-dek{font-size:16px;color:var(--dim2);line-height:1.7;margin-bottom:26px}
.art-meta{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:var(--dim);
  padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.art-meta .byline{color:var(--dim2)}
.art-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--gold3)}

.prose{max-width:var(--measure);margin:0 auto;padding:14px 28px 0}
.prose p{font-size:15px;line-height:1.8;color:var(--read);margin:0 0 22px}
.prose p.lede{font-size:16px;line-height:1.72;color:var(--bright);margin-bottom:26px}
.prose a.xlink{color:var(--gold);text-decoration:none;border-bottom:1px solid var(--gold3);transition:border-color .2s}
.prose a.xlink:hover{border-bottom-color:var(--gold)}
.prose strong{color:var(--bright);font-weight:600}
.prose em{color:var(--bright);font-style:italic}
/* understated section break — a labelled hairline, not a heading hierarchy */
.brk{
  display:flex;align-items:center;gap:14px;margin:44px 0 26px;
}
.brk::before{content:'';flex:0 0 18px;height:1px;background:var(--gold3)}
.brk::after{content:'';flex:1;height:1px;background:var(--border)}
.brk span{
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold2);
  white-space:nowrap;font-weight:600;
}
.prose blockquote{
  margin:30px 0;padding:4px 0 4px 22px;border-left:2px solid var(--gold3);
  font-size:16px;line-height:1.7;color:var(--bright);
}
.prose ul{margin:0 0 22px;padding-left:2px;list-style:none}
.prose li{
  font-size:15px;line-height:1.8;color:var(--read);margin-bottom:14px;
  padding-left:22px;position:relative;
}
.prose li::before{content:'›';position:absolute;left:2px;color:var(--gold);font-weight:700}

/* pull-figure: terminal readout used as an in-prose signature */
.fig{
  margin:34px 0;border:1px solid var(--border);border-top:2px solid var(--gold3);
  background:linear-gradient(175deg,#0f0f0f,#0a0a0a);
}
.fig-cap{
  font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);
  padding:11px 18px;border-bottom:1px solid var(--border);display:flex;
  justify-content:space-between;align-items:center;
}
.fig-cap .tag{color:var(--gold2)}
.fig-body{padding:18px}

/* regime ladder (page 1 signature) */
.regime{display:flex;flex-direction:column}
.rg-row{display:grid;grid-template-columns:104px 1fr;gap:16px;padding:14px 4px;border-top:1px solid #161616;align-items:start}
.rg-row:first-child{border-top:0}
.rg-name{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;padding-top:1px}
.rg-row.on .rg-name{color:var(--bull)}
.rg-row.off .rg-name{color:var(--bear)}
.rg-row.haven .rg-name{color:var(--gold)}
.rg-desc{font-size:12.5px;line-height:1.65;color:var(--dim2)}
.rg-desc b{color:var(--text);font-weight:600}

/* session timeline (page 2 signature) */
.sesh{display:flex;flex-direction:column;gap:14px}
.sesh-bar{display:flex;height:38px;border:1px solid var(--border);overflow:hidden}
.sesh-seg{display:flex;align-items:center;justify-content:center;font-size:9px;letter-spacing:1.2px;
  text-transform:uppercase;color:var(--text);border-right:1px solid #000;position:relative;white-space:nowrap;overflow:hidden}
.sesh-seg:last-child{border-right:0}
.sesh-seg.asia{background:rgba(56,189,248,.10);color:var(--session)}
.sesh-seg.london{background:rgba(245,197,24,.10);color:var(--gold)}
.sesh-seg.overlap{background:rgba(245,197,24,.22);color:#fff;font-weight:700}
.sesh-seg.ny{background:rgba(0,201,122,.10);color:var(--bull)}
.sesh-legend{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:10px;color:var(--dim);letter-spacing:.5px}
.sesh-legend span{display:flex;align-items:center;gap:7px}
.sesh-legend i{width:9px;height:9px;display:inline-block}
.sesh-vol{display:flex;justify-content:space-between;font-size:9px;color:var(--dim);
  letter-spacing:1px;text-transform:uppercase;padding-top:2px}

/* coach callout (page 3 signature) */
.coach{display:flex;flex-direction:column;gap:0}
.coach-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:18px;
  padding:14px 4px;border-top:1px solid #161616}
.coach-row:first-child{border-top:0}
.coach-mood{font-size:12.5px;color:var(--text);letter-spacing:.5px}
.coach-mood .mtag{color:var(--dim);font-size:10px;letter-spacing:1px;text-transform:uppercase;margin-right:8px}
.coach-wr{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.5px}
.coach-wr.bad{color:var(--bear)}
.coach-wr.ok{color:var(--text)}
.coach-wr.good{color:var(--bull)}
.coach-note{font-size:11px;color:var(--dim);padding:14px 4px 2px;border-top:1px solid #161616;line-height:1.6}

/* end-of-article CTA — understated, not a banner */
.cta{
  max-width:var(--measure);margin:60px auto 0;padding:30px 28px 0;
  border-top:1px solid var(--border);
}
.cta-inner{
  border:1px solid var(--border);border-left:2px solid var(--gold);
  background:var(--bg2);padding:26px 28px;
}
.cta-k{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold2);margin-bottom:12px}
.cta-line{font-size:15px;line-height:1.7;color:var(--text);margin-bottom:20px}
.cta-line b{color:var(--bright);font-weight:600}
.btn{
  display:inline-block;background:var(--gold);color:#000;border:none;
  padding:12px 26px;font-family:var(--f);font-size:11px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;text-decoration:none;
  transition:opacity .2s,transform .1s,box-shadow .2s;
}
.btn:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 6px 24px rgba(245,197,24,.26)}
.btn:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--dim2);border:1px solid var(--border)}
.btn-ghost:hover{color:var(--text);border-color:var(--bhi);box-shadow:none}

/* read-next */
.readnext{max-width:var(--measure);margin:40px auto 0;padding:0 28px}
.readnext .eyebrow{margin-bottom:16px}
.rn-card{display:block;text-decoration:none;border:1px solid var(--border);padding:18px 20px;
  margin-bottom:12px;transition:border-color .2s,background .2s}
.rn-card:hover{border-color:var(--gold3);background:rgba(245,197,24,.02)}
.rn-card .t{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.rn-card:hover .t{color:var(--gold)}
.rn-card .d{font-size:11.5px;color:var(--dim);line-height:1.6}

/* ── TODAY'S READ (/today) ───────────────────────────────────────────────── */
.td-head{max-width:840px;margin:0 auto;padding:56px 28px 0}
.td-masthead{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-bottom:2px solid var(--gold3);padding-bottom:14px}
.td-wordmark{font-size:20px;font-weight:700;letter-spacing:2px;color:var(--bright)}
.td-wordmark .gold{color:var(--gold)}
.td-issue{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);
  font-variant-numeric:tabular-nums;text-align:right}
.edition{max-width:840px;margin:0 auto;padding:30px 28px 0}
.ed-label{display:inline-flex;align-items:center;gap:10px;font-size:10px;letter-spacing:2px;
  text-transform:uppercase;font-weight:700;padding:5px 12px;border:1px solid var(--border)}
.ed-label.morning{color:var(--gold);border-color:var(--gold3)}
.ed-label.evening{color:var(--session);border-color:rgba(56,189,248,.3)}
.ed-label .glow{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}
.ed-title{font-size:28px;font-weight:700;line-height:1.15;letter-spacing:-.4px;color:var(--bright);margin:18px 0 14px}
.ed-summary{font-size:15.5px;line-height:1.7;color:var(--dim2);margin-bottom:8px}
.ed-stamp{font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:var(--dim);margin-top:14px}

/* leans board */
.leans{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:26px 0 8px}
.lean{border:1px solid var(--border);background:var(--bg2);padding:16px 16px 18px;border-top-width:2px}
.lean.bullish{border-top-color:var(--bull)}
.lean.bearish{border-top-color:var(--bear)}
.lean.neutral{border-top-color:var(--neut)}
.lean-asset{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim2);margin-bottom:8px}
.lean-dir{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.lean.bullish .lean-dir{color:var(--bull)}
.lean.bearish .lean-dir{color:var(--bear)}
.lean.neutral .lean-dir{color:var(--neut)}
.lean-why{font-size:11.5px;line-height:1.6;color:var(--dim2);margin-top:10px}
.lean-glyph{font-size:13px}

/* edition prose sections */
.ed-sec{max-width:840px;margin:0 auto;padding:8px 28px 0}
.ed-sec h2{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold2);
  font-weight:600;margin:34px 0 16px;display:flex;align-items:center;gap:12px}
.ed-sec h2::after{content:'';flex:1;height:1px;background:var(--border)}
.ed-sec p{font-size:15px;line-height:1.85;color:var(--read);margin:0 0 18px}
.events{border:1px solid var(--border);background:var(--bg2)}
.ev{display:grid;grid-template-columns:90px 1fr;gap:16px;padding:14px 18px;border-top:1px solid #161616}
.ev:first-child{border-top:0}
.ev-time{font-size:11px;color:var(--gold);letter-spacing:.5px;font-variant-numeric:tabular-nums;font-weight:600;padding-top:2px}
.ev-name{font-size:13px;color:var(--bright);font-weight:600;margin-bottom:4px}
.ev-note{font-size:12px;color:var(--dim2);line-height:1.6}
.risk-box{border:1px solid var(--border);border-left:2px solid var(--bear);background:var(--bear-bg);padding:18px 20px;margin:6px 0 0}
.risk-box .rk{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--bear);margin-bottom:10px;font-weight:700}
.risk-box p{font-size:14px;line-height:1.75;color:var(--text);margin:0}
.lesson-box{border:1px solid var(--border);border-left:2px solid var(--gold);background:var(--bg2);padding:18px 20px;margin:6px 0 0}
.lesson-box .lk{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold2);margin-bottom:10px;font-weight:700}
.lesson-box p{font-size:14px;line-height:1.78;color:var(--text);margin:0}

/* archive */
.archive{max-width:840px;margin:64px auto 0;padding:0 28px 80px}
.arch-head{display:flex;align-items:baseline;justify-content:space-between;
  border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:4px}
.arch-head .eyebrow{color:var(--dim2)}
.arch-head .count{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}
.arch-item{display:grid;grid-template-columns:108px 78px 1fr;gap:16px;align-items:center;
  text-decoration:none;padding:15px 4px;border-bottom:1px solid var(--border);transition:background .15s}
.arch-item:hover{background:rgba(245,197,24,.02)}
.arch-date{font-size:11px;color:var(--dim2);letter-spacing:.5px;font-variant-numeric:tabular-nums}
.arch-type{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
.arch-type.morning{color:var(--gold)}
.arch-type.evening{color:var(--session)}
.arch-sum{font-size:12.5px;color:var(--text);line-height:1.55}
.arch-item:hover .arch-sum{color:var(--bright)}
.arch-empty{padding:40px 4px;color:var(--dim);font-size:13px;text-align:center}

/* back link on archived editions */
.td-back{max-width:840px;margin:0 auto;padding:18px 28px 0}
.td-back a{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim2);text-decoration:none}
.td-back a:hover{color:var(--gold)}

/* ── FOOTER ──────────────────────────────────────────────────────────────── */
.footer{border-top:1px solid var(--border);margin-top:40px}
.footer-inner{max-width:980px;margin:0 auto;padding:28px 28px;display:flex;
  align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-brand{color:var(--gold);font-size:13px;font-weight:700;letter-spacing:2.5px;text-decoration:none}
.footer-brand em{color:#fff;font-style:normal}
.footer-right{display:flex;align-items:center;gap:18px}
.footer-link{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim2);text-decoration:none}
.footer-link:hover{color:var(--text)}
.footer-copy{font-size:10px;color:var(--dim);letter-spacing:.5px}

/* ── REVEAL ──────────────────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(16px);
  transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.rd1{transition-delay:.06s}.rd2{transition-delay:.12s}.rd3{transition-delay:.18s}

/* ── RESPONSIVE (down to 360px) ──────────────────────────────────────────── */
@media(max-width:768px){
  html{scroll-behavior:auto}
  body{padding-top:54px}
  .nav{height:54px;padding:0 18px;backdrop-filter:none;background:rgba(8,8,8,.99)}
  /* hamburger sits just left of Sign In; both pushed to the right edge */
  .nav-toggle{display:flex;margin-left:auto}
  /* links collapse into a full-width dropdown panel under the bar */
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:rgba(8,8,8,.99);border-bottom:1px solid var(--border);
    box-shadow:0 12px 24px rgba(0,0,0,.5);padding:4px 0;
  }
  .nav-links.open{display:flex}
  .nav-links .nav-link{
    font-size:12px;letter-spacing:1.5px;padding:14px 20px;
    border-bottom:1px solid var(--border);
  }
  .nav-links .nav-link:last-child{border-bottom:none}
  .wrap,.art-head,.prose,.cta,.readnext,.hub-head,.hub-list,
  .td-head,.edition,.ed-sec,.archive,.td-back{padding-left:20px;padding-right:20px}
  .hub-title{font-size:28px}
  .art-title{font-size:26px}
  .art-dek{font-size:14.5px}
  .prose p{font-size:14.5px;line-height:1.78}
  .prose p.lede{font-size:15.5px}
  /* long section-break labels must wrap on narrow screens, not overflow */
  .brk{margin:38px 0 22px}
  .brk span{white-space:normal;letter-spacing:1.8px}
  .fig-cap{flex-wrap:wrap;gap:4px 12px}
  .ed-title{font-size:23px}
  .leans{grid-template-columns:1fr;gap:10px}
  .lean-why{display:block}
  .arch-item{grid-template-columns:84px 1fr;gap:6px 12px}
  .arch-type{grid-row:1;grid-column:2}
  .arch-date{grid-row:1;grid-column:1}
  .arch-sum{grid-row:2;grid-column:1/3}
  .rg-row{grid-template-columns:84px 1fr;gap:12px}
  .ev{grid-template-columns:74px 1fr;gap:12px}
  .td-masthead{padding-bottom:12px}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:12px}
}
@media(max-width:380px){
  .hub-title{font-size:24px}
  .art-title{font-size:22px}
  .ed-title{font-size:20px}
  .sesh-seg{font-size:8px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none;transition:none}
}
