/* PairScan design system v1.0 — Bloomberg-inspired, dark-default, info-dense.
   Hand-rolled, no framework. Tokens follow pairscan_playbook v1.7.2 Часть 14.1. */

/* Self-hosted Inter + JetBrains Mono (latin / latin-ext / cyrillic / cyrillic-ext).
   Files in /static/fonts/ are downloaded from Google Fonts CDN, served with
   Cache-Control: immutable for a year. font-display: optional eliminates CLS:
   if the font isn't ready in ~100ms, the system fallback is used permanently
   for that pageview — no swap, no layout shift. The previous Google-Fonts +
   'Inter Fallback' size-adjust trick didn't survive Lighthouse HeadlessChromium
   (local('Arial') often unresolved → fallback descriptors silently dropped). */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/inter-400-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/inter-400-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/inter-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/inter-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:optional;src:url('/static/fonts/inter-600-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:optional;src:url('/static/fonts/inter-600-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:optional;src:url('/static/fonts/inter-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:optional;src:url('/static/fonts/inter-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:optional;src:url('/static/fonts/inter-700-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:optional;src:url('/static/fonts/inter-700-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:optional;src:url('/static/fonts/inter-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:optional;src:url('/static/fonts/inter-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/jetbrains-mono-400-cyrillic-ext.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/jetbrains-mono-400-cyrillic.woff2') format('woff2');unicode-range:U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/jetbrains-mono-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:optional;src:url('/static/fonts/jetbrains-mono-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}

:root {
  /* ─── BACKGROUNDS ─── */
  --bg: #0A0A0A;            /* near-black, slightly warmer than pure */
  --bg-primary: #0A0A0A;
  --panel: #141414;         /* cards, modals (legacy alias = bg-elevated) */
  --bg-elevated: #141414;
  --panel-2: #1F1F1F;       /* inputs, hover (legacy alias = bg-input) */
  --bg-input: #1F1F1F;
  --bg-overlay: rgba(10, 10, 10, 0.85);

  /* ─── TEXT ─── */
  --text: #E8E8E8;
  --text-primary: #E8E8E8;
  --muted: #9CA3AF;
  --text-secondary: #9CA3AF;
  /* Bumped from #6B7280 (~4.7:1 — borderline AA) to #9CA3AF for WCAG AAA
     contrast on bg-primary. Lighthouse mobile flagged the old value. */
  --text-tertiary: #9CA3AF;
  --text-disabled: #6B7280;

  /* ─── BRAND (Sunshade-inspired, distinct from Bloomberg) ─── */
  --accent: #FFA028;            /* legacy alias = brand-primary */
  --accent-hover: #FFB85C;
  --brand-primary: #FFA028;
  --brand-hover: #FFB85C;
  --brand-active: #E68A12;
  --brand-muted: rgba(255, 160, 40, 0.08);
  --brand-border: rgba(255, 160, 40, 0.24);

  /* ─── SEMANTIC (TradingView-aligned) ─── */
  --green: #089981;             /* legacy alias = up-strong */
  --up-strong: #089981;
  --up-soft: rgba(8, 153, 129, 0.12);
  --up-border: rgba(8, 153, 129, 0.32);

  --red: #F23645;               /* legacy alias = down-strong */
  --down-strong: #F23645;
  --down-soft: rgba(242, 54, 69, 0.12);
  --down-border: rgba(242, 54, 69, 0.32);

  --yellow: #FBBF24;            /* warning / mid drift */
  --neutral: #787B86;
  --neutral-soft: rgba(120, 123, 134, 0.12);

  /* ─── DATA-VIZ ZONES ─── */
  --zone-bottom: rgba(8, 153, 129, 0.14);
  --zone-top: rgba(242, 54, 69, 0.14);
  --zone-middle: rgba(31, 31, 31, 0.4);
  --grid-line: rgba(232, 232, 232, 0.06);
  --grid-major: rgba(232, 232, 232, 0.10);

  /* ─── BORDERS ─── */
  --border: rgba(232, 232, 232, 0.12);   /* legacy alias = border-default */
  --border-subtle: rgba(232, 232, 232, 0.08);
  --border-default: rgba(232, 232, 232, 0.12);
  --border-strong: rgba(232, 232, 232, 0.20);

  /* ─── TYPOGRAPHY ─── */
  --font-ui: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-display: 'Inter Display', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'JetBrains Mono', 'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  --mono: var(--font-mono);     /* legacy alias */

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.5rem;
  --text-7xl: 4.5rem;

  --weight-normal: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;

  --leading-tight: 1.1;
  --leading-snug: 1.25;
  --leading-normal: 1.5;
  --leading-relaxed: 1.7;

  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.05em;
  --tracking-widest: 0.1em;

  /* ─── SPACING ─── */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* ─── LAYOUT ─── */
  --container-max: 1280px;
  --container-narrow: 720px;
  --container-wide: 1440px;
  --gutter-mobile: 1rem;
  --gutter-tablet: 1.5rem;
  --gutter-desktop: 2rem;

  /* ─── RADIUS ─── */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --radius-xl: 12px;
  --radius-2xl: 16px;

  /* ─── SHADOWS ─── */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.5);
  --shadow-xl: 0 24px 64px rgba(0, 0, 0, 0.6);
  --glow-brand: 0 0 24px rgba(255, 160, 40, 0.16);
  --glow-up: 0 0 24px rgba(8, 153, 129, 0.16);
  --glow-down: 0 0 24px rgba(242, 54, 69, 0.16);

  /* ─── MOTION ─── */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --duration-fast: 120ms;
  --duration-normal: 200ms;
  --duration-slow: 320ms;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Tabular numerals everywhere numbers live — critical for quant audience */
.num, .stat-num, .stat-value, .data-cell, td.num,
.signal-big, .signal-sub, .bt-final, .bt-growth, .plan-price {
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

:focus-visible {
  outline: 2px solid var(--brand-primary);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

a {
  color: var(--accent);
  text-decoration: none;
}
a:hover { color: var(--accent-hover); text-decoration: underline; }

header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 28px;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
}
header .brand {
  font-weight: 700;
  font-size: 17px;
  color: var(--text);
}
header nav a { margin-left: 18px; font-size: 14px; }

main {
  max-width: 1200px;
  margin: 0 auto;
  padding: 32px 28px;
}

footer {
  border-top: 1px solid var(--border);
  padding: 14px 28px;
  margin-top: 48px;
  font-size: 13px;
}

h1 { margin-top: 0; font-size: 26px; }
h2 { font-size: 19px; margin-bottom: 10px; }
h3 { font-size: 16px; }

.muted { color: var(--muted); }
.small { font-size: 13px; }

code { font-family: var(--mono); background: var(--panel-2); padding: 1px 6px; border-radius: 4px; font-size: 13px; }
pre  { background: var(--panel-2); padding: 12px; border-radius: 6px; overflow-x: auto; }
pre code { padding: 0; }

/* Cards on the home page */
.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: 20px;
  margin-top: 24px;
}
.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px;
}
.card h2 { margin-top: 0; }

.btn {
  display: inline-block;
  padding: 10px 18px;
  background: var(--panel-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
}
.btn:hover { background: var(--border); }
.btn.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg-primary);
}
.btn.primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }

.search-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.search-form label { font-size: 13px; color: var(--muted); }
.search-form input[type=text],
.search-form input:not([type]) {
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 9px 12px;
  border-radius: 6px;
  font-size: 14px;
  font-family: var(--mono);
  text-transform: uppercase;
  width: 140px;
}
.search-form input:focus { outline: 2px solid var(--accent); outline-offset: -2px; }

