/* PoorCharlie v4 — Navy dark theme. Research platform. */

:root{
  /* Surface */
  --bg:#0a1124;
  --bg-alt:#0d1530;
  --surface:#131b38;
  --surface-2:#1a2444;
  --surface-3:#243056;

  /* Ink */
  --ink:#f3f0e7;
  --ink-2:#dcdbd0;
  --ink-muted:#9aa0b2;
  --ink-faint:#6b7290;

  /* Lines */
  --hairline:rgba(255,255,255,0.07);
  --hairline-strong:rgba(255,255,255,0.16);
  --hairline-accent:rgba(116,176,255,0.30);

  /* Accent: bright blue + warm gold */
  --accent:#74b0ff;
  --accent-2:#a5cbff;
  --accent-soft:rgba(116,176,255,0.10);
  --accent-deep:#1f3a5f;
  --gold:#d4a953;
  --gold-soft:rgba(212,169,83,0.12);

  /* Semantic */
  --green:#5ed29c;
  --green-soft:rgba(94,210,156,0.13);
  --amber:#f1b14a;
  --amber-soft:rgba(241,177,74,0.13);
  --red:#e87a72;
  --red-soft:rgba(232,122,114,0.13);

  /* Grades */
  --grade-a:#5ed29c;
  --grade-b:#f1b14a;
  --grade-c:#e87a72;

  /* Shadow */
  --shadow-sm: 0 1px 0 rgba(0,0,0,0.30);
  --shadow-md: 0 1px 0 rgba(0,0,0,0.30), 0 8px 24px rgba(0,0,0,0.22);
  --shadow-lg: 0 1px 0 rgba(0,0,0,0.30), 0 20px 60px rgba(0,0,0,0.35);

  /* Fonts */
  --serif: 'Charter','Iowan Old Style','Source Serif Pro',Georgia,serif;
  --sans: Inter,-apple-system,'Segoe UI',Roboto,sans-serif;
  --mono: 'SF Mono','JetBrains Mono','IBM Plex Mono',Consolas,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{
  margin:0;padding:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--serif);
  font-size:17px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body{
  background-image:
    radial-gradient(ellipse 90% 50% at 50% -10%, rgba(116,176,255,0.10), transparent 60%),
    radial-gradient(ellipse 60% 40% at 90% 20%, rgba(212,169,83,0.05), transparent 60%);
  background-attachment:fixed;
}
.sans{font-family:var(--sans)}
.num{font-variant-numeric:tabular-nums;font-feature-settings:'tnum' 1}

a{color:inherit}
img{max-width:100%;display:block}

/* ─────────────────────────────────── NAV ─────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(10,17,36,0.78);
  backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  border-bottom:1px solid var(--hairline);
}
.nav .inner{
  max-width:1240px;margin:0 auto;padding:14px 28px;
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--sans);
}
.nav .logo{
  font-weight:700;letter-spacing:-0.015em;font-size:18px;
  color:var(--ink);text-decoration:none;
  display:flex;align-items:center;gap:10px;
}
.nav .logo::before{
  content:"";width:10px;height:10px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-soft);
}
.nav .logo span{color:var(--accent)}
.nav .links{display:flex;gap:28px;align-items:center;font-size:14px}
.nav .links a{color:var(--ink-muted);text-decoration:none;font-weight:500;transition:color 0.15s}
.nav .links a:hover{color:var(--ink)}
.nav .cta{
  background:var(--accent);color:#0a1124 !important;
  padding:9px 16px;border-radius:6px;
  font-size:13px;font-weight:700;letter-spacing:0.01em;
  transition:background 0.15s;
}
.nav .cta:hover{background:var(--accent-2)}

/* ──────────────────────────── LAYOUT ──────────────────────────── */
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:800px;margin:0 auto;padding:0 28px}

/* ──────────────────────────── ELEMENTS ──────────────────────────── */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:11px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:20px;
}
.eyebrow::before{
  content:"";display:inline-block;
  width:24px;height:1px;background:var(--accent);
}

/* ────────────────────────────── HERO ────────────────────────────── */
.hero{
  padding:104px 0 96px 0;
  border-bottom:1px solid var(--hairline);
  position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size:54px 54px;
  background-position:-1px -1px;
  mask-image:radial-gradient(ellipse 75% 65% at 75% 25%, black 0%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 75% 65% at 75% 25%, black 0%, transparent 75%);
  pointer-events:none;
}
.hero .wrap{position:relative;z-index:1}
.hero h1{
  font-family:var(--serif);
  font-size:68px;line-height:1.02;letter-spacing:-0.028em;
  margin:0 0 26px 0;max-width:15ch;font-weight:400;color:var(--ink);
}
.hero .sub{
  font-family:var(--serif);
  font-size:22px;color:var(--ink-2);
  max-width:62ch;margin:0 0 40px 0;line-height:1.5;font-weight:400;
}
.hero .ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero a.primary{
  background:var(--accent);color:#0a1124;
  padding:14px 26px;border-radius:8px;
  text-decoration:none;font-family:var(--sans);font-weight:700;
  font-size:14px;letter-spacing:0.01em;
  display:inline-flex;align-items:center;gap:8px;
  transition:transform 0.15s, background 0.15s, box-shadow 0.15s;
  box-shadow:0 4px 14px rgba(116,176,255,0.22);
}
.hero a.primary:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 6px 22px rgba(116,176,255,0.32)}
.hero a.secondary{
  background:transparent;color:var(--ink);
  padding:14px 26px;border-radius:8px;
  text-decoration:none;font-family:var(--sans);font-weight:600;
  font-size:14px;letter-spacing:0.01em;
  border:1px solid var(--hairline-strong);
  transition:background 0.15s, border-color 0.15s;
}
.hero a.secondary:hover{background:var(--surface);border-color:var(--accent)}

/* Hero stats strip */
.hero .meta{
  margin-top:64px;padding-top:32px;
  border-top:1px solid var(--hairline);
  font-family:var(--sans);
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
  max-width:1000px;
}
@media(max-width:760px){.hero .meta{grid-template-columns:repeat(2,1fr)}}
.hero .meta .stat{display:flex;flex-direction:column;gap:5px}
.hero .meta .stat .l{
  font-size:11px;text-transform:uppercase;letter-spacing:0.12em;
  color:var(--ink-faint);font-weight:700;
}
.hero .meta .stat .v{
  font-size:24px;font-weight:600;color:var(--ink);
  letter-spacing:-0.01em;font-variant-numeric:tabular-nums;
}
.hero .meta .stat .s{font-size:12px;color:var(--ink-muted);line-height:1.4}

/* ────────────────────────────── SECTIONS ────────────────────────────── */
section{
  padding:96px 0;
  border-bottom:1px solid var(--hairline);
  position:relative;
}
section.alt{background:var(--bg-alt)}
section h2{
  font-family:var(--serif);
  font-size:40px;letter-spacing:-0.022em;
  margin:0 0 12px 0;font-weight:400;color:var(--ink);line-height:1.15;
}
section .lede{
  font-size:18px;color:var(--ink-muted);
  margin:0 0 48px 0;max-width:68ch;line-height:1.6;
}

/* ─────────────────────────── METHOD CARDS ─────────────────────────── */
.method{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:980px){.method{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.method{grid-template-columns:1fr}}
.method .card{
  background:var(--surface);
  border:1px solid var(--hairline);
  border-radius:14px;padding:28px 24px;position:relative;
  transition:border-color 0.2s, transform 0.2s, box-shadow 0.2s, background 0.2s;
}
.method .card:hover{
  border-color:var(--hairline-accent);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  background:var(--surface-2);
}
.method .card .num{
  font-family:var(--sans);
  font-size:11px;letter-spacing:0.14em;
  color:var(--accent);margin-bottom:14px;font-weight:700;
  display:inline-flex;align-items:center;gap:10px;
}
.method .card .num::after{
  content:"";display:inline-block;width:18px;height:1px;background:var(--accent);opacity:0.5;
}
.method .card h3{
  font-family:var(--serif);
  font-size:21px;margin:0 0 12px 0;
  font-weight:500;letter-spacing:-0.01em;line-height:1.25;color:var(--ink);
}
.method .card p{
  font-size:14.5px;color:var(--ink-muted);margin:0;line-height:1.65;
  font-family:var(--sans);
}

/* ────────────────────────── UNIVERSE GRID ────────────────────────── */
.universe-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
  padding:14px 18px;margin-bottom:24px;
  background:var(--surface);
  border:1px solid var(--hairline);
  border-radius:10px;font-family:var(--sans);
}
.universe-toolbar .filters{display:flex;gap:4px;flex-wrap:wrap}
.universe-toolbar .filter{
  font-size:13px;font-weight:600;
  padding:7px 13px;border-radius:6px;
  color:var(--ink-muted);cursor:default;background:transparent;
  transition:background 0.15s, color 0.15s;
}
.universe-toolbar .filter.active{background:var(--accent);color:#0a1124}
.universe-toolbar .filter:hover:not(.active){background:var(--surface-2);color:var(--ink)}
.universe-toolbar .filter .count{color:var(--ink-faint);font-size:12px;margin-left:6px;font-weight:500}
.universe-toolbar .filter.active .count{color:rgba(10,17,36,0.65)}
.universe-toolbar .legend{font-size:12px;color:var(--ink-faint);display:flex;gap:16px;align-items:center}
.universe-toolbar .legend .dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  margin-right:6px;vertical-align:middle;
}
.universe-toolbar .legend .dot.owned{background:var(--accent)}
.universe-toolbar .legend .dot.watch{background:var(--hairline-strong)}

