/* =================================================================
   Elite Forex Trading — shared stylesheet
   Type: Schibsted Grotesk (display) / Hanken Grotesk (body) / JetBrains Mono (data)
   ================================================================= */

:root{
  /* dark identity */
  --ink:        #0B1411;
  --ink-2:      #10201A;
  --ink-3:      #16271F;
  --ink-line:   rgba(255,255,255,.10);
  --ink-line-2: rgba(255,255,255,.16);

  /* light content */
  --paper:      #FBFAF6;
  --paper-2:    #F3F1EA;
  --paper-3:    #E9E6DB;
  --text:       #18211D;
  --text-2:     #46524C;
  --muted:      #79827C;
  --line:       #E4E0D5;
  --line-2:     #D7D2C4;

  /* accents */
  --gold:       #C29A45;
  --gold-2:     #D9B765;
  --gold-soft:  #F0E6CB;
  --green:      #1E9C6A;
  --green-2:    #2BB57E;
  --green-soft: #D9F0E5;
  --red:        #CF5848;

  --radius:   14px;
  --radius-s: 9px;
  --maxw:     1220px;
  --gutter:   clamp(18px, 4vw, 44px);

  --font-display: "Schibsted Grotesk", system-ui, -apple-system, sans-serif;
  --font-body:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;

  --shadow-1: 0 1px 2px rgba(11,20,17,.04), 0 6px 22px rgba(11,20,17,.05);
  --shadow-2: 0 2px 6px rgba(11,20,17,.06), 0 18px 48px rgba(11,20,17,.10);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--text);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.08; letter-spacing:-.02em; margin:0; }
p{ margin:0; text-wrap:pretty; }
button{ font-family:inherit; cursor:pointer; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.eyebrow{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--gold); font-weight:500;
}
.sr-only{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); }