/* Reports list */
table.reports {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
}
table.reports th,
table.reports td {
  text-align: left;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
}
table.reports th { font-size: 13px; color: var(--muted); font-weight: 500; }
table.reports td.num { text-align: right; font-family: var(--mono); }

.badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 12px;
  border-radius: 4px;
  background: var(--panel-2);
  color: var(--muted);
  font-weight: 500;
  text-transform: uppercase;
}
/* Badge text uses the bright text color; the colored background tint is the
   semantic signal. Pre-2026-05 we colored the text itself (var(--accent) /
   var(--green)) — Lighthouse mobile flagged the search/fail variants for
   borderline contrast on their tinted backgrounds (~4.9:1). White text on
   the same tint passes WCAG AAA cleanly. */
.badge-screen { background: rgba(255, 160, 40, 0.18); color: var(--text-primary); border: 1px solid rgba(255, 160, 40, 0.35); }
.badge-search { background: rgba(8, 153, 129, 0.18);  color: var(--text-primary); border: 1px solid rgba(8, 153, 129, 0.45); }

.breadcrumb { font-size: 13px; margin-bottom: 18px; }

/* Rendered markdown content */
.rendered-md table {
  border-collapse: collapse;
  margin: 14px 0;
  font-size: 13px;
  width: 100%;
  display: block;
  overflow-x: auto;
}
.rendered-md th,
.rendered-md td {
  border: 1px solid var(--border);
  padding: 6px 10px;
  text-align: left;
  white-space: nowrap;
}
.rendered-md th { background: var(--panel); font-weight: 600; }
.rendered-md tr:nth-child(even) td { background: rgba(255,255,255,0.02); }

/* Click-to-sort headers (sortable.js attaches the .sortable class). */
th.sortable { cursor: pointer; user-select: none; position: relative; }
th.sortable:hover { background: var(--panel-2); }
th.sortable::after {
  content: " ⇅";
  opacity: 0.25;
  font-size: 11px;
  margin-left: 4px;
}
th.sortable.sorted-asc::after  { content: " ▲"; opacity: 0.85; color: var(--accent); }
th.sortable.sorted-desc::after { content: " ▼"; opacity: 0.85; color: var(--accent); }

/* Status row + log panel on home */
.status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 28px 0 14px;
}
.status-pill {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px;
  background: var(--panel-2);
}
.status-ok strong  { color: var(--green); }
.status-bad strong { color: var(--red); }

.log-card { margin-top: 16px; }
pre.log {
  font-size: 12px;
  line-height: 1.45;
  max-height: 280px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-all;
  margin: 0;
}

/* Download button on report page */
.btn.small-btn {
  padding: 4px 12px;
  font-size: 12px;
  margin-left: 14px;
  vertical-align: middle;
}

/* Pair-detail page */
.badge-fail { background: rgba(242, 54, 69, 0.18); color: var(--text-primary); border: 1px solid rgba(242, 54, 69, 0.45); }

.signal-row { margin: 16px 0 24px; }
.signal-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-left: 4px solid var(--muted);
  border-radius: 10px;
  padding: 18px 22px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
}
.signal-card.zone-bottom { border-left-color: var(--green); }
.signal-card.zone-top    { border-left-color: var(--red); }
.signal-card.zone-mid    { border-left-color: var(--muted); }
.signal-label { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; }
.signal-big   { font-size: 28px; font-weight: 600; font-family: var(--mono); }
.signal-tag   { font-size: 14px; }
.signal-sub   { font-size: 12px; color: var(--muted); font-family: var(--mono); }

table.metrics-grid {
  width: auto;
  border-collapse: collapse;
  margin: 12px 0 24px;
}
table.metrics-grid td {
  padding: 7px 18px 7px 0;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
}
table.metrics-grid td.num {
  font-family: var(--mono);
  text-align: right;
  min-width: 200px;
  color: var(--text);
}

img.ratio-chart {
  display: block;
  max-width: 100%;
  border: 1px solid var(--border);
  border-radius: 8px;
  margin: 8px 0 8px;
}

.engagement-sparkline-wrap {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px 12px;
  margin: 8px 0 18px;
  overflow-x: auto;
}
.engagement-sparkline { display: block; max-width: 100%; height: auto; }

/* Peg-health dashboard — Phase 4.5 */
table.peg-table td { vertical-align: middle; }
.peg-row-bad td { background: rgba(242, 54, 69, 0.06); }
.peg-row-ok td  { background: rgba(8, 153, 129, 0.04); }
.peg-sparkline-wrap {
  background: var(--panel-2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px;
  display: inline-block;
}
.peg-sparkline-wrap svg { display: block; max-width: 240px; height: 40px; }

.bt-tabs {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  margin: 8px 0 14px;
}
.bt-tabs-label { color: var(--muted); font-size: 13px; margin-right: 4px; }
.bt-tab {
  display: inline-block;
  padding: 5px 12px;
  background: var(--panel-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  text-decoration: none;
  font-family: var(--mono);
  transition: background 0.1s;
}
.bt-tab:hover { background: var(--border); }
.bt-tab.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg-primary);
  font-weight: 600;
}
.bt-tabs-hint { flex-basis: 100%; margin-top: 2px; font-size: 12px; }

.bt-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
  margin: 12px 0 24px;
}
.bt-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px;
}
.bt-leg    { color: var(--muted); font-size: 13px; margin-bottom: 8px; }
.bt-final  { font-size: 22px; font-weight: 600; font-family: var(--mono); }
.bt-growth { font-size: 16px; font-family: var(--mono); margin: 4px 0 8px; color: var(--muted); }
.bt-growth.pos { color: var(--green); }
.bt-growth.neg { color: var(--red); }

table.trades {
  width: 100%;
  border-collapse: collapse;
  margin: 12px 0;
  font-size: 13px;
}
table.trades th,
table.trades td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}
table.trades th { background: var(--panel); color: var(--muted); font-weight: 600; }
table.trades td.num { font-family: var(--mono); text-align: right; }
.action-buy  { color: var(--green); font-weight: 500; }
.action-sell { color: var(--red);   font-weight: 500; }

/* ----- Auth, billing, admin styles ----------------------------------- */
.auth-box {
  max-width: 380px;
  margin: 40px auto;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 28px;
}
.auth-box h1 { margin-top: 0; }
.auth-form { display: flex; flex-direction: column; gap: 14px; }
.auth-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.auth-form input {
  background: var(--bg); border: 1px solid var(--border);
  color: var(--text); padding: 10px 12px; border-radius: 6px;
  font-size: 14px; font-family: inherit;
}
.auth-form input:focus { outline: 2px solid var(--accent); outline-offset: -2px; }
.error    { color: var(--red);   background: rgba(242, 54, 69, 0.1);
            padding: 10px 14px; border-radius: 6px; font-size: 14px; }
.success  { color: var(--green); background: rgba(8, 153, 129, 0.1);
            padding: 10px 14px; border-radius: 6px; font-size: 14px; }

/* tier badges */
.tier-badge {
  display: inline-block; padding: 3px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
  background: var(--panel-2); color: var(--muted);
}
.tier-badge.tier-free     { background: rgba(138, 147, 168, 0.18); color: var(--muted); }
.tier-badge.tier-personal { background: rgba(255, 160, 40, 0.18); color: var(--accent); }
.tier-badge.tier-pro      { background: rgba(8, 153, 129, 0.18); color: var(--green); }
.tier-badge.tier-admin    { background: rgba(251, 191, 36, 0.18); color: var(--yellow); }

.tier-row { display: flex; align-items: center; gap: 12px; margin: 8px 0 18px; }