.universe-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:10px;
  font-family:var(--sans);
}
@media(max-width:1080px){.universe-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:680px){.universe-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:440px){.universe-grid{grid-template-columns:repeat(2,1fr)}}
.ticker{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:8px;padding:14px 12px 12px 12px;
  text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;gap:8px;
  transition:border-color 0.15s, transform 0.15s, background 0.15s, box-shadow 0.15s;
}
.ticker:hover{
  border-color:var(--hairline-accent);
  background:var(--surface-2);
  transform:translateY(-1px);
  box-shadow:var(--shadow-sm);
}
.ticker .top{display:flex;justify-content:space-between;align-items:center}
.ticker .sym{font-weight:700;font-size:14px;letter-spacing:0.02em;color:var(--ink)}
.ticker .score{
  font-size:11px;font-weight:700;
  padding:2px 7px;border-radius:4px;
  background:var(--surface-3);color:var(--ink-2);
  letter-spacing:0.02em;font-variant-numeric:tabular-nums;
  display:inline-flex;align-items:center;gap:4px;
}
.ticker .score.exceptional{background:var(--green-soft);color:var(--green)}
.ticker .score.strong{background:var(--accent-soft);color:var(--accent)}
.ticker .score.average{background:var(--surface-3);color:var(--ink-2)}
.ticker .score.weak{background:var(--amber-soft);color:var(--amber)}
.ticker .score.poor{background:var(--red-soft);color:var(--red)}
.ticker .name{font-size:12px;color:var(--ink-muted);line-height:1.3;font-weight:500}
.ticker .tag{font-size:10px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:0.08em;font-weight:600}
.ticker.owned{border-color:var(--accent);background:var(--accent-soft)}
.ticker.owned .tag{color:var(--accent)}
.ticker.coming{opacity:0.45;border-style:dashed}
.ticker.coming .sym{color:var(--ink-muted)}

/* ─────────────────── SAMPLE DOSSIER PREVIEW ─────────────────── */
.preview{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg);
}
.preview .head{
  padding:30px 32px;border-bottom:1px solid var(--hairline);
  display:flex;justify-content:space-between;align-items:flex-start;gap:24px;
}
.preview .head .left .ticker{
  font-family:var(--sans);font-weight:700;font-size:12px;
  letter-spacing:0.1em;color:var(--accent);
  background:none;border:none;padding:0;display:block;
}
.preview .head .left h3{
  font-family:var(--serif);
  margin:8px 0 8px 0;font-size:28px;font-weight:500;letter-spacing:-0.018em;color:var(--ink);
}
.preview .head .left .desc{font-size:14px;color:var(--ink-muted);margin:0;line-height:1.55;max-width:50ch}
.preview .head .right{text-align:right;font-family:var(--sans)}
.preview .head .right .price{
  font-size:30px;font-weight:600;color:var(--ink);letter-spacing:-0.015em;
  font-variant-numeric:tabular-nums;
}
.preview .head .right .change{font-size:13px;color:var(--green);margin-top:4px;font-weight:600}
.preview .head .right .ts{
  font-size:11px;color:var(--ink-faint);margin-top:8px;
  display:inline-flex;align-items:center;gap:6px;
}
.preview .head .right .ts::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--green);box-shadow:0 0 0 3px var(--green-soft);
  display:inline-block;
}
.preview .body{
  padding:26px 32px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.18) 100%);
}
@media(max-width:880px){.preview .body{grid-template-columns:repeat(2,1fr)}}
.preview .body .stat{font-family:var(--sans)}
.preview .body .stat .label{
  font-size:10px;text-transform:uppercase;letter-spacing:0.12em;
  color:var(--ink-faint);font-weight:700;
}
.preview .body .stat .value{
  font-size:26px;font-weight:600;margin-top:6px;color:var(--ink);
  letter-spacing:-0.015em;font-variant-numeric:tabular-nums;
}
.preview .body .stat .sub{font-size:12px;color:var(--ink-muted);margin-top:4px}
.preview .verdict{
  padding:20px 32px;background:var(--accent-soft);
  border-top:1px solid var(--hairline-accent);
  font-family:var(--sans);font-size:14px;line-height:1.6;color:var(--ink-2);
}
.preview .verdict strong{color:var(--accent)}
.preview .footer{
  padding:18px 32px;border-top:1px solid var(--hairline);
  text-align:center;font-family:var(--sans);font-size:14px;
  background:var(--bg-alt);
}
.preview .footer a{
  color:var(--accent);text-decoration:none;font-weight:600;
  display:inline-flex;align-items:center;gap:6px;
}
.preview .footer a:hover{color:var(--accent-2)}

