/* components.css — Editorial Magazine UI
   Flat editorial blocks. No gradient cards. Hairline rules. Serif body. */

/* ====================================================
   COVER — magazine-cover hero for home + flagship hubs
   ==================================================== */
.cover {
  padding: var(--s9) 0 var(--s8);
  border-bottom: 1px solid var(--ink);
  position: relative;
}
.cover__masthead-rule {
  height: 4px; background: var(--ink);
  margin: 0 0 var(--s7);
}
.cover__category {
  display: inline-block;
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: var(--fw-k);
  padding: 4px 12px;
  background: var(--ink);
  color: var(--paper);
  margin-bottom: var(--s5);
}
.cover__category--rust { background: var(--rust); }
.cover__category--teal { background: var(--teal-deep); }
.cover__category--olive { background: var(--olive); }
.cover__category--plum { background: var(--plum); }
.cover__category--oxblood { background: var(--oxblood); }
.cover__category--mustard { background: var(--mustard); color: var(--ink); }
.cover__title {
  font-family: var(--font-display);
  font-weight: var(--fw-x);
  font-size: var(--fs-6xl);
  line-height: 0.92;
  letter-spacing: -0.04em;
  margin: 0 0 var(--s5);
  color: var(--ink);
  max-width: 16ch;
}
.cover__title--wide { max-width: 20ch; }
.cover__title--narrow { max-width: 12ch; }
.cover__sub {
  font-family: var(--font-body);
  font-size: var(--fs-lg);
  font-style: italic;
  line-height: 1.45;
  color: var(--ink-soft);
  margin: 0 0 var(--s6);
  max-width: 50ch;
}
.cover__byline {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: var(--s5);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
  padding-top: var(--s4);
  border-top: 1px solid var(--ink-line);
}
.cover__byline a { color: var(--ink); text-decoration: none; font-weight: var(--fw-b); }
.cover__byline strong { color: var(--ink); font-weight: var(--fw-b); }

/* Asymmetric cover with side note */
.cover--asym .container {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: var(--s8);
  align-items: end;
}
.cover--asym .cover__side {
  padding-bottom: var(--s2);
  border-left: 1px solid var(--ink-line);
  padding-left: var(--s5);
  font-family: var(--font-caption);
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  line-height: 1.5;
}
.cover--asym .cover__side strong { color: var(--ink); display: block; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: var(--s2); }
@media (max-width: 900px) { .cover--asym .container { grid-template-columns: 1fr; } .cover--asym .cover__side { border-left: 0; border-top: 1px solid var(--ink-line); padding-left: 0; padding-top: var(--s4); margin-top: var(--s5); } }

@media (max-width: 640px) {
  .cover { padding: var(--s7) 0 var(--s6); }
  .cover__title { font-size: var(--fs-4xl); }
  .cover__sub { font-size: var(--fs-base); }
}

/* ====================================================
   ARTICLE PROPER — single-column long-form reading
   ==================================================== */
.article {
  padding: var(--s7) 0 var(--s9);
  max-width: var(--w-reading);
  margin: 0 auto;
  font-family: var(--font-body);
}
.article__lead {
  font-size: var(--fs-lg);
  line-height: 1.45;
  color: var(--ink);
  font-weight: var(--fw-m);
  margin-bottom: var(--s7);
  font-style: italic;
  padding-bottom: var(--s5);
  border-bottom: 1px solid var(--ink-line);
}
.article h2 {
  font-size: var(--fs-2xl);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-top: var(--s8);
  margin-bottom: var(--s4);
  position: relative;
  padding-bottom: var(--s2);
  border-bottom: 1px solid var(--ink-line);
}
.article h2::before {
  content: "§";
  display: inline-block;
  color: var(--rust);
  margin-right: var(--s2);
  font-weight: var(--fw-r);
}
.article h3 {
  font-size: var(--fs-lg);
  letter-spacing: -0.01em;
  margin-top: var(--s7);
}
.article p {
  max-width: 65ch;
  margin: 0 0 var(--s5);
}
.article p + p { text-indent: 1.5em; }  /* magazine indent for subsequent paragraphs */
.article p.no-indent + p { text-indent: 0; }

/* Sidebar annotation — editorial side note */
.article__side {
  float: right;
  width: 240px;
  margin: 0 calc(-1 * var(--s7)) var(--s5) var(--s7);
  padding: var(--s4) var(--s5);
  background: var(--paper-tone);
  border-left: 3px solid var(--rust);
  font-family: var(--font-caption);
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--ink-soft);
}
.article__side h4 {
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink);
  margin: 0 0 var(--s2);
}
@media (max-width: 900px) {
  .article__side { float: none; width: auto; margin: var(--s5) 0; }
}

/* ====================================================
   STAT BAND — editorial fact bar (replaces metric cards)
   ==================================================== */
.stat-band {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0;
  margin: var(--s7) 0;
  padding: var(--s5) 0;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.stat-band__cell {
  padding: 0 var(--s4);
  border-right: 1px solid var(--ink-line);
}
.stat-band__cell:last-child { border-right: 0; }
.stat-band__value {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-x);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.stat-band__label {
  display: block;
  margin-top: var(--s2);
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
  font-weight: var(--fw-s);
}
.stat-band__hint {
  display: block;
  margin-top: 4px;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--ink-faint);
  font-style: italic;
}
@media (max-width: 640px) {
  .stat-band { padding: var(--s4) 0; }
  .stat-band__cell { padding: var(--s2) var(--s3); border-right: 0; border-bottom: 1px solid var(--ink-line); }
  .stat-band__cell:last-child { border-bottom: 0; }
  .stat-band__value { font-size: var(--fs-2xl); }
}

/* ====================================================
   BIG NUMBER — Bloomberg Businessweek-style giant stat
   ==================================================== */
.big-number {
  margin: var(--s8) 0;
  padding: var(--s8) 0;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  text-align: center;
}
.big-number__value {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-7xl);
  font-weight: var(--fw-x);
  line-height: 0.85;
  letter-spacing: -0.05em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.big-number__label {
  display: block;
  margin-top: var(--s4);
  font-family: var(--font-caption);
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ink-soft);
  font-weight: var(--fw-s);
}
.big-number__caption {
  display: block;
  margin: var(--s3) auto 0;
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--fs-base);
  color: var(--ink-soft);
  max-width: 38ch;
  line-height: 1.45;
}

/* ====================================================
   BYLINE & AUTHOR
   ==================================================== */
.byline-bar {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: var(--s4);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
  padding: var(--s4) 0;
  border-top: 1px solid var(--ink-line);
  border-bottom: 1px solid var(--ink-line);
  margin: 0 0 var(--s5);
}
.byline-bar img {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--ink-line);
}
.byline-bar strong { color: var(--ink); font-weight: var(--fw-b); }
.byline-bar a { color: var(--ink); text-decoration: none; font-weight: var(--fw-b); }
@media (hover: hover) and (pointer: fine) {
  .byline-bar a:hover { color: var(--rust); }
}

