/* =========================================================================
   TradingCard.news — "Obsidian Archive" design system
   Market Terminal meets Luxury Editorial.
   Authored from the Obsidian Archive DESIGN.md + five page mockups.
   Plain CSS, no build step. Custom properties for the full palette.
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. DESIGN TOKENS
   ------------------------------------------------------------------------- */
:root {
  /* --- Surfaces (the Void / the Ink / glass) --- */
  --surface:                     #131313;
  --surface-dim:                 #131313;
  --surface-bright:              #3a3939;
  --surface-container-lowest:    #0e0e0e;
  --surface-container-low:       #1c1b1b;
  --surface-container:           #201f1f;
  --surface-container-high:      #2a2a2a;
  --surface-container-highest:   #353534;
  --surface-variant:             #353534;
  --background:                  #131313;
  --void:                        #0d0d0d; /* deepest canvas per design notes */

  /* --- Text --- */
  --on-surface:                  #e5e2e1;
  --on-surface-variant:          #d0c5af;
  --on-background:               #e5e2e1;
  --inverse-surface:             #e5e2e1;
  --inverse-on-surface:          #313030;

  /* --- Outline / hairlines --- */
  --outline:                     #99907c;
  --outline-variant:             #4d4635;

  /* --- Primary (Gold) --- */
  --primary:                     #f2ca50;
  --on-primary:                  #3c2f00;
  --primary-container:           #d4af37;
  --on-primary-container:        #554300;
  --primary-fixed:               #ffe088;
  --primary-fixed-dim:           #e9c349;
  --surface-tint:                #e9c349;
  --inverse-primary:             #735c00;

  /* --- Secondary (Holo / periwinkle) --- */
  --secondary:                   #c3c0ff;
  --on-secondary:                #1d00a5;
  --secondary-container:         #3626ce;
  --on-secondary-container:      #b3b1ff;

  /* --- Tertiary (Positive / mint-green) — price UP --- */
  --tertiary:                    #58e7aa;
  --on-tertiary:                 #003824;
  --tertiary-container:          #33ca90;
  --on-tertiary-container:       #005035;

  /* --- Error (Alert / red) — price DOWN, risk --- */
  --error:                       #ffb4ab;
  --on-error:                    #690005;
  --error-container:             #93000a;
  --on-error-container:          #ffdad6;

  /* --- Editorial reading canvas (warm off-white "Paper") --- */
  --paper:                       #fbfaf8;
  --paper-ink:                   #131313;
  --paper-ink-soft:             #3a3636;
  --paper-hair:                  #e4e0d8;

  /* --- Semantic price colours (non-colour-only cues added in markup) --- */
  --price-up:                    var(--tertiary);
  --price-down:                  var(--error);
  --price-flat:                  var(--on-surface-variant);

  /* --- Accent override hook (theme setting) --- */
  --accent:                      var(--primary);

  /* --- Typography families ---
     If an admin picks fonts in Ghost's Typography panel, Ghost injects
     --gh-font-heading / --gh-font-body and those win; otherwise the brand
     fonts (Bodoni Moda display, Geist body) are the default. Data is always
     JetBrains Mono. This keeps the theme gscan-clean AND on-brand by default. */
  --font-display: var(--gh-font-heading, "Bodoni Moda", Georgia, "Times New Roman", serif);
  --font-body:    var(--gh-font-body, "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
  --font-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  /* --- Type scale (from DESIGN.md) --- */
  --display-lg:      64px;
  --headline-lg:     40px;
  --headline-lg-mob: 32px;
  --headline-md:     24px;
  --body-lg:         18px;
  --body-md:         16px;
  --data-lg:         16px;
  --data-sm:         12px;
  --label-caps:      11px;

  /* --- 8px spacing scale --- */
  --space-xs:   4px;
  --space-sm:   8px;
  --space-md:   16px;
  --space-lg:   24px;
  --space-xl:   48px;
  --space-2xl:  72px;
  --gutter:     20px;
  --container-max: 1440px;
  --reading-max:   720px;

  /* --- Radii --- */
  --radius-sm:   0.125rem; /* 2px  — buttons, inputs */
  --radius:      0.25rem;  /* 4px  — default UI */
  --radius-md:   0.375rem; /* 6px */
  --radius-lg:   0.5rem;   /* 8px  — slab cards, card images (PSA/BGS curve) */
  --radius-xl:   0.75rem;  /* 12px */
  --radius-full: 9999px;

  /* --- Effects --- */
  --glass-bg:    rgba(38, 38, 38, 0.7);
  --glass-bg-soft: rgba(38, 38, 38, 0.4);
  --glass-border: rgba(255, 255, 255, 0.1);
  --blur:        8px;
}

/* -------------------------------------------------------------------------
   2. RESET & BASE
   ------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

body {
  margin: 0;
  background: var(--background);
  color: var(--on-background);
  font-family: var(--font-body);
  font-size: var(--body-md);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

img, picture, svg, video { max-width: 100%; height: auto; display: block; }
img { background: var(--surface-container); }

a {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.2s ease;
}
a:hover { color: var(--primary-fixed); }

button { font-family: inherit; cursor: pointer; }

::selection { background: var(--primary); color: var(--on-primary); }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--void); }
::-webkit-scrollbar-thumb { background: var(--surface-container-highest); }
::-webkit-scrollbar-thumb:hover { background: var(--primary); }

/* --- Skip link (WCAG 2.2 AA) --- */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 9999;
  background: var(--primary);
  color: var(--on-primary);
  padding: var(--space-sm) var(--space-md);
  font-family: var(--font-body);
  font-weight: 700;
  border-radius: 0 0 var(--radius) 0;
}
.skip-link:focus { left: 0; color: var(--on-primary); }

/* --- Universal visible focus state (WCAG 2.2 AA) --- */
:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* -------------------------------------------------------------------------
   3. TYPOGRAPHY HELPERS
   ------------------------------------------------------------------------- */
.font-display { font-family: var(--font-display); }
.font-body    { font-family: var(--font-body); }
.font-mono    { font-family: var(--font-mono); }