/* ──────────────────────────── PRICING ──────────────────────────── */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
@media(max-width:980px){.pricing{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
.tier{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:16px;padding:36px 28px 32px 28px;
  display:flex;flex-direction:column;position:relative;
  transition:transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.tier:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--hairline-accent)}
.tier.featured{
  border-color:var(--accent);
  background:linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
  box-shadow:var(--shadow-lg), 0 0 0 1px var(--accent) inset;
}
.tier.featured::before{
  content:"Most popular";
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#0a1124;
  font-family:var(--sans);font-size:10px;letter-spacing:0.14em;
  text-transform:uppercase;padding:5px 14px;border-radius:99px;font-weight:700;
}
.tier h3{
  font-family:var(--sans);font-size:12px;letter-spacing:0.14em;
  text-transform:uppercase;margin:0 0 12px 0;
  color:var(--accent);font-weight:700;
}
.tier .price{
  font-family:var(--serif);
  font-size:48px;font-weight:400;margin:0 0 8px 0;
  letter-spacing:-0.025em;line-height:1;color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.tier .price .per{
  font-size:15px;color:var(--ink-muted);font-weight:400;
  font-family:var(--sans);letter-spacing:0;
}
.tier .billed{font-family:var(--sans);font-size:13px;color:var(--ink-faint);margin-bottom:28px}
.tier ul{
  list-style:none;padding:0;margin:0 0 28px 0;
  font-family:var(--sans);font-size:14px;color:var(--ink-2);flex-grow:1;
}
.tier ul li{
  padding:12px 0;border-bottom:1px solid var(--hairline);
  display:flex;gap:12px;align-items:flex-start;line-height:1.5;
}
.tier ul li:last-child{border-bottom:none}
.tier ul li::before{
  content:"";flex-shrink:0;width:16px;height:16px;margin-top:1px;
  background-color:var(--accent);
  -webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='black' d='M13.485 4.515a1 1 0 010 1.414l-6 6a1 1 0 01-1.414 0l-3-3a1 1 0 011.414-1.414L6.778 9.808l5.293-5.293a1 1 0 011.414 0z'/></svg>");
          mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='black' d='M13.485 4.515a1 1 0 010 1.414l-6 6a1 1 0 01-1.414 0l-3-3a1 1 0 011.414-1.414L6.778 9.808l5.293-5.293a1 1 0 011.414 0z'/></svg>");
  -webkit-mask-size:contain;mask-size:contain;
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
}
.tier .button{
  background:var(--surface-3);color:var(--ink);text-align:center;
  padding:14px 18px;border-radius:8px;text-decoration:none;
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:0.01em;
  border:1px solid var(--hairline-strong);
  transition:background 0.15s, transform 0.15s, border-color 0.15s;
}
.tier .button:hover{background:var(--surface-2);border-color:var(--accent);transform:translateY(-1px)}
.tier.featured .button{background:var(--accent);color:#0a1124;border-color:var(--accent)}
.tier.featured .button:hover{background:var(--accent-2);border-color:var(--accent-2)}
.tier .note{
  margin-top:14px;font-family:var(--sans);font-size:12px;
  color:var(--ink-faint);text-align:center;line-height:1.5;
}

/* ──────────────────────────────── FAQ ──────────────────────────────── */
.faq{
  display:grid;grid-template-columns:1fr 1fr;gap:0 48px;
  font-family:var(--sans);
}
@media(max-width:760px){.faq{grid-template-columns:1fr;gap:0}}
.faq > div{padding:24px 0;border-bottom:1px solid var(--hairline)}
.faq h4{
  font-size:16px;margin:0 0 8px 0;font-weight:600;
  color:var(--ink);letter-spacing:-0.005em;
}
.faq p{font-size:14.5px;color:var(--ink-muted);margin:0;line-height:1.65}

/* ──────────────────────────────── FOOTER ──────────────────────────────── */
.foot{
  background:#060b1a;color:#bcc1d0;
  padding:72px 0 36px 0;font-family:var(--sans);
  border-top:1px solid var(--hairline);
}
.foot .grid{display:grid;grid-template-columns:2.4fr 1fr 1fr 1fr;gap:48px}
@media(max-width:760px){.foot .grid{grid-template-columns:1fr 1fr;gap:36px 24px}}
.foot h5{
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--accent);margin:0 0 16px 0;font-weight:700;
}
.foot a{
  display:block;color:#bcc1d0;text-decoration:none;
  font-size:14px;padding:6px 0;transition:color 0.15s;
}
.foot a:hover{color:#fff}
.foot .brand{
  font-weight:700;font-size:18px;color:#fff;margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.foot .brand::before{
  content:"";width:10px;height:10px;border-radius:50%;background:var(--accent);
}
.foot .brand span{color:var(--accent)}
.foot .small{font-size:13.5px;color:#7a8093;margin-top:4px;line-height:1.6;max-width:42ch}
.foot .legal{
  margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.06);
  font-size:12px;color:#5c6478;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}

/* ═══════════════════════════════════════════════════════════════════
   DOSSIER PAGE
   ═══════════════════════════════════════════════════════════════════ */

.dossier-header{
  padding:56px 0 44px 0;
  border-bottom:1px solid var(--hairline);
  background:linear-gradient(180deg, var(--bg) 0%, var(--bg-alt) 100%);
  position:relative;overflow:hidden;
}
.dossier-header::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
                   linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 60% at 85% 30%, black 0%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 85% 30%, black 0%, transparent 75%);
}
.dossier-header > *{position:relative;z-index:1}
.dossier-header .crumb{
  font-family:var(--sans);font-size:13px;color:var(--ink-faint);
  margin-bottom:24px;font-weight:500;
}
.dossier-header .crumb a{color:var(--ink-muted);text-decoration:none}
.dossier-header .crumb a:hover{color:var(--accent)}
.dossier-header .crumb strong{color:var(--ink)}
.dossier-title-row{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:32px;flex-wrap:wrap;
}
.dossier-title-row .left .ticker{
  font-family:var(--sans);font-weight:700;font-size:12px;
  letter-spacing:0.12em;color:var(--accent);
  display:block;margin-bottom:12px;text-transform:uppercase;
}
.dossier-title-row .left h1{
  font-family:var(--serif);
  font-size:46px;letter-spacing:-0.022em;
  margin:0 0 10px 0;font-weight:400;line-height:1.08;color:var(--ink);
}
.dossier-title-row .left .meta{
  font-family:var(--sans);font-size:13.5px;color:var(--ink-muted);
  margin-top:4px;line-height:1.55;
}
.dossier-title-row .right{font-family:var(--sans);text-align:right}
.dossier-title-row .right .price{
  font-size:36px;font-weight:600;line-height:1;letter-spacing:-0.018em;
  font-variant-numeric:tabular-nums;color:var(--ink);
}
.dossier-title-row .right .change{font-size:13px;color:var(--green);margin-top:6px;font-weight:600}
.dossier-title-row .right .updated{
  font-size:11px;color:var(--ink-faint);margin-top:10px;
  display:inline-flex;align-items:center;gap:6px;
}
.dossier-title-row .right .updated::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--green);box-shadow:0 0 0 3px var(--green-soft);
  display:inline-block;
}

/* ──────────────────────── SCORE CARD ──────────────────────── */
.score-card{
  background:var(--surface);
  border:1px solid var(--hairline);
  border-radius:18px;margin:36px 0;
  font-family:var(--sans);
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.score-card .top{
  display:grid;grid-template-columns:280px 1fr;gap:0;
  border-bottom:1px solid var(--hairline);
}
@media(max-width:760px){.score-card .top{grid-template-columns:1fr}}
.score-main{
  padding:32px;
  background:linear-gradient(135deg, var(--surface-2) 0%, var(--surface) 100%);
  border-right:1px solid var(--hairline);
  display:flex;flex-direction:column;justify-content:center;
  gap:6px;position:relative;
}
@media(max-width:760px){.score-main{border-right:none;border-bottom:1px solid var(--hairline)}}
.score-main .label{
  font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:700;
}
.score-main .value{
  font-family:var(--serif);
  font-size:84px;line-height:1;font-weight:400;
  letter-spacing:-0.04em;color:var(--ink);
  font-variant-numeric:tabular-nums;
  display:inline-flex;align-items:baseline;gap:6px;
}
.score-main .value .total{font-size:24px;color:var(--ink-muted);font-weight:400;letter-spacing:-0.01em}
.score-main .band{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  margin-top:4px;
}
.score-main .band.exceptional{color:var(--green)}
.score-main .band.strong{color:var(--accent)}
.score-main .band.average{color:var(--ink-2)}
.score-main .band.weak{color:var(--amber)}
.score-main .band.poor{color:var(--red)}
.score-main .band::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:currentColor;box-shadow:0 0 0 4px currentColor;
  opacity:0.9;
}
.score-main .band.exceptional::before{box-shadow:0 0 0 4px var(--green-soft)}
.score-main .band.strong::before{box-shadow:0 0 0 4px var(--accent-soft)}
.score-main .band.weak::before{box-shadow:0 0 0 4px var(--amber-soft)}
.score-main .band.poor::before{box-shadow:0 0 0 4px var(--red-soft)}