/* Author profile feature */
.author-feature {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s8);
  align-items: start;
  margin: var(--s7) 0;
  padding-bottom: var(--s7);
  border-bottom: 4px solid var(--ink);
}
.author-feature__portrait {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: grayscale(40%);
}
.author-feature__body h1 {
  font-size: var(--fs-5xl);
  letter-spacing: -0.035em;
  margin: 0 0 var(--s3);
}
.author-feature__role {
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--rust);
  font-weight: var(--fw-k);
  margin-bottom: var(--s4);
}
.author-feature__bio {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-style: italic;
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 50ch;
}
.author-feature__meta {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--s4);
  margin-top: var(--s6);
  padding-top: var(--s5);
  border-top: 1px solid var(--ink-line);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.author-feature__meta dt { color: var(--ink-muted); margin-bottom: 4px; }
.author-feature__meta dd { color: var(--ink); margin: 0; font-weight: var(--fw-s); }
.author-feature__meta dd a { color: var(--rust); text-decoration: none; }
@media (max-width: 720px) {
  .author-feature { grid-template-columns: 1fr; }
  .author-feature__portrait { max-width: 200px; }
}

/* ====================================================
   PULL QUOTE — large editorial quote
   ==================================================== */
.pull-quote {
  margin: var(--s8) 0;
  padding: var(--s6) 0;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-b);
  line-height: 1.12;
  letter-spacing: -0.025em;
  color: var(--ink);
  max-width: 22ch;
}
.pull-quote::before { content: "\201C"; color: var(--rust); display: block; line-height: 0.8; }
.pull-quote cite {
  display: block; margin-top: var(--s4);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-muted);
  font-weight: var(--fw-s);
  font-style: normal;
}

/* ====================================================
   CASINO RANK LEADERBOARD — editorial style
   ==================================================== */
.rank-table {
  margin: var(--s7) 0;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.rank-row {
  display: grid;
  grid-template-columns: 56px 88px 1fr auto auto;
  gap: var(--s5);
  align-items: center;
  padding: var(--s5) 0;
  border-bottom: 1px solid var(--ink-line);
}
.rank-row:last-child { border-bottom: 0; }
.rank-row__num {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-x);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--ink-muted);
  font-variant-numeric: tabular-nums;
  text-align: center;
}
.rank-row[data-rank="1"] .rank-row__num { color: var(--rust); font-size: var(--fs-4xl); }
.rank-row[data-rank="2"] .rank-row__num { color: var(--rust-deep); font-size: var(--fs-3xl); }
.rank-row[data-rank="3"] .rank-row__num { color: var(--oxblood); font-size: var(--fs-3xl); }
.rank-row__logo {
  width: 80px; height: 80px;
  object-fit: contain;
  padding: 4px;
  background: var(--paper);
  border: 1px solid var(--ink-line);
}
.rank-row__name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-k);
  margin: 0 0 var(--s1);
  color: var(--ink);
  letter-spacing: -0.018em;
}
.rank-row__hook {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.45;
  color: var(--ink-soft);
  margin: 0;
  max-width: 56ch;
}
.rank-row__chips {
  display: flex; flex-wrap: wrap; gap: var(--s2);
  margin-top: var(--s2);
  font-family: var(--font-caption);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-muted);
}
.rank-row__chips span::after { content: "·"; margin-left: var(--s2); color: var(--ink-line); }
.rank-row__chips span:last-child::after { display: none; }
.rank-row__score {
  display: flex; flex-direction: column;
  align-items: center;
  min-width: 80px;
}
.rank-row__score-val {
  font-family: var(--font-mono);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-b);
  color: var(--ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}
.rank-row__score-label {
  font-family: var(--font-caption);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-muted);
  margin-top: var(--s2);
  font-weight: var(--fw-s);
}
.rank-row__cta {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: var(--fw-b);
  padding: 10px 18px;
  min-height: var(--touch-target-min);
  background: var(--ink);
  color: var(--paper) !important;
  text-decoration: none !important;
  border: 0;
  white-space: nowrap;
  transition: background var(--t-fast);
}
@media (hover: hover) and (pointer: fine) {
  .rank-row__cta:hover { background: var(--rust); }
}

@media (max-width: 860px) {
  .rank-row {
    grid-template-columns: 44px 64px 1fr;
    grid-template-rows: auto auto;
    gap: var(--s3);
    padding: var(--s4) 0;
  }
  .rank-row__score { grid-column: 1 / 4; flex-direction: row; gap: var(--s4); justify-content: flex-start; padding-top: var(--s2); }
  .rank-row__cta { grid-column: 1 / 4; width: 100%; }
  .rank-row__num { font-size: var(--fs-2xl); }
  .rank-row__logo { width: 60px; height: 60px; }
  .rank-row__name { font-size: var(--fs-lg); }
}

/* ====================================================
   BRAND DOSSIER — casino review hero (editorial profile card)
   ==================================================== */
.dossier {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--s7);
  align-items: start;
  margin: var(--s7) 0 var(--s8);
  padding: var(--s7) 0;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.dossier__logo {
  width: 180px; height: 180px;
  object-fit: contain;
  padding: 12px;
  background: var(--paper);
  border: 1px solid var(--ink-line);
}
.dossier__body { min-width: 0; }
.dossier__eyebrow {
  display: inline-block;
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: var(--fw-k);
  padding: 4px 12px;
  background: var(--rust);
  color: var(--paper);
  margin-bottom: var(--s4);
}
.dossier__title {
  font-family: var(--font-display);
  font-size: var(--fs-5xl);
  font-weight: var(--fw-x);
  line-height: 0.96;
  letter-spacing: -0.035em;
  margin: 0 0 var(--s4);
  color: var(--ink);
}
.dossier__sub {
  font-family: var(--font-body);
  font-size: var(--fs-lg);
  font-style: italic;
  line-height: 1.4;
  color: var(--ink-soft);
  margin: 0 0 var(--s5);
  max-width: 56ch;
}
.dossier__facts {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--s4);
  padding-top: var(--s5);
  border-top: 1px solid var(--ink-line);
  font-family: var(--font-caption);
}
.dossier__facts dt {
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
  margin-bottom: 4px;
  font-weight: var(--fw-s);
}
.dossier__facts dd {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  color: var(--ink);
  font-weight: var(--fw-b);
  font-variant-numeric: tabular-nums;
}
.dossier__score {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-display);
  font-weight: var(--fw-x);
  font-size: var(--fs-4xl);
  color: var(--ink);
  line-height: 1;
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
  padding: var(--s2) 0;
}
.dossier__score::after {
  content: "/ 10";
  font-family: var(--font-caption);
  font-weight: var(--fw-s);
  font-size: var(--fs-sm);
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-left: var(--s2);
}
@media (max-width: 720px) {
  .dossier { grid-template-columns: 1fr; }
  .dossier__logo { width: 120px; height: 120px; }
  .dossier__title { font-size: var(--fs-3xl); }
}

/* ====================================================
   VERDICT BLOCK — editorial conclusion
   ==================================================== */