/* pricing */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 18px;
  margin: 24px 0;
}
.plan-card {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 10px; padding: 22px;
  display: flex; flex-direction: column;
}
.plan-card h2 { margin-top: 0; }
.plan-featured { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.plan-oneshot  { border-style: dashed; }
.plan-price    { font-size: 32px; font-weight: 700; font-family: var(--mono); margin: 8px 0; }
.plan-period   { font-size: 14px; font-weight: 400; color: var(--muted); }
.plan-features { padding-left: 22px; flex-grow: 1; font-size: 14px; line-height: 1.7; color: var(--text); }
.plan-features li { margin-bottom: 4px; }
.plan-card form, .plan-card a.btn { margin-top: 12px; }

/* upgrade page */
.upgrade-box { max-width: 540px; margin: 40px auto; text-align: center; }
.upgrade-box h1 { font-size: 28px; }
.upgrade-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 20px; }

/* billing result */
.billing-result { max-width: 540px; margin: 40px auto; text-align: center; }
.billing-result-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 20px; }

/* admin */
.admin-form { max-width: 560px; }
.admin-form fieldset { border: 0; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.admin-form fieldset[disabled] { opacity: 0.5; }
.admin-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.admin-form input {
  background: var(--bg); border: 1px solid var(--border); color: var(--text);
  padding: 10px 12px; border-radius: 6px; font-family: var(--mono);
}
.admin-actions { padding-left: 18px; }
.admin-actions li { margin-bottom: 6px; }

table.admin-table {
  width: 100%; border-collapse: collapse; margin-top: 14px; font-size: 13px;
}
table.admin-table th, table.admin-table td {
  padding: 8px 12px; border-bottom: 1px solid var(--border); text-align: left; white-space: nowrap;
}
table.admin-table th { background: var(--panel); color: var(--muted); font-weight: 600; }
table.admin-table td.num { font-family: var(--mono); text-align: right; }
/* admin/users action buttons — three little forms inline per row */
.btn.small { padding: 4px 10px; font-size: 12px; }
.btn.danger { background: rgba(242, 54, 69, 0.15); border-color: rgba(242, 54, 69, 0.4); color: var(--red); }
.btn.danger:hover { background: rgba(242, 54, 69, 0.28); }
.inline-form { display: inline-block; margin: 0 4px 4px 0; }
.admin-actions-cell { white-space: normal; min-width: 280px; }
.checkbox-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; margin: 8px 0; cursor: pointer;
}
.checkbox-row input[type=checkbox] { width: 16px; height: 16px; cursor: pointer; }
.admin-select, .admin-days {
  background: var(--bg); color: var(--text); border: 1px solid var(--border);
  border-radius: 4px; padding: 3px 6px; font-size: 12px; font-family: inherit;
}
.admin-days { width: 60px; }

.status-pill.status-paid     { background: rgba(8, 153, 129, 0.18); color: var(--green); }
.status-pill.status-pending  { background: rgba(251, 191, 36, 0.18); color: var(--yellow); }
.status-pill.status-failed   { background: rgba(242, 54, 69, 0.18); color: var(--red); }
.status-pill.status-cancelled{ background: rgba(138, 147, 168, 0.18); color: var(--muted); }
.status-pill.status-paid_over{ background: rgba(255, 160, 40, 0.18); color: var(--accent); }

/* one-shot CTA on pair page */
.oneshot-cta {
  background: rgba(255, 160, 40, 0.08);
  border: 1px dashed var(--accent);
  border-radius: 10px; padding: 18px 22px; margin: 18px 0 26px;
}
.oneshot-cta h3 { margin: 0 0 8px; font-size: 15px; }
.oneshot-cta-buttons { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }

.nav-user { padding: 0 8px; font-family: var(--mono); }
.lang-toggle {
  font-size: 12px; padding: 4px 10px; border-radius: 4px;
  border: 1px solid var(--border); margin-left: 4px;
}
.lang-toggle:hover { background: var(--panel-2); text-decoration: none; }

/* ---------- Responsive: tablet (≤1024px) and mobile (≤768px) -------- */
@media (max-width: 1024px) {
  main { padding: 22px 18px; }
  main.landing { max-width: 100%; }
  main.landing h1 { font-size: 30px; }
  .lead { font-size: 16px; }
  .features, .cards, .pricing-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
  }
}

/* Hamburger toggle — desktop default = hidden. Pure CSS, no JS. */
.nav-toggle, .nav-toggle-btn { display: none; }

@media (max-width: 768px) {
  body { font-size: 14px; }
  header {
    padding: 12px 16px;
    gap: 8px;
    flex-wrap: wrap;        /* nav drops to next row when expanded */
    align-items: center;
  }
  header .brand { font-size: 15px; flex-grow: 1; }

  /* Show the burger button. Three lines that morph to ✕ on :checked. */
  .nav-toggle-btn {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 36px;
    height: 36px;
    padding: 6px 8px;
    cursor: pointer;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--panel);
  }
  .nav-toggle-btn span {
    display: block;
    width: 100%;
    height: 2px;
    background: var(--text);
    border-radius: 1px;
    transition: transform 0.18s, opacity 0.18s;
  }
  .nav-toggle:checked + .nav-toggle-btn span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }
  .nav-toggle:checked + .nav-toggle-btn span:nth-child(2) { opacity: 0; }
  .nav-toggle:checked + .nav-toggle-btn span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  /* Collapse nav by default on mobile; expand when checkbox is :checked. */
  header nav {
    display: none;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    margin-top: 12px;
    gap: 4px;
    padding-top: 10px;
    border-top: 1px solid var(--border);
  }
  .nav-toggle:checked ~ nav { display: flex; }

  header nav a {
    margin-left: 0;
    padding: 10px 12px;
    font-size: 14px;
    border-radius: 6px;
  }
  header nav a:hover { background: var(--panel-2); text-decoration: none; }
  header nav a.btn { padding: 10px 14px; text-align: center; }
  .lang-toggle {
    align-self: flex-start;
    margin: 4px 0;
  }
  .nav-user { display: none; }  /* hide email on phone — too long */
  main { padding: 18px 14px; }
  main.landing h1 { font-size: 24px; line-height: 1.3; }
  h1 { font-size: 22px; }
  h2 { font-size: 17px; }
  .hero { padding: 22px 0 16px; }
  .hero-cta { flex-direction: column; align-items: stretch; }
  .hero-cta .btn { text-align: center; }
  .features, .cards, .pricing-grid, .bt-row, .example-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .feature, .card, .plan-card, .bt-card {
    padding: 16px;
  }
  .signal-card {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 8px;
  }
  .stat-num { font-size: 22px; }
  .upgrade-cta, .billing-result-cta, .oneshot-cta-buttons {
    flex-direction: column;
  }
  .upgrade-cta .btn, .billing-result-cta .btn, .oneshot-cta-buttons .btn,
  .upgrade-cta button, .oneshot-cta-buttons button {
    width: 100%;
    text-align: center;
  }
  .auth-box { margin: 20px 14px; padding: 22px; }
  .pricing-grid .plan-card { text-align: left; }
  table.metrics-grid td.num { min-width: auto; }
  /* Tables in markdown reports + admin tables — let them scroll horizontally. */
  .rendered-md table, table.admin-table, table.trades, table.reports {
    font-size: 12px;
  }
  /* Hide some columns on very narrow screens. */
  table.reports th:nth-child(3), table.reports td:nth-child(3) { display: none; }
  .steps li { padding-left: 44px; }
  .steps li::before { width: 30px; height: 30px; font-size: 13px; }
}