.score-pillars{padding:24px 28px;display:flex;flex-direction:column;gap:14px}
.pillar{display:grid;grid-template-columns:120px 1fr 60px;gap:18px;align-items:center}
@media(max-width:600px){.pillar{grid-template-columns:90px 1fr 50px;gap:12px}}
.pillar .pl{font-size:12px;font-weight:600;color:var(--ink-2);letter-spacing:0.02em}
.pillar .pb{
  height:8px;border-radius:4px;background:var(--surface-3);
  position:relative;overflow:hidden;
}
.pillar .pb .fill{
  position:absolute;left:0;top:0;height:100%;border-radius:4px;
  background:linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 100%);
}
.pillar .pb .fill.green{background:linear-gradient(90deg, var(--green) 0%, #8ce5b8 100%)}
.pillar .pb .fill.amber{background:linear-gradient(90deg, var(--amber) 0%, #f7c977 100%)}
.pillar .pb .fill.red{background:linear-gradient(90deg, var(--red) 0%, #f0a09a 100%)}
.pillar .ps{
  text-align:right;font-variant-numeric:tabular-nums;
  font-weight:700;font-size:13px;color:var(--ink);
}
.pillar .ps .max{color:var(--ink-faint);font-weight:500}

.score-scale{
  padding:14px 28px;display:flex;gap:0;
  font-size:11px;font-family:var(--sans);
  background:var(--bg-alt);border-top:1px solid var(--hairline);
}
.score-scale .band{
  flex:1;padding:8px 10px;text-align:center;font-weight:600;
  color:var(--ink-faint);letter-spacing:0.04em;
  border-right:1px solid var(--hairline);
}
.score-scale .band:last-child{border-right:none}
.score-scale .band.active{color:var(--ink);background:var(--surface-2)}
.score-scale .band.active.exceptional{color:var(--green)}
.score-scale .band.active.strong{color:var(--accent)}
.score-scale .band.active.average{color:var(--ink-2)}
.score-scale .band.active.weak{color:var(--amber)}
.score-scale .band.active.poor{color:var(--red)}

/* ─────────────────────── VERDICT BAR ─────────────────────── */
.verdict-bar{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:14px;padding:24px 28px;margin:36px 0;
  display:grid;grid-template-columns:repeat(5,1fr);gap:28px;
  font-family:var(--sans);box-shadow:var(--shadow-sm);
}
@media(max-width:880px){.verdict-bar{grid-template-columns:repeat(2,1fr)}}
.verdict-bar .cell .l{
  font-size:10px;text-transform:uppercase;letter-spacing:0.12em;
  color:var(--ink-faint);font-weight:700;
}
.verdict-bar .cell .v{
  font-size:24px;font-weight:600;margin-top:6px;
  letter-spacing:-0.015em;font-variant-numeric:tabular-nums;line-height:1.1;
  color:var(--ink);
}
.verdict-bar .cell .v.green{color:var(--green)}
.verdict-bar .cell .v.amber{color:var(--amber)}
.verdict-bar .cell .v.red{color:var(--red)}
.verdict-bar .cell .s{font-size:12px;color:var(--ink-muted);margin-top:4px;line-height:1.4}

.thesis{
  font-family:var(--serif);
  font-size:20px;line-height:1.6;color:var(--ink);
  margin:36px 0 48px 0;padding:8px 0 8px 24px;
  border-left:3px solid var(--accent);
  max-width:72ch;
}

/* ─────────────────────── DOSSIER CARDS ─────────────────────── */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:52px}
@media(max-width:760px){.cards{grid-template-columns:1fr}}
.cards.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:880px){.cards.three{grid-template-columns:1fr}}
.cards.one{grid-template-columns:1fr}
.dcard{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:14px;padding:28px;box-shadow:var(--shadow-sm);
}
.dcard .h{
  font-family:var(--sans);
  font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:12px;
  display:inline-flex;align-items:center;gap:10px;
}
.dcard .h::after{content:"";display:inline-block;width:24px;height:1px;background:var(--accent);opacity:0.5}
.dcard h3{
  font-family:var(--serif);
  margin:0 0 18px 0;font-size:22px;font-weight:500;
  letter-spacing:-0.015em;color:var(--ink);
}
.dcard p{font-size:15.5px;line-height:1.68;color:var(--ink-2);margin:0 0 14px 0}
.dcard p:last-child{margin-bottom:0}
.dcard p strong{color:var(--ink)}
.dcard ul.flush{list-style:none;padding:0;margin:0;font-family:var(--sans)}
.dcard ul.flush li{
  padding:11px 0;border-bottom:1px solid var(--hairline);
  font-size:14px;display:flex;justify-content:space-between;gap:12px;
}
.dcard ul.flush li:last-child{border-bottom:none}
.dcard ul.flush li .k{color:var(--ink-muted)}
.dcard ul.flush li .v{font-weight:600;color:var(--ink);text-align:right;font-variant-numeric:tabular-nums}
.dcard ul.numbered{list-style:none;padding:0;margin:0;counter-reset:item}
.dcard ul.numbered li{
  counter-increment:item;padding:14px 0;
  border-bottom:1px solid var(--hairline);
  position:relative;padding-left:42px;font-size:14px;
}
.dcard ul.numbered li::before{
  content:counter(item, decimal-leading-zero);
  position:absolute;left:0;top:14px;
  font-family:var(--sans);font-weight:700;font-size:11px;
  color:var(--accent);background:var(--accent-soft);
  width:28px;height:22px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:4px;letter-spacing:0.05em;
}
.dcard ul.numbered li:last-child{border-bottom:none}
.dcard ul.numbered li b{
  font-family:var(--sans);display:block;margin-bottom:4px;
  font-size:14px;color:var(--ink);font-weight:600;
}
.dcard ul.numbered li span.note{color:var(--ink-muted);font-size:13.5px;line-height:1.6}

/* Big stat grid */
.bignums{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;font-family:var(--sans)}
@media(max-width:600px){.bignums{grid-template-columns:repeat(2,1fr)}}
.bignums .stat{
  background:var(--bg-alt);border:1px solid var(--hairline);
  border-radius:8px;padding:14px;
}
.bignums .stat .l{
  font-size:10px;text-transform:uppercase;letter-spacing:0.12em;
  color:var(--ink-faint);font-weight:700;
}
.bignums .stat .v{
  font-size:22px;font-weight:600;margin-top:6px;color:var(--ink);
  letter-spacing:-0.015em;font-variant-numeric:tabular-nums;line-height:1.1;
}
.bignums .stat .s{font-size:11px;color:var(--ink-muted);margin-top:4px}

/* ────────────────── MOAT CHECKLIST ────────────────── */
.moat-check{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:14px;padding:28px;margin-bottom:28px;
  font-family:var(--sans);box-shadow:var(--shadow-sm);
}
.moat-check .h{
  font-family:var(--sans);font-size:10px;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:8px;
}
.moat-check h3{
  font-family:var(--serif);margin:0 0 6px 0;
  font-size:22px;font-weight:500;letter-spacing:-0.015em;color:var(--ink);
}
.moat-check .sub{font-size:13.5px;color:var(--ink-muted);margin:0 0 22px 0;line-height:1.55}
.moat-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0 32px;
}
@media(max-width:760px){.moat-grid{grid-template-columns:1fr;gap:0}}
.moat-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:11px 0;border-bottom:1px solid var(--hairline);
}
.moat-item:last-child{border-bottom:none}
.moat-item .mark{
  font-size:10px;font-weight:700;letter-spacing:0.06em;
  padding:3px 8px;border-radius:4px;flex-shrink:0;
  min-width:44px;text-align:center;text-transform:uppercase;
  margin-top:1px;font-variant-numeric:tabular-nums;
}
.moat-item.yes .mark{background:var(--green-soft);color:var(--green)}
.moat-item.mod .mark{background:var(--amber-soft);color:var(--amber)}
.moat-item.no .mark{background:var(--surface-3);color:var(--ink-muted)}
.moat-item .text{font-size:13.5px;color:var(--ink-2);line-height:1.55;font-weight:500}
.moat-item .text em{color:var(--ink-muted);font-style:normal;font-weight:400;display:block;margin-top:1px;font-size:12.5px}

/* Valuation card */
.valuation-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media(max-width:600px){.valuation-grid{grid-template-columns:1fr}}
.iv-display{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-deep) 100%);
  color:#fff;border-radius:14px;padding:28px;text-align:center;
  font-family:var(--sans);
  box-shadow:0 12px 32px rgba(116,176,255,0.20), inset 0 1px 0 rgba(255,255,255,0.15);
}
.iv-display .l{
  font-size:10px;text-transform:uppercase;letter-spacing:0.18em;
  color:rgba(255,255,255,0.75);font-weight:700;
}
.iv-display .v{
  font-family:var(--serif);
  font-size:52px;font-weight:400;margin:10px 0 8px 0;color:#fff;
  letter-spacing:-0.03em;line-height:1;
  font-variant-numeric:tabular-nums;
}
.iv-display .s{font-size:13px;color:rgba(255,255,255,0.85);line-height:1.5}
.iv-detail{
  margin-top:20px;background:var(--bg-alt);border:1px solid var(--hairline);
  padding:20px;border-radius:10px;
  font-family:var(--sans);font-size:13px;color:var(--ink-muted);line-height:1.7;
}
.iv-detail strong{color:var(--ink);display:block;margin-bottom:10px;font-size:13px}

/* Our take */
.our-take{
  background:var(--surface);border:1px solid var(--hairline-accent);
  border-radius:14px;padding:36px;margin-bottom:28px;
  position:relative;box-shadow:var(--shadow-md);
}
.our-take::before{
  content:"";position:absolute;top:0;left:0;
  width:4px;height:100%;background:var(--accent);
  border-radius:14px 0 0 14px;
}
.our-take .h{
  font-family:var(--sans);font-size:11px;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:10px;
}
.our-take h3{
  font-family:var(--serif);margin:0 0 18px 0;
  font-size:24px;font-weight:500;letter-spacing:-0.015em;color:var(--ink);
}
.our-take p{
  font-family:var(--serif);
  font-size:17.5px;line-height:1.7;margin:0 0 14px 0;color:var(--ink);
}
.our-take .sig{font-family:var(--sans);font-size:12px;color:var(--ink-faint);margin-top:22px}

/* Latest quarter */
.latest{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:14px;padding:28px;margin-bottom:28px;
  box-shadow:var(--shadow-sm);
}
.latest .h{
  font-family:var(--sans);font-size:11px;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:10px;
  display:flex;justify-content:space-between;align-items:center;
}
.latest .h .when{color:var(--ink-faint);font-weight:500;letter-spacing:0.06em}
.latest h3{
  font-family:var(--serif);margin:0 0 14px 0;
  font-size:20px;font-weight:500;letter-spacing:-0.01em;color:var(--ink);
}
.latest ul{margin:0;padding-left:22px;font-size:15px;line-height:1.65}
.latest ul li{margin-bottom:8px;color:var(--ink-2)}
.latest ul li strong{color:var(--ink)}

/* Peers */
.peers{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;font-family:var(--sans)}
@media(max-width:760px){.peers{grid-template-columns:1fr}}
.peer{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:10px;padding:16px;text-decoration:none;color:var(--ink);
  transition:border-color 0.15s, transform 0.15s, background 0.15s, box-shadow 0.15s;
}
.peer:hover{
  border-color:var(--hairline-accent);background:var(--surface-2);
  transform:translateY(-1px);box-shadow:var(--shadow-sm);
}
.peer .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.peer .sym{font-weight:700;font-size:13px;letter-spacing:0.04em;color:var(--accent)}
.peer .score{
  font-size:10px;background:var(--accent-soft);color:var(--accent);
  padding:3px 8px;border-radius:4px;font-weight:700;letter-spacing:0.02em;
  font-variant-numeric:tabular-nums;
}
.peer .name{font-size:13px;color:var(--ink-muted);line-height:1.5}