.verdict,
.verdict-block {
  margin: var(--s8) 0;
  padding: var(--s7);
  background-color: #16182d;
  color: #faf6ef;
  border-left: 8px solid var(--rust);
}
.verdict-block .verdict__eyebrow,
.verdict-block-eyebrow { color: var(--rust-bright); }
.verdict-block h2, .verdict-block h3 { color: #faf6ef; }
.verdict-block p { color: rgba(250, 246, 239, 0.85); }
.verdict__eyebrow {
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: var(--fw-k);
  color: var(--rust-bright);
  margin-bottom: var(--s3);
}
.verdict h3 {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-x);
  color: var(--paper);
  margin: 0 0 var(--s4);
  letter-spacing: -0.022em;
  line-height: 1.1;
}
.verdict p { color: var(--ink-inverse-2); max-width: 60ch; font-family: var(--font-body); margin: 0 0 var(--s3); }
.verdict p:last-child { margin-bottom: 0; }

/* ====================================================
   LEDGER (pros / cons two-column)
   ==================================================== */
.ledger {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin: var(--s7) 0;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.ledger__col {
  padding: var(--s5) var(--s5) var(--s5) 0;
}
.ledger__col + .ledger__col { border-left: 1px solid var(--ink-line); padding-left: var(--s5); padding-right: 0; }
.ledger__head {
  display: flex; align-items: center; gap: var(--s3);
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: var(--fw-k);
  margin-bottom: var(--s4);
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--ink-line);
}
.ledger__col--pos .ledger__head { color: var(--status-strong); }
.ledger__col--neg .ledger__head { color: var(--status-weak); }
.ledger__head::before {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  font-weight: var(--fw-x);
}
.ledger__col--pos .ledger__head::before { content: "+"; color: var(--status-strong); }
.ledger__col--neg .ledger__head::before { content: "−"; color: var(--status-weak); }
.ledger__list { list-style: none; padding: 0; margin: 0; }
.ledger__list li {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.5;
  padding: var(--s3) 0;
  border-bottom: 1px solid var(--ink-line);
  color: var(--ink);
}
.ledger__list li:last-child { border-bottom: 0; }
@media (max-width: 720px) {
  .ledger { grid-template-columns: 1fr; }
  .ledger__col + .ledger__col { border-left: 0; border-top: 1px solid var(--ink-line); padding-left: 0; padding-top: var(--s5); }
}

/* ====================================================
   FAQ — editorial accordion
   ==================================================== */
.qa {
  margin: var(--s8) 0;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.qa__head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: var(--s5) 0;
  border-bottom: 1px solid var(--ink);
}
.qa__head h2 {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-x);
  margin: 0;
  letter-spacing: -0.025em;
}
.qa__head h2::before { content: ""; }
.qa__count {
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--ink-muted);
  font-weight: var(--fw-s);
}
.qa__item {
  border-bottom: 1px solid var(--ink-line);
  counter-increment: qa-num;
}
.qa__item:last-child { border-bottom: 0; }
.qa__item > summary {
  cursor: pointer;
  padding-block: var(--s4);
  padding-inline: 0;
  min-height: var(--touch-target-min);
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: var(--s4);
  align-items: baseline;
  list-style: none;
  transition: color var(--t-fast);
}
.qa__item > summary::-webkit-details-marker { display: none; }
.qa__item > summary::before {
  content: counter(qa-num, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  font-weight: var(--fw-b);
  color: var(--rust);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}
.qa__q,
.qa__item > summary {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: var(--fw-b);
  color: var(--ink);
  letter-spacing: -0.014em;
  line-height: 1.3;
}
.qa__item > summary::after {
  content: "+";
  font-family: var(--font-mono);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-r);
  color: var(--rust);
  line-height: 1;
  transition: transform var(--t-fast);
}
.qa__item[open] > summary::after { content: "−"; }
@media (hover: hover) and (pointer: fine) {
  .qa__item > summary:hover .qa__q,
  .qa__item > summary:hover { color: var(--rust); }
}
.qa__a {
  padding: 0 var(--s7) var(--s5) calc(48px + var(--s4));
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--ink-soft);
}
.qa__a p { margin: 0 0 var(--s3); max-width: 60ch; }
.qa__a p:last-child { margin-bottom: 0; }
.qa { counter-reset: qa-num; }
@media (max-width: 640px) {
  .qa__item > summary { grid-template-columns: 36px 1fr auto; gap: var(--s2); }
  .qa__a { padding-left: calc(36px + var(--s2)); padding-right: 0; }
  .qa__q { font-size: var(--fs-base); }
}

/* ====================================================
   SECTION RULE — magazine-style section divider
   ==================================================== */
.rule {
  margin: var(--s9) 0;
  height: 0;
  border: 0;
  border-top: 1px solid var(--ink);
  position: relative;
}
.rule__label {
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  background: var(--paper);
  padding: 0 var(--s4);
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--ink-muted);
  font-weight: var(--fw-s);
}

/* Three-star section break (publishing convention) */
.fleuron {
  text-align: center;
  margin: var(--s8) 0;
  font-family: var(--font-display);
  font-size: var(--fs-md);
  letter-spacing: 1em;
  color: var(--rust);
  font-weight: var(--fw-r);
}
.fleuron::before { content: "* * *"; }

/* ====================================================
   GUIDE-CARD GRID — editorial card-grid for hubs
   ==================================================== */
.guide-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
  margin: var(--s6) 0;
  border-top: 4px solid var(--ink);
}
.guide-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.guide-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.guide-grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.guide-card {
  display: flex; flex-direction: column;
  padding: var(--s6) var(--s5);
  border-bottom: 1px solid var(--ink);
  border-right: 1px solid var(--ink-line);
  text-decoration: none;
  color: var(--ink);
  background: var(--paper);
  transition: background var(--t-fast);
}
.guide-card:last-child { border-right: 0; }
@media (hover: hover) and (pointer: fine) {
  .guide-card:hover { background: var(--paper-dark); text-decoration: none; }
}
.guide-card__category {
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: var(--fw-k);
  color: var(--rust);
  margin-bottom: var(--s3);
}
.guide-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: var(--fw-b);
  letter-spacing: -0.018em;
  line-height: 1.18;
  margin: 0 0 var(--s3);
  color: var(--ink);
}
.guide-card__excerpt {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
  flex-grow: 1;
}
.guide-card__cta {
  margin-top: var(--s4);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: var(--fw-s);
  color: var(--rust);
}
@media (max-width: 900px) {
  .guide-grid--3, .guide-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .guide-card:nth-child(2n) { border-right: 0; }
}
@media (max-width: 600px) {
  .guide-grid, .guide-grid--2, .guide-grid--3, .guide-grid--4 { grid-template-columns: 1fr; }
  .guide-card { border-right: 0; }
}