.display-lg {
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, var(--display-lg));
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.headline-lg {
  font-family: var(--font-display);
  font-size: clamp(var(--headline-lg-mob), 4.5vw, var(--headline-lg));
  font-weight: 600;
  line-height: 1.2;
}
.headline-md {
  font-family: var(--font-display);
  font-size: var(--headline-md);
  font-weight: 500;
  line-height: 1.3;
}
.body-lg { font-size: var(--body-lg); line-height: 1.6; }
.body-md { font-size: var(--body-md); line-height: 1.5; }

.data, .data-lg {
  font-family: var(--font-mono);
  font-size: var(--data-lg);
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.data-sm {
  font-family: var(--font-mono);
  font-size: var(--data-sm);
  font-weight: 400;
  line-height: 1.4;
  font-variant-numeric: tabular-nums;
}
.label-caps {
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.mute   { color: var(--on-surface-variant); }
.muted-2 { color: var(--outline); }
.gold   { color: var(--primary); }
.italic { font-style: italic; }

/* --- Holo wordmark / grail shimmer --- */
.holo {
  background: linear-gradient(135deg, #d4af37 0%, #f2ca50 25%, #ffffff 50%, #f2ca50 75%, #d4af37 100%);
  background-size: 200% 200%;
  animation: holo-shine 4s linear infinite;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@keyframes holo-shine { to { background-position: 200% center; } }

/* -------------------------------------------------------------------------
   4. LAYOUT
   ------------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.section { padding-block: var(--space-xl); }
.section-tight { padding-block: var(--space-lg); }

.row { display: flex; align-items: center; }
.col { display: flex; flex-direction: column; }
.wrap { flex-wrap: wrap; }
.grow { flex: 1 1 auto; }
.between { justify-content: space-between; }
.end { align-items: flex-end; }
.start { align-items: flex-start; }
.center { align-items: center; justify-content: center; }

.gap-xs { gap: var(--space-xs); }
.gap-sm { gap: var(--space-sm); }
.gap-md { gap: var(--space-md); }
.gap-lg { gap: var(--space-lg); }
.gap-xl { gap: var(--space-xl); }

.grid { display: grid; gap: var(--space-lg); }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-lg); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-lg); }
.grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--space-xl); }

.col-span-3  { grid-column: span 3; }
.col-span-4  { grid-column: span 4; }
.col-span-5  { grid-column: span 5; }
.col-span-6  { grid-column: span 6; }
.col-span-7  { grid-column: span 7; }
.col-span-8  { grid-column: span 8; }
.col-span-9  { grid-column: span 9; }

.divider { border: 0; border-top: 1px solid var(--outline-variant); margin: 0; }

/* -------------------------------------------------------------------------
   5. ELEVATION — Slab & Glass
   ------------------------------------------------------------------------- */
.glass {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--blur));
  -webkit-backdrop-filter: blur(var(--blur));
  border: 1px solid var(--glass-border);
}
.glass-soft {
  background: var(--glass-bg-soft);
  backdrop-filter: blur(var(--blur));
  -webkit-backdrop-filter: blur(var(--blur));
  border: 1px solid var(--glass-border);
}

/* The Slab: acrylic graded-card housing with a sweep-shine on hover */
.slab {
  border: 1px solid var(--glass-border);
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
}
.slab::after {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.05), transparent);
  transform: skewX(-25deg);
  transition: left 0.6s ease;
  pointer-events: none;
}
.slab:hover::after { left: 150%; }

.holo-bg {
  background: linear-gradient(135deg, rgba(88,231,170,0.08) 0%, rgba(195,192,255,0.08) 50%, rgba(242,202,80,0.08) 100%);
}

.panel {
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
}

/* -------------------------------------------------------------------------
   6. BUTTONS
   ------------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 14px var(--space-lg);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  min-height: 44px; /* WCAG tap target */
  transition: filter 0.2s ease, transform 0.1s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.btn:active { transform: scale(0.97); }
.btn-primary {
  background: var(--primary);
  color: var(--on-primary);
  border-color: var(--primary);
}
.btn-primary:hover { filter: brightness(1.1); color: var(--on-primary); }
.btn-gold-container {
  background: var(--primary-container);
  color: var(--on-primary-container);
  border-color: var(--primary-container);
}
.btn-gold-container:hover { filter: brightness(1.1); color: var(--on-primary-container); }
/* Ghost / secondary: 1px outline, no fill */
.btn-ghost {
  background: transparent;
  color: var(--on-surface);
  border-color: var(--outline-variant);
}
.btn-ghost:hover { border-color: var(--primary); color: var(--on-surface); }
.btn-ghost-blue {
  background: transparent;
  color: var(--secondary);
  border-color: var(--secondary);
}
.btn-ghost-blue:hover { background: rgba(195,192,255,0.08); color: var(--secondary); }
.btn-sm { padding: var(--space-xs) var(--space-md); min-height: 36px; }
.btn-full { width: 100%; }

/* -------------------------------------------------------------------------
   7. BADGES, CHIPS, PILLS
   ------------------------------------------------------------------------- */
.kicker {
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--primary);
}
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px var(--space-sm);
  border: 1px solid var(--outline-variant);
  background: var(--surface-container-highest);
  color: var(--on-surface-variant);
  border-radius: var(--radius-sm);
}
.chip-gold {
  color: var(--primary);
  background: rgba(242,202,80,0.1);
  border-color: rgba(242,202,80,0.25);
}
/* Status pills (rounded — design reserves full-round for status only) */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}
.pill-live { background: rgba(88,231,170,0.12); color: var(--tertiary); }
.pill-live .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--tertiary); animation: pulse 1.8s ease infinite; }
.pill-sponsored { background: rgba(195,192,255,0.12); color: var(--secondary); }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

/* Confirmed / Rumour / Leak / Analysis badges (brief §News index) */
.badge-confirmed { color: var(--tertiary); background: rgba(88,231,170,0.1); border-color: rgba(88,231,170,0.3); }
.badge-rumour    { color: var(--primary); background: rgba(242,202,80,0.1); border-color: rgba(242,202,80,0.3); }
.badge-leak      { color: var(--secondary); background: rgba(195,192,255,0.1); border-color: rgba(195,192,255,0.3); }
.badge-analysis  { color: var(--on-surface-variant); }