/* Dossier CTA */
.dossier-cta{
  margin:56px 0;padding:40px;
  background:linear-gradient(135deg, var(--surface) 0%, var(--surface-2) 100%);
  border:1px solid var(--hairline-accent);border-radius:14px;
  text-align:center;font-family:var(--sans);
  box-shadow:var(--shadow-md);position:relative;overflow:hidden;
}
.dossier-cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 40% at 30% 0%, var(--accent-soft) 0%, transparent 60%);
  pointer-events:none;
}
.dossier-cta > *{position:relative;z-index:1}
.dossier-cta .lead{
  font-family:var(--serif);font-size:20px;color:var(--ink);
  margin:0 0 22px 0;line-height:1.5;font-weight:400;
}
.dossier-cta .lead strong{color:var(--accent);font-weight:600}
.dossier-cta a{
  display:inline-block;background:var(--accent);color:#0a1124;
  padding:14px 32px;border-radius:8px;text-decoration:none;
  font-weight:700;font-size:14px;letter-spacing:0.01em;
  transition:background 0.15s, transform 0.15s, box-shadow 0.15s;
  box-shadow:0 4px 14px rgba(116,176,255,0.25);
}
.dossier-cta a:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 8px 22px rgba(116,176,255,0.38)}

/* Mobile polish */
@media(max-width:760px){
  .hero{padding:64px 0 64px 0}
  .hero h1{font-size:42px;letter-spacing:-0.02em}
  .hero .sub{font-size:18px}
  .hero .meta{margin-top:40px;padding-top:24px}
  section{padding:64px 0}
  section h2{font-size:32px}
  .dossier-title-row .left h1{font-size:34px}
  .score-main .value{font-size:64px}
}

/* ════════════════════════════════════════════════════════════════════
   STRUCTURED RESEARCH REPORT (Parts 1-6 layout)
   ════════════════════════════════════════════════════════════════════ */

/* Top header strip: price / change / market cap / EV / score */
.rep-header-strip{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:14px;margin:28px 0 36px;
  padding:22px 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
  font-family:var(--sans);box-shadow:var(--shadow-sm);
}
@media(max-width:980px){.rep-header-strip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.rep-header-strip{grid-template-columns:repeat(2,1fr)}}
.rep-header-strip .cell{display:flex;flex-direction:column;gap:5px;min-width:0}
.rep-header-strip .cell .l{
  font-size:10px;text-transform:uppercase;letter-spacing:0.14em;
  color:var(--ink-faint);font-weight:700;
}
.rep-header-strip .cell .v{
  font-size:22px;font-weight:600;color:var(--ink);
  letter-spacing:-0.012em;font-variant-numeric:tabular-nums;line-height:1.15;
}
.rep-header-strip .cell .s{font-size:12px;color:var(--ink-muted);line-height:1.4}
.rep-header-strip .cell.score-cell .v.exceptional{color:var(--green)}
.rep-header-strip .cell.score-cell .v.strong{color:var(--accent)}
.rep-header-strip .cell.score-cell .v.average{color:var(--ink-2)}
.rep-header-strip .cell.score-cell .v.weak{color:var(--amber)}
.rep-header-strip .cell.score-cell .v.poor{color:var(--red)}

/* Pillar notes inside score-card */
.pillar{
  display:grid;
  grid-template-columns:120px 1fr 60px;
  grid-template-areas:"label bar score" "note note note";
  gap:4px 18px;align-items:center;
}
@media(max-width:600px){.pillar{grid-template-columns:90px 1fr 50px;gap:4px 12px}}
.pillar .pl{grid-area:label}
.pillar .pb{grid-area:bar}
.pillar .ps{grid-area:score}
.pillar .note{
  grid-area:note;
  font-size:11.5px;color:var(--ink-faint);line-height:1.5;
  padding-left:0;padding-top:2px;font-style:italic;
}
@media(min-width:601px){.pillar .note{padding-left:138px}}

/* Compact one-line thesis under the score card */
.rep-thesis{
  font-family:var(--serif);
  font-size:18px;line-height:1.55;color:var(--ink);
  margin:8px 0 48px 0;padding:14px 22px;
  background:var(--surface);border:1px solid var(--hairline);
  border-left:3px solid var(--accent);border-radius:0 10px 10px 0;
  max-width:90ch;
}
.rep-thesis strong{color:var(--accent)}

/* Part section */
.rep-part{margin:64px 0 0}
.rep-part-h{
  display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;
  padding-bottom:14px;margin-bottom:28px;
  border-bottom:2px solid var(--hairline-accent);
}
.rep-part-h .num{
  font-family:var(--sans);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--accent);font-weight:700;
}
.rep-part-h h2{
  font-family:var(--serif);font-size:34px;margin:0;
  font-weight:400;letter-spacing:-0.022em;color:var(--ink);line-height:1.15;
}

/* Subsection */
.rep-sub{margin-bottom:36px}
.rep-sub:last-child{margin-bottom:0}
.rep-sub-h{
  font-family:var(--sans);
  font-size:14px;font-weight:700;letter-spacing:0.02em;
  color:var(--ink);margin:0 0 14px 0;
  display:flex;align-items:baseline;gap:12px;
}
.rep-sub-h .n{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:700}

/* Bullets */
.rep-bullets{margin:0;padding:0;list-style:none;font-family:var(--sans);background:var(--surface);
  border:1px solid var(--hairline);border-radius:10px;overflow:hidden}
.rep-bullets li{
  padding:11px 18px 11px 32px;position:relative;
  font-size:14px;color:var(--ink-2);line-height:1.55;
  border-bottom:1px solid var(--hairline);
}
.rep-bullets li::before{
  content:"";position:absolute;left:14px;top:18px;
  width:5px;height:5px;border-radius:50%;background:var(--accent);
}
.rep-bullets li:last-child{border-bottom:none}
.rep-bullets li b, .rep-bullets li strong{color:var(--ink);font-weight:600}
.rep-bullets li sup{color:var(--accent);font-weight:700;margin-left:3px}

/* Data tables */
.rep-table-wrap{
  background:var(--surface);border:1px solid var(--hairline);border-radius:10px;
  overflow:hidden;
}
.rep-table{
  width:100%;border-collapse:collapse;font-family:var(--sans);font-size:13.5px;
  font-variant-numeric:tabular-nums;
}
.rep-table th{
  text-align:left;font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-faint);padding:12px 16px;
  border-bottom:1px solid var(--hairline-strong);background:var(--bg-alt);
}
.rep-table th.right, .rep-table td.right{text-align:right}
.rep-table td{
  padding:11px 16px;border-bottom:1px solid var(--hairline);color:var(--ink-2);
}
.rep-table tbody tr:last-child td{border-bottom:none}
.rep-table td.label{color:var(--ink-muted)}
.rep-table td.value{color:var(--ink);font-weight:600}
.rep-table td.pos{color:var(--green);font-weight:600}
.rep-table td.neg{color:var(--red);font-weight:600}
.rep-table td.flag{color:var(--amber);font-weight:600}
.rep-table tbody tr:hover{background:var(--surface-2)}

/* Notes / flags under a table */
.rep-notes{
  margin-top:14px;padding:14px 18px;
  background:var(--surface);border-left:3px solid var(--amber);
  border-radius:0 8px 8px 0;font-family:var(--sans);font-size:13px;color:var(--ink-2);
  line-height:1.6;
}
.rep-notes b{color:var(--amber);font-weight:700;display:block;margin-bottom:4px}
.rep-notes.green{border-left-color:var(--green)}
.rep-notes.green b{color:var(--green)}
.rep-notes.red{border-left-color:var(--red)}
.rep-notes.red b{color:var(--red)}
.rep-notes sup{color:var(--accent);font-weight:700}

/* ─────────────────────────── TOC SIDEBAR ─────────────────────────── */
/* Auto-injected by toc.js on each research-report page. */

html{scroll-padding-top:80px}

.wrap.report-with-toc{
  display:grid;
  grid-template-columns:230px 1fr;
  gap:48px;
  align-items:start;
  max-width:1320px;
}
@media(max-width:1080px){.wrap.report-with-toc{grid-template-columns:200px 1fr;gap:32px}}
@media(max-width:980px){.wrap.report-with-toc{display:block}}

.report-toc{
  position:sticky;top:76px;align-self:start;
  font-family:var(--sans);
  max-height:calc(100vh - 100px);overflow-y:auto;
  grid-column:1;grid-row:1;
  scrollbar-width:thin;scrollbar-color:var(--hairline-strong) transparent;
}
.report-toc::-webkit-scrollbar{width:6px}
.report-toc::-webkit-scrollbar-track{background:transparent}
.report-toc::-webkit-scrollbar-thumb{background:var(--hairline-strong);border-radius:3px}
@media(max-width:980px){.report-toc{position:static;margin-bottom:28px;max-height:none}}