/* ====================================================
   CASINO CONTACT — brand-card alternative (editorial)
   ==================================================== */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
  margin: var(--s6) 0;
  border-top: 4px solid var(--ink);
}
.contact {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  align-items: center;
  gap: var(--s4);
  padding: var(--s5);
  border-bottom: 1px solid var(--ink);
  border-right: 1px solid var(--ink-line);
  text-decoration: none;
  color: var(--ink);
  background: var(--paper);
  transition: background var(--t-fast);
}
@media (hover: hover) and (pointer: fine) {
  .contact:hover { background: var(--paper-dark); text-decoration: none; }
}
.contact__logo {
  width: 56px; height: 56px;
  object-fit: contain;
  padding: 4px;
  background: var(--paper);
  border: 1px solid var(--ink-line);
}
.contact__name {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: var(--fw-b);
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.012em;
}
.contact__hook {
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  color: var(--ink-muted);
  margin: 2px 0 0;
  line-height: 1.4;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.contact__score {
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  font-weight: var(--fw-b);
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
@media (max-width: 600px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact { border-right: 0; }
}

/* ====================================================
   DOSSIER COMPARE — versus block (editorial style)
   ==================================================== */
.compare {
  display: grid;
  grid-template-columns: 1fr 64px 1fr;
  align-items: stretch;
  gap: 0;
  margin: var(--s8) 0;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.compare__side {
  padding: var(--s6) var(--s5);
  text-align: center;
}
.compare__side + .compare__divider + .compare__side { border-left: 1px solid var(--ink-line); }
.compare__divider {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-x);
  color: var(--rust);
  letter-spacing: 0.08em;
  border-left: 1px solid var(--ink-line);
  border-right: 1px solid var(--ink-line);
}
.compare__logo {
  width: 80px; height: 80px;
  margin: 0 auto var(--s3);
  object-fit: contain;
  padding: 4px;
  background: var(--paper);
  border: 1px solid var(--ink-line);
}
.compare__name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-k);
  margin: 0 0 var(--s2);
  letter-spacing: -0.018em;
}
.compare__score {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-b);
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.03em;
  line-height: 1;
  margin: var(--s2) 0;
}
.compare__hook {
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--fs-base);
  color: var(--ink-soft);
  line-height: 1.4;
  margin: var(--s2) auto var(--s4);
  max-width: 32ch;
}
.compare__cta {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: var(--fw-b);
  padding: 12px 20px;
  min-height: var(--touch-target-min);
  background: var(--ink);
  color: var(--paper);
  text-decoration: none;
  transition: background var(--t-fast);
}
@media (hover: hover) and (pointer: fine) {
  .compare__cta:hover { background: var(--rust); color: var(--paper); text-decoration: none; }
}
@media (max-width: 640px) {
  .compare { grid-template-columns: 1fr; border-bottom: 0; }
  .compare__side + .compare__divider + .compare__side { border-left: 0; border-top: 1px solid var(--ink-line); }
  .compare__divider { display: none; }
}

/* ====================================================
   ROADMAP / TIER LADDER — for KYC pages
   ==================================================== */
.tier-row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: var(--s5);
  align-items: center;
  padding: var(--s5) 0;
  border-bottom: 1px solid var(--ink-line);
}
.tier-row:first-child { border-top: 4px solid var(--ink); padding-top: var(--s5); }
.tier-row__num {
  font-family: var(--font-display);
  font-size: var(--fs-4xl);
  font-weight: var(--fw-x);
  color: var(--rust);
  line-height: 0.9;
  text-align: center;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.04em;
}
.tier-row__title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-b);
  margin: 0 0 var(--s1);
}
.tier-row__desc {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink-soft);
  margin: 0;
  line-height: 1.5;
  max-width: 60ch;
}
.tier-row__check {
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: var(--fw-s);
  color: var(--ink-muted);
}
.tier-row--active { background: var(--paper-tone); padding-left: var(--s4); padding-right: var(--s4); }
.tier-row--active .tier-row__num { color: var(--ink); }
.tier-row--active .tier-row__check { color: var(--rust); }
@media (max-width: 640px) {
  .tier-row { grid-template-columns: 56px 1fr; }
  .tier-row__check { grid-column: 1 / 3; text-align: center; }
  .tier-row__num { font-size: var(--fs-3xl); }
}

/* ====================================================
   SPEC LIST — definition list (network / token specs)
   ==================================================== */
.spec-list {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 0;
  margin: var(--s6) 0;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.spec-list dt {
  padding: var(--s3) var(--s4) var(--s3) 0;
  border-bottom: 1px solid var(--ink-line);
  border-right: 1px solid var(--ink-line);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
  font-weight: var(--fw-s);
}
.spec-list dd {
  padding: var(--s3) 0 var(--s3) var(--s4);
  margin: 0;
  border-bottom: 1px solid var(--ink-line);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink);
}
.spec-list dt:last-of-type, .spec-list dd:last-of-type { border-bottom: 0; }
.spec-list dd code { font-family: var(--font-mono); font-size: 0.92em; background: var(--paper-tone); padding: 1px 6px; }
@media (max-width: 600px) {
  .spec-list { grid-template-columns: 1fr; }
  .spec-list dt { border-right: 0; padding: var(--s3) 0 var(--s1); }
  .spec-list dd { padding: 0 0 var(--s3); }
}

/* ====================================================
   CODE BLOCK — for contract addresses
   ==================================================== */
.contract-card {
  margin: var(--s6) 0;
  padding: var(--s5) var(--s6);
  background: var(--ink-bg);
  color: var(--paper);
  border-left: 6px solid var(--rust);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  overflow-x: auto;
}
.contract-card__label {
  display: block;
  font-family: var(--font-caption);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--rust-bright);
  margin-bottom: var(--s2);
  font-weight: var(--fw-k);
}
.contract-card code { background: transparent; color: var(--paper); padding: 0; word-break: break-all; }

/* ====================================================
   AFFILIATE DISCLOSURE BAR
   ==================================================== */
.disclosure {
  margin: 0 0 var(--s6);
  padding: var(--s3) 0;
  border-top: 1px solid var(--ink-line);
  border-bottom: 1px solid var(--ink-line);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
}
.disclosure strong { color: var(--ink); font-weight: var(--fw-b); }
.disclosure a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--rust); }

/* ====================================================
   GLOSSARY ENTRIES — editorial dictionary
   ==================================================== */
.glossary-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 0;
  margin: var(--s7) 0;
  border-top: 4px solid var(--ink);
}
.glossary-entry {
  padding: var(--s5);
  border-bottom: 1px solid var(--ink-line);
  border-right: 1px solid var(--ink-line);
}
.glossary-entry__term {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: var(--fw-b);
  color: var(--ink);
  margin: 0 0 var(--s2);
  letter-spacing: -0.014em;
}
.glossary-entry__term::before {
  content: "§ ";
  color: var(--rust);
  font-family: var(--font-body);
  font-weight: var(--fw-r);
}
.glossary-entry__def {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
}
@media (max-width: 720px) { .glossary-list { grid-template-columns: 1fr; } .glossary-entry { border-right: 0; } }

/* ====================================================
   CALC WIDGET — tools
   ==================================================== */
