:root {
      --paper: #faf9f6;
      --paper-dim: #f5f3ee;
      --paper-sink: #f0ede5;
      --ink: #18181b;
      --ink-soft: #3f3f46;
      --ink-muted: #71717a;
      --ink-faint: #a1a1aa;
      --rule: #e4e4e7;
      --rule-soft: #eceae3;
      --accent: #c2410c;
      --accent-light: #ea580c;
      --accent-wash: #fef3ec;
      --alert: #9a3412;
      --alert-wash: #fef2f2;
      --positive: #15803d;
      --positive-wash: #f0fdf4;
      --serif: 'Newsreader', Georgia, 'Times New Roman', serif;
      --sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
      --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    }
    * { margin: 0; padding: 0; box-sizing: border-box; }
    html { font-size: 16px; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
    body {
      background: var(--paper);
      color: var(--ink);
      font-family: var(--sans);
      line-height: 1.6;
      font-weight: 500;
      -webkit-font-smoothing: antialiased;
      overflow-x: hidden;
    }
    .container {
      max-width: 680px;
      margin: 0 auto;
      padding: 0 1.25rem 6rem;
    }

    /* Topbar */
    .topbar {
      position: sticky; top: 0; z-index: 10;
      background: rgba(250, 249, 246, 0.94);
      backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
      border-bottom: 1px solid var(--rule);
      padding: 0.9rem 1.25rem;
      display: flex; align-items: center; justify-content: space-between;
    }
    .topbar-left { display: flex; align-items: center; gap: 0.75rem; }
    .topbar-brand {
      font-family: var(--serif); font-weight: 600;
      font-size: 1.0625rem; letter-spacing: -0.02em;
      color: var(--ink); text-decoration: none;
      font-variation-settings: "opsz" 32;
    }
    .topbar-sep {
      color: var(--ink-faint);
      font-family: var(--serif); font-weight: 500;
      font-size: 1rem;
    }
    .topbar-section {
      font-family: var(--sans); font-size: 0.6875rem;
      color: var(--ink-muted); font-weight: 500;
      text-transform: uppercase; letter-spacing: 0.1em;
    }
    .topbar-status {
      display: inline-flex; align-items: center; gap: 0.4rem;
      font-size: 0.6875rem; color: var(--ink-muted);
      text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500;
    }
    .live-dot {
      width: 7px; height: 7px; background: var(--positive);
      border-radius: 50%;
      animation: pulse 2.4s ease-in-out infinite;
    }
    @keyframes pulse {
      0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(21, 128, 61, 0.35); }
      50% { opacity: 0.75; box-shadow: 0 0 0 6px rgba(21, 128, 61, 0); }
    }

    /* Article header */
    .article-header { padding: 3rem 0 2rem; }
    .kicker {
      font-family: var(--sans);
      font-size: 0.6875rem; font-weight: 600;
      color: var(--accent);
      text-transform: uppercase; letter-spacing: 0.14em;
      margin-bottom: 1.125rem;
    }
    .article-title {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 2rem; font-weight: 500;
      line-height: 1.12; letter-spacing: -0.025em;
      color: var(--ink);
      margin-bottom: 1.5rem;
      max-width: 28ch;
    }
    .byline {
      display: flex; flex-wrap: wrap; gap: 0.5rem 1rem;
      font-family: var(--sans);
      font-size: 0.75rem;
      color: var(--ink-muted);
      align-items: center;
      padding-top: 1.25rem;
      border-top: 1px solid var(--rule);
    }
    .byline strong { color: var(--ink); font-weight: 500; }
    .byline-dot {
      width: 3px; height: 3px; border-radius: 50%;
      background: var(--ink-faint);
      display: inline-block;
    }

    /* Lede with drop cap */
    .lede {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1.375rem; font-weight: 500;
      line-height: 1.4; letter-spacing: -0.015em;
      color: var(--ink-soft);
      margin: 2rem 0 2.5rem;
      max-width: 34ch;
    }
    .lede strong { color: var(--ink); font-weight: 600; }

    /* Hero signal card — from v1, adapted to cream palette */
    .hero-signal {
      background: var(--paper-dim);
      border: 1px solid var(--rule);
      border-radius: 6px;
      overflow: hidden;
      margin-bottom: 2.5rem;
    }
    .hero-top {
      padding: 1.25rem 1.25rem 1.125rem;
      border-bottom: 1px solid var(--rule-soft);
    }
    .hero-price-row {
      display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem;
    }
    .price-cell {
      display: flex; flex-direction: column; gap: 0.3rem;
    }
    .price-cell:first-child {
      padding-right: 1rem;
      border-right: 1px solid var(--rule);
    }
    .price-cell:last-child { padding-left: 1rem; }
    .price-label {
      font-family: var(--sans);
      font-size: 0.625rem; font-weight: 600;
      color: var(--ink-muted);
      text-transform: uppercase; letter-spacing: 0.08em;
    }
    .price-value {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 2.25rem; font-weight: 500;
      letter-spacing: -0.04em;
      font-variant-numeric: tabular-nums;
      line-height: 1;
      color: var(--ink);
    }
    .price-value.estimate { color: var(--accent); }
    .delta {
      font-family: var(--mono);
      font-size: 0.75rem;
      color: var(--ink-muted);
      font-variant-numeric: tabular-nums;
      margin-top: 0.25rem;
    }
    .delta.negative { color: var(--alert); }
    .delta.positive { color: var(--positive); }

    .hero-action {
      display: flex; align-items: center; justify-content: space-between;
      padding: 1rem 1.25rem;
      background: var(--accent-wash);
      border-bottom: 1px solid var(--rule-soft);
      gap: 1rem;
    }
    .action-left { display: flex; align-items: center; gap: 0.875rem; }
    .signal-badge {
      background: var(--ink); color: var(--paper);
      font-family: var(--sans);
      font-size: 0.6875rem; font-weight: 700;
      padding: 0.45rem 0.75rem; border-radius: 3px;
      letter-spacing: 0.04em; text-transform: uppercase;
    }
    .signal-caption {
      font-family: var(--serif);
      font-style: italic;
      font-size: 0.9375rem;
      color: var(--ink-soft);
      line-height: 1.3;
    }
    .signal-caption strong {
      font-style: normal; font-weight: 600; color: var(--ink);
    }
    .conviction {
      text-align: right;
    }
    .conviction-value {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1rem; font-weight: 600;
      color: var(--ink); letter-spacing: 0.02em;
    }
    .conviction-label {
      font-family: var(--sans);
      font-size: 0.5625rem; color: var(--ink-muted);
      text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600;
    }

    .hero-levels {
      display: grid; grid-template-columns: repeat(4, 1fr);
      padding: 1rem 1.25rem;
    }
    .level-cell {
      display: flex; flex-direction: column; gap: 0.2rem;
    }
    .level-cell:not(:first-child) {
      border-left: 1px solid var(--rule);
      padding-left: 0.875rem;
    }
    .level-cell:not(:last-child) { padding-right: 0.875rem; }
    .level-label {
      font-family: var(--sans);
      font-size: 0.5625rem; color: var(--ink-faint);
      text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600;
    }
    .level-value {
      font-family: var(--mono);
      font-size: 0.9375rem; font-weight: 600;
      font-variant-numeric: tabular-nums;
      color: var(--ink-muted);
    }

    /* Event chips — from v1 */
    .event-chips {
      display: flex; gap: 0.4rem;
      padding: 0.625rem 1.25rem 0;
      overflow-x: auto; -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
    }
    .event-chips::-webkit-scrollbar { display: none; }
    .event-chip {
      flex: 0 0 auto;
      font-size: 0.6875rem; font-family: var(--mono);
      color: var(--ink-soft);
      background: var(--paper);
      border: 1px solid var(--rule);
      padding: 0.35rem 0.65rem;
      border-radius: 2px;
      text-decoration: none;
      white-space: nowrap;
      display: inline-flex; align-items: center; gap: 0.4rem;
      transition: all 0.15s;
    }
    .event-chip:hover { border-color: var(--ink); color: var(--ink); }
    .chip-dot { width: 6px; height: 6px; border-radius: 50%; }

    /* Signal timeline — from v1, relabeled */
    .timeline {
      display: flex; align-items: flex-start;
      padding-bottom: 0.5rem;
      overflow-x: auto; -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
    }
    .timeline::-webkit-scrollbar { display: none; }
    .timeline-event {
      flex: 0 0 auto;
      display: flex; flex-direction: column;
      align-items: center; min-width: 88px;
      position: relative;
    }
    .timeline-event:not(:last-child)::after {
      content: '';
      position: absolute;
      top: 8px; left: 56%; width: 88%; height: 1px;
      background: var(--rule);
      z-index: 0;
    }
    .timeline-dot {
      width: 14px; height: 14px;
      border-radius: 50%;
      border: 3px solid var(--paper);
      box-shadow: 0 0 0 1px var(--rule);
      z-index: 1;
      margin-bottom: 0.5rem;
    }
    .timeline-dot.pos { background: var(--positive); box-shadow: 0 0 0 1px var(--positive); }
    .timeline-dot.neu { background: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
    .timeline-dot.neg { background: var(--alert); box-shadow: 0 0 0 1px var(--alert); }
    .timeline-date {
      font-size: 0.625rem; font-family: var(--mono);
      color: var(--ink-muted); margin-bottom: 0.15rem;
      font-variant-numeric: tabular-nums;
    }
    .timeline-label {
      font-size: 0.6875rem; font-weight: 600;
      color: var(--ink-soft); text-align: center;
      line-height: 1.3; font-family: var(--sans);
      letter-spacing: 0.02em;
    }

    /* Chart */
    .chart-block { margin-bottom: 3rem; }
    .chart-container {
      background: var(--paper-dim);
      border-top: 1px solid var(--rule);
      border-bottom: 1px solid var(--rule);
      padding: 1.25rem 0.5rem 1rem;
      margin: 0 -1.25rem;
    }
    #chart { width: 100%; height: 360px; }
    .chart-caption {
      font-family: var(--serif);
      font-style: italic;
      font-size: 0.75rem;
      color: var(--ink-muted);
      padding: 0.75rem 1.25rem 0.25rem;
      line-height: 1.5;
    }

    /* Essay body */
    .essay {
      margin-bottom: 3rem;
    }
    .essay > p {
      font-weight: 500 !important;
      color: #262626;
      font-family: var(--sans);
      font-size: 1.0625rem;
      line-height: 1.7;
      color: var(--ink-soft);
      margin-bottom: 1.25rem;
      font-weight: 500;
    }
    
    .essay h2 {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1.375rem;
      font-weight: 500;
      letter-spacing: -0.02em;
      color: var(--ink);
      line-height: 1.25;
      margin-top: 2.5rem;
      margin-bottom: 1rem;
    }
    .essay a {
      color: var(--accent);
      text-decoration: none;
      border-bottom: 1px solid var(--accent-wash);
    }
    .essay a:hover {
      border-bottom-color: var(--accent);
    }
    .essay sup {
      font-size: 0.6875rem;
      color: var(--accent);
      font-weight: 600;
      margin: 0 0.15rem;
    }
    .essay-pull {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1.375rem;
      font-weight: 500;
      font-style: italic;
      line-height: 1.45;
      color: var(--ink);
      padding: 1.75rem 0 1.75rem 1.25rem;
      border-left: 3px solid var(--accent);
      margin: 2.5rem 0;
      letter-spacing: -0.015em;
    }

    /* Section kicker rule */
    .section-rule {
      border: 0;
      border-top: 1px solid var(--rule);
      margin: 2.5rem 0;
    }
    .section-head {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 1.5rem;
      gap: 1rem;
    }
    .section-kicker {
      font-family: var(--sans);
      font-size: 0.625rem;
      font-weight: 600;
      color: var(--ink-muted);
      text-transform: uppercase;
      letter-spacing: 0.14em;
    }
    .section-meta {
      font-family: var(--sans);
      font-size: 0.75rem;
      color: var(--ink-faint);
    }

    /* What we're watching */
    .watching-list {
      display: flex; flex-direction: column;
    }
    .watching-row {
      display: grid;
      grid-template-columns: 72px 1fr auto;
      gap: 1rem;
      align-items: baseline;
      padding: 0.875rem 0;
      border-bottom: 1px solid var(--rule-soft);
    }
    .watching-row:first-child { border-top: 1px solid var(--rule); }
    .watching-date {
      font-family: var(--mono);
      font-size: 0.8125rem;
      color: var(--ink-muted);
      font-variant-numeric: tabular-nums;
    }
    .watching-title {
      font-family: var(--serif);
      font-size: 0.9375rem;
      color: var(--ink-soft);
      line-height: 1.4;
    }
    .watching-row.critical .watching-date {
      color: var(--accent);
      font-weight: 600;
    }
    .watching-row.critical .watching-title {
      color: var(--ink);
    }
    .watching-distance {
      font-family: var(--mono);
      font-size: 0.6875rem;
      color: var(--ink-faint);
    }

    /* Inverse thesis */
    .inverse-block {
      padding: 1.5rem 0 1.5rem 1.25rem;
      border-left: 2px solid var(--alert);
      margin: 0;
    }
    .inverse-title {
      font-family: var(--sans);
      font-size: 0.625rem;
      font-weight: 600;
      color: var(--alert);
      text-transform: uppercase;
      letter-spacing: 0.14em;
      margin-bottom: 1rem;
    }
    .inverse-item {
      font-family: var(--sans);
      font-size: 1rem;
      font-style: italic;
      color: var(--ink-soft);
      line-height: 1.55;
      margin-bottom: 0.75rem;
    }
    .inverse-item::before {
      content: '—';
      color: var(--alert);
      font-style: normal;
      margin-right: 0.5rem;
      font-weight: 500;
    }
    .inverse-item:last-child { margin-bottom: 0; }

    /* Track record - HERO SECTION */
    .record-hero {
      padding: 2.25rem 0;
      margin: 0;
    }
    .record-head {
      margin-bottom: 1.75rem;
    }
    .record-kicker {
      font-family: var(--sans);
      font-size: 0.625rem;
      font-weight: 600;
      color: var(--accent);
      text-transform: uppercase;
      letter-spacing: 0.14em;
      margin-bottom: 0.625rem;
    }
    .record-title {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1.75rem;
      font-weight: 500;
      letter-spacing: -0.025em;
      line-height: 1.2;
      color: var(--ink);
      margin-bottom: 0.75rem;
      max-width: 26ch;
    }
    .record-subtitle {
      font-family: var(--sans);
      font-style: italic;
      font-size: 0.9375rem;
      color: var(--ink-muted);
      line-height: 1.55;
      max-width: 42ch;
    }
    .record-headline-stats {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 0;
      padding: 1.5rem 0;
      border-top: 1px solid var(--ink);
      border-bottom: 1px solid var(--rule);
      margin-bottom: 2rem;
    }
    .record-stat {
      padding-right: 1rem;
      border-right: 1px solid var(--rule);
    }
    .record-stat:not(:first-child) { padding-left: 1rem; }
    .record-stat:last-child { border-right: 0; padding-right: 0; }
    .record-stat-value {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 2.25rem;
      font-weight: 500;
      font-variant-numeric: tabular-nums;
      letter-spacing: -0.035em;
      line-height: 0.95;
      color: var(--ink);
      margin-bottom: 0.35rem;
    }
    .record-stat-value.positive { color: var(--positive); }
    .record-stat-label {
      font-family: var(--sans);
      font-size: 0.625rem;
      color: var(--ink-muted);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      font-weight: 600;
    }

    /* Ledger grid */
    .ledger-note {
      font-family: var(--sans);
      font-style: italic;
      font-size: 0.8125rem;
      color: var(--ink-muted);
      margin-bottom: 1rem;
      line-height: 1.5;
    }
    .ledger {
      display: flex; flex-direction: column;
    }
    .ledger-row {
      display: grid;
      grid-template-columns: 52px 1fr auto;
      gap: 0.875rem;
      align-items: flex-start;
      padding: 0.875rem 0;
      border-bottom: 1px solid var(--rule-soft);
      text-decoration: none;
      color: inherit;
    }
    .ledger-row:first-child { border-top: 1px solid var(--rule); }
    .ledger-row:hover { background: var(--paper-dim); margin: 0 -0.5rem; padding: 0.875rem 0.5rem; }
    .ledger-date {
      font-family: var(--mono);
      font-size: 0.6875rem;
      color: var(--ink-faint);
      font-variant-numeric: tabular-nums;
      padding-top: 0.15rem;
    }
    .ledger-body {
      min-width: 0;
    }
    .ledger-question {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--ink);
      line-height: 1.35;
      margin-bottom: 0.3rem;
      overflow: hidden;
      text-overflow: ellipsis;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
    }
    .ledger-detail {
      font-family: var(--mono);
      font-size: 0.6875rem;
      color: var(--ink-muted);
      font-variant-numeric: tabular-nums;
      line-height: 1.5;
    }
    .ledger-result {
      text-align: right;
      padding-top: 0.15rem;
    }
    .ledger-roi {
      font-family: var(--mono);
      font-size: 0.875rem;
      font-weight: 600;
      font-variant-numeric: tabular-nums;
      letter-spacing: -0.01em;
    }
    .ledger-roi.win { color: var(--positive); }
    .ledger-roi.loss { color: var(--alert); }
    .ledger-outcome {
      font-family: var(--sans);
      font-size: 0.6rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      font-weight: 600;
      color: var(--ink-faint);
      margin-top: 0.2rem;
    }
    .ledger-footer {
      padding-top: 1rem;
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      font-family: var(--sans);
      font-size: 0.75rem;
      color: var(--ink-muted);
    }
    .ledger-link {
      color: var(--accent);
      text-decoration: none;
      font-weight: 500;
      border-bottom: 1px solid var(--accent-wash);
    }
    .ledger-link:hover { border-bottom-color: var(--accent); }

    /* Sources bibliography */
    .sources-list {
      display: flex; flex-direction: column;
    }
    .source-entry {
      padding: 0.75rem 0;
      border-bottom: 1px solid var(--rule-soft);
      display: flex;
      gap: 0.75rem;
      align-items: baseline;
    }
    .source-entry:first-child { border-top: 1px solid var(--rule); }
    .source-num {
      font-family: var(--mono);
      font-size: 0.6875rem;
      color: var(--accent);
      font-weight: 600;
      min-width: 20px;
    }
    .source-body {
      flex: 1;
      font-family: var(--serif);
      font-size: 0.8125rem;
      color: var(--ink-soft);
      line-height: 1.55;
    }
    .source-body strong {
      color: var(--ink);
      font-weight: 600;
    }
    .source-body a {
      color: var(--ink-muted);
      text-decoration: underline;
      text-underline-offset: 2px;
      text-decoration-color: var(--rule);
    }

    /* Cite this analysis */
    .cite-block {
      background: var(--paper-dim);
      border: 1px solid var(--rule);
      border-radius: 4px;
      padding: 1.75rem 1.5rem;
      margin: 2.5rem 0;
    }
    .cite-kicker {
      font-family: var(--sans);
      font-size: 0.625rem;
      font-weight: 600;
      color: var(--accent);
      text-transform: uppercase;
      letter-spacing: 0.14em;
      margin-bottom: 0.5rem;
    }
    .cite-title {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1.25rem;
      font-weight: 500;
      letter-spacing: -0.02em;
      line-height: 1.25;
      color: var(--ink);
      margin-bottom: 0.625rem;
    }
    .cite-desc {
      font-family: var(--sans);
      font-style: italic;
      font-size: 0.875rem;
      color: var(--ink-muted);
      line-height: 1.55;
      margin-bottom: 1.5rem;
      max-width: 42ch;
    }
    .cite-buttons {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
      margin-bottom: 1.25rem;
    }
    .cite-btn {
      background: var(--paper);
      border: 1px solid var(--rule);
      border-radius: 2px;
      padding: 0.625rem 0.875rem;
      font-family: var(--sans);
      font-size: 0.75rem;
      font-weight: 500;
      color: var(--ink);
      cursor: pointer;
      transition: all 0.15s;
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
    }
    .cite-btn:hover {
      border-color: var(--ink);
      background: var(--paper);
    }
    .cite-btn.copied {
      border-color: var(--positive);
      background: var(--positive-wash);
      color: var(--positive);
    }
    .cite-embed {
      background: var(--paper);
      border: 1px solid var(--rule);
      border-radius: 2px;
      padding: 0.875rem 1rem;
      font-family: var(--mono);
      font-size: 0.6875rem;
      color: var(--ink-muted);
      line-height: 1.5;
      overflow-x: auto;
      white-space: pre;
      margin-top: 0.5rem;
    }
    .cite-embed-label {
      font-family: var(--sans);
      font-size: 0.625rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--ink-faint);
      font-weight: 600;
      margin-bottom: 0.3rem;
    }

    /* Methodology note */
    .method-block {
      padding: 1.5rem 0;
      border-top: 1px solid var(--rule);
      border-bottom: 1px solid var(--rule);
      margin: 2.5rem 0;
    }
    .method-title {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1rem;
      font-weight: 600;
      color: var(--ink);
      margin-bottom: 0.625rem;
      letter-spacing: -0.01em;
    }
    .method-desc {
      font-family: var(--sans);
      font-style: italic;
      font-size: 0.875rem;
      color: var(--ink-muted);
      line-height: 1.6;
      margin-bottom: 0.875rem;
      max-width: 48ch;
    }
    .method-link {
      font-family: var(--sans);
      font-size: 0.75rem;
      color: var(--accent);
      text-decoration: none;
      font-weight: 500;
      border-bottom: 1px solid var(--accent-wash);
      padding-bottom: 1px;
    }
    .method-link:hover { border-bottom-color: var(--accent); }

    /* Related markets */
    .related-scroll {
      display: flex; gap: 1rem;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
      margin: 0 -1.25rem;
      padding: 0 1.25rem 0.5rem;
    }
    .related-scroll::-webkit-scrollbar { display: none; }
    .related-card {
      flex: 0 0 240px;
      background: var(--paper);
      border: 1px solid var(--rule);
      border-radius: 4px;
      padding: 1.125rem;
      text-decoration: none;
      color: var(--ink);
      transition: border-color 0.15s;
    }
    .related-card:hover { border-color: var(--ink); }
    .related-question {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 0.9375rem;
      font-weight: 500;
      line-height: 1.35;
      margin-bottom: 1rem;
      min-height: 2.8rem;
      color: var(--ink);
    }
    .related-bottom {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
    }
    .related-price {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1.125rem;
      font-weight: 500;
      font-variant-numeric: tabular-nums;
      letter-spacing: -0.03em;
      color: var(--ink);
    }
    .related-view {
      font-family: var(--sans);
      font-size: 0.625rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--ink-muted);
    }

    /* Appendix: trading levels (for traders, demoted) */
    .appendix {
      background: var(--paper-dim);
      border-radius: 4px;
      padding: 1.25rem 1.25rem;
      margin: 1.5rem 0;
    }
    .appendix-label {
      font-family: var(--sans);
      font-size: 0.5625rem;
      font-weight: 600;
      color: var(--ink-faint);
      text-transform: uppercase;
      letter-spacing: 0.14em;
      margin-bottom: 0.75rem;
    }
    .appendix-levels {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
    }
    .appendix-level {
      padding-right: 0.75rem;
      border-right: 1px solid var(--rule);
    }
    .appendix-level:not(:first-child) { padding-left: 0.75rem; }
    .appendix-level:last-child { border-right: 0; padding-right: 0; }
    .appendix-label2 {
      font-family: var(--sans);
      font-size: 0.5625rem;
      color: var(--ink-faint);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      font-weight: 600;
      margin-bottom: 0.2rem;
    }
    .appendix-value {
      font-family: var(--mono);
      font-size: 0.875rem;
      font-weight: 600;
      color: var(--ink-muted);
      font-variant-numeric: tabular-nums;
    }

    /* Premium card — custom analysis framing */
    .premium {
      padding: 2rem 0 1.5rem;
      border-top: 1px solid var(--rule);
      margin-top: 2.5rem;
    }
    .premium-kicker {
      font-family: var(--sans);
      font-size: 0.625rem;
      color: var(--accent);
      text-transform: uppercase;
      letter-spacing: 0.14em;
      font-weight: 600;
      margin-bottom: 0.75rem;
    }
    .premium-title {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 1.5rem;
      font-weight: 500;
      letter-spacing: -0.025em;
      line-height: 1.2;
      margin-bottom: 1rem;
      color: var(--ink);
      max-width: 26ch;
    }
    .premium-desc {
      font-family: var(--serif);
      font-size: 0.9375rem;
      color: var(--ink-muted);
      line-height: 1.6;
      margin-bottom: 1.5rem;
      max-width: 46ch;
    }
    .premium-features {
      display: flex; flex-direction: column;
      gap: 0.625rem;
      margin-bottom: 1.75rem;
    }
    .premium-feature {
      font-family: var(--sans);
      font-size: 0.875rem;
      color: var(--ink-soft);
      font-style: italic;
      padding-left: 1rem;
      position: relative;
      line-height: 1.5;
    }
    .premium-feature::before {
      content: '—';
      color: var(--accent);
      position: absolute;
      left: 0;
      font-style: normal;
      font-weight: 500;
    }
    .waitlist-form {
      display: flex; gap: 0.5rem; max-width: 420px;
    }
    .waitlist-input {
      flex: 1; background: var(--paper);
      border: 1px solid var(--rule); border-radius: 2px;
      padding: 0.8rem 0.875rem; font-size: 0.875rem;
      font-family: var(--sans); color: var(--ink);
    }
    .waitlist-input:focus { outline: none; border-color: var(--accent); }
    .waitlist-btn {
      background: var(--ink); color: var(--paper);
      border: 0; border-radius: 2px;
      padding: 0.8rem 1.25rem; font-size: 0.8125rem;
      font-weight: 600; cursor: pointer;
      font-family: var(--sans); white-space: nowrap;
      letter-spacing: 0.02em;
    }
    .waitlist-btn:hover { background: var(--accent); }

    /* Brand footer */
    .brand-footer {
      padding: 4rem 0 2rem;
      margin-top: 3rem;
      border-top: 1px solid var(--rule);
    }
    .brand-wordmark {
      font-family: var(--serif);
      font-variation-settings: "opsz" 32;
      font-size: 5rem;
      font-weight: 500;
      letter-spacing: -0.05em;
      line-height: 0.9;
      color: var(--ink);
      margin-bottom: 1rem;
    }
    .brand-tag {
      font-family: var(--serif);
      font-style: italic;
      font-size: 0.9375rem;
      color: var(--ink-muted);
      max-width: 40ch;
      line-height: 1.5;
      margin-bottom: 1.5rem;
    }
    .brand-meta {
      font-family: var(--sans);
      font-size: 0.6875rem;
      color: var(--ink-faint);
      line-height: 1.6;
    }
    .brand-meta a {
      color: var(--ink-muted);
      text-decoration: underline;
      text-underline-offset: 3px;
      text-decoration-color: var(--rule);
    }

    /* Toast */
    .toast {
      position: fixed;
      bottom: 1.25rem;
      left: 50%;
      transform: translateX(-50%) translateY(120%);
      background: var(--ink);
      color: var(--paper);
      padding: 0.75rem 1.25rem;
      font-family: var(--sans);
      font-size: 0.8125rem;
      font-weight: 500;
      border-radius: 2px;
      z-index: 100;
      transition: transform 0.25s ease-out;
      pointer-events: none;
      max-width: calc(100vw - 2rem);
    }
    .toast.show {
      transform: translateX(-50%) translateY(0);
    }

    @media (min-width: 640px) {
      .container { padding: 0 1.5rem 6rem; max-width: 720px; }
      .article-title { font-size: 2.625rem; }
      .lede { font-size: 1.625rem; }
      #chart { height: 420px; }
      .brand-wordmark { font-size: 7rem; }
      .essay > p {
      font-weight: 500 !important;
      color: #262626; font-size: 1.125rem; }
      .record-title { font-size: 2rem; }
      .record-stat-value { font-size: 2.625rem; }
    }
    @media (max-width: 380px) {
      .brand-wordmark { font-size: 3.75rem; }
      .article-title { font-size: 1.75rem; }
      .lede { font-size: 1.1875rem; }
      .view-value { font-size: 1.25rem; }
      .record-stat-value { font-size: 1.875rem; }
    }

/* Premium paywall */
.premium-toggle { position: fixed; bottom: 1rem; right: 1rem; z-index: 20; background: var(--ink); color: var(--paper); font-family: var(--sans); font-size: 0.6875rem; font-weight: 600; padding: 0.6rem 0.875rem; border-radius: 2px; text-transform: uppercase; letter-spacing: 0.08em; cursor: pointer; border: 0; box-shadow: 0 4px 12px rgba(0,0,0,0.12); }
.premium-toggle:hover { background: var(--accent); }
body.premium .premium-gated { display: block; }
body:not(.premium) .premium-gated { display: none; }
body:not(.premium) .essay > p.essay-preview-end { position: relative; padding-bottom: 3rem; }
body:not(.premium) .essay > p.essay-preview-end::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 120px; background: linear-gradient(180deg, transparent 0%, var(--paper) 90%); pointer-events: none; }
.paywall-gate { padding: 2rem 1.5rem; background: var(--paper-dim); border: 1px solid var(--rule); border-radius: 4px; text-align: center; margin: 1rem 0 2.5rem; }
body.premium .paywall-gate { display: none; }
.paywall-gate .kicker-small { font-family: var(--sans); font-size: 0.625rem; color: var(--accent); text-transform: uppercase; letter-spacing: 0.14em; font-weight: 600; margin-bottom: 0.5rem; }
.paywall-gate h3 { font-family: var(--serif); font-variation-settings: "opsz" 32; font-size: 1.375rem; font-weight: 600; letter-spacing: -0.02em; margin-bottom: 0.75rem; color: var(--ink); line-height: 1.25; }
.paywall-gate p { font-family: var(--serif); font-size: 0.9375rem; font-style: italic; font-weight: 500; color: var(--ink-muted); line-height: 1.55; max-width: 42ch; margin: 0 auto 1.25rem; }
.paywall-gate .paywall-cta { display: inline-flex; gap: 0.75rem; align-items: center; background: var(--ink); color: var(--paper); font-family: var(--sans); font-size: 0.8125rem; font-weight: 600; padding: 0.75rem 1.125rem; border-radius: 2px; text-decoration: none; letter-spacing: 0.02em; border: 0; cursor: pointer; }
.paywall-gate .paywall-cta:hover { background: var(--accent); }
.paywall-gate .paywall-alt { display: block; margin-top: 0.875rem; font-family: var(--sans); font-size: 0.75rem; color: var(--ink-muted); }
.paywall-gate .paywall-alt a { color: var(--ink-soft); text-decoration: underline; text-underline-offset: 2px; cursor: pointer; }