@media (max-width: 480px) {
  main.landing h1 { font-size: 21px; }
  .plan-price { font-size: 26px; }
  header nav a.btn-login { padding: 4px 10px; font-size: 12px; }
  header nav a:not(.btn) { font-size: 12px; }
  .lang-toggle { padding: 3px 8px; }
}

/* iPhone SE class (≤ 380 px viewport). Playbook Часть 13 specifically
   calls out 380 px as the QA target — anything that fits here fits 99 %
   of phones. The default rules already collapse to single-column at this
   width via the 768 px breakpoint; what we tighten further:
     • side padding shrinks so content doesn't get squeezed out by gutter,
     • the hero H1 drops one notch — at 48 px it overflows on 375 px iPhones,
     • CTAs and chips compress so they don't wrap awkwardly,
     • table cells lose extra padding (data density becomes painful otherwise),
     • the trial-banner CTA wraps under instead of fighting for inline space. */
@media (max-width: 380px) {
  main { padding: var(--space-3) var(--space-3); }
  .hero-title { font-size: var(--text-4xl); line-height: 1.15; }
  .hero-eyebrow { font-size: var(--text-xs); }
  .hero-cta .btn,
  .hero-cta .btn-large { width: 100%; padding: 12px 16px; font-size: 14px; }
  .demo-stats { font-size: var(--text-xs); }
  .trust-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-2); }
  .plan-card { padding: var(--space-4); }
  .plan-price { font-size: var(--text-3xl); }
  .pair-actions-grid { gap: var(--space-3); }
  .dash-status-bar { padding: var(--space-2) var(--space-3); gap: var(--space-2); }
  .dash-status-text { font-size: var(--text-xs); }
  .chip { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); }
  .trial-banner { flex-direction: column; align-items: flex-start; gap: var(--space-2); }
  .trial-banner .btn,
  .trial-banner .btn-text { align-self: stretch; text-align: center; }
  table.pairs-table th,
  table.pairs-table td { padding: var(--space-1) var(--space-2); font-size: var(--text-xs); }
  .footer-cols { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* Landing page */
.btn-login { padding: 8px 18px; font-size: 13px; }
.btn-large { padding: 14px 28px; font-size: 15px; }

main.landing { max-width: 980px; }
main.landing h1 { font-size: 38px; line-height: 1.2; margin: 16px 0; }
main.landing h1 .accent { color: var(--accent); }
main.landing h2 { font-size: 24px; margin-top: 48px; }

.lead {
  font-size: 17px;
  line-height: 1.6;
  color: var(--text);
  max-width: 760px;
  margin: 12px 0 28px;
}

.hero {
  padding: 36px 0 24px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 24px;
}
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 18px; }

.features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  margin: 28px 0;
}
.feature {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px;
}
.feature h3 { margin: 0 0 10px; font-size: 17px; }
.feature p  { margin: 0; font-size: 14px; line-height: 1.55; color: var(--muted); }

.steps { padding-left: 0; counter-reset: step; list-style: none; }
.steps li {
  counter-increment: step;
  position: relative;
  padding: 14px 0 14px 52px;
  border-bottom: 1px solid var(--border);
  font-size: 15px;
  line-height: 1.55;
}
.steps li::before {
  content: counter(step);
  position: absolute;
  left: 0;
  top: 14px;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: var(--accent);
  color: var(--bg-primary);
  font-weight: 700;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.steps li:last-child { border-bottom: 0; }

.example {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px;
  margin-top: 32px;
}
.example h2 { margin-top: 0; }
.example-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 18px;
  margin: 20px 0 8px;
}
.example-stat {
  background: var(--panel-2);
  padding: 18px 20px;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.stat-num   { font-size: 26px; font-weight: 700; color: var(--accent); font-family: var(--mono); }
.stat-label { color: var(--text); font-size: 14px; }
.stat-sub   { color: var(--muted); font-size: 12px; font-family: var(--mono); }
.example-note { margin-top: 18px; }

.caveats ul {
  padding-left: 22px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--muted);
}
.caveats li { margin-bottom: 6px; }
.caveats li strong { color: var(--text); }

.cta-bottom {
  text-align: center;
  padding: 48px 0 16px;
  border-top: 1px solid var(--border);
  margin-top: 48px;
}
.cta-bottom h2 { margin: 0 0 12px; }
.cta-bottom p  { color: var(--muted); margin: 0 0 20px; }

/* FAQ — collapsible <details>/<summary>. */
.faq {
  margin-top: 48px;
  border-top: 1px solid var(--border);
  padding-top: 24px;
}
.faq h2 { margin-bottom: 18px; }
.faq-item {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 10px;
  overflow: hidden;
  transition: border-color 0.15s;
}
.faq-item[open] { border-color: var(--accent); }
.faq-item > summary {
  cursor: pointer;
  list-style: none;
  padding: 16px 22px 16px 48px;
  font-weight: 600;
  font-size: 15px;
  position: relative;
  color: var(--text);
  user-select: none;
}
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item > summary::before {
  content: "+";
  position: absolute;
  left: 18px; top: 50%;
  transform: translateY(-50%);
  width: 22px; height: 22px;
  background: var(--panel-2);
  border-radius: 50%;
  font-weight: 600;
  font-size: 17px;
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.18s, background 0.18s;
}
.faq-item[open] > summary::before {
  content: "−";
  background: var(--accent);
  color: var(--bg-primary);
  transform: translateY(-50%) rotate(180deg);
}
.faq-item > summary:hover { background: rgba(255, 160, 40, 0.04); }
.faq-item > p {
  padding: 0 22px 18px 48px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
  margin: 0;
}
.rendered-md h1 { padding-bottom: 8px; border-bottom: 1px solid var(--border); }
.rendered-md h2 { margin-top: 32px; padding-bottom: 6px; border-bottom: 1px solid var(--border); }
.rendered-md h3 { margin-top: 24px; }
.rendered-md ul, .rendered-md ol { padding-left: 24px; }
.rendered-md hr { border: none; border-top: 1px solid var(--border); margin: 24px 0; }
.rendered-md code { font-size: 12.5px; }

/* ════════════════════════════════════════════════════════════════════════
   Landing v2 components (PairScan redesign — playbook v1.7.2 Часть 14).
   ════════════════════════════════════════════════════════════════════════ */

/* Eyebrow caps label */
.eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--brand-primary);
  margin-bottom: var(--space-3);
}

/* Hero — 3-line H1 + status dot */
main.landing .hero { padding: var(--space-12) 0 var(--space-8); border-bottom: 1px solid var(--border-subtle); }
.hero-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  margin: 0 0 var(--space-5);
  max-width: 22ch;
}
.hero-title__accent { color: var(--text-secondary); font-weight: var(--weight-medium); }
@media (min-width: 768px) { .hero-title { font-size: var(--text-5xl); } }
@media (min-width: 1024px) { .hero-title { font-size: var(--text-6xl); } }
.hero-status {
  display: flex; align-items: center; gap: var(--space-2);
  margin-top: var(--space-8);
  color: var(--text-tertiary);
}

/* Pulsing live status dot */
.status-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--up-strong);
  box-shadow: 0 0 8px var(--up-strong);
  animation: ps-pulse 2s ease-in-out infinite;
}
@keyframes ps-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.5; }
}

/* Text-CTA (subtle inline link) */
.btn-text {
  color: var(--brand-primary);
  font-weight: var(--weight-semibold);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-color: rgba(255, 160, 40, 0.3);
}
.btn-text:hover { text-decoration-color: var(--brand-primary); color: var(--brand-hover); }

/* Block 2: Live demo widget */
.demo {
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  background: linear-gradient(180deg, var(--brand-muted) 0%, var(--bg-elevated) 60%);
  margin: var(--space-12) 0;
}
.demo h2 { margin-top: var(--space-2); }