.calc-widget {
  margin: var(--s7) 0;
  padding: var(--s6);
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--paper-dark);
}
.calc-widget__section-title {
  display: block;
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  font-weight: var(--fw-k);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0 0 var(--s5);
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--ink-line);
}
.calc-widget__inputs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s4);
  margin-bottom: var(--s5);
}
.calc-widget__field { display: flex; flex-direction: column; gap: 4px; }
.calc-widget__field-row { display: flex; gap: var(--s3); align-items: end; }
.calc-widget__label { font-family: var(--font-caption); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.12em; font-weight: var(--fw-s); color: var(--ink); }
.calc-widget__hint { font-family: var(--font-body); font-style: italic; font-size: var(--fs-xs); color: var(--ink-muted); line-height: 1.45; }
.calc-widget__field input, .calc-widget__field select {
  padding: 10px 12px;
  font-family: var(--font-mono);
  font-size: var(--fs-base);
  border: 1px solid var(--ink);
  background: var(--paper);
  color: var(--ink);
  width: 100%;
}
.calc-widget__field input:focus, .calc-widget__field select:focus { outline: 2px solid var(--rust); outline-offset: 1px; }
.calc-widget__radio-group { display: flex; flex-wrap: wrap; gap: var(--s2); }
.calc-widget__radio {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 14px;
  min-height: var(--touch-target-min);
  border: 1px solid var(--ink);
  background: var(--paper);
  cursor: pointer;
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
@media (hover: hover) and (pointer: fine) {
  .calc-widget__radio:hover { background: var(--ink); color: var(--paper); }
}
.calc-widget__radio input { margin: 0; accent-color: var(--rust); }
.calc-widget__outputs {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--s4);
  margin-top: var(--s5);
  padding-top: var(--s5);
  border-top: 1px solid var(--ink-line);
}
.calc-widget__output {
  padding: var(--s4);
  background: var(--paper);
  border: 1px solid var(--ink);
  text-align: center;
}
.calc-widget__output--accent { background: var(--ink); color: var(--paper); }
.calc-widget__output-label {
  display: block;
  font-family: var(--font-caption);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--ink-muted);
  font-weight: var(--fw-s);
  margin-bottom: var(--s2);
}
.calc-widget__output--accent .calc-widget__output-label { color: rgba(250,246,239,0.7); }
.calc-widget__output-value {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-b);
  color: var(--ink);
  line-height: 1;
  letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
}
.calc-widget__output--accent .calc-widget__output-value { color: var(--paper); }
.calc-widget__output-value--big { font-size: var(--fs-3xl); color: var(--rust); }
.calc-widget__verdict {
  margin-top: var(--s5);
  padding: var(--s4) var(--s5);
  background: var(--ink-bg);
  color: var(--paper);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  border-left: 4px solid var(--rust);
}
.calc-widget__verdict strong { color: var(--rust-bright); }
.calc-widget__note { margin-top: var(--s3); font-family: var(--font-body); font-style: italic; font-size: var(--fs-sm); color: var(--ink-muted); }

/* ====================================================
   ARTICLE LISTING — Bloomberg / NYTimes article preview cards
   ==================================================== */
.article-listing {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: var(--s7);
  margin: var(--s7) 0;
  padding-top: var(--s7);
  border-top: 4px solid var(--ink);
}
.article-listing__lead {
  border-right: 1px solid var(--ink-line);
  padding-right: var(--s7);
}
.article-listing__lead .listing-category { font-size: var(--fs-xs); }
.article-listing__lead .listing-title { font-size: var(--fs-3xl); line-height: 1; }
.article-listing__lead .listing-excerpt { font-size: var(--fs-base); }
.listing {
  text-decoration: none;
  color: var(--ink);
  display: block;
}
@media (hover: hover) and (pointer: fine) {
  .listing:hover { color: var(--rust); text-decoration: none; }
  .listing:hover .listing-title { text-decoration: underline; text-decoration-thickness: 1px; }
}
.listing-category {
  display: inline-block;
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: var(--fw-k);
  color: var(--rust);
  margin-bottom: var(--s3);
}
.listing-title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-b);
  color: var(--ink);
  line-height: 1.18;
  letter-spacing: -0.018em;
  margin: 0 0 var(--s3);
}
.listing-excerpt {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
  max-width: 50ch;
}
.listing-meta {
  margin-top: var(--s3);
  font-family: var(--font-caption);
  font-size: var(--fs-xxs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-muted);
}
@media (max-width: 900px) {
  .article-listing { grid-template-columns: 1fr 1fr; }
  .article-listing__lead { grid-column: 1 / 3; border-right: 0; padding-right: 0; padding-bottom: var(--s5); border-bottom: 1px solid var(--ink-line); }
}
@media (max-width: 600px) {
  .article-listing { grid-template-columns: 1fr; }
  .article-listing__lead { grid-column: 1; }
}

/* ====================================================
   TWO-COLUMN MAGAZINE — flowing columns
   ==================================================== */
.two-col {
  margin: var(--s7) 0;
  column-count: 2;
  column-gap: var(--s7);
  column-rule: 1px solid var(--ink-line);
  font-family: var(--font-body);
}
.two-col h2 { column-span: all; margin-top: var(--s7); }
.two-col p { max-width: none; }
@media (max-width: 640px) { .two-col { column-count: 1; } }

/* ====================================================
   CTA BUTTONS (editorial)
   ==================================================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--s2);
  padding: 12px var(--s5);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  font-weight: var(--fw-b);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  text-decoration: none;
  border: 0;
  cursor: pointer;
  white-space: nowrap;
  min-height: 44px;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.btn--primary { background: var(--ink); color: var(--paper); }
.btn--ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.btn--rust { background: var(--rust); color: var(--paper); }
.btn--inverse { background: var(--paper); color: var(--ink); }
@media (hover: hover) and (pointer: fine) {
  .btn:hover { text-decoration: none; }
  .btn--primary:hover { background: var(--rust); color: var(--paper); }
  .btn--ghost:hover { background: var(--ink); color: var(--paper); }
  .btn--rust:hover { background: var(--rust-deep); color: var(--paper); }
  .btn--inverse:hover { background: var(--rust); color: var(--paper); }
}

.cta-sticky {
  display: inline-flex; align-items: center; justify-content: center;
  position: fixed; bottom: var(--s5); right: var(--s5); z-index: var(--z-overlay);
  padding: 14px var(--s5);
  min-height: var(--touch-target-min);
  background: var(--ink);
  color: var(--paper) !important;
  font-family: var(--font-caption);
  font-weight: var(--fw-b);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  text-decoration: none !important;
  box-shadow: 0 4px 16px rgba(22,24,45,0.18);
  transition: background var(--t-fast);
}
@media (hover: hover) and (pointer: fine) {
  .cta-sticky:hover { background: var(--rust); }
}

/* ====================================================
   CHIPS / TAGS — editorial micro labels
   ==================================================== */