.report-toc .toc-inner{
  background:var(--surface);
  border:1px solid var(--hairline);
  border-radius:12px;
  padding:18px 20px;
  box-shadow:var(--shadow-sm);
}

.report-toc .toc-h{
  font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:14px;
  padding-bottom:10px;border-bottom:1px solid var(--hairline);
}

.report-toc ul{list-style:none;margin:0;padding:0}

.report-toc .toc-link{
  display:flex;align-items:baseline;gap:10px;
  padding:7px 0 7px 12px;margin-left:-12px;
  color:var(--ink-muted);text-decoration:none;
  font-size:13px;line-height:1.4;
  border-left:2px solid transparent;
  transition:color 0.15s, border-color 0.15s;
}
.report-toc .toc-link:hover{color:var(--ink)}
.report-toc .toc-link.active{
  color:var(--accent);
  border-left-color:var(--accent);
  font-weight:600;
}

.report-toc .toc-l1{font-weight:600;font-size:13px}
.report-toc .toc-l1 .n{
  color:var(--ink-faint);
  font-variant-numeric:tabular-nums;font-weight:700;
  font-size:11px;min-width:14px;
}

.report-toc .toc-l2{
  font-size:12px;color:var(--ink-faint);
  padding-left:26px;font-weight:500;
}
.report-toc .toc-l2 .n{
  font-size:10.5px;color:var(--ink-faint);
  font-weight:600;min-width:24px;font-variant-numeric:tabular-nums;
}
.report-toc .toc-l2:hover{color:var(--ink-muted)}

.report-toc .toc-sub{margin:0 0 8px 0}
.report-toc ul li{margin-bottom:0}

.report-main{
  grid-column:2;grid-row:1;
  min-width:0; /* Prevent grid blowout from long tables */
}

/* Per-section source line &mdash; backend-only, hidden from readers.
   Kept in the DOM so source citations are inspectable via view-source. */
.rep-source{display:none}

/* Verdict block signature (last reviewed / next review dates) &mdash;
   backend-only; reader sees the analytical content but not the meta. */
.rep-verdict .sig{display:none}
.rep-source-visible{
  font-family:var(--sans);font-size:11px;color:var(--ink-faint);
  margin-top:12px;padding-top:8px;
  display:flex;flex-wrap:wrap;gap:8px;align-items:baseline;
}
.rep-source .lbl{
  color:var(--ink-muted);font-weight:700;
  text-transform:uppercase;letter-spacing:0.1em;font-size:10px;
}
.rep-source code{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  background:var(--surface-2);padding:2px 7px;border-radius:3px;
}

/* Competitor cards */
.competitors{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;font-family:var(--sans)}
@media(max-width:760px){.competitors{grid-template-columns:1fr}}
.competitor{
  background:var(--surface);border:1px solid var(--hairline);border-radius:10px;padding:16px 18px;
}
.competitor .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;gap:12px}
.competitor .name{font-weight:700;font-size:14px;color:var(--ink);letter-spacing:-0.005em}
.competitor .role{
  font-size:10px;color:var(--accent);
  text-transform:uppercase;letter-spacing:0.1em;font-weight:700;
  background:var(--accent-soft);padding:3px 8px;border-radius:4px;
}
.competitor .body{font-size:13px;color:var(--ink-muted);line-height:1.55}

/* Sources block at bottom &mdash; backend-only, hidden from readers.
   Kept in the DOM so source citations are inspectable via view-source. */
.sources-block{display:none}
.sources-block-visible{
  background:var(--bg-alt);border:1px solid var(--hairline);border-radius:12px;
  padding:28px 32px;margin:56px 0 28px;font-family:var(--sans);
}
.sources-block .h{
  font-family:var(--sans);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--accent);margin:0 0 6px;font-weight:700;
}
.sources-block h3{
  font-family:var(--serif);font-size:22px;margin:0 0 18px;
  font-weight:500;letter-spacing:-0.015em;color:var(--ink);
}
.sources-list{margin:0;padding:0;list-style:none;font-size:12.5px;color:var(--ink-2)}
.sources-list li{
  padding:9px 0;border-bottom:1px solid var(--hairline);
  display:grid;grid-template-columns:28px 1fr;gap:10px;align-items:start;line-height:1.55;
}
.sources-list li:last-child{border-bottom:none}
.sources-list li .n{
  color:var(--accent);font-weight:700;font-size:12px;
}
.sources-list li code{
  font-family:var(--mono);font-size:11.5px;color:var(--ink-muted);
  background:var(--surface);padding:2px 7px;border-radius:3px;
  word-break:break-all;
}
.sources-list li .desc{display:block;margin-top:3px;color:var(--ink-muted);font-size:12px}

/* Verdict footer (compact, before sources) */
.rep-verdict{
  background:var(--surface);border:1px solid var(--hairline-accent);
  border-radius:12px;padding:22px 26px;margin:32px 0;
  font-family:var(--sans);position:relative;
}
.rep-verdict::before{
  content:"";position:absolute;left:0;top:0;width:4px;height:100%;
  background:var(--accent);border-radius:12px 0 0 12px;
}
.rep-verdict .h{
  font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:8px;
}
.rep-verdict h3{
  font-family:var(--serif);font-size:20px;margin:0 0 12px;
  font-weight:500;letter-spacing:-0.01em;color:var(--ink);
}
.rep-verdict ul{margin:0;padding:0;list-style:none}
.rep-verdict ul li{
  padding:7px 0 7px 22px;position:relative;
  font-size:14px;color:var(--ink-2);line-height:1.55;
}
.rep-verdict ul li::before{
  content:"";position:absolute;left:6px;top:14px;
  width:5px;height:5px;border-radius:50%;background:var(--accent);
}
.rep-verdict ul li b{color:var(--ink);font-weight:600}
.rep-verdict .sig{
  font-size:11px;color:var(--ink-faint);margin-top:14px;
  padding-top:12px;border-top:1px solid var(--hairline);
}

/* ════════════════════════════════════════════════════════════════════
   PROGRESSIVE DISCLOSURE: .rep-expand (native <details>)
   ════════════════════════════════════════════════════════════════════ */

.rep-expand{
  margin:14px 0 0;
  border:1px solid var(--hairline);
  border-radius:8px;
  background:var(--bg-alt);
  font-family:var(--sans);
  overflow:hidden;
}
.rep-expand summary{
  cursor:pointer;
  padding:11px 16px;
  font-size:12.5px;font-weight:600;
  color:var(--accent);
  letter-spacing:0.015em;
  display:flex;align-items:center;gap:12px;
  list-style:none;user-select:none;
  transition:background 0.15s;
}
.rep-expand summary::-webkit-details-marker{display:none}
.rep-expand summary::before{
  content:"+";
  flex-shrink:0;
  width:18px;height:18px;line-height:16px;
  text-align:center;
  border:1px solid var(--accent);
  border-radius:4px;
  font-size:14px;font-weight:700;
  background:transparent;color:var(--accent);
  transition:background 0.15s, color 0.15s;
}
.rep-expand[open] summary::before{
  content:"\2212"; /* minus */
  background:var(--accent);
  color:var(--bg);
}
.rep-expand summary:hover{background:var(--surface)}
.rep-expand summary .ex-tag{
  margin-left:auto;
  font-size:10px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:600;
}
.rep-expand .ex-body{
  padding:16px;
  border-top:1px solid var(--hairline);
  font-size:13.5px;color:var(--ink-2);line-height:1.65;
  background:var(--surface);
}
.rep-expand .ex-body > p{margin:0 0 10px}
.rep-expand .ex-body > p:last-child{margin-bottom:0}
.rep-expand .ex-body b,.rep-expand .ex-body strong{color:var(--ink);font-weight:600}
.rep-expand .ex-body em{color:var(--ink-muted);font-style:normal}

/* Mini-table inside expandable */
.rep-expand .ex-table{
  width:100%;border-collapse:collapse;margin:8px 0;
  font-family:var(--sans);font-size:12.5px;
  font-variant-numeric:tabular-nums;
}
.rep-expand .ex-table th{
  font-size:10px;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--ink-faint);text-align:left;padding:7px 10px;
  border-bottom:1px solid var(--hairline-strong);font-weight:700;
}
.rep-expand .ex-table th.right,
.rep-expand .ex-table td.right{text-align:right}
.rep-expand .ex-table td{
  padding:7px 10px;border-bottom:1px solid var(--hairline);
  color:var(--ink-2);
}
.rep-expand .ex-table tr:last-child td{border-bottom:none}
.rep-expand .ex-table td.pos{color:var(--green);font-weight:600}
.rep-expand .ex-table td.neg{color:var(--red);font-weight:600}
.rep-expand .ex-table td.flag{color:var(--amber);font-weight:600}