/* -------------------------------------------------------------------------
   8. PRICE / DATA — monospaced, up=green / down=red
   Non-colour cue: ▲ / ▼ glyph + .is-up/.is-down classes.
   ------------------------------------------------------------------------- */
.price {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.price-lg { font-size: var(--headline-md); color: var(--primary); }
.delta {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--data-sm);
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.is-up   { color: var(--price-up); }
.is-down { color: var(--price-down); }
.is-flat { color: var(--price-flat); }
.is-up::before   { content: "\25B2"; font-size: 0.8em; } /* ▲ */
.is-down::before { content: "\25BC"; font-size: 0.8em; } /* ▼ */

/* Data table */
.data-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: var(--data-sm); }
.data-table thead th {
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: left;
  color: var(--on-surface-variant);
  padding: var(--space-md) var(--space-lg);
  background: var(--surface-container-low);
  border-bottom: 1px solid var(--outline-variant);
}
.data-table tbody td { padding: var(--space-md) var(--space-lg); border-bottom: 1px solid rgba(77,70,53,0.3); }
.data-table tbody tr:nth-child(odd) { background: rgba(28,27,27,0.4); } /* zebra */
.data-table tbody tr:hover { background: rgba(195,192,255,0.05); } /* electric-blue 5% */
.data-table .num { text-align: right; }

/* -------------------------------------------------------------------------
   9. HEADER & NAV
   ------------------------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(19,19,19,0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--outline-variant);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
  padding-block: var(--space-md);
}
.brand {
  font-family: var(--font-display);
  font-size: var(--headline-md);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--primary);
  white-space: nowrap;
}
.brand:hover { color: var(--primary); }
.brand img { max-height: 32px; width: auto; }

.primary-nav { display: none; gap: var(--space-lg); align-items: center; }
.primary-nav a {
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
}
.primary-nav a:hover { color: var(--primary); }
.primary-nav a[aria-current="page"],
.primary-nav .nav-current {
  color: var(--primary);
  border-bottom: 2px solid var(--primary);
  padding-bottom: 2px;
}

.secondary-nav {
  border-top: 1px solid var(--outline-variant);
  background: var(--surface-container-lowest);
}
.secondary-nav__inner {
  display: flex;
  gap: var(--space-lg);
  align-items: center;
  overflow-x: auto;
  white-space: nowrap;
  padding-block: 10px;
  scrollbar-width: thin;
}
.secondary-nav a {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
}
.secondary-nav a:hover { color: var(--primary); }

.header-search {
  position: relative;
  display: none;
}
.header-search input {
  background: var(--surface-container-low);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  padding: var(--space-xs) var(--space-md) var(--space-xs) 38px;
  color: var(--on-surface);
  font-family: var(--font-body);
  font-size: var(--body-md);
  width: 230px;
  min-height: 40px;
  transition: border-color 0.2s ease;
}
.header-search input::placeholder { color: var(--outline); }
.header-search input:focus { outline: none; border-color: var(--primary); }
.header-search .ico {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--outline);
}

.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  background: transparent; border: 0; color: var(--on-surface-variant);
  border-radius: var(--radius);
}
.icon-btn:hover { color: var(--primary); }

.mobile-only { display: inline-flex; }

/* -------------------------------------------------------------------------
   10. FOOTER
   ------------------------------------------------------------------------- */
.site-footer {
  background: var(--surface-container-lowest);
  border-top: 1px solid var(--outline-variant);
  margin-top: var(--space-2xl);
  padding-block: var(--space-xl) var(--space-lg);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}
.footer-brand p { color: var(--on-surface-variant); font-size: var(--body-md); max-width: 30ch; }
.footer-col h4 {
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--primary);
  margin: 0 0 var(--space-md);
}
.footer-col a {
  display: block;
  color: var(--on-surface-variant);
  font-size: var(--body-md);
  padding-block: 4px;
}
.footer-col a:hover { color: var(--on-surface); }
.footer-bottom {
  margin-top: var(--space-xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--outline-variant);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--outline);
}
.footer-bottom a { color: var(--outline); }
.footer-bottom a:hover { color: var(--primary); }
.footer-social { display: flex; gap: var(--space-md); }
.footer-social a { color: var(--outline); }
.footer-social a:hover { color: var(--primary); }

/* -------------------------------------------------------------------------
   11. CARDS (news cards, card-grid, story tiles)
   ------------------------------------------------------------------------- */
.news-card { display: flex; flex-direction: column; }
.news-card__media {
  overflow: hidden;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius);
  margin-bottom: var(--space-md);
  aspect-ratio: 16 / 9;
}
.news-card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.news-card:hover .news-card__media img { transform: scale(1.05); }
.news-card__meta { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-sm); flex-wrap: wrap; }
.news-card__title {
  font-family: var(--font-display);
  font-size: var(--headline-md);
  font-weight: 500;
  line-height: 1.3;
  margin: 0 0 var(--space-sm);
  transition: color 0.2s ease;
}
.news-card:hover .news-card__title,
.news-card a:hover .news-card__title { color: var(--primary); }
.news-card__title a { color: inherit; }
.news-card__excerpt {
  color: var(--on-surface-variant);
  font-size: var(--body-md);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.read-time { color: var(--outline); font-family: var(--font-mono); font-size: 10px; }

/* Image placeholder (empty state, never a fake image) */
.imgph {
  display: flex; align-items: center; justify-content: center;
  background:
    repeating-linear-gradient(45deg, var(--surface-container) 0 10px, var(--surface-container-low) 10px 20px);
  color: var(--outline);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius);
}
.imgph .label-caps { color: var(--outline); }

/* Graded slab card (component from DESIGN.md) */
.slab-card { padding: var(--space-md); }
.slab-card__label {
  background: var(--surface-container-highest);
  padding: var(--space-sm);
  margin-bottom: var(--space-md);
  border-bottom: 1px solid var(--outline-variant);
  display: flex; justify-content: space-between; align-items: center;
}
.slab-card__grade { font-family: var(--font-display); font-size: var(--headline-md); font-style: italic; }
.slab-card__img {
  width: 100%; aspect-ratio: 3 / 4; object-fit: cover;
  border-radius: var(--radius-sm); margin-bottom: var(--space-md);
}