/* ============================================================
   Signal card v2 — dramatic dark hero
   ============================================================ */
.signal-card {
  --bull: #34d399;
  --bull-dim: rgba(52, 211, 153, 0.18);
  --bear: #f87171;
  --bear-dim: rgba(248, 113, 113, 0.18);
  --card-bg: #0e0e10;
  --card-bg-soft: #16161a;
  --card-ink: #f4f4f5;
  --card-ink-soft: #a1a1aa;
  --card-ink-faint: #52525b;
  --card-rule: rgba(255, 255, 255, 0.08);
  --edge-color: var(--card-ink);
  background: var(--card-bg);
  color: var(--card-ink);
  border-radius: 8px;
  overflow: hidden;
  margin: 2.5rem 0 3rem;
  box-shadow: 0 30px 60px -20px rgba(12, 10, 20, 0.35), 0 8px 20px -8px rgba(12, 10, 20, 0.2);
  position: relative;
}
.signal-card.bull { --edge-color: var(--bull); }
.signal-card.bear { --edge-color: var(--bear); }
.signal-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--edge-color);
  opacity: 0.85;
}

.sc-head {
  display: flex; align-items: center; gap: 0.625rem;
  padding: 1rem 1.5rem 0.75rem;
  font-family: var(--sans);
  font-size: 0.625rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--card-ink-soft);
}
.sc-head-label { color: var(--edge-color); }
.sc-head-sep { flex: 1; height: 1px; background: var(--card-rule); }
.sc-head-meta { color: var(--card-ink-faint); font-weight: 500; letter-spacing: 0.08em; }