.chip {
  display: inline-block;
  font-family: var(--font-caption);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: var(--fw-s);
  padding: 2px 8px;
  background: transparent;
  color: var(--ink-soft);
  border: 1px solid var(--ink-line);
}
.chip--rust { color: var(--rust); border-color: var(--rust); }
.chip--solid { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ====================================================
   PAYMENT TABLE / DATA-DENSE
   ==================================================== */
.data-table-wrap {
  margin: var(--s6) 0;
  overflow-x: auto;
  border-top: 4px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.data-table { margin: 0; border: 0; }
.data-table thead th {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-caption);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: var(--fw-k);
  padding: var(--s3) var(--s4);
  border-bottom: 2px solid var(--ink);
}
.data-table td {
  padding: var(--s3) var(--s4);
  border-bottom: 1px solid var(--ink-line);
  vertical-align: middle;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--ink);
}
@media (hover: hover) and (pointer: fine) {
  .data-table tbody tr:hover { background: var(--paper-dark); }
}
.data-table__brand {
  display: inline-flex; align-items: center;
  gap: var(--s3);
  font-family: var(--font-display);
  font-weight: var(--fw-b);
  color: var(--ink);
}
.data-table__brand img {
  width: 32px; height: 32px;
  object-fit: contain;
  padding: 2px;
  background: var(--paper);
  border: 1px solid var(--ink-line);
}

/* ====================================================
   RELATED BLOCK — footer-style index
   ==================================================== */
.related-block {
  margin: var(--s9) 0 0;
  padding: var(--s7) 0;
  border-top: 4px solid var(--ink);
}
.related-block h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-x);
  letter-spacing: -0.022em;
  margin: 0 0 var(--s5);
}
.related-block ul {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s3) var(--s5);
}
.related-block li { margin: 0; }
.related-block a {
  display: flex; align-items: baseline; gap: var(--s2);
  padding: var(--s3) 0;
  border-bottom: 1px solid var(--ink-line);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  text-decoration: none;
  transition: color var(--t-fast);
}
.related-block a::before {
  content: "→";
  color: var(--rust);
  font-family: var(--font-caption);
  font-weight: var(--fw-b);
}
@media (hover: hover) and (pointer: fine) {
  .related-block a:hover { color: var(--rust); text-decoration: underline; }
}

/* ====================================================
   RESPONSIBLE GAMBLING FOOTER NOTE
   ==================================================== */
.rg-foot {
  margin: var(--s9) 0 0;
  padding: var(--s6) 0;
  border-top: 1px solid var(--ink-line);
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  color: var(--ink-muted);
  text-align: center;
  line-height: 1.65;
}
.rg-foot a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--rust); }
@media (hover: hover) and (pointer: fine) {
  .rg-foot a:hover { color: var(--rust); }
}

/* ====================================================
   FOLIO STRIP — page indicator (magazine convention)
   ==================================================== */
.folio {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: var(--s2) 0;
  margin-top: var(--s8);
  border-top: 1px solid var(--ink);
  font-family: var(--font-caption);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ink-muted);
  font-weight: var(--fw-s);
}

/* ============================================================
   T55 monetization blocks — CTA + rating cards
   Added V5.7.47 to expose existing editorial elements as T55-recognizable.
============================================================ */
.cta-block {
  display: block;
  margin: var(--s6) auto;
  padding: var(--s5) var(--s6);
  background: var(--paper);
  border: 1px solid var(--ink-line);
  border-radius: 4px;
  text-decoration: none;
  color: var(--ink);
  transition: border-color 0.15s, box-shadow 0.15s;
}
@media (hover: hover) and (pointer: fine) {
  .cta-block:hover { border-color: var(--rust); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
}

.cta-block.cta-primary,
.cta-block.cta-button.visit-casino,
.cta-block.cta-button.play-now {
  background: var(--rust);
  color: var(--paper);
  border-color: var(--rust);
  font-weight: var(--fw-b);
  text-align: center;
  padding: var(--s4) var(--s7);
  display: inline-block;
  min-height: 44px;
  line-height: 1.3;
}
@media (hover: hover) and (pointer: fine) {
  .cta-block.cta-primary:hover,
  .cta-block.cta-button.visit-casino:hover {
    background: var(--rust-deep);
    border-color: var(--rust-deep);
    color: var(--paper);
  }
}

.cta-block.cta-hero {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s5);
  align-items: center;
  padding: var(--s6) var(--s7);
  background-color: var(--paper-warm);
  background-image: linear-gradient(180deg, var(--paper-warm) 0%, var(--paper) 100%);
  color: var(--ink);
  border: 2px solid var(--rust);
  border-radius: 6px;
  margin: var(--s5) auto;
}
.cta-hero__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-right: var(--s5);
  border-right: 1px solid var(--ink-line);
}
.cta-hero__score {
  font-family: var(--ff-mono);
  font-size: var(--fs-4xl);
  font-weight: var(--fw-b);
  color: var(--rust);
  line-height: 1;
}
.cta-hero__scale {
  font-family: var(--ff-mono);
  font-size: var(--fs-lg);
  color: var(--ink-muted);
}
.cta-hero__label {
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--ink-muted);
  margin-top: var(--s2);
}
.cta-hero .cta-block.cta-primary {
  justify-self: end;
}

.cta-block.cta-card {
  text-align: center;
  padding: var(--s7) var(--s6);
  background: var(--paper-warm);
  border: 1px solid var(--ink-line);
  margin: var(--s8) auto;
}
.cta-block__heading {
  margin: 0 0 var(--s3);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-b);
  color: var(--ink);
}
.cta-block.cta-card p {
  margin: 0 0 var(--s5);
  font-size: var(--fs-lg);
  color: var(--ink-muted);
}

.cta-block.cta-inline {
  background: transparent;
  border: 0;
  border-left: 3px solid var(--rust);
  padding: var(--s3) var(--s5);
  margin: var(--s5) 0;
}
.cta-block__copy {
  margin: 0;
  font-size: var(--fs-md);
  line-height: 1.6;
}

/* Rating block (when applied to .dossier — already styled, just add T55-recognizable classes) */
.rating-card.score-card { /* inherits .dossier */ }

.rating-table.rating-block {
  margin: var(--s5) 0;
}

@media (max-width: 768px) {
  .cta-block.cta-hero { grid-template-columns: 1fr; padding: var(--s5) var(--s4); }
  .cta-hero__rating { border-right: 0; border-bottom: 1px solid var(--ink-line); padding: 0 0 var(--s4); }
  .cta-hero .cta-block.cta-primary { justify-self: stretch; width: 100%; }
}

/* ============================================================
   MOBILE-FIRST UTILITIES (V5.8.3)
   Reusable wrappers for tables, tile grids, and horizontal scroll.
============================================================ */

/* Horizontal scroll wrapper for wide tables / data on mobile */
.compare-wrapper,
.table-wrap {
  margin: var(--s6) 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--ink-line) transparent;
}
.compare-wrapper > table,
.table-wrap > table { margin: 0; min-width: 720px; }
@media (min-width: 1024px) {
  .compare-wrapper > table,
  .table-wrap > table { min-width: 0; }
}