/* Demo widget tab strip — 4 example pairs the visitor can flip between.
   Tabs sit above the chart+stats grid. Active tab gets the brand color
   and a slight elevation; idle tabs are subtle so they don't fight with
   the H2. Horizontal scroll on narrow viewports so all four fit on iPhone. */
.demo-tabs {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin: var(--space-3) 0 var(--space-4);
}
.demo-tab {
  background: var(--bg-elevated);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out);
}
.demo-tab:hover { color: var(--text-primary); border-color: var(--border-default); }
.demo-tab.is-active {
  background: var(--brand-muted);
  color: var(--text-primary);
  border-color: var(--brand-border);
  font-weight: var(--weight-semibold);
}
.demo-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin: var(--space-5) 0;
}
@media (min-width: 1024px) {
  .demo-grid { grid-template-columns: 3fr 2fr; gap: var(--space-8); }
}
.demo-chart img { border-radius: var(--radius-lg); width: 100%; height: auto; }
.demo-side h3 { margin: 0 0 var(--space-1); font-family: var(--font-mono); }
.demo-bt { margin-top: var(--space-5); padding-top: var(--space-4); border-top: 1px solid var(--border-subtle); }
.demo-bt .num--big { font-size: var(--text-3xl); margin: 0; }

/* Tabular row (label + value) — used in demo side panel */
.tabular-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--border-subtle);
  gap: var(--space-4);
}
.tabular-row__label { color: var(--text-secondary); font-size: var(--text-sm); }
.tabular-row__value { color: var(--text-primary); }

/* Numeric helpers */
.num--big { font-size: var(--text-5xl); font-weight: var(--weight-bold); letter-spacing: var(--tracking-tight); line-height: 1; margin: 0; }
.num--positive { color: var(--up-strong); }
.num--negative { color: var(--down-strong); }
.num--neutral { color: var(--neutral); }

/* Block 3: Trust strip */
.trust { padding: var(--space-12) 0; border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); }
.trust-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}
@media (min-width: 768px) { .trust-grid { grid-template-columns: repeat(4, 1fr); } }
.trust-item { display: flex; flex-direction: column; gap: var(--space-1); }
.trust-item .num--big { font-size: var(--text-4xl); }
.trust-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--text-tertiary);
}

/* Block 4: How — keep existing .steps but tweak */
.how .steps li { padding-left: 56px; padding-top: var(--space-4); padding-bottom: var(--space-4); border-bottom: 1px solid var(--border-subtle); }
.how .steps li strong { font-size: var(--text-lg); display: block; margin-bottom: var(--space-2); }
.how .steps li p { margin: 0; }

/* Block 5: Real example */
.example { border: 1px solid var(--border-subtle); border-radius: var(--radius-xl); padding: var(--space-8); margin: var(--space-12) 0; }
.example-big { font-size: var(--text-6xl); margin: var(--space-4) 0 var(--space-1); }
.example-2col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin: var(--space-6) 0;
}
@media (min-width: 768px) { .example-2col { grid-template-columns: 1fr 1fr; } }
.example-2col .example-stat {
  background: var(--bg-input);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: flex-start;
}
.example-2col .example-stat .stat-num { font-size: var(--text-4xl); font-weight: var(--weight-bold); color: var(--text-primary); }
.example-note { line-height: var(--leading-relaxed); margin: var(--space-5) 0; }

/* Block 6: Unique angle — 3 columns */
.angle { padding: var(--space-12) 0; }
.angle-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  margin: var(--space-6) 0;
}
@media (min-width: 768px) { .angle-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); } }
.angle-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.angle-card h3 { margin: 0 0 var(--space-3); font-size: var(--text-lg); }

/* Block 7: Where it fails — 5 paragraphs */
.fail { padding: var(--space-12) 0; max-width: var(--container-narrow); }
.fail-para {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-5);
  padding-left: var(--space-4);
  border-left: 2px solid var(--down-border);
}

/* Block 8: Methodology preview */
.method { padding: var(--space-12) 0; max-width: var(--container-narrow); }
.method .btn { margin: var(--space-4) 0 var(--space-3); }

/* Block 9: Pricing tease */
.pricing-tease { padding: var(--space-12) 0; }
.pricing-tease .pricing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  margin: var(--space-6) 0;
}
@media (min-width: 768px) {
  .pricing-tease .pricing-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
}
.plan-card { position: relative; }
.plan-featured {
  background: linear-gradient(180deg, var(--brand-muted) 0%, var(--bg-elevated) 50%);
  border-color: var(--brand-border);
  transform: scale(1.02);
}
.plan-badge {
  position: absolute;
  top: -10px; right: var(--space-4);
  background: var(--brand-primary);
  color: var(--bg-primary);
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-widest);
  border-radius: var(--radius-sm);
}
.founder-offer {
  margin-top: var(--space-8);
  padding: var(--space-6);
  border: 1px dashed var(--brand-border);
  border-radius: var(--radius-lg);
  background: var(--brand-muted);
  text-align: center;
}
.founder-offer h3 { margin: 0 0 var(--space-2); }
.founder-offer .btn { margin-top: var(--space-3); }

/* Block 11: Rich footer (3 columns) */
.footer-rich {
  background: var(--bg-elevated);
  border-top: 1px solid var(--border-subtle);
  padding: var(--space-10) var(--gutter-mobile) var(--space-6);
  margin-top: var(--space-16);
}
.footer-cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  max-width: var(--container-max);
  margin: 0 auto;
}
@media (min-width: 768px) {
  .footer-cols { grid-template-columns: 2fr 1fr 1fr; gap: var(--space-10); }
}
.footer-col h4 { margin: 0 0 var(--space-3); font-size: var(--text-sm); }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: var(--space-2); font-size: var(--text-sm); }
.footer-col a { color: var(--text-secondary); }
.footer-col a:hover { color: var(--brand-primary); }
.footer-disclaimer {
  max-width: var(--container-max);
  margin: var(--space-8) auto 0;
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}

/* Mobile tweaks for new components */
@media (max-width: 767px) {
  .hero-cta { flex-direction: column; align-items: stretch; }
  .hero-cta .btn { text-align: center; }
  .demo { padding: var(--space-5); }
  .trust-grid { gap: var(--space-4); }
  .trust-item .num--big { font-size: var(--text-3xl); }
  .example-big { font-size: var(--text-4xl); }
  .plan-featured { transform: none; }
}

/* ════════════════════════════════════════════════════════════════════════
   Dashboard v2 components (R3 redesign — playbook v1.7.2 Часть 4.1).
   ════════════════════════════════════════════════════════════════════════ */

/* Status bar — thin Bloomberg-style strip with last/next screen + tier */
.dash-status-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin: 0 0 var(--space-4);
  flex-wrap: wrap;
}
.dash-status-text { display: inline-flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.dash-status-spacer { flex: 1; min-width: var(--space-2); }

/* Trial-by-action banner — sits between the status bar and the table.
   Two variants share the same flex layout: ".trial-banner-active" uses
   the brand sunshade tint (positive surprise — granted free week) while
   ".trial-banner-expired" goes neutral with a slight warning border to
   signal the upsell without screaming. */
.trial-banner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  margin: 0 0 var(--space-4);
  font-size: var(--text-sm);
  flex-wrap: wrap;
}
.trial-banner-active {
  background: var(--brand-muted);
  border: 1px solid var(--brand-border);
  color: var(--text-primary);
}
.trial-banner-expired {
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  color: var(--text-primary);
}
.trial-icon { font-size: var(--text-lg); }
.trial-text { flex: 1; min-width: 0; }
.trial-text strong { color: var(--text-primary); margin-right: var(--space-1); }