.sc-stage {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 1.5rem;
  padding: 0.75rem 1.5rem 1.5rem;
  border-bottom: 1px solid var(--card-rule);
}
.sc-edge { display: flex; flex-direction: column; gap: 0.35rem; }
.sc-edge-number {
  font-family: var(--serif);
  font-variation-settings: "opsz" 48;
  font-size: clamp(4.5rem, 12vw, 7rem);
  font-weight: 500;
  line-height: 0.88;
  letter-spacing: -0.055em;
  color: var(--edge-color);
  font-variant-numeric: tabular-nums;
}
.sc-edge-unit {
  font-size: 0.42em; font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--card-ink-soft);
  margin-left: 0.15em;
}
.sc-edge-label {
  font-family: var(--sans);
  font-size: 0.75rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--card-ink-soft);
}

.sc-verdict { display: flex; flex-direction: column; align-items: flex-end; gap: 0.75rem; }
.sc-verdict-pill {
  font-family: var(--sans);
  font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.55rem 0.875rem;
  border-radius: 3px;
  background: var(--edge-color);
  color: var(--card-bg);
  text-transform: uppercase;
}
.signal-card.flat .sc-verdict-pill { background: var(--card-ink); }
.sc-verdict-conviction {
  display: flex; align-items: center; gap: 0.5rem;
  font-family: var(--sans);
  font-size: 0.625rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--card-ink-soft);
}
.sc-dots { display: inline-flex; gap: 3px; }
.sc-dots i {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--card-ink-faint);
  display: block;
}
.sc-dots.c-low i:nth-child(1),
.sc-dots.c-medium i:nth-child(1),
.sc-dots.c-medium i:nth-child(2),
.sc-dots.c-high i { background: var(--edge-color); }