/* Sticky first column for wide compare tables (.compare-table) */
.compare-table { width: 100%; }
.compare-table th:first-child,
.compare-table td:first-child {
  position: sticky;
  left: 0;
  background: var(--paper);
  z-index: 1;
}
.compare-table thead th:first-child { background: var(--paper); }

/* Tile grid — mobile-first responsive grid (1 → 2 → 3 → 4 cols) */
.tile-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s5);
  margin: var(--s6) 0;
}
@media (min-width: 600px) {
  .tile-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
  .tile-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1200px) {
  .tile-grid--4 { grid-template-columns: repeat(4, 1fr); }
}
.tile-grid--2 { grid-template-columns: 1fr; }
@media (min-width: 600px) {
  .tile-grid--2 { grid-template-columns: repeat(2, 1fr); }
}
.tile-grid--3 { grid-template-columns: 1fr; }
@media (min-width: 600px) {
  .tile-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
  .tile-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

/* Generic block stack helper — force vertical layout on mobile */
@media (max-width: 640px) {
  .stack-mobile {
    display: block !important;
    grid-template-columns: 1fr !important;
  }
  .stack-mobile > * + * { margin-top: var(--s4); }
}

/* Mobile-first hardening for major editorial blocks */
@media (max-width: 640px) {
  /* Article — keep reading column, reduce padding */
  .article { padding: var(--s5) 0 var(--s7); }

  /* Cover already responsive (line 88+) — reinforce title clamp */
  .cover__title { max-width: 100%; }
  .cover--asym .container { gap: var(--s5); }

  /* Dossier — already 1fr at ≤720, reinforce */
  .dossier { padding: var(--s5) 0; gap: var(--s4); margin: var(--s5) 0; }

  /* Stat band — keep auto-fit but ensure cells stack on tiny viewports */
  .stat-band__value { font-size: var(--fs-xl); }

  /* Verdict, big-number — reduce padding */
  .verdict { padding: var(--s5); margin: var(--s6) 0; }
  .big-number { padding: var(--s6) 0; margin: var(--s6) 0; }
  .big-number__value { font-size: var(--fs-5xl); }

  /* Calc widget — pad less on small screens */
  .calc-widget { padding: var(--s5) var(--s4); }
  .calc-widget__radio-group { gap: var(--s2); }

  /* Pull-quote — smaller on mobile */
  .pull-quote { font-size: var(--fs-2xl); padding: var(--s5) 0; margin: var(--s6) 0; }

  /* Author feature — already 1fr at ≤720, reinforce portrait */
  .author-feature__portrait { max-width: 160px; margin: 0 auto; }
  .author-feature__body h1 { font-size: var(--fs-3xl); }

  /* Tier row — already responsive, reinforce */
  .tier-row__title { font-size: var(--fs-lg); }
  .tier-row__desc { font-size: var(--fs-sm); }

  /* Cta-block variants pad less on mobile */
  .cta-block { padding: var(--s4); margin: var(--s5) auto; }
  .cta-block.cta-card { padding: var(--s5) var(--s4); margin: var(--s6) auto; }
  .cta-block__heading { font-size: var(--fs-xl); }

  /* Sticky CTA — smaller and tucked against safe area */
  .cta-sticky {
    bottom: max(var(--s3), env(safe-area-inset-bottom));
    right: max(var(--s3), env(safe-area-inset-right));
    padding: 10px var(--s4);
    font-size: var(--fs-xxs);
  }

  /* Article side note (float fallback at ≤900 already handled) */
  .article__side { padding: var(--s3) var(--s4); }

  /* Two-column flow goes single on mobile (existing rule at 640) */
}

@media (max-width: 480px) {
  /* Extreme tiny — make rank-row CTAs and dossier readable */
  .dossier__title { font-size: var(--fs-2xl); }
  .dossier__sub { font-size: var(--fs-base); }
  .rank-row__name { font-size: var(--fs-md); }
  .rank-row__hook { font-size: var(--fs-sm); }
  .cta-hero__score { font-size: var(--fs-3xl); }
}


/* ====================================================================
   T58 V5.8.3 — required structural blocks (dossier-grid alias + hero
   tagline/chips + criteria-rating block + calc-widget tool interface).
   ==================================================================== */

.dossier-grid {
  /* alias of .dossier — styled via existing rules; keeps T58 happy. */
}

.cta-hero__pitch {
  display: flex;
  flex-direction: column;
  gap: var(--s2);
  margin-top: var(--s3);
}
.cta-hero__tagline {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink);
  font-style: italic;
}
.cta-hero__chips {
  margin: 0;
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.cta-hero__chips span { white-space: nowrap; }

.criteria-rating {
  margin: var(--s7) 0;
  padding: var(--s6);
  background-color: var(--paper-tone, #f7f3ec);
  color: var(--ink);
  border-left: 4px solid var(--rust, #b94a3c);
}
.criteria-rating__title {
  margin: 0 0 var(--s4);
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-k, 800);
  color: var(--ink);
}
.rating-row.criterion {
  display: grid;
  grid-template-columns: 1fr 2fr auto;
  gap: var(--s4);
  align-items: center;
  padding: var(--s3) 0;
  border-bottom: 1px solid var(--ink-line, rgba(22,24,45,0.12));
}
.rating-row.criterion:last-child { border-bottom: 0; }
.criterion__label {
  font-family: var(--font-caption);
  font-size: var(--fs-sm);
  font-weight: var(--fw-s, 600);
  color: var(--ink);
}
.criterion__bar {
  display: block;
  height: 8px;
  background: rgba(22, 24, 45, 0.08);
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}
.criterion__bar > span {
  display: block;
  height: 100%;
  background: var(--rust, #b94a3c);
}
.criterion__score {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: var(--fw-b, 700);
  color: var(--ink);
  text-align: right;
  white-space: nowrap;
}
@media (max-width: 640px) {
  .rating-row.criterion {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
  }
  .criterion__bar { grid-column: 1 / -1; }
}

/* Calculator widget — tool_interface required by T58 for tool pages. */
.tool-interface.calc-widget {
  margin: var(--s7) auto;
  padding: var(--s6);
  background-color: var(--paper, #fbf9f4);
  color: var(--ink);
  border: 1px solid var(--ink-line, rgba(22,24,45,0.12));
}
.calc-form {
  display: grid;
  gap: var(--s5);
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}
@media (max-width: 720px) {
  .calc-form { grid-template-columns: 1fr; }
}
.calc-widget__inputs,
.calc-widget__output {
  border: 0;
  margin: 0;
  padding: 0;
}
.calc-widget__legend,
.calc-widget__output-title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: var(--fw-k, 800);
  margin-bottom: var(--s3);
  color: var(--ink);
}
.calc-widget__field {
  display: flex;
  flex-direction: column;
  gap: var(--s1);
  margin-bottom: var(--s3);
  font-family: var(--font-caption);
  font-size: var(--fs-sm);
  color: var(--ink);
}
.calc-widget__field input[type="number"],
.calc-widget__field input[type="range"] {
  padding: var(--s2);
  border: 1px solid var(--ink-line, rgba(22,24,45,0.18));
  background: var(--paper, #fff);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: var(--fs-base);
  width: 100%;
}
.calc-widget__radios {
  border: 0;
  padding: 0;
  margin: var(--s3) 0;
  display: flex;
  gap: var(--s3);
  flex-wrap: wrap;
}
.calc-widget__radios legend {
  font-family: var(--font-caption);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-muted);
  width: 100%;
  margin-bottom: var(--s2);
}
.calc-widget__radios label {
  display: inline-flex;
  align-items: center;
  gap: var(--s1);
  font-family: var(--font-caption);
  font-size: var(--fs-sm);
}
.calc-widget__metrics {
  display: grid;
  gap: var(--s2);
  grid-template-columns: 1fr;
}
.calc-widget__metrics > div {
  display: flex;
  justify-content: space-between;
  padding: var(--s2) 0;
  border-bottom: 1px solid var(--ink-line, rgba(22,24,45,0.10));
}
.calc-widget__metrics > div:last-child { border-bottom: 0; }
.calc-widget__metrics dt {
  font-family: var(--font-caption);
  font-size: var(--fs-sm);
  color: var(--ink-muted);
}
.calc-widget__metrics dd {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-base);
  font-weight: var(--fw-b, 700);
  color: var(--ink);
}
.calc-widget__output-value--positive { color: #2f7a3a; }
.calc-widget__output-value--negative { color: #b94a3c; }
.calc-widget__verdict {
  margin: var(--s4) 0 0;
  padding: var(--s3);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  background: rgba(22, 24, 45, 0.04);
  border-left: 3px solid var(--ink-line, rgba(22,24,45,0.18));
}
.calc-widget__verdict--good {
  background: rgba(47, 122, 58, 0.10);
  border-left-color: #2f7a3a;
}
.calc-widget__verdict--neutral {
  background: rgba(180, 130, 0, 0.10);
  border-left-color: #b48200;
}
.calc-widget__verdict--bad {
  background: rgba(185, 74, 60, 0.10);
  border-left-color: #b94a3c;
}

/* ============================================================
   V5.8.3 ETAP 4 — Page-type templates: tile, spec-table, steps,
   compare-grid, featured-leaderboard
   ============================================================ */

/* === FEATURED LEADERBOARD on home === */
.featured-leaderboard {
  margin: var(--s8) auto;
}
.featured-leaderboard__title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-k);
  color: var(--ink);
  margin: 0 0 var(--s3);
}
.featured-leaderboard__lead {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink-muted);
  margin: 0 0 var(--s5);
}

/* === TILE — child of .tile-grid (cluster navigation) === */
.tile {
  display: block;
  background-color: var(--paper-tone, #f7f2ea);
  border: 1px solid var(--ink-line);
  border-left: 4px solid var(--rust);
  min-height: 120px;
  transition: background-color var(--t-fast) var(--ease);
}
.tile__link {
  display: block;
  padding: var(--s5) var(--s4);
  color: var(--ink);
  text-decoration: none;
  min-height: inherit;
}
@media (hover: hover) and (pointer: fine) {
  .tile:hover {
    background-color: var(--paper-dark, #efe7da);
    border-left-color: var(--rust-deep, var(--oxblood));
  }
}
.tile__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: var(--fw-k);
  color: var(--ink);
  margin: 0 0 var(--s2);
}
.tile__sub {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--ink-muted);
  margin: 0;
}

/* === SPEC TABLE — at-a-glance fact band === */
.spec-table {
  background-color: var(--paper-tone, #f7f2ea);
  padding: var(--s6);
  border-left: 4px solid var(--rust);
  margin: var(--s7) auto;
}
.spec-table__title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-k);
  color: var(--ink);
  margin: 0 0 var(--s4);
}
.spec-table__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s3) var(--s5);
  margin: 0;
}
@media (min-width: 640px) {
  .spec-table__grid { grid-template-columns: 1fr 1fr; }
}
.spec-table__grid > div {
  display: flex;
  flex-direction: column;
  gap: var(--s1);
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--ink-line);
}
.spec-table__grid dt {
  font-family: var(--font-caption, var(--font-body));
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
  font-weight: var(--fw-s, 600);
}
.spec-table__grid dd {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink);
  font-weight: var(--fw-m, 500);
  margin: 0;
}