/* Chip filters — 1-click switches, not dropdowns */
.chip-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin: 0 0 var(--space-5);
}
.chip {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-4);
  border-radius: 999px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  text-decoration: none;
  transition: background var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}
.chip:hover {
  background: var(--bg-input);
  border-color: var(--border-default);
  color: var(--text-primary);
  text-decoration: none;
}
.chip.chip-active {
  background: var(--brand-muted);
  border-color: var(--brand-border);
  color: var(--brand-primary);
}
.chip.chip-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--text-tertiary);
}
.chip.chip-ghost:hover { color: var(--brand-primary); background: transparent; }
.chip-spacer { flex: 1; }

/* Dashboard cards — compact replacement for old .cards/.card */
.dash-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin: 0 0 var(--space-5);
}
.dash-card h2 { margin: 0 0 var(--space-2); font-size: var(--text-2xl); }
.dash-card h3 { margin: 0 0 var(--space-2); font-size: var(--text-xl); }

.dash-primary {
  background: linear-gradient(180deg, var(--brand-muted) 0%, var(--bg-elevated) 60%);
  border-color: var(--brand-border);
}
.dash-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.dash-card-head h2 a { color: var(--text-primary); }
.dash-card-head h2 a:hover { color: var(--brand-primary); text-decoration: none; }
.dash-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
  margin-top: var(--space-4);
}
.dash-actions .inline-form { margin: 0; }

/* Admin section — collapsed by default, no visual weight when closed */
.dash-admin {
  margin-top: var(--space-8);
  border-top: 1px solid var(--border-subtle);
  padding-top: var(--space-4);
}
.dash-admin > summary {
  cursor: pointer;
  list-style: none;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  padding: var(--space-2) 0;
  user-select: none;
}
.dash-admin > summary::-webkit-details-marker { display: none; }
.dash-admin > summary::before {
  content: "▸ ";
  display: inline-block;
  width: 1em;
  transition: transform var(--duration-fast);
}
.dash-admin[open] > summary::before { content: "▾ "; }
.dash-admin > summary:hover { color: var(--text-primary); }
.dash-admin .status-row { margin-top: var(--space-3); }
.dash-admin .log-card { margin-top: var(--space-3); }

@media (max-width: 767px) {
  .dash-status-bar { gap: var(--space-2); }
  .dash-status-spacer { flex-basis: 100%; height: 0; }
  .chip-row { gap: var(--space-1); }
  .chip { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); }
  .density-toggle { display: none; }  /* hide on mobile to save space */
}

/* Sortable pairs table on dashboard (R3 batch 4) */
.dash-pairs { margin: 0 0 var(--space-6); }
.dash-pairs-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin: 0 0 var(--space-3); flex-wrap: wrap; gap: var(--space-3);
}
.dash-pairs-head h2 { margin: 0; font-size: var(--text-xl); }
.dash-pairs-table {
  width: 100%;
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.dash-pairs-table th {
  background: var(--bg-input);
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--text-tertiary);
  font-weight: var(--weight-semibold);
  cursor: pointer;             /* sortable.js wires click on every th */
  user-select: none;
  position: relative;
  transition: color var(--duration-fast) var(--ease-out),
              background var(--duration-fast) var(--ease-out);
}
.dash-pairs-table th:hover { color: var(--text-primary); background: var(--border-subtle); }
/* Always-visible sort affordance (⇅) so it's obvious the column is clickable. */
.dash-pairs-table th::after {
  content: " ⇅";
  opacity: 0.4;
  font-size: 11px;
  margin-left: 4px;
}
.dash-pairs-table th.sorted-asc::after  { content: " ▲"; opacity: 1; color: var(--brand-primary); }
.dash-pairs-table th.sorted-desc::after { content: " ▼"; opacity: 1; color: var(--brand-primary); }

.dash-pairs-table td {
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--border-subtle);
}
.dash-pairs-table th.num, .dash-pairs-table td.num { text-align: right; }
.dash-pairs-table tr:hover td { background: var(--bg-input); }
.dash-pairs-table a { color: var(--brand-primary); }
@media (max-width: 767px) {
  /* Hide secondary columns on phone — keep pair / zone / position. */
  .dash-pairs-table th:nth-child(n+4), .dash-pairs-table td:nth-child(n+4) { display: none; }
}

/* Density toggle (Bloomberg-style compact mode) */
.density-toggle {
  cursor: pointer;
  font-family: var(--font-ui);
  font-size: var(--text-xs);
}
body[data-density="compact"] .dash-card { padding: var(--space-3) var(--space-4); margin-bottom: var(--space-3); }
body[data-density="compact"] .dash-card h2 { font-size: var(--text-lg); }
body[data-density="compact"] .dash-card h3 { font-size: var(--text-base); }
body[data-density="compact"] .dash-status-bar { padding: var(--space-2) var(--space-3); }
body[data-density="compact"] .chip-row { margin-bottom: var(--space-3); }
body[data-density="compact"] .reports th, body[data-density="compact"] .reports td,
body[data-density="compact"] .admin-table th, body[data-density="compact"] .admin-table td {
  padding: 4px 8px;
  font-size: var(--text-xs);
}

/* Watchlist (R5 polish — replace inline styles) */
.watchlist-wrap { background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-6); }
.watchlist-coins-row { display: flex; gap: var(--space-2); align-items: end; flex-wrap: wrap; }
.watchlist-coin-label { flex: 1 1 100px; }
.watchlist-ticker { text-transform: uppercase; font-family: var(--font-mono); }
.watchlist-back { margin-top: var(--space-4); }
.watchlist-free-locked { margin-top: var(--space-4); }