/* -------------------------------------------------------------------------
   12. MARKET PULSE strip
   ------------------------------------------------------------------------- */
.pulse-strip {
  background: var(--surface-container-lowest);
  border-block: 1px solid var(--outline-variant);
  padding-block: var(--space-lg);
}
.pulse-item { display: flex; align-items: center; gap: var(--space-lg); }
.pulse-item__icon {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; flex: 0 0 40px;
}
.pulse-item__icon.up   { background: rgba(88,231,170,0.1); color: var(--tertiary); }
.pulse-item__icon.down { background: rgba(255,180,171,0.1); color: var(--error); }
.pulse-item__icon.gold { background: rgba(242,202,80,0.1); color: var(--primary); }

/* -------------------------------------------------------------------------
   13. HERO
   ------------------------------------------------------------------------- */
.hero { padding-block: var(--space-xl); }
.hero__lead-title {
  font-family: var(--font-display);
  font-size: clamp(var(--headline-lg-mob), 4.5vw, var(--headline-lg));
  font-weight: 600;
  line-height: 1.15;
  margin: var(--space-md) 0 var(--space-lg);
}
.hero__lead-title a { color: inherit; }
.hero__lead-title a:hover { color: var(--primary); }
.hero__standfirst { font-size: var(--body-lg); line-height: 1.6; color: var(--on-surface-variant); margin-bottom: var(--space-xl); max-width: 56ch; }

/* -------------------------------------------------------------------------
   14. TERMINAL SEARCH
   ------------------------------------------------------------------------- */
.terminal-search { position: relative; max-width: 960px; margin-inline: auto; }
.terminal-search input {
  width: 100%;
  background: var(--surface-container-high);
  border: 2px solid var(--outline-variant);
  padding: var(--space-lg) 64px;
  font-family: var(--font-display);
  font-size: var(--headline-md);
  color: var(--on-surface);
  outline: none;
  transition: border-color 0.2s ease;
}
.terminal-search input::placeholder { color: var(--outline); }
.terminal-search input:focus { border-color: var(--primary); }
.terminal-search .ico { position: absolute; left: var(--space-lg); top: 50%; transform: translateY(-50%); color: var(--primary); }
.kbd {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--surface-container-lowest);
  border: 1px solid var(--outline-variant);
  padding: 2px 6px; font-family: var(--font-mono); font-size: 10px;
  border-radius: var(--radius-sm);
}

/* -------------------------------------------------------------------------
   15. NEWSLETTER block
   ------------------------------------------------------------------------- */
.newsletter {
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  padding: var(--space-xl);
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
}
.newsletter::before {
  content: ""; position: absolute; right: -60px; top: -60px;
  width: 220px; height: 220px; background: rgba(242,202,80,0.05);
  border-radius: 50%; filter: blur(60px); pointer-events: none;
}
.newsletter__form { display: flex; gap: 0; flex-wrap: wrap; }
.newsletter__form input[type="email"] {
  flex: 1 1 220px;
  background: var(--surface-container-low);
  border: 1px solid var(--outline-variant);
  border-right: 0;
  padding: var(--space-md) var(--space-lg);
  color: var(--on-surface);
  font-family: var(--font-body);
  font-size: var(--body-md);
  min-height: 48px;
  outline: none;
}
.newsletter__form input[type="email"]:focus { border-color: var(--primary); }
.newsletter__form button { white-space: nowrap; border-radius: 0; }
.newsletter__note { font-family: var(--font-body); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--outline); margin-top: var(--space-sm); }
.form-message { font-size: var(--data-sm); margin-top: var(--space-sm); }
.form-message.error { color: var(--error); }
.form-message.success { color: var(--tertiary); display: none; }

/* -------------------------------------------------------------------------
   16. DISCLOSURE / TRUST / COMPLIANCE blocks
   ------------------------------------------------------------------------- */
.disclosure {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
  padding: var(--space-md) var(--space-lg);
  background: rgba(195,192,255,0.06);
  border: 1px solid var(--outline-variant);
  border-left: 3px solid var(--secondary);
  border-radius: var(--radius);
}
.disclosure--affiliate { border-left-color: var(--primary); background: rgba(242,202,80,0.06); }
.disclosure--ai { border-left-color: var(--secondary); background: var(--surface-container-low); }
.disclosure__icon { color: var(--secondary); flex: 0 0 auto; margin-top: 2px; }
.disclosure--affiliate .disclosure__icon { color: var(--primary); }
.disclosure__body { font-size: var(--data-sm); line-height: 1.55; color: var(--on-surface-variant); }
.disclosure__body strong { color: var(--on-surface); }

/* Not-financial-advice note */
.nfa-note {
  font-family: var(--font-body);
  font-size: var(--data-sm);
  line-height: 1.5;
  color: var(--on-surface-variant);
  padding: var(--space-sm) var(--space-md);
  border: 1px dashed var(--outline-variant);
  border-radius: var(--radius);
  background: var(--surface-container-low);
}

/* Key takeaways */
.takeaways {
  background: rgba(242,202,80,0.05);
  border-left: 4px solid var(--primary);
  padding: var(--space-lg);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.takeaways h3 { margin: 0 0 var(--space-md); }
.takeaways ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-md); }
.takeaways li { display: flex; gap: var(--space-sm); align-items: flex-start; }
.takeaways li .ico { color: var(--primary); flex: 0 0 auto; margin-top: 2px; }

/* Why-trust-us / details disclosure */
details.trust-box {
  background: var(--surface-container-low);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
}
details.trust-box summary {
  list-style: none;
  cursor: pointer;
  padding: var(--space-md) var(--space-lg);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  min-height: 44px;
}
details.trust-box summary::-webkit-details-marker { display: none; }
details.trust-box summary .chev { transition: transform 0.2s ease; }
details.trust-box[open] summary .chev { transform: rotate(180deg); }
details.trust-box .trust-box__body { padding: 0 var(--space-lg) var(--space-lg); color: var(--on-surface-variant); font-size: var(--body-md); }
details.trust-box .trust-box__body p { margin: 0 0 var(--space-sm); }