/* ============ TICKER ============ */
.ticker{
  background:var(--ink); color:#cfd8d3; border-bottom:1px solid var(--ink-line);
  font-family:var(--font-mono); font-size:.74rem; overflow:hidden; white-space:nowrap;
}
.ticker__track{
  display:inline-flex; gap:34px; align-items:center; padding:7px 0;
  animation:ticker 38s linear infinite;
}
.ticker:hover .ticker__track{ animation-play-state:paused; }
.ticker__item{ display:inline-flex; gap:8px; align-items:center; }
.ticker__sym{ color:#9aa6a0; letter-spacing:.04em; }
.ticker__val{ color:#e8ede9; }
.up{ color:var(--green-2); }
.down{ color:var(--red); }
@keyframes ticker{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .ticker__track{ animation:none; } }

/* ============ HEADER ============ */
.site-head{
  position:sticky; top:0; z-index:60;
  background:rgba(11,20,17,.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--ink-line); color:#eef2ef;
}
.site-head__row{ display:flex; align-items:center; gap:28px; height:70px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand__mark{
  width:34px; height:34px; flex:none; transform:rotate(45deg);
  background:linear-gradient(135deg,var(--gold-2),var(--gold)); border-radius:7px;
  display:grid; place-items:center;
}
.brand__mark span{ transform:rotate(-45deg); font-family:var(--font-display); font-weight:700; font-size:.9rem; color:var(--ink); }
.brand__name{ display:flex; flex-direction:column; line-height:1; }
.brand__name b{ font-family:var(--font-display); font-weight:600; font-size:1.22rem; letter-spacing:-.01em; color:#fff; }
.brand__name b::after{ content:""; display:inline-block; width:7px; height:7px; margin-left:9px; vertical-align:middle; border-radius:2px; background:var(--gold); transform:translateY(-1px); }

.nav{ display:flex; gap:6px; margin-left:auto; align-items:center; }
.nav a{
  font-size:.95rem; color:#c2ccc6; padding:9px 13px; border-radius:8px;
  transition:color .15s, background .15s;
}
.nav a:hover{ color:#fff; background:var(--ink-line); }
.nav a.is-active{ color:#fff; }
.nav a.is-active::after{ content:""; display:block; height:2px; background:var(--gold); border-radius:2px; margin-top:4px; }

.head-actions{ display:flex; align-items:center; gap:10px; margin-left:8px; }
.icon-btn{
  width:40px; height:40px; display:grid; place-items:center; border-radius:9px;
  background:var(--ink-line); border:1px solid var(--ink-line-2); color:#dfe6e2;
}
.icon-btn:hover{ background:var(--ink-line-2); }
.icon-btn svg{ width:18px; height:18px; }
.nav-toggle{ display:none; }

/* mobile nav panel */
.mnav{ display:none; background:var(--ink-2); border-bottom:1px solid var(--ink-line); }
.mnav.open{ display:block; }
.mnav a{ display:block; padding:14px var(--gutter); color:#d4ddd8; border-top:1px solid var(--ink-line); font-size:1rem; }
.mnav a:first-child{ border-top:none; }

/* ============ HERO ============ */
.hero{ background:var(--ink); color:#eef2ef; position:relative; overflow:hidden; }
.hero::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 80% at 85% -10%, rgba(194,154,69,.16), transparent 60%),
    radial-gradient(50% 70% at 0% 110%, rgba(30,156,106,.12), transparent 60%);
  pointer-events:none;
}
.hero__inner{ position:relative; padding:clamp(48px,7vw,92px) 0 clamp(40px,5vw,64px); }
.hero h1{
  font-size:clamp(2.5rem,6vw,4.5rem); color:#fff; max-width:14ch; margin-top:20px;
}
.hero h1 .accent{ color:var(--gold-2); }
.hero__sub{ color:#aeb8b2; font-size:clamp(1.05rem,1.6vw,1.25rem); max-width:52ch; margin-top:22px; }

.hero-search{ margin-top:34px; max-width:560px; display:flex; gap:10px; }
.hero-search input{
  flex:1; height:54px; border-radius:11px; border:1px solid var(--ink-line-2);
  background:var(--ink-2); color:#fff; padding:0 18px; font-family:var(--font-body); font-size:1rem;
}
.hero-search input::placeholder{ color:#7e8a84; }
.hero-search input:focus{ outline:none; border-color:var(--gold); }
.hero-search button{
  height:54px; padding:0 22px; border-radius:11px; border:none;
  background:var(--gold); color:var(--ink); font-weight:600; font-size:1rem; font-family:var(--font-display);
}
.hero-search button:hover{ background:var(--gold-2); }

.hero-stats{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.chip{
  font-family:var(--font-mono); font-size:.78rem; color:#cdd6d1;
  border:1px solid var(--ink-line-2); border-radius:999px; padding:7px 14px;
}
.chip b{ color:var(--gold-2); font-weight:500; }

/* ============ SECTION SHELL ============ */
.section{ padding:clamp(54px,7vw,88px) 0; }
.section--paper2{ background:var(--paper-2); }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:38px; }
.section-head h2{ font-size:clamp(1.8rem,3.4vw,2.5rem); }
.section-head p{ color:var(--text-2); margin-top:10px; max-width:46ch; }
.link-more{ font-family:var(--font-mono); font-size:.8rem; letter-spacing:.04em; color:var(--text); border-bottom:1px solid var(--line-2); padding-bottom:3px; white-space:nowrap; }
.link-more:hover{ color:var(--gold); border-color:var(--gold); }

/* ============ CATEGORY GRID ============ */
.cat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cat-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:24px 22px 22px; display:flex; flex-direction:column; min-height:210px;
  transition:border-color .18s, transform .18s, box-shadow .18s;
}
.cat-card:hover{ border-color:var(--gold); transform:translateY(-3px); box-shadow:var(--shadow-2); }
.cat-card__top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:auto; }
.cat-card__num{ font-family:var(--font-mono); font-size:.95rem; color:var(--gold); font-weight:500; }
.cat-card__count{ font-family:var(--font-mono); font-size:.72rem; color:var(--muted); letter-spacing:.04em; }
.cat-card h3{ font-size:1.22rem; margin-top:28px; }
.cat-card p{ color:var(--text-2); font-size:.95rem; margin-top:9px; }
.cat-card__go{ margin-top:18px; font-family:var(--font-mono); font-size:.78rem; color:var(--text); display:inline-flex; gap:7px; align-items:center; }
.cat-card:hover .cat-card__go{ color:var(--gold); }
.cat-card__go .arr{ transition:transform .18s; }
.cat-card:hover .cat-card__go .arr{ transform:translateX(4px); }

/* ============ ARTICLE CARDS ============ */
.art-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.art-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:transform .18s, box-shadow .18s; }
.art-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-2); }
.art-card__media{ aspect-ratio:16/10; }
.art-card__body{ padding:20px 20px 22px; display:flex; flex-direction:column; flex:1; }
.art-card__cat{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--green); }
.art-card h3{ font-size:1.18rem; margin-top:11px; line-height:1.2; }
.art-card:hover h3{ color:var(--gold); }
.art-card p{ color:var(--text-2); font-size:.93rem; margin-top:10px; }
.art-card__meta{ margin-top:auto; padding-top:16px; font-family:var(--font-mono); font-size:.72rem; color:var(--muted); display:flex; gap:12px; }

/* placeholder media */
.ph{
  background:
    repeating-linear-gradient(135deg, var(--paper-2) 0 11px, var(--paper-3) 11px 22px);
  position:relative; display:grid; place-items:center; color:var(--muted);
}
.ph::after{
  content:attr(data-label); font-family:var(--font-mono); font-size:.72rem; letter-spacing:.08em;
  color:#9aa097; background:rgba(251,250,246,.78); padding:5px 11px; border-radius:6px; border:1px solid var(--line);
}

/* ============ AD SLOT ============ */
.ad{
  border:1px dashed var(--line-2); border-radius:var(--radius-s); background:var(--paper-2);
  display:grid; place-items:center; text-align:center; padding:22px; min-height:108px;
}
.ad small{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); display:block; margin-bottom:6px; }
.ad span{ font-family:var(--font-mono); font-size:.82rem; color:var(--text-2); }
.ad--leader{ max-width:760px; margin-inline:auto; }

/* ============ NEWSLETTER (footer-cta) ============ */
.cta{ background:var(--ink-2); color:#eef2ef; border-radius:var(--radius); padding:clamp(28px,4vw,46px); display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; border:1px solid var(--ink-line); }
.cta h3{ color:#fff; font-size:clamp(1.4rem,2.4vw,1.9rem); max-width:18ch; }
.cta p{ color:#aeb8b2; margin-top:8px; max-width:40ch; font-size:.96rem; }
.cta__form{ display:flex; gap:10px; flex:1; min-width:280px; max-width:440px; }
.cta__form input{ flex:1; height:50px; border-radius:10px; border:1px solid var(--ink-line-2); background:var(--ink); color:#fff; padding:0 16px; font-family:var(--font-body); }
.cta__form input::placeholder{ color:#7e8a84; }
.cta__form input:focus{ outline:none; border-color:var(--gold); }
.cta__form button{ height:50px; padding:0 20px; border:none; border-radius:10px; background:var(--gold); color:var(--ink); font-weight:600; font-family:var(--font-display); }
.cta__form button:hover{ background:var(--gold-2); }

/* ============ FOOTER ============ */
.site-foot{ background:var(--ink); color:#aeb8b2; padding:clamp(48px,6vw,72px) 0 28px; }
.foot-grid{ display:grid; grid-template-columns:1.6fr repeat(3,1fr); gap:38px; padding-bottom:40px; border-bottom:1px solid var(--ink-line); }
.foot-brand .brand__name b{ color:#fff; }
.foot-about{ margin-top:18px; font-size:.92rem; max-width:34ch; color:#9aa6a0; }
.foot-col h4{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:#cdd6d1; font-weight:500; margin-bottom:16px; }
.foot-col a{ display:block; padding:6px 0; font-size:.92rem; color:#9aa6a0; }
.foot-col a:hover{ color:var(--gold-2); }
.foot-bottom{ padding-top:24px; display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-family:var(--font-mono); font-size:.72rem; color:#79847e; }
.risk{ margin-top:22px; font-size:.74rem; line-height:1.6; color:#79847e; max-width:none; }

/* ============ BREADCRUMB ============ */
.crumb{ font-family:var(--font-mono); font-size:.76rem; color:var(--muted); display:flex; gap:9px; align-items:center; flex-wrap:wrap; }
.crumb a:hover{ color:var(--gold); }
.crumb .sep{ color:var(--line-2); }

/* ============ CATEGORY PAGE ============ */
.cat-hero{ background:var(--ink); color:#eef2ef; }
.cat-hero__inner{ padding:clamp(40px,5vw,68px) 0; }
.cat-hero h1{ font-size:clamp(2.2rem,4.6vw,3.4rem); color:#fff; margin-top:16px; max-width:18ch; }
.cat-hero p{ color:#aeb8b2; margin-top:16px; max-width:56ch; font-size:1.08rem; }

.layout{ display:grid; grid-template-columns:1fr 312px; gap:48px; align-items:start; }
.toolbar{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:26px; flex-wrap:wrap; }
.toolbar .count{ font-family:var(--font-mono); font-size:.8rem; color:var(--muted); }
.chips{ display:flex; gap:8px; flex-wrap:wrap; }
.fchip{ font-family:var(--font-mono); font-size:.78rem; padding:8px 14px; border-radius:999px; border:1px solid var(--line-2); color:var(--text-2); background:#fff; }
.fchip:hover{ border-color:var(--gold); color:var(--text); }
.fchip.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* list rows */
.post-list{ display:flex; flex-direction:column; }
.post-row{ display:grid; grid-template-columns:200px 1fr; gap:22px; padding:26px 0; border-top:1px solid var(--line); }
.post-row:first-child{ border-top:none; }
.post-row__media{ aspect-ratio:16/11; border-radius:10px; overflow:hidden; }
.post-row__cat{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--green); }
.post-row h3{ font-size:1.42rem; margin-top:9px; }
.post-row:hover h3{ color:var(--gold); }
.post-row p{ color:var(--text-2); margin-top:10px; font-size:.98rem; max-width:60ch; }
.post-row__meta{ margin-top:14px; font-family:var(--font-mono); font-size:.74rem; color:var(--muted); display:flex; gap:14px; }

/* sidebar */
.side{ display:flex; flex-direction:column; gap:26px; position:sticky; top:90px; }
.side-card{ border:1px solid var(--line); border-radius:var(--radius); padding:22px; background:#fff; }
.side-card h4{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:500; margin-bottom:16px; }
.pop-item{ display:flex; gap:14px; padding:12px 0; border-top:1px solid var(--line); align-items:flex-start; }
.pop-item:first-of-type{ border-top:none; }
.pop-item__n{ font-family:var(--font-mono); color:var(--gold); font-size:.85rem; }
.pop-item a{ font-family:var(--font-display); font-weight:500; font-size:.98rem; line-height:1.25; }
.pop-item a:hover{ color:var(--gold); }
.tag-cloud{ display:flex; flex-wrap:wrap; gap:8px; }
.tag-cloud a{ font-family:var(--font-mono); font-size:.76rem; padding:6px 11px; border-radius:7px; background:var(--paper-2); color:var(--text-2); }
.tag-cloud a:hover{ background:var(--gold-soft); color:var(--text); }

/* pagination */
.pager{ display:flex; gap:8px; margin-top:36px; align-items:center; }
.pager a, .pager span{ min-width:42px; height:42px; display:grid; place-items:center; border:1px solid var(--line-2); border-radius:9px; font-family:var(--font-mono); font-size:.85rem; color:var(--text-2); padding:0 12px; }
.pager a:hover{ border-color:var(--gold); color:var(--text); }
.pager .is-current{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* ============ ARTICLE PAGE ============ */
.article-head{ padding:clamp(34px,4vw,52px) 0 0; }
.article-head h1{ font-size:clamp(2.1rem,4.4vw,3.2rem); margin-top:18px; max-width:20ch; }
.article-head .dek{ font-size:clamp(1.1rem,1.7vw,1.32rem); color:var(--text-2); margin-top:18px; max-width:60ch; }
.article-meta{ display:flex; align-items:center; gap:16px; margin-top:24px; font-family:var(--font-mono); font-size:.78rem; color:var(--muted); flex-wrap:wrap; }
.article-meta .author{ display:flex; align-items:center; gap:10px; color:var(--text); }
.avatar{ width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,var(--gold-2),var(--green)); }
.lead-media{ aspect-ratio:16/8; border-radius:var(--radius); overflow:hidden; margin:34px 0; }

.article-layout{ display:grid; grid-template-columns:1fr minmax(0,720px) 1fr; gap:40px; }
.article-layout > .toc{ grid-column:1; }
.article-body{ grid-column:2; }
.article-layout > .side-rail{ grid-column:3; }

.toc{ position:sticky; top:90px; align-self:start; }
.toc h4{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
.toc a{ display:block; padding:6px 0 6px 14px; border-left:2px solid var(--line); color:var(--text-2); font-size:.88rem; line-height:1.35; }
.toc a:hover, .toc a.is-active{ border-color:var(--gold); color:var(--text); }

.side-rail{ position:sticky; top:90px; align-self:start; display:flex; flex-direction:column; gap:24px; }

.prose{ font-size:1.12rem; line-height:1.75; color:#26302b; }
.prose > * + *{ margin-top:1.35em; }
.prose h2{ font-size:1.85rem; margin-top:1.9em; padding-top:.2em; }
.prose h3{ font-size:1.35rem; margin-top:1.6em; }
.prose p{ color:#2c352f; }
.prose a{ color:var(--green); border-bottom:1px solid var(--green-soft); }
.prose a:hover{ border-color:var(--green); }
.prose ul, .prose ol{ padding-left:1.3em; }
.prose li{ margin-top:.5em; }
.prose li::marker{ color:var(--gold); }
.prose strong{ color:var(--text); }
.prose blockquote{ border-left:3px solid var(--gold); padding:4px 0 4px 22px; font-family:var(--font-display); font-size:1.3rem; line-height:1.4; color:var(--text); font-style:normal; }
.prose figure{ margin:0; }
.prose figcaption{ font-family:var(--font-mono); font-size:.76rem; color:var(--muted); margin-top:10px; text-align:center; }
.prose img, .prose .ph{ border-radius:10px; }

.callout{ background:var(--green-soft); border:1px solid #BBE3CE; border-radius:var(--radius); padding:22px 24px; }
.callout .k{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--green); display:block; margin-bottom:8px; }
.callout p{ color:#1d3a2c; font-size:1rem; }

table.data{ width:100%; border-collapse:collapse; font-size:.96rem; }
table.data th, table.data td{ text-align:left; padding:12px 14px; border-bottom:1px solid var(--line); }
table.data thead th{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); background:var(--paper-2); }
table.data td:first-child{ font-weight:600; }

.author-box{ display:flex; gap:18px; align-items:flex-start; border:1px solid var(--line); border-radius:var(--radius); padding:24px; margin-top:44px; background:#fff; }
.author-box .avatar{ width:56px; height:56px; flex:none; }
.author-box h4{ font-family:var(--font-display); font-size:1.1rem; }
.author-box .role{ font-family:var(--font-mono); font-size:.74rem; color:var(--green); margin-top:3px; }
.author-box p{ color:var(--text-2); margin-top:10px; font-size:.94rem; }

/* responsive */
@media (max-width:1080px){
  .cat-grid{ grid-template-columns:repeat(2,1fr); }
  .art-grid{ grid-template-columns:repeat(2,1fr); }
  .layout{ grid-template-columns:1fr; }
  .side{ position:static; flex-direction:row; flex-wrap:wrap; }
  .side-card{ flex:1; min-width:240px; }
  .article-layout{ grid-template-columns:1fr; }
  .article-layout > .toc, .article-body, .article-layout > .side-rail{ grid-column:1; }
  .toc, .side-rail{ position:static; }
  .toc{ display:none; }
}
@media (max-width:760px){
  .nav, .head-actions .icon-btn--search{ display:none; }
  .nav-toggle{ display:grid; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .art-grid{ grid-template-columns:1fr; }
  .post-row{ grid-template-columns:1fr; }
  .post-row__media{ max-width:none; }
  .section-head{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:440px){
  .cat-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; }
  .hero-search{ flex-direction:column; }
  .hero-search button{ width:100%; }
}

/* --- generated content: image fills for lead + card media --- */
.lead-media img, .art-card__media img{ width:100%; height:100%; object-fit:cover; display:block; }
.lead-media{ background:var(--paper-2); }

/* ============================================================
   Reusable article UX components (introduced batch 24+)
   ============================================================ */

/* Style/spec "at a glance" grid */
.prose .spec-cap{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin:1.7em 2px .5em; }
.prose .spec-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(148px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin:.2em 0 0; }
.prose .spec-grid .spec{ background:var(--paper); padding:15px 17px; }
.prose .spec-grid .spec .lbl{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.13em; text-transform:uppercase; color:var(--muted); display:block; margin-bottom:6px; }
.prose .spec-grid .spec .val{ font-family:var(--font-display); font-size:1.01rem; font-weight:600; color:var(--text); line-height:1.3; }
.prose .spec-grid .spec .val.hi{ color:var(--green); }
.prose .spec-grid .spec .val.warn{ color:var(--red); }
.prose .spec-grid .spec .val.mid{ color:var(--gold); }

/* Warning / caution callout variant */
.prose .callout.callout--warn{ background:#FBE9E5; border-color:#E6B9AE; }
.prose .callout.callout--warn .k{ color:var(--red); }
.prose .callout.callout--warn p{ color:#5e2820; }

/* Comparison table */
.prose .table-wrap{ overflow-x:auto; margin:1.6em 0; border:1px solid var(--line); border-radius:var(--radius); }
.prose table.compare{ width:100%; border-collapse:collapse; font-size:.96rem; min-width:520px; }
.prose table.compare th, .prose table.compare td{ text-align:left; padding:11px 15px; border-bottom:1px solid var(--line); vertical-align:top; }
.prose table.compare thead th{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); background:#F3F1E9; }
.prose table.compare tbody tr:last-child td{ border-bottom:none; }
.prose table.compare td:first-child, .prose table.compare th:first-child{ font-weight:600; color:var(--text); }
.prose table.compare td .mono{ font-family:var(--font-mono); font-size:.86rem; color:var(--muted); }