/* Print styles (R7) — quants do print methodology + cornerstone articles. */
@media print {
  /* Hide chrome that doesn't help on paper. */
  header, footer, nav, .footer-rich,
  .cmdk-overlay, .onboarding-overlay,
  .pair-actions, .blog-post-foot, .pricing-tease,
  .chip-row, .dash-status-bar, .dash-admin {
    display: none !important;
  }
  /* High contrast on white paper. */
  body, html {
    background: #fff !important;
    color: #000 !important;
  }
  .blog-body, .rendered-md, .blog-post-head {
    color: #000 !important;
  }
  .blog-body a {
    color: #000 !important;
    text-decoration: underline !important;
  }
  /* Show full URL after links so the print is self-contained. */
  .blog-body a[href]::after {
    content: " (" attr(href) ")";
    font-size: 0.85em;
    color: #555;
  }
  /* Don't inject the URL for fragment-only links. */
  .blog-body a[href^="#"]::after { content: ""; }
  /* Larger body text + page-break heuristics. */
  body { font-size: 12pt; line-height: 1.5; }
  h1, h2, h3 { page-break-after: avoid; }
  pre, blockquote, .blog-toc { page-break-inside: avoid; }
  pre, code { background: #f4f4f4 !important; color: #000 !important; }
}

/* Cmd+K search overlay (R3 batch 5) */
.cmdk-overlay {
  position: fixed; inset: 0;
  background: var(--bg-overlay);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 10vh;
  z-index: 99;
  animation: onb-fade-in var(--duration-fast) var(--ease-out);
}
.cmdk-overlay[hidden] { display: none; }
.cmdk-card {
  width: min(560px, calc(100vw - 32px));
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: var(--space-3) var(--space-3) var(--space-2);
}
.cmdk-input {
  width: 100%;
  background: transparent;
  border: 0;
  outline: 0;
  padding: var(--space-3);
  color: var(--text-primary);
  font-size: var(--text-lg);
  font-family: var(--font-ui);
}
.cmdk-input::placeholder { color: var(--text-tertiary); }
.cmdk-results {
  max-height: 50vh;
  overflow-y: auto;
  margin-top: var(--space-2);
}
.cmdk-group h3 {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin: var(--space-3) var(--space-3) var(--space-1);
}
.cmdk-group ul { list-style: none; padding: 0; margin: 0; }
.cmdk-group li a {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  color: var(--text-primary);
}
.cmdk-group li a:hover { background: var(--bg-input); text-decoration: none; }
.cmdk-coin { font-family: var(--font-mono); font-weight: var(--weight-medium); }
.cmdk-meta { font-size: var(--text-xs); }
.cmdk-empty { text-align: center; padding: var(--space-5) var(--space-3); }
.cmdk-hint {
  margin: var(--space-2) var(--space-3) var(--space-1);
  text-align: center;
  font-size: 11px;
}
.cmdk-trigger {
  cursor: pointer;
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}
@media (max-width: 767px) {
  .cmdk-trigger { display: none; }  /* mobile uses native search forms */
}

/* Onboarding overlay (R3 — first-visit modal) */
.onboarding-overlay {
  position: fixed; inset: 0;
  background: var(--bg-overlay);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
  animation: onb-fade-in var(--duration-normal) var(--ease-out);
}
.onboarding-overlay[hidden] { display: none; }
@keyframes onb-fade-in { from { opacity: 0; } to { opacity: 1; } }

.onboarding-card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8) var(--space-6) var(--space-6);
  max-width: 460px;
  margin: var(--space-4);
  box-shadow: var(--shadow-xl), var(--glow-brand);
}
.onboarding-card h2 { margin: 0 0 var(--space-3); font-size: var(--text-2xl); }
.onboarding-card .btn { margin-top: var(--space-5); }
.onboarding-close {
  position: absolute;
  top: var(--space-3); right: var(--space-3);
  width: 32px; height: 32px;
  border: 0;
  background: transparent;
  color: var(--text-tertiary);
  font-size: 24px;
  cursor: pointer;
  border-radius: var(--radius-sm);
}
.onboarding-close:hover { color: var(--text-primary); background: var(--bg-input); }

/* ════════════════════════════════════════════════════════════════════════
   Pair-detail v2 components (R4 redesign — playbook v1.7.2 Часть 4.2).
   ════════════════════════════════════════════════════════════════════════ */

/* Breadcrumb — already exists; tighten spacing */
.breadcrumb { font-size: var(--text-sm); color: var(--text-tertiary); margin-bottom: var(--space-3); }

/* Pair hero — name + status badges */
.pair-hero {
  margin: 0 0 var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
}
.pair-hero-title {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin: 0 0 var(--space-3);
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  letter-spacing: var(--tracking-tight);
}
.pair-hero-title .pair-sep { color: var(--text-tertiary); font-weight: var(--weight-normal); }
.pair-hero-title .badge { font-size: var(--text-xs); align-self: center; }
@media (min-width: 768px) {
  .pair-hero-title { font-size: var(--text-4xl); }
}
.peg-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* Collapsible trades / metrics — stay compact when not interesting */
.pair-trades, .pair-metrics {
  margin: var(--space-6) 0;
  border-top: 1px solid var(--border-subtle);
  padding-top: var(--space-3);
}
.pair-trades > summary,
.pair-metrics > summary {
  cursor: pointer;
  list-style: none;
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  padding: var(--space-2) 0;
  user-select: none;
  color: var(--text-primary);
}
.pair-trades > summary::-webkit-details-marker,
.pair-metrics > summary::-webkit-details-marker { display: none; }
.pair-trades > summary::before,
.pair-metrics > summary::before {
  content: "▸ ";
  display: inline-block;
  width: 1em;
  color: var(--text-tertiary);
  transition: transform var(--duration-fast);
}
.pair-trades[open] > summary::before,
.pair-metrics[open] > summary::before { content: "▾ "; }
.pair-trades > summary:hover,
.pair-metrics > summary:hover { color: var(--brand-primary); }
.pair-metrics .metrics-grid { width: 100%; max-width: 540px; }

/* Action panel — 3 columns of mini-cards */
.pair-actions { margin: var(--space-10) 0 var(--space-6); }
.pair-actions h2 { margin: 0 0 var(--space-4); }
.pair-actions-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .pair-actions-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
}
.pair-action-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.pair-action-card h3 { margin: 0 0 var(--space-1); font-size: var(--text-base); }
.pair-action-card p { margin: 0; }
.pair-action-card .btn,
.pair-action-card .btn-text { align-self: flex-start; margin-top: auto; }
.pair-action-status {
  margin: 0;
  color: var(--up-strong);
  font-weight: var(--weight-semibold);
}

/* Swap-venue list inside the "Execute the swap" action card. The card may
   render 1..3 venues (Kraken/Bybit/Jupiter for xStocks; Binance/Bybit for
   crypto), so each row needs to read as a distinct option, not a paragraph. */
.pair-action-card .swap-venue {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding-top: var(--space-2);
  border-top: 1px solid var(--border-subtle);
}
.pair-action-card .swap-venue:first-of-type {
  border-top: 0;
  padding-top: 0;
}
.swap-venue-name {
  font-size: var(--text-sm);
  color: var(--fg-strong);
}
.swap-venue-legs {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.swap-venue-note {
  margin: 0;
  font-size: var(--text-xs);
}
.pair-action-card .swap-venue .btn-text {
  align-self: flex-start;
  margin-top: 0;
}

/* Pair FAQ — same styling as landing FAQ but tighter */
.pair-faq { margin: var(--space-10) 0 var(--space-6); }
.pair-faq h2 { margin: 0 0 var(--space-4); }
.pair-faq .faq-item { margin-bottom: var(--space-2); }

/* Zone-reentry timer (R4) — under signal-card, freshness indicator */
.zone-timer {
  margin: 0 0 var(--space-5);
  padding: var(--space-2) var(--space-3);
  background: var(--bg-elevated);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
  display: inline-block;
}
.zone-timer strong { color: var(--text-primary); }

/* Sticky-on-scroll action panel for desktop (≥1024px).
   Stays in the page at its natural position on mobile/tablet. On wide
   viewports the .pair-actions section becomes sticky to the top of the
   viewport so the watchlist + Binance + alerts CTAs stay reachable. */
@media (min-width: 1024px) {
  .pair-actions {
    position: sticky;
    top: var(--space-4);
    background: var(--bg-primary);
    z-index: 5;
    box-shadow: 0 -8px 16px -8px var(--bg-primary);  /* soft fade above */
    margin-top: var(--space-12);
  }
}

/* ════════════════════════════════════════════════════════════════════════
   Internal pages v2 components (R5 redesign).
   ════════════════════════════════════════════════════════════════════════ */

/* Preferences — sectioned with id-anchors */
.prefs-wrap { max-width: 760px; }
.prefs-section {
  margin-bottom: var(--space-5);
  scroll-margin-top: var(--space-8);  /* anchor lands below sticky header */
}
.prefs-section h2 {
  margin: 0 0 var(--space-2);
  font-size: var(--text-xl);
}
.prefs-subhead {
  margin: var(--space-6) 0 var(--space-2);
  font-size: var(--text-base);
  color: var(--text-secondary);
}
.prefs-select { width: 240px; max-width: 100%; }
.prefs-upgrade { margin-top: var(--space-3); }
.prefs-hint {
  margin: -4px 0 var(--space-2);
  padding-left: var(--space-6);
}

/* Upgrade — locked-features card */
.upgrade-locked-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin: var(--space-6) auto;
  max-width: 480px;
  text-align: left;
}
.upgrade-locked-card h3 {
  margin: 0 0 var(--space-3);
  font-size: var(--text-base);
}
.upgrade-locked-list {
  margin: 0 0 var(--space-3);
  padding-left: var(--space-5);
  list-style: none;
}
.upgrade-locked-list li {
  position: relative;
  margin-bottom: var(--space-2);
  padding-left: var(--space-5);
  color: var(--text-primary);
  font-size: var(--text-sm);
}
.upgrade-locked-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--up-strong);
  font-weight: var(--weight-bold);
}