/* Counterfeit / risk advisory */
.advisory {
  background: rgba(147,0,10,0.18);
  border: 1px solid rgba(255,180,171,0.3);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}
.advisory__head { display: flex; align-items: center; gap: var(--space-md); margin-bottom: var(--space-md); color: var(--error); }
.advisory ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.advisory li { display: flex; gap: var(--space-sm); color: var(--on-error-container); }

/* Awaiting-data empty state (data surfaces with no feed yet) */
.awaiting-data {
  border: 1px dashed var(--outline-variant);
  background: var(--surface-container-low);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  text-align: center;
}
.awaiting-data .ico { color: var(--primary); margin-inline: auto; margin-bottom: var(--space-md); }
.awaiting-data h3 { margin: 0 0 var(--space-sm); }
.awaiting-data p { color: var(--on-surface-variant); max-width: 52ch; margin: 0 auto; }
.awaiting-data .tag {
  display: inline-block; margin-top: var(--space-md);
  font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--primary); border: 1px solid rgba(242,202,80,0.3); padding: 4px 10px; border-radius: var(--radius-full);
}

/* -------------------------------------------------------------------------
   17. POST / ARTICLE (warm off-white reading canvas)
   ------------------------------------------------------------------------- */
.post-hero { padding-block: var(--space-xl); border-bottom: 1px solid var(--outline-variant); }
.post-hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--headline-lg-mob), 4.5vw, var(--headline-lg));
  font-weight: 600;
  line-height: 1.15;
  margin: var(--space-md) 0;
}
.post-hero__standfirst { font-size: var(--body-lg); line-height: 1.6; color: var(--on-surface-variant); max-width: 60ch; }

.author-card {
  display: flex; align-items: center; gap: var(--space-md);
  padding: var(--space-md);
}
.author-card__avatar {
  width: 56px; height: 56px; border-radius: 50%; overflow: hidden; flex: 0 0 56px;
  border: 1px solid var(--outline); background: var(--surface-container);
}
.author-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.author-card__placeholder {
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--primary-container), var(--inverse-primary));
  color: var(--on-primary); font-family: var(--font-display); font-weight: 600;
}

/* The reading canvas — warm off-white per DESIGN.md "Paper" */
.article-canvas { background: var(--paper); color: var(--paper-ink); }
.article-canvas a { color: var(--inverse-primary); text-decoration: underline; text-decoration-color: rgba(115,92,0,0.4); }
.article-canvas a:hover { text-decoration-color: var(--inverse-primary); }

.post-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  padding-block: var(--space-xl);
  align-items: start;
}

.post-body {
  font-family: var(--font-body);
  font-size: var(--body-lg);
  line-height: 1.7;
  color: var(--paper-ink);
}
.post-body > * + * { margin-top: var(--space-lg); }
.post-body h2, .post-body h3, .post-body h4 {
  font-family: var(--font-display);
  color: var(--void);
  line-height: 1.25;
  margin-top: var(--space-xl);
  scroll-margin-top: 90px;
}
.post-body h2 { font-size: 28px; font-weight: 600; }
.post-body h3 { font-size: 22px; font-weight: 600; }
.post-body p { margin: 0; }
.post-body a { font-weight: 500; }
.post-body img { border-radius: var(--radius); margin-inline: auto; }
.post-body figure { margin: var(--space-xl) 0; }
.post-body figcaption { font-family: var(--font-mono); font-size: var(--data-sm); color: var(--paper-ink-soft); font-style: italic; margin-top: var(--space-sm); text-align: center; }
.post-body blockquote {
  border-left: 4px solid var(--primary-container);
  background: rgba(242,202,80,0.08);
  margin: var(--space-xl) 0;
  padding: var(--space-md) var(--space-lg);
  font-family: var(--font-display);
  font-size: var(--headline-md);
  font-style: italic;
  color: var(--void);
}
.post-body ul, .post-body ol { padding-left: 1.4em; }
.post-body li + li { margin-top: var(--space-sm); }
.post-body hr { border: 0; border-top: 1px solid var(--paper-hair); margin: var(--space-xl) 0; }
.post-body code {
  font-family: var(--font-mono); font-size: 0.9em;
  background: rgba(0,0,0,0.06); padding: 2px 5px; border-radius: var(--radius-sm);
}
.post-body pre {
  background: var(--void); color: var(--on-surface);
  padding: var(--space-lg); border-radius: var(--radius); overflow-x: auto;
}
.post-body pre code { background: transparent; padding: 0; }
.post-body table { width: 100%; border-collapse: collapse; font-size: var(--body-md); }
.post-body th, .post-body td { padding: var(--space-sm) var(--space-md); border: 1px solid var(--paper-hair); text-align: left; }
.post-body th { background: rgba(0,0,0,0.04); font-family: var(--font-body); font-weight: 700; }
.post-body .kg-bookmark-card { border: 1px solid var(--paper-hair); border-radius: var(--radius); overflow: hidden; }

/* Article figure on canvas */
.canvas-figure figcaption { color: var(--paper-ink-soft); text-align: left; }