/* "Data pending" stub — visibly different from sourced content */
.rep-expand .data-pending{
  background:var(--amber-soft);
  border-left:3px solid var(--amber);
  padding:10px 14px;border-radius:0 6px 6px 0;
  font-size:12.5px;color:var(--ink-2);
}
.rep-expand .data-pending b{color:var(--amber);font-weight:700}

/* Tighter inside the verdict block */
.rep-verdict .rep-expand{margin-top:10px}

/* ────────────────────────────────────────────────────────────────────
   INLINE EXPAND PATTERNS — bullet, card, table-row, list-item
   ──────────────────────────────────────────────────────────────────── */

/* Common reveal panel that drops below the trigger element */
.ex-reveal{
  margin-top:10px;padding:11px 14px;
  background:var(--bg-alt);border-left:2px solid var(--accent);
  border-radius:0 6px 6px 0;
  font-family:var(--sans);
  font-size:12.8px;color:var(--ink-2);line-height:1.6;
}
.ex-reveal > p{margin:0 0 8px}
.ex-reveal > p:last-child{margin-bottom:0}
.ex-reveal b,.ex-reveal strong{color:var(--ink);font-weight:600}
.ex-reveal em{color:var(--ink-muted);font-style:normal}
.ex-reveal .ex-table{
  width:100%;border-collapse:collapse;margin:6px 0;
  font-family:var(--sans);font-size:12px;
  font-variant-numeric:tabular-nums;
}
.ex-reveal .ex-table th{
  font-size:10px;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--ink-faint);text-align:left;padding:6px 9px;
  border-bottom:1px solid var(--hairline-strong);font-weight:700;
}
.ex-reveal .ex-table th.right,
.ex-reveal .ex-table td.right{text-align:right}
.ex-reveal .ex-table td{
  padding:6px 9px;border-bottom:1px solid var(--hairline);
}
.ex-reveal .ex-table tr:last-child td{border-bottom:none}
.ex-reveal .ex-table td.pos{color:var(--green);font-weight:600}
.ex-reveal .ex-table td.neg{color:var(--red);font-weight:600}
.ex-reveal .ex-table td.flag{color:var(--amber);font-weight:600}
.ex-reveal .data-pending{
  background:var(--amber-soft);border-left:3px solid var(--amber);
  padding:8px 12px;border-radius:0 5px 5px 0;
  font-size:12px;color:var(--ink-2);margin-top:8px;
}
.ex-reveal .data-pending b{color:var(--amber);font-weight:700}

/* Pattern A — bullet-level expand inside <ul class="rep-bullets"> */
.rep-bullets li > details.bul-expand{display:block;margin:-2px 0}
.rep-bullets li > details.bul-expand > summary{
  list-style:none;cursor:pointer;
  padding-right:30px;position:relative;
  display:block;
}
.rep-bullets li > details.bul-expand > summary::-webkit-details-marker{display:none}
.rep-bullets li > details.bul-expand > summary::after{
  content:"+";
  position:absolute;right:0;top:2px;
  width:18px;height:18px;line-height:16px;
  text-align:center;
  border:1px solid var(--hairline-strong);
  border-radius:4px;
  font-size:13px;font-weight:700;
  color:var(--ink-muted);
  transition:background 0.15s, color 0.15s, border-color 0.15s;
  font-family:var(--sans);
}
.rep-bullets li > details.bul-expand:hover > summary::after{
  border-color:var(--accent);color:var(--accent);
}
.rep-bullets li > details.bul-expand[open] > summary::after{
  content:"\2212";
  background:var(--accent);color:var(--bg);border-color:var(--accent);
}
.rep-bullets li > details.bul-expand > .ex-reveal{margin-top:8px}

/* Pattern B — wrap any block element in <details class="block-expand"> */
details.block-expand{display:block;margin:0}
details.block-expand > summary{
  list-style:none;cursor:pointer;display:block;
  padding-right:32px;position:relative;
}
details.block-expand > summary::-webkit-details-marker{display:none}
details.block-expand > summary::after{
  content:"+";
  position:absolute;right:0;top:0;
  width:18px;height:18px;line-height:16px;
  text-align:center;
  border:1px solid var(--hairline-strong);
  border-radius:4px;
  font-size:13px;font-weight:700;
  color:var(--ink-muted);
  transition:background 0.15s, color 0.15s, border-color 0.15s;
  font-family:var(--sans);
}
details.block-expand:hover > summary::after{border-color:var(--accent);color:var(--accent)}
details.block-expand[open] > summary::after{
  content:"\2212";
  background:var(--accent);color:var(--bg);border-color:var(--accent);
}

/* Competitor card with expand */
.competitor details.block-expand > summary{padding-right:38px}
.competitor details.block-expand > summary::after{top:-2px;right:-4px}
.competitor details.block-expand > .ex-reveal{margin-top:10px;margin-bottom:-6px}

/* Moat item with expand */
.moat-item details.block-expand{flex:1;min-width:0}
.moat-item details.block-expand > summary::after{top:50%;transform:translateY(-50%);right:-4px}
.moat-item details.block-expand > .ex-reveal{
  font-size:11.5px;padding:8px 11px;margin-top:8px;
}

/* Verdict bullet with expand — same as rep-bullets pattern but slimmer */
.rep-verdict ul li > details.bul-expand{display:block}
.rep-verdict ul li > details.bul-expand > summary{
  list-style:none;cursor:pointer;
  padding-right:28px;position:relative;display:block;
}
.rep-verdict ul li > details.bul-expand > summary::-webkit-details-marker{display:none}
.rep-verdict ul li > details.bul-expand > summary::after{
  content:"+";
  position:absolute;right:0;top:2px;
  width:18px;height:18px;line-height:16px;text-align:center;
  border:1px solid var(--hairline-strong);border-radius:4px;
  font-size:13px;font-weight:700;color:var(--ink-muted);
  transition:background 0.15s, color 0.15s, border-color 0.15s;
  font-family:var(--sans);
}
.rep-verdict ul li > details.bul-expand:hover > summary::after{border-color:var(--accent);color:var(--accent)}
.rep-verdict ul li > details.bul-expand[open] > summary::after{
  content:"\2212";background:var(--accent);color:var(--bg);border-color:var(--accent);
}

/* Numbered risk list with expand */
.dcard .numbered > li > details.bul-expand{display:block}
.dcard .numbered > li > details.bul-expand > summary{
  list-style:none;cursor:pointer;display:block;
  padding-right:32px;position:relative;
}
.dcard .numbered > li > details.bul-expand > summary::-webkit-details-marker{display:none}
.dcard .numbered > li > details.bul-expand > summary::after{
  content:"+";
  position:absolute;right:0;top:0;
  width:18px;height:18px;line-height:16px;text-align:center;
  border:1px solid var(--hairline-strong);border-radius:4px;
  font-size:13px;font-weight:700;color:var(--ink-muted);
  transition:background 0.15s, color 0.15s, border-color 0.15s;
  font-family:var(--sans);
}
.dcard .numbered > li > details.bul-expand:hover > summary::after{border-color:var(--accent);color:var(--accent)}
.dcard .numbered > li > details.bul-expand[open] > summary::after{
  content:"\2212";background:var(--accent);color:var(--bg);border-color:var(--accent);
}

/* Pattern C — table-row expand (JS-driven, <details> can't be a <tr>) */
.rep-table .ex-row .ex-tog{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;line-height:16px;
  margin-left:8px;
  border:1px solid var(--hairline-strong);
  border-radius:4px;
  background:transparent;color:var(--ink-muted);
  font:700 12px var(--sans);
  cursor:pointer;vertical-align:middle;
  transition:background 0.15s, color 0.15s, border-color 0.15s;
  padding:0;
}
.rep-table .ex-row .ex-tog:hover{border-color:var(--accent);color:var(--accent)}
.rep-table .ex-row.is-open .ex-tog{
  background:var(--accent);color:var(--bg);border-color:var(--accent);
}
.rep-table .ex-row.is-open + .ex-panel{display:table-row}
.rep-table .ex-panel{display:none;background:var(--bg-alt)}
.rep-table .ex-panel > td{
  padding:0 !important;border-bottom:1px solid var(--hairline) !important;
}
.rep-table .ex-panel .ex-reveal{
  border-left:none;border-radius:0;
  border-top:1px solid var(--hairline-accent);
  background:var(--bg-alt);
  margin:0;padding:12px 16px;
}
.rep-table .ex-row:hover + .ex-panel{background:var(--bg-alt)}
.rep-table .ex-row.is-open{background:var(--surface-2)}

/* ════════════════════════════════════════════════════════════════════
   INTERACTIVE DCF CALCULATOR
   ════════════════════════════════════════════════════════════════════ */