/* Founder offer states (R5 lifetime endpoint) */
.founder-counter {
  margin: var(--space-3) 0;
  letter-spacing: var(--tracking-wide);
  color: var(--brand-primary);
  font-weight: var(--weight-semibold);
}
.founder-status {
  margin: var(--space-3) 0;
  font-weight: var(--weight-semibold);
}
.founder-offer--soldout {
  border-style: solid;
  border-color: var(--border-default);
  background: var(--bg-elevated);
  opacity: 0.7;
}

/* ════════════════════════════════════════════════════════════════════════
   Blog + Methodology v1 components (R6 redesign).
   ════════════════════════════════════════════════════════════════════════ */

.blog-header { padding: var(--space-12) 0 var(--space-8); border-bottom: 1px solid var(--border-subtle); margin-bottom: var(--space-8); }
.blog-header h1 { font-family: var(--font-display); font-size: var(--text-5xl); letter-spacing: var(--tracking-tight); margin: var(--space-2) 0 var(--space-4); }

.blog-list { list-style: none; padding: 0; margin: 0; }
.blog-list-item {
  padding: var(--space-6) 0;
  border-bottom: 1px solid var(--border-subtle);
}
.blog-list-item:last-child { border-bottom: none; }
.blog-list-title {
  margin: var(--space-2) 0 var(--space-2);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-snug);
}
.blog-list-title a { color: var(--text-primary); }
.blog-list-title a:hover { color: var(--brand-primary); text-decoration: none; }

.blog-meta { display: flex; flex-wrap: wrap; gap: var(--space-1); align-items: center; margin: 0 0 var(--space-2); }
.blog-tag {
  display: inline-block;
  padding: 0 var(--space-1);
  color: var(--brand-primary);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}

/* Single post — long-form prose */
.blog-post { max-width: 720px; margin: 0 auto; padding: var(--space-8) 0; }
.blog-post-head { margin: 0 0 var(--space-8); padding-bottom: var(--space-6); border-bottom: 1px solid var(--border-subtle); }
.blog-post-head h1 {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  margin: var(--space-2) 0 var(--space-3);
}
@media (min-width: 768px) {
  .blog-post-head h1 { font-size: var(--text-5xl); }
}

.blog-body { font-size: var(--text-base); line-height: var(--leading-relaxed); }
.blog-body h2 { margin-top: var(--space-10); font-size: var(--text-2xl); }
.blog-body h3 { margin-top: var(--space-8); font-size: var(--text-xl); }
.blog-body p { margin: 0 0 var(--space-4); }
.blog-body ul, .blog-body ol { margin: 0 0 var(--space-4); padding-left: var(--space-6); }
.blog-body li { margin-bottom: var(--space-2); }
.blog-body a { color: var(--brand-primary); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255, 160, 40, 0.3); }
.blog-body a:hover { text-decoration-color: var(--brand-primary); }
.blog-body code { font-family: var(--font-mono); background: var(--bg-input); padding: 2px 6px; border-radius: var(--radius-sm); font-size: 0.9em; }
.blog-body pre { background: var(--bg-input); padding: var(--space-4); border-radius: var(--radius-md); overflow-x: auto; }
.blog-body pre code { background: transparent; padding: 0; }
.blog-body blockquote {
  border-left: 3px solid var(--brand-primary);
  padding: var(--space-2) var(--space-4);
  margin: var(--space-4) 0;
  color: var(--text-secondary);
}

.blog-post-foot {
  margin-top: var(--space-12);
  padding: var(--space-6);
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  text-align: center;
}
.blog-post-foot .btn { margin-top: var(--space-2); }

/* Methodology TOC */
.blog-toc {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  margin: 0 0 var(--space-8);
}
.blog-toc ul { margin: var(--space-2) 0 0; padding-left: var(--space-5); list-style: none; }
.blog-toc li { margin-bottom: var(--space-1); }
.blog-toc a { color: var(--text-secondary); }
.blog-toc a:hover { color: var(--brand-primary); }

/* ════════════════════════════════════════════════════════════════════════
   Search wait/error pages (Phase 5 — async background search). The wait
   page sits between POST /search and the rendered report once the
   background task finishes; the error page surfaces the .error.txt
   marker the worker writes on failure.
   ════════════════════════════════════════════════════════════════════════ */

.search-wait {
  max-width: 560px;
  margin: 6vh auto 0;
  padding: 0 var(--space-4);
}
.search-wait-card {
  text-align: center;
  padding: var(--space-8) var(--space-6);
}
.search-wait-card h1 {
  margin: var(--space-4) 0 var(--space-2);
  font-size: var(--text-2xl);
  letter-spacing: -0.01em;
}
.search-wait-card p { margin: var(--space-2) 0; }
.search-wait-coin {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  color: var(--brand-primary);
  font-weight: 600;
}

/* Equalizer-bars spinner — 4 vertical bars staggered 150ms apart so the
   composite reads as left→right wave. Inline-flex so it sits centered
   above the heading without flexbox parent gymnastics. */
.search-wait-spinner {
  display: inline-flex;
  align-items: flex-end;
  gap: 5px;
  height: 36px;
}
.search-wait-bar {
  display: inline-block;
  width: 6px;
  background: var(--brand-primary);
  border-radius: 2px;
  animation: search-wait-bounce 1.2s ease-in-out infinite;
}
.search-wait-bar:nth-child(1) { animation-delay: 0s;   }
.search-wait-bar:nth-child(2) { animation-delay: 0.15s; }
.search-wait-bar:nth-child(3) { animation-delay: 0.3s;  }
.search-wait-bar:nth-child(4) { animation-delay: 0.45s; }
@keyframes search-wait-bounce {
  0%, 100% { height: 8px;  opacity: 0.5; }
  50%      { height: 36px; opacity: 1;   }
}

/* Step strip — three-phase indicator (fetch → filter → backtest). The
   pulse dot drifts horizontally so the user can see *something* moving
   between the meta-refresh ticks. Pure CSS, no JS. */
.search-wait-progress {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin: var(--space-4) 0 var(--space-2) !important;
  padding: 6px 14px;
  background: rgba(255, 160, 40, 0.08);
  border: 1px solid rgba(255, 160, 40, 0.25);
  border-radius: 999px;
  font-size: var(--text-sm);
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  color: var(--text-secondary);
}
.search-wait-step { color: var(--text-secondary); }
.search-wait-pulse {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--up-strong);
  box-shadow: 0 0 8px var(--up-strong);
  animation: ps-pulse 2s ease-in-out infinite;
  margin-right: var(--space-1);
}
.search-wait-hint { margin-top: var(--space-4) !important; }

/* Error variant — same shell, muted spinner replaced by a static cross */
.search-wait-failed {
  border-color: var(--down-strong, #DC2626);
}
.search-wait-x {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(220, 38, 38, 0.12);
  color: var(--down-strong, #DC2626);
  font-weight: 700;
  font-size: var(--text-xl);
}
.search-wait-actions { margin-top: var(--space-4) !important; }