/* On-canvas key-takeaways / trust variants */
.article-canvas .takeaways { background: rgba(115,92,0,0.06); border-left-color: var(--primary-container); }
.article-canvas .takeaways h3 { color: var(--void); }
.article-canvas .takeaways li .ico { color: var(--inverse-primary); }
.article-canvas details.trust-box { background: #fff; border-color: var(--paper-hair); }
.article-canvas details.trust-box .trust-box__body { color: var(--paper-ink-soft); }
.article-canvas .nfa-note { background: #fff; border-color: var(--paper-hair); color: var(--paper-ink-soft); }
.article-canvas .disclosure { background: #fff; border-color: var(--paper-hair); }
.article-canvas .disclosure__body { color: var(--paper-ink-soft); }
.article-canvas .disclosure__body strong { color: var(--void); }

/* Sidebar TOC */
.toc-card {
  position: sticky; top: 90px;
  background: rgba(255,255,255,0.6);
  border: 1px solid var(--paper-hair);
  padding: var(--space-md);
  border-radius: var(--radius);
  backdrop-filter: blur(4px);
}
.toc-card h4 { margin: 0 0 var(--space-md); padding-bottom: var(--space-xs); border-bottom: 1px solid var(--paper-hair); color: var(--paper-ink-soft); }
.toc-card ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.toc-card a { color: var(--paper-ink); display: block; font-size: var(--body-md); text-decoration: none; }
.toc-card a:hover, .toc-card a.active { color: var(--inverse-primary); }

/* Pro promo (dark island inside canvas) */
.pro-island {
  background: var(--background); color: var(--on-surface);
  border: 1px solid var(--outline); padding: var(--space-md);
  border-radius: var(--radius);
}
.pro-island h4 { color: var(--primary); margin: 0 0 var(--space-sm); }

/* Sources block */
.sources { border: 1px solid var(--paper-hair); border-radius: var(--radius); padding: var(--space-lg); background: #fff; }
.sources h3 { margin: 0 0 var(--space-md); color: var(--void); }
.sources ol { margin: 0; padding-left: 1.4em; }
.sources li { margin-bottom: var(--space-sm); font-size: var(--body-md); }

/* Inline valuation widget (on canvas) */
.val-widget {
  display: flex; flex-wrap: wrap; gap: var(--space-lg);
  align-items: center; justify-content: space-between;
  background: var(--surface-container-low); color: var(--on-surface);
  border: 1px solid rgba(242,202,80,0.2);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}
.val-widget__thumb { width: 64px; height: 90px; flex: 0 0 64px; overflow: hidden; border: 1px solid var(--outline-variant); border-radius: var(--radius-sm); }
.val-widget__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* Correction banner */
.correction-banner {
  display: flex; gap: var(--space-md); align-items: flex-start;
  padding: var(--space-md) var(--space-lg);
  background: rgba(147,0,10,0.1);
  border: 1px solid rgba(255,180,171,0.3);
  border-radius: var(--radius);
}
.correction-banner .ico { color: var(--error); flex: 0 0 auto; }

/* Author bio card on canvas */
.bio-card {
  display: flex; gap: var(--space-lg); flex-wrap: wrap;
  background: #fff; border: 1px solid var(--paper-hair);
  border-radius: var(--radius-lg); padding: var(--space-lg);
}
.bio-card__avatar { width: 88px; height: 88px; flex: 0 0 88px; overflow: hidden; border-radius: var(--radius); }
.bio-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.bio-card h3 { margin: 0; color: var(--void); }
.bio-card .bio-meta a { color: var(--inverse-primary); font-family: var(--font-mono); font-size: var(--data-sm); }

/* Mobile floating TOC */
.mobile-toc { position: fixed; bottom: var(--gutter); right: var(--gutter); z-index: 60; }
.mobile-toc__trigger {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--primary); color: var(--on-primary);
  border: 0; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
.mobile-toc__menu {
  position: absolute; bottom: 68px; right: 0; width: 260px;
  background: var(--glass-bg); backdrop-filter: blur(var(--blur));
  border: 1px solid var(--glass-border);
  padding: var(--space-md); border-radius: var(--radius-lg);
}
.mobile-toc__menu[hidden] { display: none; }
.mobile-toc__menu h4 { color: var(--primary); margin: 0 0 var(--space-sm); }
.mobile-toc__menu ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.mobile-toc__menu a { color: var(--on-surface); }

/* Legal / trust page nav links */
.legal-nav-link {
  display: block;
  padding: var(--space-sm) var(--space-md);
  font-family: var(--font-body);
  font-size: var(--label-caps);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  border-left: 2px solid transparent;
}
.legal-nav-link:hover { color: var(--primary); border-left-color: var(--outline-variant); }
.legal-nav-link[aria-current="page"] { color: var(--primary); border-left-color: var(--primary); background: rgba(242,202,80,0.05); }

/* Dark-context body copy: legal/trust pages render on the dark background,
   so re-skin the shared .post-body prose for legibility on dark. */
.post-body--dark { color: var(--on-surface); }
.post-body--dark h2, .post-body--dark h3, .post-body--dark h4 { color: var(--primary); }
.post-body--dark a { color: var(--accent); text-decoration: underline; text-decoration-color: rgba(242,202,80,0.4); }
.post-body--dark a:hover { text-decoration-color: var(--primary); }
.post-body--dark blockquote {
  border-left-color: var(--primary);
  background: rgba(242,202,80,0.06);
  color: var(--on-surface);
}
.post-body--dark figcaption { color: var(--on-surface-variant); }
.post-body--dark hr { border-top-color: var(--outline-variant); }
.post-body--dark th { background: var(--surface-container-high); border-color: var(--outline-variant); }
.post-body--dark td { border-color: var(--outline-variant); }
.post-body--dark code { background: var(--surface-container-high); }

/* -------------------------------------------------------------------------
   17b. KOENIG EDITOR CARDS (required by Ghost / gscan)
   Styles for content produced by Ghost's editor: wide/full images, galleries,
   bookmark cards, callouts, buttons, headers, embeds, products, toggles,
   captions. Tuned for the warm article canvas and re-skinned for dark.
   ------------------------------------------------------------------------- */
.kg-width-wide   { width: 100%; }
.kg-width-full   { width: 100%; }
@media (min-width: 1024px) {
  .post-body .kg-width-wide { width: min(120%, 920px); margin-inline: auto; transform: translateX(0); }
  .post-body .kg-width-full { width: 100vw; max-width: 100vw; margin-left: 50%; transform: translateX(-50%); }
}
.kg-image { display: block; margin-inline: auto; max-width: 100%; height: auto; border-radius: var(--radius); }
.kg-image-card figcaption,
.kg-embed-card figcaption,
.kg-gallery-card figcaption { font-family: var(--font-mono); font-size: var(--data-sm); text-align: center; margin-top: var(--space-sm); }

.kg-gallery-container { display: flex; flex-direction: column; gap: 8px; max-width: 1040px; margin-inline: auto; }
.kg-gallery-row { display: flex; gap: 8px; }
.kg-gallery-image img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Bookmark card */
.kg-bookmark-card,
.kg-bookmark-card * { box-sizing: border-box; }
.kg-bookmark-card { width: 100%; margin: var(--space-lg) 0; }
.kg-bookmark-container {
  display: flex;
  min-height: 148px;
  color: inherit;
  text-decoration: none;
  border: 1px solid var(--paper-hair);
  border-radius: var(--radius);
  overflow: hidden;
  background: #fff;
}
.kg-bookmark-content { flex: 1 1 0; display: flex; flex-direction: column; justify-content: flex-start; padding: 20px; overflow: hidden; }
.kg-bookmark-title { font-family: var(--font-body); font-weight: 700; color: var(--void); }
.kg-bookmark-description {
  font-size: var(--data-sm); color: var(--paper-ink-soft); margin-top: 8px;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.kg-bookmark-metadata { display: flex; align-items: center; margin-top: 14px; font-size: var(--data-sm); color: var(--void); font-weight: 500; flex-wrap: wrap; }
.kg-bookmark-icon { width: 20px; height: 20px; margin-right: 8px; }
.kg-bookmark-author::after { content: "•"; margin: 0 6px; }
.kg-bookmark-publisher { overflow: hidden; max-width: 240px; white-space: nowrap; text-overflow: ellipsis; }
.kg-bookmark-thumbnail { position: relative; flex: 0 0 33%; min-width: 33%; }
.kg-bookmark-thumbnail img { width: 100%; height: 100%; object-fit: cover; }
/* Dark-context bookmark (legal pages) */
.post-body--dark .kg-bookmark-container { background: var(--surface-container); border-color: var(--outline-variant); }
.post-body--dark .kg-bookmark-title { color: var(--on-surface); }
.post-body--dark .kg-bookmark-description,
.post-body--dark .kg-bookmark-metadata { color: var(--on-surface-variant); }

/* Callout card */
.kg-callout-card { display: flex; padding: var(--space-md) var(--space-lg); border-radius: var(--radius); margin: var(--space-lg) 0; }
.kg-callout-card-grey { background: rgba(0,0,0,0.05); }
.kg-callout-card-white { background: #fff; border: 1px solid var(--paper-hair); }
.kg-callout-card-blue { background: rgba(195,192,255,0.12); }
.kg-callout-card-green { background: rgba(88,231,170,0.12); }
.kg-callout-card-yellow { background: rgba(242,202,80,0.12); }
.kg-callout-card-red { background: rgba(255,180,171,0.14); }
.kg-callout-card-pink { background: rgba(242,202,80,0.1); }
.kg-callout-card-purple { background: rgba(195,192,255,0.14); }
.kg-callout-card-accent { background: rgba(242,202,80,0.12); }
.kg-callout-emoji { padding-right: var(--space-md); font-size: 20px; line-height: 1.4; }
.kg-callout-text { font-size: var(--body-md); line-height: 1.5; }

/* Button card */
.kg-button-card { display: flex; }
.kg-button-card.kg-align-center { justify-content: center; }
.kg-btn {
  display: inline-flex; align-items: center; padding: 0 var(--space-lg); height: 44px;
  font-family: var(--font-body); font-weight: 700; font-size: var(--body-md);
  border-radius: var(--radius-sm); text-decoration: none;
}
.kg-btn-accent { background: var(--primary); color: var(--on-primary); }

/* Header card */
.kg-header-card { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--space-2xl) var(--space-lg); text-align: center; }
.kg-header-card h2.kg-header-card-header { font-family: var(--font-display); }

/* Embeds, audio, video, file, product, toggle */
.kg-embed-card { display: flex; flex-direction: column; align-items: center; width: 100%; margin: var(--space-lg) 0; }
.kg-card.kg-audio-card,
.kg-card.kg-video-card,
.kg-card.kg-file-card { margin: var(--space-lg) 0; }
.kg-file-card-container {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-md);
  border: 1px solid var(--paper-hair); border-radius: var(--radius); padding: var(--space-md) var(--space-lg);
}
.kg-product-card .kg-product-card-container {
  border: 1px solid var(--paper-hair); border-radius: var(--radius); padding: var(--space-lg);
}
.kg-toggle-card { border: 1px solid var(--paper-hair); border-radius: var(--radius); padding: var(--space-md) var(--space-lg); margin: var(--space-md) 0; }
.kg-toggle-heading { display: flex; justify-content: space-between; align-items: center; cursor: pointer; }

/* Signup / nft / blockquote alt */
.kg-signup-card { border-radius: var(--radius-lg); margin: var(--space-lg) 0; }
.kg-blockquote-alt { font-style: italic; }

/* -------------------------------------------------------------------------
   18. AUTHOR / EXPERTISE page (E-E-A-T)
   ------------------------------------------------------------------------- */
.author-hero {
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  margin-bottom: var(--space-xl);
}
.author-hero__avatar {
  width: 120px; height: 120px; flex: 0 0 120px;
  border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--outline);
}
.author-hero__avatar img { width: 100%; height: 100%; object-fit: cover; }
.expertise-list { display: flex; flex-wrap: wrap; gap: var(--space-sm); }

/* -------------------------------------------------------------------------
   19. SECTION HEADINGS
   ------------------------------------------------------------------------- */
.section-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: var(--space-md); flex-wrap: wrap;
  margin-bottom: var(--space-xl);
}
.section-head h2 {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, var(--headline-lg));
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0;
  line-height: 1.1;
}
.section-head p { color: var(--on-surface-variant); margin: var(--space-sm) 0 0; }
.filter-row { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.filter-btn {
  font-family: var(--font-body);
  font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: var(--space-xs) var(--space-md);
  background: var(--surface-container-low);
  border: 1px solid var(--outline-variant);
  color: var(--on-surface-variant);
  border-radius: var(--radius-sm);
  min-height: 36px;
}
.filter-btn:hover, .filter-btn.active { border-color: var(--primary); color: var(--primary); background: var(--surface-container-high); }

/* Breadcrumbs */
.breadcrumbs {
  font-family: var(--font-mono); font-size: 10px;
  color: var(--outline);
  padding-block: var(--space-md);
  border-bottom: 1px solid var(--outline-variant);
}
.breadcrumbs a { color: var(--on-surface-variant); }
.breadcrumbs a:hover { color: var(--primary); }
.breadcrumbs .sep { color: var(--outline-variant); margin-inline: 6px; }
.breadcrumbs .current { color: var(--on-surface); }

/* Pagination */
.pagination { display: flex; justify-content: center; align-items: center; gap: var(--space-md); padding-block: var(--space-xl); }
.pagination a, .pagination .page-number {
  font-family: var(--font-mono); font-size: var(--data-sm);
  color: var(--on-surface-variant);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  min-height: 44px; display: inline-flex; align-items: center;
}
.pagination a:hover { border-color: var(--primary); color: var(--primary); }

/* -------------------------------------------------------------------------
   20. SEARCH MODAL
   ------------------------------------------------------------------------- */
.search-modal {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(13,13,13,0.85);
  backdrop-filter: blur(6px);
  display: none;
  padding-top: 12vh;
}
.search-modal.open { display: block; }
.search-modal__inner { max-width: 720px; margin-inline: auto; padding-inline: var(--gutter); }
.search-modal input {
  width: 100%;
  background: var(--surface-container-high);
  border: 2px solid var(--outline-variant);
  color: var(--on-surface);
  font-family: var(--font-display);
  font-size: var(--headline-md);
  padding: var(--space-lg);
  outline: none;
}
.search-modal input:focus { border-color: var(--primary); }
.search-modal__hint { color: var(--outline); font-family: var(--font-mono); font-size: var(--data-sm); margin-top: var(--space-md); text-align: center; }
.search-modal__close { position: absolute; top: var(--space-lg); right: var(--space-lg); }

/* -------------------------------------------------------------------------
   21. MEMBERSHIP / pricing tiers
   ------------------------------------------------------------------------- */
.tier-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
.tier {
  background: var(--surface-container); border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg); padding: var(--space-xl);
  display: flex; flex-direction: column; gap: var(--space-md);
}
.tier.featured { border-color: var(--primary); position: relative; }
.tier.featured::before {
  content: "Most popular"; position: absolute; top: -11px; left: var(--space-xl);
  background: var(--primary); color: var(--on-primary);
  font-family: var(--font-body); font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 3px 10px; border-radius: var(--radius-full);
}
.tier__price { font-family: var(--font-mono); font-size: var(--display-lg); font-weight: 500; color: var(--primary); line-height: 1; }
.tier ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.tier li { display: flex; gap: var(--space-sm); align-items: flex-start; font-size: var(--body-md); }
.tier li .ico { color: var(--primary); flex: 0 0 auto; margin-top: 2px; }

/* -------------------------------------------------------------------------
   22. MARKET INDEX surfaces (bento)
   ------------------------------------------------------------------------- */
.index-card {
  background: var(--glass-bg-soft);
  backdrop-filter: blur(var(--blur));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  position: relative; overflow: hidden;
}
.index-card.featured { border-color: rgba(242,202,80,0.2); }
.confidence-bars { display: inline-flex; gap: 3px; }
.confidence-bars span { width: 4px; height: 16px; background: var(--outline-variant); }
.confidence-bars span.on { background: var(--primary); }

/* Pricing matrix */
.matrix-row { display: flex; justify-content: space-between; align-items: center; padding-bottom: var(--space-sm); border-bottom: 1px solid var(--outline-variant); }
.matrix-row.highlight { color: var(--primary); font-weight: 700; }
.meter { width: 100%; height: 4px; background: var(--surface-container); border-radius: var(--radius-full); overflow: hidden; }
.meter__fill { height: 100%; background: var(--tertiary); }
.meter__fill.gold { background: var(--primary); }

/* -------------------------------------------------------------------------
   23. UTILITY ICONS
   ------------------------------------------------------------------------- */
.ico { width: 18px; height: 18px; flex: 0 0 auto; stroke-width: 1.5; }
.ico-sm { width: 14px; height: 14px; }
.ico-lg { width: 28px; height: 28px; }

.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }
.mb-0 { margin-bottom: 0; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.hidden { display: none; }

/* -------------------------------------------------------------------------
   24. RESPONSIVE
   ------------------------------------------------------------------------- */
@media (min-width: 640px) {
  .tier-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 768px) {
  .footer-grid { grid-template-columns: repeat(4, 1fr); }
  .footer-brand { grid-column: span 4; }
  .pulse-strip__inner { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1024px) {
  .primary-nav { display: flex; }
  .header-search { display: block; }
  .mobile-only { display: none; }
  .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1fr; }
  .footer-brand { grid-column: span 2; }
  .tier-grid { grid-template-columns: repeat(3, 1fr); }

  /* Article 3-col: TOC | content | promo */
  .post-layout.has-rails { grid-template-columns: 3fr 6fr 3fr; }
  .post-layout.has-toc   { grid-template-columns: 1fr 3fr; }

  /* Hide the floating mobile TOC on desktop (rails carry the TOC there) */
  .desktop-hide { display: none !important; }
}

/* Collapse 12-col grid helpers below desktop */
@media (max-width: 1023px) {
  .grid-12 { grid-template-columns: 1fr; gap: var(--space-lg); }
  .col-span-3, .col-span-4, .col-span-5, .col-span-6,
  .col-span-7, .col-span-8, .col-span-9 { grid-column: span 1; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .lg-hide { display: none; }
}
@media (max-width: 767px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .pulse-strip__inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .terminal-search input { font-size: var(--body-lg); padding: var(--space-md) 56px; }
  .data-table { font-size: 11px; }
  .data-table thead th, .data-table tbody td { padding: var(--space-sm); }
  .md-hide { display: none; }
}

/* Print */
@media print {
  .site-header, .site-footer, .mobile-toc, .newsletter, .ad-slot,
  .pro-island, .search-modal, .secondary-nav { display: none !important; }
  body { background: #fff; color: #000; }
  .article-canvas { background: #fff; }
}