.sc-gauge {
  padding: 1.25rem 1.5rem;
  display: flex; flex-direction: column; gap: 0.75rem;
  border-bottom: 1px solid var(--card-rule);
}
.sc-gauge-row {
  display: grid;
  grid-template-columns: 4.5rem 1fr 3rem;
  align-items: center;
  gap: 0.875rem;
}
.sc-gauge-label {
  font-family: var(--sans);
  font-size: 0.625rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--card-ink-soft);
}
.sc-gauge-track {
  position: relative;
  height: 6px;
  background: var(--card-bg-soft);
  border-radius: 1px;
  overflow: visible;
}
.sc-gauge-fill {
  position: absolute; top: 0; left: 0; bottom: 0;
  border-radius: 1px;
}
.sc-gauge-fill.market { background: var(--card-ink-soft); opacity: 0.55; }
.sc-gauge-fill.ours { background: var(--edge-color); }
.sc-gauge-marker {
  position: absolute; top: -3px; bottom: -3px;
  width: 2px;
  transform: translateX(-1px);
}
.sc-gauge-marker.ours { background: var(--edge-color); }
.sc-gauge-marker.market { background: var(--card-ink); opacity: 0.85; }
.sc-gauge-value {
  font-family: var(--mono);
  font-size: 0.8125rem; font-weight: 500;
  color: var(--card-ink);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.sc-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--card-bg-soft);
}
.sc-stat {
  padding: 0.9rem 1rem;
  display: flex; flex-direction: column; gap: 0.25rem;
  border-right: 1px solid var(--card-rule);
}
.sc-stat:last-child { border-right: 0; }
.sc-stat-label {
  font-family: var(--sans);
  font-size: 0.5625rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--card-ink-faint);
}
.sc-stat-value {
  font-family: var(--mono);
  font-size: 0.9375rem; font-weight: 500;
  color: var(--card-ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.sc-stat-value.accent { color: var(--edge-color); }

@media (max-width: 560px) {
  .sc-stage { grid-template-columns: 1fr; align-items: flex-start; }
  .sc-verdict { align-items: flex-start; }
  .sc-edge-number { font-size: clamp(4rem, 22vw, 5.5rem); }
  .sc-stats { grid-template-columns: repeat(2, 1fr); }
  .sc-stat:nth-child(2) { border-right: 0; }
  .sc-stat:nth-child(1), .sc-stat:nth-child(2) { border-bottom: 1px solid var(--card-rule); }
  .sc-gauge-row { grid-template-columns: 3.5rem 1fr 2.5rem; gap: 0.625rem; }
}

/* ============================================================
   Lacuna's call — minimal verdict card replacing the old hero
   ============================================================ */
.lacuna-call {
  margin: 2rem 0 2.5rem;
  padding: 1.5rem 1.75rem;
  background: var(--paper-dim);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  display: flex;
  align-items: baseline;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.lacuna-call .lc-kicker {
  font-family: var(--sans);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  flex: 0 0 auto;
}
.lacuna-call .lc-verdict {
  font-family: var(--serif);
  font-variation-settings: "opsz" 48;
  font-size: 2.25rem;
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
}
.lacuna-call.verdict-yes .lc-verdict { color: #15803d; }
.lacuna-call.verdict-no  .lc-verdict { color: #b91c1c; }
.lacuna-call .lc-context {
  font-family: var(--sans);
  font-size: 0.875rem;
  color: var(--ink-muted);
  margin-left: auto;
}
.lacuna-call .lc-context strong {
  color: var(--ink);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   Inline source cards — native-styled platform embeds
   ============================================================ */
/* Strip global .essay a styling from inline-card internal links */
.essay .pm-card a,
.essay .x-card a,
.essay .pm-card a:hover,
.essay .x-card a:hover {
  border-bottom: 0 !important;
  background: none !important;
}
.essay .inline-source {
  margin: 1.75rem 0 2rem;
  padding: 0;
}
.essay .inline-source .lacuna-caption {
  font-family: var(--serif) !important;
  font-variation-settings: "opsz" 16;
  font-style: italic;
  font-size: 0.875rem !important;
  line-height: 1.5 !important;
  color: var(--ink-muted) !important;
  font-weight: 500 !important;
  margin: 0.625rem 0 0 0.875rem !important;
  padding: 0 !important;
  max-width: 52ch;
  display: block;
}

/* ── Polymarket-style comment card (light, native) ── */
.essay .pm-card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 1rem 1.125rem;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  transition: border-color 0.15s ease;
}
.essay .pm-card:hover {
  border-color: #d1d5db;
}
.essay .pm-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.625rem;
}
.essay .pm-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  overflow: hidden;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.essay .pm-avatar img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.essay .pm-avatar-fallback {
  color: white;
  font-weight: 700;
  font-size: 0.875rem;
  font-family: inherit;
}
.essay .pm-meta { flex: 1; min-width: 0; }
.essay .pm-name-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.essay .pm-name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: #111827;
  font-family: inherit;
}
.essay .pm-time {
  font-size: 0.8125rem;
  color: #6b7280;
  font-family: inherit;
}
.essay .pm-source-link {
  font-size: 0.6875rem;
  font-weight: 700;
  color: #2563eb !important;
  background: #eff6ff !important;
  padding: 0.2rem 0.5rem;
  border-radius: 99px;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  font-family: inherit;
}
.essay .pm-source-link:hover {
  background: #dbeafe !important;
}
.essay .pm-body {
  font-family: inherit !important;
  font-size: 0.9375rem !important;
  line-height: 1.5 !important;
  color: #1f2937 !important;
  font-weight: 400 !important;
  margin: 0 0 0.625rem !important;
  white-space: pre-wrap;
  word-break: break-word;
}
.essay .pm-foot {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding-top: 0.5rem;
  border-top: 1px solid #f3f4f6;
}
.essay .pm-heart {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: inherit;
  font-size: 0.8125rem;
  color: #6b7280;
}
.essay .pm-heart svg {
  width: 18px; height: 18px;
  fill: currentColor;
}
.essay .pm-heart.filled svg {
  fill: #ef4444;
}
.essay .pm-heart.filled {
  color: #ef4444;
  font-weight: 600;
}

/* ── X-style tweet card (dark, native) ── */
.essay .x-card {
  display: block;
  text-decoration: none;
  color: #e7e9ea;
  background: #16181c;
  border: 1px solid #2f3336;
  border-radius: 16px;
  padding: 0.875rem 1rem 0.625rem;
  font-family: "TwitterChirp", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  transition: background-color 0.15s ease;
}
.essay .x-card:hover {
  background: #1c1f23;
}
.essay .x-head {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  margin-bottom: 0.625rem;
}
.essay .x-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  overflow: hidden;
  background: #2f3336;
  flex-shrink: 0;
}
.essay .x-avatar img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.essay .x-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  flex: 1;
  min-width: 0;
}
.essay .x-name {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #e7e9ea;
  font-family: inherit;
}
.essay .x-handle {
  font-size: 0.875rem;
  color: #71767b;
  font-family: inherit;
}
.essay .x-logo {
  width: 18px; height: 18px;
  fill: #e7e9ea;
  flex-shrink: 0;
}
.essay .x-body {
  font-family: inherit !important;
  font-size: 0.9375rem !important;
  line-height: 1.45 !important;
  color: #e7e9ea !important;
  font-weight: 400 !important;
  margin: 0 0 0.625rem !important;
  word-break: break-word;
}
.essay .x-body a {
  color: #1d9bf0 !important;
  text-decoration: none !important;
  background: none !important;
  border-bottom: 0 !important;
}
.essay .x-body a:hover { text-decoration: underline !important; }
.essay .x-logo-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none !important;
  border-bottom: 0 !important;
  background: none !important;
}
.essay .x-date {
  font-size: 0.8125rem;
  color: #71767b;
  margin-bottom: 0.625rem;
  font-family: inherit;
}
.essay .x-foot {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid #2f3336;
}
.essay .x-action {
  display: inline-flex;
  align-items: center;
  color: #71767b;
  flex: 0 0 auto;
}
.essay .x-action.right {
  margin-left: auto;
}
.essay .x-action svg {
  width: 18px; height: 18px;
  fill: currentColor;
}