/* === COMPARE GRID — section wrapper around a compare-table === */
.compare-grid {
  margin: var(--s7) auto;
}
.compare-grid__title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-k);
  color: var(--ink);
  margin: 0 0 var(--s4);
}
.compare-grid .compare-wrapper {
  margin-top: 0;
}

/* === STEPS — numbered counter list for setup workflows === */
.steps {
  counter-reset: step-counter;
  list-style: none;
  padding: 0;
  margin: var(--s7) auto;
  display: grid;
  gap: var(--s4);
}
.steps__item {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: var(--s4);
  padding: var(--s4);
  background-color: var(--paper-tone, #f7f2ea);
  border-left: 4px solid var(--rust);
  counter-increment: step-counter;
}
.steps__item::before {
  content: counter(step-counter);
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-x, 800);
  color: var(--rust);
  line-height: 1;
}
.steps__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: var(--fw-b, 700);
  color: var(--ink);
  margin: 0 0 var(--s2);
}
.steps__desc {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink);
  margin: 0;
}

/* === PAGE TOC — in-page nav for KYC/wallet pages === */
.onpage-nav {
  margin: var(--s6) auto;
  padding: var(--s4) var(--s5);
  border-left: 4px solid var(--rust);
  background-color: var(--paper-tone, #f7f2ea);
}
.onpage-nav__title {
  font-family: var(--font-display);
  font-size: var(--fs-base);
  font-weight: var(--fw-k);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
  margin: 0 0 var(--s2);
}
.onpage-nav__list {
  list-style: decimal inside;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--s1);
}
.onpage-nav__list li {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.onpage-nav__list .toc-link {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: var(--ink-line);
  text-underline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  .onpage-nav__list .toc-link:hover {
    color: var(--rust);
    text-decoration-color: var(--rust);
  }
}

/* Mobile-first hardening for V5.8.3 templates */
@media (max-width: 640px) {
  .featured-leaderboard { margin: var(--s6) auto; }
  .spec-table { padding: var(--s5); margin: var(--s6) auto; }
  .spec-table__grid { gap: var(--s3); }
  .compare-grid { margin: var(--s6) auto; }
  .steps { margin: var(--s6) auto; gap: var(--s3); }
  .steps__item { grid-template-columns: 44px 1fr; padding: var(--s3); gap: var(--s3); }
  .steps__item::before { font-size: var(--fs-2xl); }
  .tile { min-height: 100px; }
  .tile__link { padding: var(--s4); }
  .onpage-nav { margin: var(--s5) auto; padding: var(--s3) var(--s4); }
}