.dcf-calc{
  margin-top:18px;
  background:var(--surface);
  border:1px solid var(--hairline-accent);
  border-radius:12px;
  padding:22px 24px;
  font-family:var(--sans);
  position:relative;
}
.dcf-calc::before{
  content:"";position:absolute;left:0;top:0;
  width:3px;height:100%;background:var(--accent);
  border-radius:12px 0 0 12px;
}
.dcf-calc .dcf-h{
  font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:6px;
}
.dcf-calc .dcf-sub{
  font-size:12.5px;color:var(--ink-muted);margin:0 0 18px;line-height:1.55;
}
.dcf-calc .dcf-sub b{color:var(--ink-2);font-weight:600}

.dcf-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
  margin-bottom:18px;
}
.dcf-grid .dcf-field{
  background:var(--bg-alt);border:1px solid var(--hairline);
  border-radius:8px;padding:11px 14px;
  display:flex;flex-direction:column;gap:6px;
  transition:border-color 0.15s;
}
.dcf-grid .dcf-field:focus-within{border-color:var(--accent)}
.dcf-grid .dcf-field .dcf-l{
  font-size:10px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:700;
}
.dcf-grid .dcf-field .dcf-input-row{
  display:flex;align-items:baseline;gap:4px;
}
.dcf-grid .dcf-field input{
  flex:1;width:100%;min-width:0;
  background:transparent;border:none;outline:none;
  font:600 18px/1 var(--sans);
  color:var(--ink);font-variant-numeric:tabular-nums;
  letter-spacing:-0.01em;
  padding:0;
}
.dcf-grid .dcf-field input::-webkit-outer-spin-button,
.dcf-grid .dcf-field input::-webkit-inner-spin-button{margin:0}
.dcf-grid .dcf-field .dcf-u{
  font-size:14px;color:var(--ink-muted);font-weight:500;
}

.dcf-out{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;
  padding:16px;
  background:linear-gradient(180deg, var(--bg-alt) 0%, var(--bg) 100%);
  border:1px solid var(--hairline-accent);
  border-radius:10px;
  margin-bottom:12px;
}
.dcf-out .dcf-r{display:flex;flex-direction:column;gap:6px}
.dcf-out .dcf-r .dcf-l{
  font-size:10px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:700;
}
.dcf-out .dcf-r .dcf-v{
  font-family:var(--serif);
  font-size:30px;font-weight:400;color:var(--ink);
  letter-spacing:-0.02em;line-height:1;
  font-variant-numeric:tabular-nums;
}
.dcf-out .dcf-r .dcf-v.pos{color:var(--green)}
.dcf-out .dcf-r .dcf-v.neg{color:var(--red)}

.dcf-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end}
.dcf-reset{
  background:transparent;color:var(--ink-muted);
  border:1px solid var(--hairline-strong);
  padding:7px 14px;border-radius:6px;
  font:600 12px var(--sans);letter-spacing:0.02em;
  cursor:pointer;transition:background 0.15s, color 0.15s, border-color 0.15s;
}
.dcf-reset:hover{background:var(--surface-2);color:var(--ink);border-color:var(--accent)}

.dcf-calc .dcf-note{
  font-size:11.5px;color:var(--ink-faint);line-height:1.55;
  margin-top:12px;padding-top:12px;border-top:1px solid var(--hairline);
  font-style:italic;
}

/* Mobile */
@media(max-width:760px){
  .dcf-grid{grid-template-columns:repeat(2,1fr)}
  .dcf-out{grid-template-columns:1fr;gap:14px}
  .dcf-out .dcf-r .dcf-v{font-size:26px}
  .dcf-calc{padding:18px 18px}
}
@media(max-width:440px){
  .dcf-grid{grid-template-columns:1fr 1fr;gap:10px}
}

/* ════════════════════════════════════════════════════════════════════
   MOBILE OPTIMIZATION (tablet 760px / phone 600px / narrow 440px)
   ════════════════════════════════════════════════════════════════════ */

/* Tables scroll horizontally below 760px so 4&ndash;6 column tables stay legible */
@media(max-width:760px){
  .rep-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .rep-table{min-width:560px}
  .rep-table th,.rep-table td{padding:9px 12px;font-size:13px}
}

/* Tablet (760px) &mdash; nav, dossier header, headings */
@media(max-width:760px){
  .wrap,.wrap-narrow{padding:0 18px}
  .nav .inner{padding:11px 18px}
  .nav .links{gap:16px;font-size:13px}
  .nav .links a:not(.cta){display:none}
  .nav .cta{padding:8px 14px;font-size:12px}

  .dossier-header{padding:34px 0 28px 0}
  .dossier-title-row{flex-direction:column;align-items:flex-start;gap:18px}
  .dossier-title-row .right{text-align:left}
  .dossier-title-row .left h1{font-size:32px}
  .dossier-title-row .left .meta{font-size:12.5px}
  .dossier-title-row .right .price{font-size:28px}

  .rep-header-strip{padding:18px 18px;gap:18px;margin:20px 0 28px}
  .rep-header-strip .cell .v{font-size:18px}

  .rep-part{margin:44px 0 0}
  .rep-part-h{margin-bottom:22px;padding-bottom:11px;gap:12px}
  .rep-part-h h2{font-size:26px}
  .rep-sub{margin-bottom:28px}
  .rep-bullets li{padding:10px 14px 10px 28px;font-size:13.5px}
  .rep-bullets li::before{left:12px;top:17px}

  .rep-thesis{font-size:16px;padding:12px 16px;margin:8px 0 36px}

  .score-card{margin:24px 0;border-radius:14px}
  .score-main{padding:24px 20px}
  .score-main .value{font-size:64px}
  .score-pillars{padding:20px}
  .score-scale{flex-wrap:wrap;gap:8px;padding:14px 18px}

  .our-take{padding:24px;border-radius:12px}
  .our-take h3{font-size:21px}
  .our-take p{font-size:16px}

  .latest{padding:22px;border-radius:12px}
  .latest ul{font-size:14px}

  .rep-verdict{padding:18px 20px}
  .rep-verdict h3{font-size:18px}

  .dossier-cta{padding:28px 22px;margin:36px 0;border-radius:12px}

  .preview .head{flex-direction:column;padding:24px 22px;gap:14px}
  .preview .head .right{text-align:left}
  .preview .head .left h3{font-size:24px}
  .preview .head .right .price{font-size:26px}
  .preview .body{padding:22px;gap:18px}

  /* Universe toolbar wraps cleanly */
  .universe-toolbar{padding:12px 14px}
  .universe-toolbar .filter{padding:6px 10px;font-size:12px}
  .universe-toolbar .legend{font-size:11px;gap:12px}

  /* Pricing */
  .tier{padding:28px 22px}

  /* Hero */
  .hero{padding:56px 0 56px 0}
  .hero h1{font-size:36px;margin-bottom:20px}
  .hero .sub{font-size:17px;margin-bottom:28px}
  .hero .ctas{gap:10px}
  .hero a.primary,.hero a.secondary{padding:12px 20px;font-size:13px}
}

/* Phone (600px) */
@media(max-width:600px){
  .wrap,.wrap-narrow{padding:0 16px}
  .dossier-title-row .left h1{font-size:28px}
  .dossier-title-row .left .meta{line-height:1.5}
  .rep-header-strip{grid-template-columns:repeat(2,1fr);gap:14px;padding:16px}
  .rep-header-strip .cell .v{font-size:16px}
  .rep-header-strip .cell .s{font-size:11px}
  .rep-part-h h2{font-size:22px}
  .rep-part-h .num{font-size:10px}
  section h2{font-size:26px}
  .hero h1{font-size:30px}
  .hero .meta{grid-template-columns:1fr 1fr;gap:18px}
  .hero .meta .stat .v{font-size:20px}
  .score-main .value{font-size:52px}
  .score-main .band{font-size:12px;padding:4px 10px}
  .preview .body{grid-template-columns:1fr 1fr}
  .preview .body .stat .value{font-size:22px}

  /* Prevent grid blowout: ensure all flex/grid items can shrink */
  .report-main,.rep-bullets,.rep-table-wrap,.cards,.preview{min-width:0}
}

/* Very narrow (440px) */
@media(max-width:440px){
  .rep-header-strip{grid-template-columns:1fr 1fr}
  .universe-grid{gap:8px}
  .preview .body{grid-template-columns:1fr}
  .universe-toolbar .legend{display:none}
  .pillar{grid-template-columns:80px 1fr 44px;gap:4px 10px}
  .pillar .pl{font-size:12px}
  .pillar .ps{font-size:13px}
  .pillar .note{padding-left:0 !important;font-size:11px}
  .nav .links{gap:10px}
  .nav .logo{font-size:16px}
}