/* ============================================================
   Article hero — integrated card (cover left, content right)
   Mirrors v2 lead card layout but applied to individual articles
   ============================================================ */
.article-wide {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem 1.25rem 5rem;
}
.art-body-narrow {
  max-width: 680px;
  margin: 0 auto;
}

.art-hero {
  background: var(--paper-dim);
  border: 1px solid var(--rule);
  border-top: 4px solid var(--ink);
  border-radius: 6px;
  overflow: hidden;
  margin: 1rem 0 1.5rem;
  display: grid;
  grid-template-columns: 1fr;
}
.art-hero--verdict-yes { border-top-color: #15803d; }
.art-hero--verdict-no  { border-top-color: #b91c1c; }
.art-hero--has-cover { grid-template-columns: 1.1fr 1fr; }

.art-hero-cover {
  position: relative;
  background: var(--paper-sink);
  overflow: hidden;
  min-height: 440px;
}
.art-hero-cover img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(0.92) contrast(1.02);
}
.art-hero-credit {
  position: absolute;
  bottom: 0.75rem;
  left: 0.875rem;
  font-family: var(--sans);
  font-size: 0.5625rem;
  color: rgba(255, 255, 255, 0.92);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  background: rgba(0, 0, 0, 0.6);
  padding: 0.25rem 0.55rem;
  border-radius: 2px;
  backdrop-filter: blur(3px);
}

.art-hero-body {
  padding: 2rem 2.5rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
}
.art-hero-meta {
  display: flex;
  gap: 0.625rem;
  align-items: center;
}
.art-hero-cat {
  font-family: var(--sans);
  font-size: 0.625rem;
  font-weight: 700;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
.art-hero-sep {
  width: 3px; height: 3px;
  background: var(--ink-faint);
  border-radius: 50%;
  display: inline-block;
}
.art-hero-sub {
  font-family: var(--sans);
  font-size: 0.625rem;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
}
.art-hero-title {
  font-family: var(--serif);
  font-variation-settings: "opsz" 72;
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 0;
  max-width: 22ch;
}
.art-hero-source {
  display: block;
  font-family: var(--sans);
  font-size: 0.75rem;
  color: var(--ink-muted);
  padding-top: 0.5rem;
  border-top: 1px dashed var(--rule);
  margin-top: -0.25rem;
  text-decoration: none;
  transition: color 0.15s ease;
}
.art-hero-source:hover { color: var(--accent); }
.art-hero-source em {
  font-family: var(--serif);
  font-style: italic;
  color: var(--ink-soft);
  transition: color 0.15s ease;
}
.art-hero-source:hover em { color: var(--accent); }
.art-hero-source-arrow {
  display: inline-block;
  margin-left: 0.125rem;
  color: var(--ink-faint);
  font-size: 0.625rem;
  transition: transform 0.15s ease, color 0.15s ease;
}
.art-hero-source:hover .art-hero-source-arrow {
  color: var(--accent);
  transform: translate(2px, -2px);
}
.art-hero-lede {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.0625rem;
  line-height: 1.45;
  color: var(--ink-soft);
  margin: 0;
  max-width: 54ch;
}
.art-hero-chart { margin: 0.5rem 0 0.75rem; }
.art-hero-foot {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-top: 1rem;
  border-top: 1px solid var(--rule);
}
.art-hero-verdict { display: flex; align-items: baseline; gap: 0.75rem; }
.art-hero-verdict-kicker {
  font-family: var(--sans);
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
.art-hero-verdict-word {
  font-family: var(--serif);
  font-variation-settings: "opsz" 48;
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.art-hero-verdict--verdict-yes .art-hero-verdict-word { color: #15803d; }
.art-hero-verdict--verdict-no  .art-hero-verdict-word { color: #b91c1c; }
.art-hero-price { text-align: right; }
.art-hero-price-val {
  font-family: var(--mono);
  font-size: 1.125rem;
  color: var(--ink);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  display: block;
}
.art-hero-price-lbl {
  font-family: var(--sans);
  font-size: 0.5625rem;
  color: var(--ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 600;
}

/* Byline strip below the hero */
.art-byline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  align-items: center;
  max-width: 680px;
  margin: 0 auto 1.75rem;
  padding-top: 0.75rem;
  font-family: var(--sans);
  font-size: 0.75rem;
  color: var(--ink-muted);
}
.art-byline strong { color: var(--ink); font-weight: 500; }
.art-byline a {
  color: var(--ink-muted);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.art-byline a:hover { color: var(--accent); }

@media (max-width: 900px) {
  .art-hero--has-cover { grid-template-columns: 1fr; }
  .art-hero-cover { min-height: 0; aspect-ratio: 16 / 9; }
  .art-hero-body { padding: 1.5rem 1.5rem; }
  .article-wide { padding: 1.5rem 1rem 4rem; }
}

/* ============================================================
   Article cover image (legacy, kept for backward compat)
   ============================================================ */
.article-source {
  font-family: var(--sans);
  font-size: 0.75rem;
  color: var(--ink-muted);
  margin-top: -0.625rem;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px dashed var(--rule);
}
.article-source em {
  font-family: var(--serif);
  font-style: italic;
  color: var(--ink-soft);
  font-size: 0.8125rem;
}
.article-cover {
  margin: 0 0 2rem;
  padding: 0;
  position: relative;
  overflow: hidden;
  border-radius: 4px;
  background: var(--paper-sink);
  aspect-ratio: 16 / 9;
}
.article-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(0.92) contrast(1.02);
}
.article-cover figcaption {
  position: absolute;
  bottom: 0.75rem;
  left: 0.875rem;
  font-family: var(--sans);
  font-size: 0.5625rem;
  color: rgba(255, 255, 255, 0.92);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  background: rgba(0, 0, 0, 0.6);
  padding: 0.25rem 0.55rem;
  border-radius: 2px;
  backdrop-filter: blur(3px);
}
