@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");

@font-face {
  font-family: "Geist Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("/static/fonts/geist-mono/geist-mono-latin-400-normal.woff2") format("woff2");
}

@font-face {
  font-family: "Geist Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url("/static/fonts/geist-mono/geist-mono-latin-500-normal.woff2") format("woff2");
}

@font-face {
  font-family: "Geist Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url("/static/fonts/geist-mono/geist-mono-latin-600-normal.woff2") format("woff2");
}

@font-face {
  font-family: "Geist Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url("/static/fonts/geist-mono/geist-mono-latin-700-normal.woff2") format("woff2");
}

:root {
  --font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono: "Geist Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  --radius: 4px;
  --radius-lg: 6px;
}

html[data-palette="light"],
:root {
  color-scheme: light;
  --bg:         #ebebeb;
  --bg-soft:    #f2f2f2;
  --panel:      #fafafa;
  --panel-2:    #dbd7db;
  --ink:        #1c1f1d;
  --ink-2:      #2f3433;
  --muted:      #6a6e69;
  --muted-2:    #8a8d8b;
  --line:       #d6d6d6;
  --line-soft:  #e5dfd0;
  --accent:     #894d67;
  --accent-soft: color-mix(in srgb, var(--accent) 16%, transparent);
  --accent-2:   #15706a;
  --up:         #15706a;
  --up-soft:    color-mix(in srgb, var(--up) 16%, transparent);
  --down:       #a94735;
  --down-soft:  color-mix(in srgb, var(--down) 16%, transparent);
  --grid:       #ededed;
  --sma10:      #c28b22;
  --sma20:      #2f6fa3;
  --sma50:      #6a6e69;
  --on-accent:  #ffffff;
  --shadow-rgb: 42 42 42;
  --overlay:    rgba(26, 26, 26, 0.46);
  --card-shadow: 0 1px 0 rgb(var(--shadow-rgb) / .04), 0 10px 28px -18px rgb(var(--shadow-rgb) / .18);
  --gold:       var(--accent-2);
  --tooltip-bg: #1c1f1d;
  --tooltip-fg: #ebebeb;
  /* Regime traffic-light tokens: must stay distinct from --up/--down in every
     palette (light's --accent-2 is teal, which collides with green). */
  --regime-yellow: #c28b22;
  --regime-orange: #b05a2e;
}

html[data-palette="beige"] {
  color-scheme: light;
  --bg:         #f1ebde;
  --bg-soft:    #ece5d4;
  --panel:      #fbf8f0;
  --panel-2:    #f6f1e3;
  --ink:        #1c1f1d;
  --ink-2:      #2f3433;
  --muted:      #6a6e69;
  --muted-2:    #8a8d87;
  --line:       #d8cfbe;
  --line-soft:  #e5dfd0;
  --accent:     #15706a;
  --accent-soft: color-mix(in srgb, var(--accent) 16%, transparent);
  --accent-2:   #c28b22;
  --up:         #15706a;
  --up-soft:    color-mix(in srgb, var(--up) 16%, transparent);
  --down:       #a94735;
  --down-soft:  color-mix(in srgb, var(--down) 16%, transparent);
  --grid:       #e3dccb;
  --sma10:      #c28b22;
  --sma20:      #2f6fa3;
  --sma50:      #6a6e69;
  --on-accent:  #ffffff;
  --shadow-rgb: 67 54 38;
  --overlay:    rgba(30, 24, 16, 0.5);
  --card-shadow: 0 1px 0 rgb(var(--shadow-rgb) / .04), 0 10px 28px -18px rgb(var(--shadow-rgb) / .18);
  --gold:       var(--accent-2);
  --tooltip-bg: #1c1f1d;
  --tooltip-fg: #f1ebde;
  --regime-yellow: #c28b22;
  --regime-orange: #b05a2e;
}

html[data-palette="dark"] {
  color-scheme: dark;
  /* TradingView-aligned dark palette */
  --bg:         #131722;      /* main canvas */
  --bg-soft:    #1e222d;      /* sidebar / chrome */
  --panel:      #1e222d;      /* cards / inputs */
  --panel-2:    #232732;      /* elevated surfaces (metrics strip) */
  --ink:        #d1d4dc;      /* primary text */
  --ink-2:      #b2b5be;
  --muted:      #787b86;      /* secondary text */
  --muted-2:    #5d6068;
  --line:       #2a2e39;      /* borders / dividers */
  --line-soft:  #1f232d;
  --accent:     #26a69a;      /* TV bullish teal — primary accent */
  --accent-soft: color-mix(in srgb, var(--accent) 14%, transparent);
  --accent-2:   #f7b955;      /* amber for rank / highlights */
  --up:         #26a69a;      /* TV bullish */
  --up-soft:    color-mix(in srgb, var(--up) 14%, transparent);
  --down:       #ef5350;      /* TV bearish */
  --down-soft:  color-mix(in srgb, var(--down) 14%, transparent);
  --grid:       #2a2e39;
  --sma10:      #f7b955;
  --sma20:      #2962ff;      /* TV indicator blue */
  --sma50:      #787b86;
  --on-accent:  #ffffff;
  --shadow-rgb: 0 0 0;
  --overlay:    rgba(0, 0, 0, 0.6);
  --card-shadow: 0 0 0 1px var(--line);
  --gold:       var(--accent-2);
  --tooltip-bg: #d1d4dc;
  --tooltip-fg: #131722;
  --regime-yellow: #f7b955;
  --regime-orange: #ef8250;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.45;
  font-variant-numeric: tabular-nums;
}

button,
input,
select {
  font: inherit;
}

.login-error {
  color: var(--down);
  font-size: 13px;
}

.billing-banner {
  margin: 10px 18px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 35%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent-2) 8%, var(--panel));
  color: var(--ink);
  padding: 10px 12px;
  font-size: 13px;
}

.billing-banner-ok {
  border-color: color-mix(in srgb, var(--up) 32%, var(--line));
  background: color-mix(in srgb, var(--up) 7%, var(--panel));
}

.billing-banner-bad {
  border-color: color-mix(in srgb, var(--down) 35%, var(--line));
  background: color-mix(in srgb, var(--down) 8%, var(--panel));
}

.billing-banner-copy {
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  flex-wrap: wrap;
}

.billing-banner-copy strong {
  font-weight: 750;
}

.billing-banner-copy span {
  color: var(--muted);
}

.billing-banner-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.auth-link {
  justify-self: center;
  border: 0;
  background: transparent;
  color: var(--accent);
  cursor: pointer;
  padding: 2px 4px;
  font-size: 13px;
}

.auth-link:hover {
  text-decoration: underline;
}

/* Trial-ended page (free tier) */
.trial-ended {
  min-height: 100vh;
  background: var(--bg);
  color: var(--ink);
  display: flex;
  flex-direction: column;
}

.trial-ended-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 24px;
  border-bottom: 1px solid var(--line);
}

.trial-ended-header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.trial-ended-main {
  flex: 1;
  display: grid;
  place-items: center;
  padding: 32px 24px 80px;
}

.trial-ended-card {
  width: 100%;
  max-width: 520px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 36px 36px 32px;
  box-shadow: var(--card-shadow);
  text-align: center;
}

.trial-ended-eyebrow {
  display: inline-block;
  border: 1px solid var(--down);
  color: var(--down);
  padding: 2px 12px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 18px;
}

.trial-ended-card h1 {
  margin: 0 0 14px;
  font-family: var(--font-mono);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
}

.trial-ended-card p {
  margin: 0 0 14px;
  color: var(--ink-2);
  font-size: 14px;
  line-height: 1.5;
}

.trial-ended-card .trial-ended-sub {
  color: var(--muted);
  font-size: 13px;
  margin-bottom: 24px;
}

.trial-ended-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 6px;
}

.trial-ended-actions .button {
  padding: 10px 18px;
  text-decoration: none;
  font-size: 13px;
}

/* Landing page */
.landing,
.landing ~ .modal-overlay {
  color-scheme: light;
  --bg:         #ebebeb;
  --bg-soft:    #f2f2f2;
  --panel:      #fafafa;
  --panel-2:    #dbd7db;
  --ink:        #1c1f1d;
  --ink-2:      #2f3433;
  --muted:      #6a6e69;
  --muted-2:    #8a8d8b;
  --line:       #d6d6d6;
  --line-soft:  #e5dfd0;
  --accent:     #894d67;
  --accent-soft: color-mix(in srgb, var(--accent) 16%, transparent);
  --accent-2:   #15706a;
  --up:         #15706a;
  --up-soft:    color-mix(in srgb, var(--up) 16%, transparent);
  --down:       #a94735;
  --down-soft:  color-mix(in srgb, var(--down) 16%, transparent);
  --grid:       #ededed;
  --sma10:      #c28b22;
  --sma20:      #2f6fa3;
  --sma50:      #6a6e69;
  --on-accent:  #ffffff;
  --shadow-rgb: 42 42 42;
  --overlay:    rgba(26, 26, 26, 0.46);
  --card-shadow: 0 1px 0 rgb(var(--shadow-rgb) / .04), 0 10px 28px -18px rgb(var(--shadow-rgb) / .18);
  --gold:       var(--accent-2);
  --tooltip-bg: #1c1f1d;
  --tooltip-fg: #ebebeb;
}

.landing {
  display: block;
  min-height: 100dvh;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.45;
  font-variant-numeric: tabular-nums;
  overflow-x: hidden;
}

.landing a {
  color: inherit;
  text-decoration: none;
}

.landing button,
.landing input {
  font: inherit;
}

.landing .site-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 24px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  background: color-mix(in srgb, var(--bg) 90%, transparent);
  backdrop-filter: blur(12px);
}

.landing .brand,
.landing .hero-brand,
.landing .mock-brand {
  display: inline-flex;
  align-items: baseline;
  gap: 0;
  font-family: var(--font-mono);
  min-width: max-content;
  font-size: 22px;
  font-weight: 600;
}

.landing .brand-q {
  color: var(--accent);
}

.landing .brand-dot {
  color: var(--accent-2);
  margin: 0 -1px;
}

.landing .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
}

.landing .nav-links a {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0;
}

.landing .nav-links a:hover {
  color: var(--ink);
  background: var(--panel-2);
}

.landing .nav-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.landing .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 15px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--panel);
  color: var(--ink);
  cursor: pointer;
  font-weight: 700;
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
  white-space: nowrap;
}

.landing .btn:hover {
  transform: translateY(-1px);
  border-color: var(--muted-2);
}

.landing .btn:active {
  transform: translateY(1px);
}

.landing .btn.primary {
  border-color: var(--accent);
  background: var(--accent);
  color: #ffffff;
}

.landing .btn.dark {
  border-color: var(--ink);
  background: var(--ink);
  color: var(--panel);
}

.landing .start-short {
  display: none;
}

.landing .hero {
  position: relative;
  min-height: 96dvh;
  padding: 86px 24px 48px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  isolation: isolate;
}

.landing .hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(235, 235, 235, 0.96), rgba(235, 235, 235, 0.82) 38%, rgba(235, 235, 235, 0.36) 72%),
    linear-gradient(0deg, rgba(235, 235, 235, 0.95), rgba(235, 235, 235, 0.18) 34%, rgba(235, 235, 235, 0.10));
}

.landing .hero-scene {
  position: absolute;
  inset: 64px 24px 28px;
  z-index: 0;
  display: grid;
  grid-template-columns: 260px minmax(720px, 1fr);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  box-shadow: 0 42px 120px -66px rgb(var(--shadow-rgb) / 0.65);
  transform: translate3d(6%, 0, 0) scale(0.98);
  transform-origin: 70% 50%;
  overflow: hidden;
}

.landing .mock-sidebar {
  border-right: 1px solid var(--line);
  background: var(--bg-soft);
  padding: 18px 14px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.landing .mock-label {
  font-family: var(--font-mono);
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.landing .mock-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px;
}

.landing .mock-tab,
.landing .mock-box,
.landing .mock-plus {
  border: 1px solid var(--line);
  border-radius: 5px;
  background: var(--panel);
}

.landing .mock-tab {
  display: grid;
  place-items: center;
  min-height: 38px;
  font-family: var(--font-mono);
  font-weight: 800;
}

.landing .mock-tab.active {
  border-color: var(--accent);
  background: var(--accent);
  color: #ffffff;
}

.landing .mock-box {
  padding: 13px;
  display: grid;
  gap: 8px;
}

.landing .mock-line {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  color: var(--muted);
  font-size: 11px;
}

.landing .mock-plus {
  margin-top: auto;
  min-height: 54px;
  padding: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--font-mono);
}

.landing .mock-main {
  min-width: 0;
  display: grid;
  grid-template-rows: auto auto 1fr;
  background: var(--bg);
}

.landing .mock-topbar {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 58px;
  padding: 9px 18px;
  border-bottom: 1px solid var(--line);
}

.landing .mock-modes {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
}

.landing .mock-modes span {
  font-family: var(--font-mono);
  padding: 4px 9px;
  border-radius: 999px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.landing .mock-modes .active {
  background: var(--accent);
  color: #ffffff;
}

.landing .mock-search {
  font-family: var(--font-mono);
  width: min(270px, 22vw);
  height: 36px;
  border: 1px solid var(--line);
  border-radius: 5px;
  background: var(--panel);
  color: var(--muted);
  display: flex;
  align-items: center;
  padding: 0 12px;
}

.landing .mock-risk {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
}

.landing .risk-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--down);
  box-shadow: 0 0 0 4px var(--down-soft);
}

.landing .mock-summary {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  padding: 0 28px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
}

.landing .trial-pill {
  padding: 4px 12px;
  border: 1px solid var(--down);
  border-radius: 999px;
  color: var(--down);
  background: var(--panel);
  font-size: 11px;
}

.landing .mock-wall {
  display: grid;
  grid-template-columns: repeat(3, minmax(240px, 1fr));
  gap: 16px;
  align-content: start;
  padding: 20px 28px;
}

.landing .stock-card {
  min-height: 240px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--panel);
  overflow: hidden;
  box-shadow: 0 18px 42px -32px rgb(var(--shadow-rgb) / 0.5);
}

.landing .stock-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 13px 14px 8px;
}

.landing .rank {
  font-family: var(--font-mono);
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 900;
}

.landing .symbol {
  display: inline-block;
  margin-left: 4px;
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 900;
}

.landing .sector {
  margin-top: 2px;
  color: var(--muted);
  font-size: 11px;
}

.landing .score {
  font-family: var(--font-mono);
  color: var(--accent);
  text-align: right;
  font-size: 22px;
  font-weight: 900;
}

.landing .grade {
  font-family: var(--font-mono);
  color: var(--muted);
  text-align: right;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.landing .chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 0 14px 8px;
}

.landing .chip {
  font-family: var(--font-mono);
  padding: 3px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--line-soft);
  color: var(--ink-2);
  font-size: 10px;
  font-weight: 800;
}

.landing .chart {
  width: 100%;
  height: 152px;
  border-top: 1px solid var(--line-soft);
  display: block;
}

.landing .hero-copy {
  position: relative;
  z-index: 2;
  width: min(1120px, 100%);
  margin: 0 auto;
  padding: 120px 0 18px;
}

.landing .eyebrow {
  margin: 0 0 14px;
  color: var(--accent);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0;
}

.landing h1 {
  margin: 0;
  max-width: 720px;
  font-size: 78px;
  line-height: 0.92;
  font-weight: 700;
  letter-spacing: 0;
}

.landing h1 .hero-brand {
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

.landing .hero-copy p {
  max-width: 660px;
  margin: 22px 0 0;
  color: var(--ink-2);
  font-size: 20px;
  line-height: 1.55;
}

.landing .hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.landing .section {
  position: relative;
  padding: 96px 24px;
  border-bottom: 1px solid var(--line);
}

.landing .section-inner {
  width: min(1180px, 100%);
  margin: 0 auto;
}

.landing .section-head {
  display: grid;
  gap: 16px;
  max-width: 820px;
  margin-bottom: 34px;
}

.landing h2 {
  margin: 0;
  max-width: 760px;
  font-size: 46px;
  line-height: 0.98;
  font-weight: 700;
  letter-spacing: 0;
}

.landing .section-head p,
.landing .lead {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.65;
}

.landing .mode-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.landing .mode-card {
  position: relative;
  min-height: 402px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  overflow: hidden;
  box-shadow: 0 18px 42px -34px rgb(var(--shadow-rgb) / 0.42);
  display: grid;
  grid-template-rows: 42px minmax(100px, auto) 132px 1fr;
  gap: 0;
}

.landing .mode-card::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4px;
  background: var(--accent);
  transform: scaleX(var(--mode-fill, 0.78));
  transform-origin: 0 50%;
}

.landing .mode-card.soon {
  background: color-mix(in srgb, var(--panel) 86%, var(--bg-soft));
}

.landing .mode-card.soon::after {
  background: var(--accent-2);
}

.landing .mode-card.soon .mode-tag {
  border-color: color-mix(in srgb, var(--accent-2) 38%, var(--line));
  color: color-mix(in srgb, var(--accent-2) 76%, var(--ink));
  background: color-mix(in srgb, var(--accent-2) 12%, var(--panel));
}

.landing .mode-card header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.landing .mode-name {
  font-size: 18px;
  font-weight: 700;
}

.landing .mode-tag {
  font-family: var(--font-mono);
  padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel-2);
  font-size: 10px;
  font-weight: 900;
}

.landing .mode-card p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.58;
  overflow: hidden;
}

.landing .mode-card .chart {
  height: 132px;
  margin: 0 -16px;
  width: calc(100% + 32px);
  align-self: stretch;
}

.landing .metric-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 7px;
  align-self: end;
  padding-top: 14px;
}

.landing .mini-metric {
  padding: 9px 8px;
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  background: var(--panel-2);
}

.landing .mini-metric b {
  font-family: var(--font-mono);
  display: block;
  color: var(--accent);
  font-size: 15px;
}

.landing .mini-metric span {
  font-family: var(--font-mono);
  display: block;
  color: var(--muted);
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
}

.landing .monitor {
  background: var(--panel-2);
}

.landing .proof {
  background: var(--bg);
}

.landing .proof-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(330px, 0.58fr);
  gap: 18px;
  align-items: stretch;
}

.landing .proof-card,
.landing .score-card,
.landing .detail-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: 0 18px 48px -38px rgb(var(--shadow-rgb) / 0.55);
}

.landing .proof-card {
  overflow: hidden;
}

.landing .proof-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
  border-bottom: 1px solid var(--line);
}

.landing .proof-symbol {
  font-family: var(--font-mono);
  font-size: 26px;
  font-weight: 700;
}

.landing .proof-symbol span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 500;
}

.landing .proof-score {
  display: grid;
  justify-items: end;
  gap: 2px;
  font-family: var(--font-mono);
}

.landing .proof-score strong {
  color: var(--accent);
  font-size: 28px;
  line-height: 1;
}

.landing .proof-score span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
}

.landing .proof-chart {
  width: 100%;
  height: 320px;
  display: block;
}

.landing .proof-callouts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 12px 16px 16px;
  border-top: 1px solid var(--line-soft);
}

.landing .callout {
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  background: var(--panel-2);
}

.landing .callout b {
  display: block;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 12px;
}

.landing .callout span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.landing .score-card {
  padding: 16px;
  display: grid;
  gap: 14px;
}

.landing .score-card h3 {
  margin: 0;
  font-size: 22px;
  line-height: 1.05;
}

.landing .score-card p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.55;
}

.landing .score-bars {
  display: grid;
  gap: 10px;
}

.landing .score-bar {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  background: var(--panel-2);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
}

.landing .score-bar b {
  color: var(--accent);
  font-size: 13px;
}

.landing .detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.landing .detail-card {
  padding: 14px;
}

.landing .detail-card b {
  display: block;
  color: var(--ink);
  font-size: 16px;
}

.landing .detail-card span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.landing .monitor-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(330px, 0.55fr);
  gap: 18px;
  align-items: stretch;
}

.landing .monitor-board,
.landing .monitor-side,
.landing .workflow-panel,
.landing .price-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: 0 18px 48px -38px rgb(var(--shadow-rgb) / 0.55);
}

.landing .monitor-board {
  overflow: hidden;
}

.landing .monitor-toolbar {
  min-height: 58px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
}

.landing .monitor-title {
  font-size: 18px;
  font-weight: 700;
}

.landing .muted {
  color: var(--muted);
  font-size: 13px;
}

.landing .regime-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  padding: 0 11px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 900;
}

.landing .monitor-chart {
  width: 100%;
  height: 360px;
  display: block;
}

.landing .monitor-context {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding: 12px 16px 16px;
  border-top: 1px solid var(--line-soft);
}

.landing .context-chip {
  padding: 9px 10px;
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  background: var(--panel-2);
  font-family: var(--font-mono);
}

.landing .context-chip b {
  display: block;
  color: var(--accent);
  font-size: 12px;
}

.landing .context-chip span {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
  text-transform: uppercase;
}

.landing .monitor-side {
  padding: 16px;
  display: grid;
  gap: 12px;
}

.landing .heat-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  background: var(--panel-2);
}

.landing .heat-row span {
  font-family: var(--font-mono);
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.landing .heat-row strong {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 13px;
}

.landing .heat-row.hot strong {
  color: var(--down);
}

.landing .heat-row.gold strong {
  color: var(--accent-2);
}

.landing .watch-mini {
  display: grid;
  gap: 8px;
  margin-top: 6px;
}

.landing .watch-line {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  align-items: center;
  padding: 9px 10px;
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  background: var(--panel-2);
  font-family: var(--font-mono);
}

.landing .watch-line b {
  font-size: 13px;
}

.landing .watch-line span {
  color: var(--muted);
  font-size: 11px;
}

.landing .watch-line strong {
  color: var(--accent);
}

.landing .workflow-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.landing .workflow-panel {
  padding: 18px;
  min-height: 250px;
  display: grid;
  align-content: start;
  gap: 14px;
}

.landing .step-num {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  font-family: var(--font-mono);
  border-radius: 50%;
  background: var(--accent);
  color: #ffffff;
  font-weight: 900;
}

.landing .workflow-panel h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
}

.landing .workflow-panel p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6;
}

.landing .slider-demo {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.landing .slider-demo i {
  display: block;
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent) var(--w), var(--line-soft) var(--w));
}

.landing .pricing {
  background: var(--bg);
}

.landing .pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.landing .price-card {
  position: relative;
  padding: 24px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.landing .price-card.featured {
  border-color: var(--accent);
  box-shadow: 0 24px 74px -44px rgb(21 112 106 / 0.7);
}

.landing .price-card header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  min-height: 118px;
}

.landing .plan {
  margin: 0 0 7px;
  font-size: 24px;
  font-weight: 700;
}

.landing .price {
  display: flex;
  align-items: baseline;
  gap: 7px;
  color: var(--ink);
}

.landing .price strong {
  font-size: 42px;
  line-height: 1;
  font-weight: 700;
}

.landing .price span {
  color: var(--muted);
}

.landing .plan-badge {
  font-family: var(--font-mono);
  padding: 5px 9px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel-2);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.landing .price-card.featured .plan-badge {
  border-color: var(--accent);
  background: var(--accent);
  color: #ffffff;
}

.landing .plan-cta {
  width: 100%;
  margin-top: 16px;
}

.landing .plan-fit {
  min-height: 44px;
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.landing .features {
  list-style: none;
  margin: 18px 0 0;
  padding: 18px 0 0;
  border-top: 1px solid var(--line);
  min-height: 192px;
  display: grid;
  gap: 11px;
}

.landing .features li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 9px;
  font-size: 16px;
  color: var(--ink-2);
}

.landing .features li::before {
  content: "";
  width: 12px;
  height: 12px;
  margin-top: 4px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: inset 0 0 0 3px var(--accent-soft);
}

.landing .small-note {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.landing .plan-note {
  margin: 18px 0 0;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.landing .final {
  padding: 78px 24px;
  background: var(--ink);
  color: var(--panel);
}

.landing .final .section-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.landing .final h2 {
  color: #ffffff;
}

.landing .final p {
  max-width: 640px;
  color: color-mix(in srgb, var(--panel) 72%, transparent);
}

.landing .final .btn {
  min-width: 180px;
  border-color: var(--panel);
}

.landing .disclaimer {
  padding: 24px;
  color: var(--muted);
  background: var(--bg-soft);
  font-size: 11px;
  line-height: 1.65;
}

.landing .disclaimer .section-inner {
  display: grid;
  gap: 8px;
}

.landing .reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.18, 0.82, 0.24, 1);
}

.landing .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.landing .reveal:nth-child(2) {
  transition-delay: 0.08s;
}

.landing .reveal:nth-child(3) {
  transition-delay: 0.16s;
}

.landing .reveal:nth-child(4) {
  transition-delay: 0.24s;
}

@media (max-width: 1160px) {
  .landing .hero-scene {
    grid-template-columns: 210px minmax(720px, 1fr);
    transform: translate3d(12%, 0, 0) scale(0.94);
  }

  .landing .mock-wall {
    grid-template-columns: repeat(2, minmax(240px, 1fr));
  }

  .landing .mode-grid,
  .landing .workflow-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .landing .site-nav {
    padding: 10px 14px;
  }

  .landing .nav-links {
    display: none;
  }

  .landing .hero {
    min-height: 92dvh;
    padding: 76px 18px 48px;
  }

  .landing .hero-scene {
    inset: 62px -420px 52px 18px;
    grid-template-columns: 190px 720px;
    transform: translate3d(0, 0, 0) scale(0.9);
    transform-origin: left center;
    opacity: 0.82;
  }

  .landing .hero::before {
    background:
      linear-gradient(90deg, rgba(235, 235, 235, 0.98), rgba(235, 235, 235, 0.9) 54%, rgba(235, 235, 235, 0.5)),
      linear-gradient(0deg, rgba(235, 235, 235, 0.96), rgba(235, 235, 235, 0.2) 42%);
  }

  .landing h1 {
    font-size: 48px;
    line-height: 1;
  }

  .landing .hero-copy p {
    font-size: 16px;
  }

  .landing .section {
    padding: 72px 18px;
  }

  .landing .proof-layout,
  .landing .monitor-layout,
  .landing .pricing-grid,
  .landing .final .section-inner {
    grid-template-columns: 1fr;
    display: grid;
  }

  .landing h2 {
    font-size: 32px;
  }

  .landing .mode-grid,
  .landing .workflow-grid {
    grid-template-columns: 1fr;
  }

  .landing .monitor-chart {
    height: 280px;
  }

  .landing .proof-chart {
    height: 260px;
  }

  .landing .proof-callouts,
  .landing .monitor-context,
  .landing .detail-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .landing .brand {
    font-size: 17px;
  }

  .landing .btn {
    min-height: 36px;
    padding: 0 9px;
    font-size: 12px;
  }

  .landing .site-nav {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 8px;
    padding-bottom: 10px;
    width: 100vw;
    max-width: 100vw;
    overflow: hidden;
  }

  .landing .nav-actions {
    justify-self: stretch;
    width: min(calc(100vw - 28px), 360px);
    max-width: min(calc(100vw - 28px), 360px);
    min-width: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
  }

  .landing .nav-actions .btn {
    width: 100%;
    min-width: 0;
  }

  .landing .nav-start .start-full {
    display: none;
  }

  .landing .nav-start .start-short {
    display: inline;
  }

  .landing h1 {
    font-size: 42px;
  }

  .landing .mock-sidebar {
    display: none;
  }

  .landing .hero-scene {
    grid-template-columns: 720px;
    inset: 96px -520px 52px -80px;
  }

  .landing .mock-topbar {
    gap: 8px;
  }

  .landing .mock-brand,
  .landing .mock-search,
  .landing .mock-risk {
    display: none;
  }

  .landing .mock-wall {
    grid-template-columns: 1fr;
    width: 420px;
  }

  .landing .price-card {
    padding: 18px;
  }

  .landing .price-card header {
    display: grid;
  }
}

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

  .landing .reveal {
    opacity: 1;
    transform: none;
  }
}

/* Auth modal */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 24px;
  background: var(--overlay);
  backdrop-filter: blur(2px);
}

.auth-modal {
  position: relative;
  width: min(400px, 100%);
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--panel);
  padding: 28px;
  box-shadow: 0 24px 60px rgb(var(--shadow-rgb) / 0.35);
}

.auth-modal h2 {
  margin: 0;
  font-size: 22px;
}

.auth-modal p {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  color: var(--muted);
}

.auth-modal input {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 11px 12px;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-mono);
}

.auth-modal input:focus {
  outline: 1px solid var(--accent);
  border-color: var(--accent);
}

.modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--muted);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.modal-close:hover {
  background: var(--bg);
  color: var(--ink);
}

/* Customize colors modal */
.customize-modal {
  position: relative;
  width: min(560px, 100%);
  max-height: min(82vh, 760px);
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--panel);
  box-shadow: 0 24px 60px rgb(var(--shadow-rgb) / 0.35);
}

.customize-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 20px 24px 12px;
  border-bottom: 1px solid var(--line);
}

.customize-head h2 {
  margin: 0;
  font-size: 18px;
}

.customize-head p {
  margin: 4px 0 0;
  font-size: 12px;
  line-height: 1.4;
  color: var(--muted);
}

.customize-body {
  overflow: auto;
  padding: 4px 24px 16px;
}

.customize-group {
  margin-top: 16px;
}

.customize-group h3 {
  margin: 0 0 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.customize-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px 18px;
}

.customize-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 0;
  min-width: 0;
  cursor: pointer;
}

.customize-row-label {
  min-width: 0;
  font-size: 12.5px;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.customize-swatch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.customize-hex {
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
}

.customize-row input[type="color"] {
  width: 34px;
  height: 24px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  cursor: pointer;
}

.customize-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 24px;
  border-top: 1px solid var(--line);
}

@media (max-width: 520px) {
  .customize-grid {
    grid-template-columns: 1fr;
  }
}

/* User menu */
.user-menu {
  position: relative;
}

.user-menu-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--panel);
  color: var(--muted);
  cursor: pointer;
}

.user-menu-trigger.active,
.user-menu-trigger:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

.user-menu-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 20;
  min-width: 200px;
  padding: 6px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--card-shadow);
}

.user-menu-label {
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
  color: var(--muted);
}

.user-menu-email {
  padding: 6px 10px 8px;
  max-width: 240px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}

.user-menu-item {
  width: 100%;
  text-align: left;
  border: 0;
  border-radius: var(--radius);
  background: transparent;
  color: var(--ink);
  padding: 9px 10px;
  font-size: 13px;
  cursor: pointer;
}

.user-menu-item:hover {
  background: var(--bg-soft);
}

.user-menu-item-theme {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.user-menu-value {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0;
}

.app {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 340px 1fr;
  isolation: isolate;
}

.app.sidebar-collapsed {
  grid-template-columns: 44px 1fr;
}

.sidebar {
  height: 100vh;
  height: 100dvh;
  max-height: 100vh;
  max-height: 100dvh;
  overflow: auto;
  border-right: 1px solid var(--line);
  background: var(--bg-soft);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: sticky;
  top: 0;
  align-self: start;
  z-index: 8;
}

.sidebar::-webkit-scrollbar { width: 8px; }
.sidebar::-webkit-scrollbar-thumb { background: var(--line); border-radius: 4px; }

.sidebar-rail {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--line);
}

.rail-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
  color: var(--muted);
}

.sidebar-content {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.sidebar-collapsed .sidebar {
  overflow: hidden;
  padding: 10px;
}

.sidebar-collapsed .sidebar-rail {
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-bottom: 0;
  padding-bottom: 0;
}

.sidebar-collapsed .sidebar-content {
  display: none;
}

.eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--muted);
}

.actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.actions .action-wide {
  grid-column: 1 / -1;
}

.view-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}

.view-switch button {
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--ink);
  border-radius: var(--radius);
  padding: 7px 10px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 500;
}

.view-switch button:hover:not(.active) {
  border-color: var(--muted-2);
}

.view-switch button.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--on-accent);
}

.button {
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--ink);
  border-radius: var(--radius);
  padding: 7px 12px;
  cursor: pointer;
  text-align: center;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
}

.button:hover:not(:disabled) {
  border-color: var(--muted-2);
}

.button.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--on-accent);
}

.button.primary:hover:not(:disabled) {
  filter: brightness(0.95);
  border-color: var(--accent);
}

.button-ghost {
  background: transparent;
}

.button:disabled {
  cursor: default;
  opacity: 0.55;
}

.mode-pill-link {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--muted);
}

.mode-pill-link:hover {
  color: var(--ink);
  border-color: var(--muted-2);
  background: transparent;
}

.status {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  padding: 10px 12px;
  font-size: 11px;
  color: var(--muted);
  display: grid;
  gap: 4px;
  line-height: 1.4;
}

.status-warning {
  margin-top: 4px;
  color: var(--down);
  font-weight: 600;
  line-height: 1.35;
}

.status-working {
  color: var(--accent);
  font-weight: 600;
  line-height: 1.35;
}

.preset-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  padding: 10px 12px;
  display: grid;
  gap: 8px;
}

.preset-panel h2 {
  margin: 0;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0;
}

.panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.plus-body,
.preset-inline {
  display: grid;
  gap: 8px;
}

.plus-panel {
  margin-bottom: 12px;
}

.preset-panel input,
.preset-panel select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg);
  color: var(--ink);
  padding: 7px 10px;
  font-size: 12px;
}

.preset-panel input:focus,
.preset-panel select:focus {
  outline: 1px solid var(--accent);
  border-color: var(--accent);
}

.preset-actions {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 5px;
}

.preset-actions .button {
  min-width: 0;
  padding: 6px 5px;
  font-size: 10.5px;
  white-space: nowrap;
}

.file-hidden {
  display: none;
}

.options-panel {
  display: grid;
  gap: 10px;
  padding-top: 4px;
}

.option-title {
  margin-top: 4px;
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
}

.option-row {
  display: grid;
  grid-template-columns: 18px 1fr;
  align-items: center;
  gap: 10px;
  color: var(--ink);
  font-size: 12px;
  line-height: 1.3;
  justify-content: start;
  text-align: left;
}

.option-row input[type="checkbox"] {
  margin: 0;
  accent-color: var(--accent);
}

.sector-list {
  display: grid;
  gap: 8px;
  max-height: 170px;
  overflow: auto;
  padding: 2px 4px 2px 0;
}

.control-section {
  margin-top: 10px;
  border-top: 1px solid var(--line);
  padding-top: 9px;
}

.control-section-title {
  margin: 0 0 7px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: 0;
}

.group {
  margin-top: 9px;
}

.group h3 {
  margin: 0 0 6px;
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
}

.control {
  padding: 8px 0;
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.control-slider {
  padding: 7px 0;
  gap: 4px;
}

.control:last-child {
  border-bottom: 0;
}

.control-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(96px, max-content);
  align-items: baseline;
  gap: 10px;
}

.control-label {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.3;
  min-width: 0;
}

.control-bool .control-row {
  align-items: center;
}

.control-foot {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  margin-top: 2px;
}

.control-foot .desc {
  margin-top: 0;
}

.label-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-self: end;
  flex-shrink: 0;
}

.info {
  width: 16px;
  height: 16px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--panel);
  color: var(--muted);
  cursor: help;
  font-size: 10px;
  font-weight: 600;
  line-height: 14px;
  text-align: center;
  flex: 0 0 auto;
}

.label-wrap:hover .info,
.label-wrap:focus-within .info {
  color: var(--accent);
  border-color: var(--accent);
}

.tooltip {
  position: absolute;
  right: 0;
  bottom: calc(100% + 8px);
  z-index: 10;
  width: min(280px, calc(100vw - 48px));
  padding: 10px 12px;
  border: 1px solid var(--ink-2);
  border-radius: var(--radius);
  background: var(--tooltip-bg);
  color: var(--tooltip-fg);
  box-shadow: var(--card-shadow);
  font-size: 11.5px;
  font-weight: 400;
  line-height: 1.4;
  text-align: left;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: normal;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}

.tooltip::after {
  content: "";
  position: absolute;
  right: 4px;
  top: 100%;
  border: 6px solid transparent;
  border-top-color: var(--tooltip-bg);
}

.label-wrap:hover .tooltip,
.label-wrap:focus-within .tooltip {
  opacity: 1;
  visibility: visible;
}

.value {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 7px;
  color: var(--accent);
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: 11.5px;
  font-weight: 500;
  white-space: nowrap;
  justify-self: end;
  text-align: right;
}

.value-num {
  white-space: nowrap;
}

.rejected-count {
  color: var(--down);
  font-weight: 500;
  font-size: 10.5px;
}

.control input[type="range"] {
  width: 100%;
  accent-color: var(--accent);
  height: 4px;
}

.control[data-spec="min_leader_1m_high_gap_pct"] .control-label,
.control[data-spec="min_leader_1m_high_gap_pct"] .value {
  color: var(--down);
}

.control[data-spec="min_leader_1m_high_gap_pct"] input[type="range"],
.control[data-spec="min_leader_1m_high_gap_pct"] input[type="checkbox"] {
  accent-color: var(--down);
}

.control[data-spec="min_leader_1m_high_gap_pct"] .slider-number:focus {
  outline-color: var(--down);
  border-color: var(--down);
}

.slider-stack {
  display: grid;
  gap: 4px;
}

.slider-tools {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}

.control .slider-tools .slider-number {
  width: 74px;
  padding: 4px 7px;
  font-size: 11.5px;
}

.mini-toggle {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 10.5px;
  font-weight: 500;
  white-space: nowrap;
}

.mini-toggle input[type="checkbox"] {
  margin: 0;
  accent-color: var(--accent);
}

.control input[type="number"],
.control input[type="text"],
.control select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg);
  color: var(--ink);
  padding: 6px 9px;
  font-size: 12px;
}

.control input[type="number"]:focus,
.control input[type="text"]:focus,
.control select:focus {
  outline: 1px solid var(--accent);
  border-color: var(--accent);
}

.control-search {
  display: grid;
  gap: 6px;
  margin-top: 4px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--muted);
}

.control-search input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg);
  color: var(--ink);
  padding: 7px 9px;
  font-size: 12px;
  font-weight: 500;
  text-transform: none;
}

.control-search input:focus {
  outline: 1px solid var(--accent);
  border-color: var(--accent);
}

.tog {
  width: 30px;
  height: 18px;
  border-radius: 999px;
  background: var(--line);
  position: relative;
  cursor: pointer;
  border: 0;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.15s ease;
}

.tog::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--panel);
  box-shadow: 0 1px 2px rgb(var(--shadow-rgb) / 0.2);
  transition: transform 0.15s ease;
}

.tog.on {
  background: var(--accent);
}

.tog.on::after {
  transform: translateX(12px);
}

.desc {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.3;
  margin-top: 2px;
}

.main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 0;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 4;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  padding: 6px 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.topbar-primary,
.topbar-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.topbar-primary {
  flex-shrink: 0;
}

.topbar-actions {
  flex: 1;
}

.topbar .topbar-mobile-toggle,
.topbar-mobile-title {
  display: none;
}

.brand-mark {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0;
  color: var(--ink);
  white-space: nowrap;
  flex-shrink: 0;
}

.brand-q {
  color: var(--accent);
}

.brand-dot {
  color: var(--accent-2);
  margin: 0 -0.08em;
}

.topbar-title {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
  color: var(--ink);
}

.mode-selector {
  position: relative;
  flex-shrink: 0;
}

.mode-current {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px;
  background: var(--panel);
  cursor: pointer;
  color: var(--muted);
}

.mode-current:hover .mode-caret {
  color: var(--ink);
}

.mode-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  color: var(--muted);
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s ease, color 0.12s ease;
}

.mode-caret {
  width: 21px;
  height: 21px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  border-radius: 999px;
  transition: color 0.12s ease, background 0.12s ease;
}

.mode-caret svg {
  display: block;
}

.mode-pill:hover:not(.active) {
  color: var(--ink);
}

.mode-pill.active {
  background: var(--accent);
  color: var(--on-accent);
}

.mode-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 40;
  min-width: 176px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 5px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.14);
}

.mode-menu .mode-pill {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
}

.mode-menu-section-label {
  margin: 5px 4px 2px;
  padding-top: 6px;
  border-top: 1px solid var(--line-soft);
  color: var(--muted);
  font-size: 10px;
  font-weight: 650;
  text-transform: uppercase;
  letter-spacing: 0;
}

.mode-menu-section-label:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.snapshot-picker {
  height: 32px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  color: var(--muted);
  font-size: 11px;
  white-space: nowrap;
  flex-shrink: 0;
}

.snapshot-picker select {
  width: 156px;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  cursor: pointer;
}

.snapshot-picker select:focus {
  outline: 1px solid var(--accent);
  outline-offset: 2px;
}

.search {
  position: relative;
  flex: 1 1 170px;
  min-width: 160px;
  max-width: 260px;
}

.symbol-search {
  width: 100%;
  height: 32px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--ink);
  border-radius: var(--radius);
  padding: 0 12px 0 30px;
  font: inherit;
  font-size: 12.5px;
  font-variant-ligatures: none;
  font-feature-settings: "liga" 0, "calt" 0;
  text-overflow: clip;
}

.symbol-search:focus {
  outline: 1px solid var(--accent);
  border-color: var(--accent);
}

.search-placeholder {
  position: absolute;
  left: 30px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  font: inherit;
  font-size: 12.5px;
  font-variant-ligatures: none;
  font-feature-settings: "liga" 0, "calt" 0;
  line-height: 1;
  pointer-events: none;
  white-space: nowrap;
}

.search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  pointer-events: none;
}

.search-hint {
  position: absolute;
  left: 0;
  top: calc(100% + 7px);
  z-index: 12;
  width: max-content;
  max-width: min(260px, calc(100vw - 32px));
  padding: 7px 9px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--tooltip-bg);
  color: var(--tooltip-fg);
  box-shadow: var(--card-shadow);
  font-size: 11px;
  line-height: 1.35;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity 0.12s ease, visibility 0.12s ease;
}

.search:hover .search-hint,
.search:focus-within .search-hint {
  opacity: 1;
  visibility: visible;
}

.topbar-spacer {
  flex: 1;
}

.mm-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 6px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  font-size: 12px;
  color: var(--ink);
  white-space: nowrap;
  flex-shrink: 0;
  cursor: pointer;
  transition: border-color 0.12s ease;
}

.mm-pill:hover {
  border-color: var(--muted-2);
}

.mm-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--up);
  box-shadow: 0 0 0 3px var(--up-soft);
  flex-shrink: 0;
}

.mm-pill .state {
  font-weight: 600;
  letter-spacing: 0;
}

.mm-pill .meta {
  color: var(--muted);
  font-size: 11px;
}

@media (max-width: 1100px) {
  .mm-pill .meta { display: none; }
}

.mm-pill.regime-red .mm-dot,
.mm-pill.defensive .mm-dot,
.mm-pill.selective-short-term-pressure .mm-dot,
.mm-pill.overheated-pullback-risk .mm-dot,
.mm-pill.defensive-tape-setups-holding .mm-dot {
  background: var(--down);
  box-shadow: 0 0 0 3px var(--down-soft);
}

.mm-pill.regime-orange .mm-dot {
  background: var(--regime-orange);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--regime-orange) 20%, transparent);
}

.mm-pill.regime-yellow .mm-dot,
.mm-pill.oversold-bounce-watch .mm-dot,
.mm-pill.constructive-but-setup-light .mm-dot,
.mm-pill.selective-setups-holding .mm-dot {
  background: var(--regime-yellow);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--regime-yellow) 20%, transparent);
}

.mm-pill.regime-green .mm-dot,
.mm-pill.risk-on-dashboard-confirmed .mm-dot,
.mm-pill.breakout-friendly .mm-dot {
  background: var(--up);
  box-shadow: 0 0 0 3px var(--up-soft);
}

.mm-pill.loading .mm-dot,
.mm-pill.no-data .mm-dot {
  background: var(--muted);
  box-shadow: 0 0 0 3px var(--line);
}

.mm-pill.loading,
.mm-pill.no-data {
  color: var(--muted);
}

.subheader {
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  padding: 8px 24px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
}

.crumb {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  flex-wrap: wrap;
  white-space: normal;
  min-width: 0;
  overflow: visible;
  text-overflow: ellipsis;
}

.crumb h1 {
  margin: 0;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.05;
  white-space: nowrap;
}

.crumb .count {
  color: var(--muted);
  font-size: 13px;
  white-space: nowrap;
}

.crumb .count strong {
  color: var(--ink);
  font-weight: 600;
}

.bubble-picker {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  min-width: 0;
  color: var(--muted);
  font-size: 10px;
  font-weight: 650;
  white-space: nowrap;
}

.bubble-picker > span {
  margin-right: 3px;
  color: var(--muted);
}

.bubble-picker button {
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--muted);
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 650;
  line-height: 1;
  cursor: pointer;
}

.bubble-picker button:hover {
  border-color: var(--muted-2);
  color: var(--ink);
}

.bubble-picker button:disabled {
  cursor: default;
  opacity: 0.45;
}

.bubble-picker button:disabled:hover {
  border-color: var(--line);
  color: var(--muted);
}

.bubble-picker button.active {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

.bubble-picker strong {
  color: var(--ink);
  font-weight: 750;
}

.chart-export-status {
  margin-left: 4px;
  color: var(--accent);
  font-weight: 750;
}

.bubble-picker button.custom-run-button {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--on-accent);
  font-weight: 750;
  box-shadow: 0 0 0 2px var(--accent-soft);
}

.bubble-picker button.custom-run-button:hover:not(:disabled) {
  color: var(--on-accent);
  filter: brightness(0.96);
}

.bubble-picker button.custom-run-button:disabled {
  cursor: default;
  opacity: 0.58;
}

.crumb .count em {
  font-style: normal;
  color: var(--accent);
  font-weight: 600;
}

.subheader-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-self: end;
}

.data-trust-strip {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 24px;
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  color: var(--muted);
  font-size: 10.5px;
  overflow-x: auto;
}

.data-trust-item {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  min-width: max-content;
  padding: 3px 7px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
}

.data-trust-item strong {
  color: var(--ink);
  font-weight: 700;
}

.data-trust-item.ok strong {
  color: var(--up);
}

.data-trust-item.warn strong {
  color: var(--accent-2);
}

.data-trust-item.bad strong {
  color: var(--down);
}

.result-count {
  color: var(--ink);
  font-weight: 500;
}

.density-picker {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 2px;
  background: var(--panel);
  gap: 1px;
}

.density-picker button {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  color: var(--muted);
  border-radius: 999px;
  cursor: pointer;
  font-size: 11px;
  padding: 0;
}

.density-picker button:hover:not(.active) {
  color: var(--ink);
}

.density-picker button.active {
  background: var(--accent);
  color: var(--on-accent);
}

.investigation-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 24px 0;
  font-size: 12px;
  color: var(--muted);
}

.investigation-bar-label strong {
  color: var(--ink);
  font-weight: 600;
}

.custom-stale-banner {
  margin: 12px 24px 0;
  padding: 10px 14px;
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 12px;
  font-weight: 650;
}

.custom-stale-wall .card {
  opacity: 0.42;
  filter: grayscale(0.35) saturate(0.62);
}

.custom-stale-wall .card:hover {
  opacity: 0.58;
}

.investigation-wall {
  padding-top: 12px;
  padding-bottom: 0;
}

.investigation-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-soft);
  border-color: var(--line-soft);
  box-shadow: none;
  opacity: 0.78;
  transition: opacity 0.12s ease, border-color 0.12s ease;
}

.investigation-card:hover {
  opacity: 1;
  border-color: var(--muted-2);
}

.investigation-card .symbol {
  color: var(--muted);
}

.investigation-card.bad {
  border-color: var(--down);
  opacity: 0.92;
}

.investigation-card-summary {
  padding: 0 12px 8px;
  color: var(--muted);
  font-size: 11.5px;
  line-height: 1.4;
}

.investigation-card.bad .investigation-card-summary {
  color: var(--down);
}

.investigation-card-chips {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 12px 12px;
  background: var(--panel-2);
  border-top: 1px solid var(--line-soft);
}

.investigation-card-chips .investigation-list {
  margin-top: 0;
}

.investigation {
  border-bottom: 1px solid var(--line);
  background: var(--panel);
  padding: 10px 22px;
  color: var(--muted);
  font-size: 13px;
}

.investigation.bad {
  color: var(--down);
}

.investigation-title {
  font-weight: 600;
}

.investigation-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.investigation-chip {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px;
  border: 1px solid var(--down-soft);
  border-radius: 14px;
  background: var(--down-soft);
  color: var(--down);
  padding: 4px 10px;
  font-size: 11.5px;
  font-weight: 500;
  line-height: 1.4;
  white-space: normal;
  text-align: left;
  max-width: 100%;
  cursor: pointer;
  transition: border-color 0.12s ease, background 0.12s ease;
}

.investigation-chip:hover {
  border-color: var(--down);
  background: color-mix(in srgb, var(--down) 18%, transparent);
}

.investigation-chip.marginal {
  border-color: var(--line);
  background: var(--bg-soft);
  color: var(--ink-2);
}

.investigation-chip.marginal:hover {
  border-color: var(--muted-2);
  background: var(--panel);
}

.investigation-chip.marginal .chip-current {
  color: var(--ink-2);
  opacity: 0.85;
}

.investigation-chip.marginal .chip-needed {
  color: var(--accent);
}

.investigation-chip:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

@keyframes control-flash {
  0%   { background: transparent; }
  20%  { background: var(--accent-soft); }
  100% { background: transparent; }
}

.control-flash {
  animation: control-flash 1.6s ease-out;
  border-radius: var(--radius);
}

.investigation-chip .chip-label {
  font-weight: 600;
}

.investigation-chip .chip-current {
  color: var(--down);
  opacity: 0.85;
}

.investigation-chip .chip-value {
  color: var(--ink-2);
  opacity: 0.9;
}

.investigation-chip .chip-arrow {
  color: var(--muted);
  font-weight: 400;
  margin: 0 2px;
}

.investigation-chip .chip-needed {
  color: var(--accent);
  font-weight: 600;
}

.investigation-chart {
  max-width: 620px;
  margin-top: 10px;
}

.investigation-chart .chart {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  opacity: 0.66;
  filter: saturate(0.72);
}

.wall {
  flex: 1;
  padding: 18px 24px 64px;
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(min(340px, 100%), 1fr));
  align-content: start;
  justify-content: center;
}

.wall.density-1 { grid-template-columns: repeat(auto-fill, minmax(min(440px, 100%), 480px)); gap: 20px; }
.wall.density-2 { grid-template-columns: repeat(auto-fill, minmax(min(340px, 100%), 1fr)); gap: 14px; }
.wall.density-3 { grid-template-columns: repeat(auto-fill, minmax(min(260px, 100%), 1fr)); gap: 10px; }

.wall-item {
  display: contents;
}

.wall-spacer {
  grid-column: 1 / -1;
  min-height: 0;
  pointer-events: none;
}

.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 302px;
  box-shadow: var(--card-shadow);
  transition: border-color 0.12s ease;
}

.card:hover {
  border-color: var(--muted-2);
}

.card-breakout-confirmed {
  border-color: color-mix(in srgb, var(--up) 72%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--up) 20%, transparent), transparent 94px),
    var(--panel);
}

.card-breakout-failed {
  border-color: color-mix(in srgb, var(--down) 72%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--down) 19%, transparent), transparent 94px),
    var(--panel);
}

.card-breakout-pending {
  border-color: color-mix(in srgb, var(--accent-2) 62%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent-2) 14%, transparent), transparent 94px),
    var(--panel);
}

.card-head {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  align-items: start;
  padding: 12px 12px 6px;
}

.id-block {
  display: flex;
  align-items: baseline;
  gap: 7px;
  min-width: 0;
}

.id-stack {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.id-line {
  display: flex;
  align-items: baseline;
  gap: 7px;
  min-width: 0;
  line-height: 1;
}

.id-sub {
  color: var(--muted);
  font-size: 11px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 1px;
}

.id-sub.sector-healthcare {
  color: var(--down);
}

.rank {
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 700;
}

.symbol {
  color: var(--ink);
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: 0;
}

.symbol:hover,
.symbol:focus {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.ext-link {
  align-self: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--muted);
  font-size: 9.5px;
  font-weight: 500;
  line-height: 1;
  padding: 2px 6px;
  text-decoration: none;
  letter-spacing: 0;
}

.ext-link:hover,
.ext-link:focus {
  border-color: var(--accent);
  color: var(--accent);
}

.score-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1;
}

.score {
  color: var(--accent);
  font-size: 18px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.score-block .grade {
  margin-top: 5px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
  line-height: 1;
}

.card-actions {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.expand-btn,
.hide-card-btn {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--panel);
  color: var(--muted);
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  padding: 0;
  transition: background 0.12s ease, border-color 0.12s ease, color 0.12s ease;
}

.expand-btn:hover,
.hide-card-btn:hover {
  color: var(--ink);
  border-color: var(--muted-2);
}

.expand-btn.open {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent);
}

.hide-card-btn svg {
  display: block;
}

.icon-button {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--panel);
  color: var(--accent);
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  padding: 0;
}

.icon-button.active {
  background: var(--accent-soft);
  border-color: var(--accent);
}

.sidebar-toggle,
.section-toggle {
  background: var(--panel);
  border-color: var(--line);
  color: var(--accent);
  transition: border-color 0.12s ease;
}

.sidebar-toggle:hover,
.section-toggle:hover {
  border-color: var(--accent);
}

.sidebar-toggle svg,
.section-toggle svg {
  display: block;
}

.section-toggle.active {
  background: var(--panel);
}


.grade {
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 750;
  text-transform: uppercase;
  letter-spacing: 0;
}

.signal-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  min-width: 0;
  padding: 0 12px 7px;
  overflow: visible;
}

.signal-pill {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  flex: 0 0 auto;
  max-width: calc(100% - 2px);
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--ink-2);
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  padding: 3px 8px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.signal-pill span {
  color: var(--muted);
  flex: 0 0 auto;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0;
}

.signal-pill strong {
  flex: 0 0 auto;
  color: var(--ink);
  font-weight: 700;
}

.signal-pill.steady.good {
  border-color: var(--up);
  background: var(--up-soft);
}

.signal-pill.steady.good strong {
  color: var(--up);
}

.signal-pill.steady.watch {
  border-color: var(--accent-2);
}

.signal-pill.steady.watch strong {
  color: var(--accent-2);
}

.signal-pill.steady.bad {
  border-color: var(--down);
  background: var(--down-soft);
}

.signal-pill.steady.bad strong {
  color: var(--down);
}

.signal-pill.confirmation.confirmed {
  border-color: var(--up);
  background: var(--up-soft);
}

.signal-pill.confirmation.confirmed strong {
  color: var(--up);
}

.signal-pill.confirmation.failed {
  border-color: var(--down);
  background: var(--down-soft);
}

.signal-pill.confirmation.failed strong {
  color: var(--down);
}

.signal-pill.confirmation.pending {
  border-color: var(--accent-2);
  background: color-mix(in srgb, var(--accent-2) 12%, transparent);
}

.signal-pill.confirmation.pending strong {
  color: var(--accent-2);
}

.badges {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 6px;
  padding: 0 12px 8px;
  min-width: 0;
}

.badge-list {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  min-width: 0;
  flex: 1 1 auto;
  overflow: hidden;
}

.badges.expanded {
  flex-wrap: wrap;
}

.badges.expanded .badge-list {
  flex-wrap: wrap;
  overflow: visible;
}

.badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--bg-soft);
  color: var(--ink-2);
  font-size: 10.5px;
  font-weight: 500;
  line-height: 1;
  padding: 3px 10px;
  white-space: nowrap;
  flex-shrink: 0;
}

.badge-soft {
  color: var(--muted);
}

.badge-good {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

.badge-event {
  border-color: var(--down);
  background: var(--down-soft);
  color: var(--down);
}

.badge-event-pending {
  border-style: dashed;
  background: transparent;
}

.badge-alert {
  border-color: var(--down);
  background: var(--down);
  color: var(--on-accent);
  animation: badge-pulse 1.8s ease-in-out infinite;
}

.badge-confirmation.confirmed {
  border-color: var(--up);
  background: var(--up-soft);
  color: var(--up);
}

.badge-confirmation.failed {
  border-color: var(--down);
  background: var(--down-soft);
  color: var(--down);
}

.badge-confirmation.pending {
  border-color: var(--accent-2);
  background: color-mix(in srgb, var(--accent-2) 12%, transparent);
  color: var(--accent-2);
}

@keyframes badge-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

.badge-more {
  border-color: var(--line);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  font: inherit;
  font-size: 10.5px;
  font-weight: 500;
  flex-shrink: 0;
}

.badge-more:hover {
  color: var(--ink);
  border-color: var(--muted-2);
}

.metrics-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--panel-2);
  border-top: 1px solid var(--line-soft);
}

.metric-cell {
  padding: 8px 10px;
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  min-width: 0;
}

.metric-cell:nth-child(4n) {
  border-right: none;
}

.metric-cell:nth-last-child(-n + 4) {
  border-bottom: none;
}

.metric-cell span {
  display: block;
  color: var(--muted);
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.metric-cell strong {
  display: block;
  margin-top: 3px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.metric-cell .change.up {
  color: var(--up);
}

.metric-cell .change.down {
  color: var(--down);
}

.admin-block {
  border-top: 1px solid var(--line-soft);
}

.admin-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 6px 12px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--muted);
  font: inherit;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.admin-toggle:hover {
  color: var(--ink);
}

.admin-caret {
  color: var(--muted);
  font-size: 14px;
  line-height: 1;
}

.metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  padding: 4px 12px 12px;
}

.metric {
  border-top: 1px solid var(--line-soft);
  padding-top: 6px;
  min-width: 0;
}

.metric span {
  display: block;
  color: var(--muted);
  font-size: 10px;
}

.metric strong {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}

.chart {
  --chart-height: 190px;
  height: var(--chart-height);
  width: 100%;
  border-top: 1px solid var(--line-soft);
  position: relative;
}

.chart-canvas {
  height: var(--chart-height);
  width: 100%;
}

.chart-placeholder {
  height: var(--chart-height);
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: 12px;
}

.chart-meta {
  position: absolute;
  left: 8px;
  bottom: 6px;
  max-width: calc(100% - 16px);
  padding: 3px 5px;
  border-radius: var(--radius);
  background: var(--panel);
  color: var(--muted);
  font-size: 10px;
  font-weight: 600;
  pointer-events: none;
  opacity: 0.92;
}

.notice {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.empty {
  padding: 28px;
  color: var(--muted);
}

.monitor-main {
  background: var(--bg);
}

.monitor-subheader .subheader-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  min-width: 0;
}

.monitor-subheader .subheader-controls span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--muted);
  padding: 3px 8px;
  font-size: 10.5px;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
}

.monitor-shell {
  flex: 1;
  display: grid;
  gap: 14px;
  padding: 18px 24px 64px;
  align-content: start;
}

.monitor-overview {
  min-height: 0;
}

.monitor-overview.defensive,
.monitor-overview.selective-short-term-pressure,
.monitor-overview.overheated-pullback-risk,
.monitor-overview.defensive-tape-setups-holding {
  border-color: color-mix(in srgb, var(--down) 55%, var(--line));
}

.monitor-overview.oversold-bounce-watch,
.monitor-overview.constructive-but-setup-light,
.monitor-overview.selective-setups-holding {
  border-color: color-mix(in srgb, var(--accent-2) 50%, var(--line));
}

.monitor-overview.risk-on-dashboard-confirmed,
.monitor-overview.breakout-friendly {
  border-color: color-mix(in srgb, var(--up) 55%, var(--line));
}

.score.up {
  color: var(--up);
}

.score.down {
  color: var(--down);
}

/* --- Market Monitor v2 regime engine --------------------------------------- */
/* The base .card min-height (302px) is sized for scanner result cards; the
   regime cards are naturally short and would otherwise trap dead whitespace. */
.regime-hero,
.regime-timeline-card,
.flips-card,
.rule-checklist-card,
.index-card {
  min-height: 0;
}

.regime-hero {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-left: 4px solid var(--line);
}
.regime-hero.regime-green { border-left-color: var(--up); }
.regime-hero.regime-yellow { border-left-color: var(--regime-yellow); }
.regime-hero.regime-orange { border-left-color: var(--regime-orange); }
.regime-hero.regime-red { border-left-color: var(--down); }

.regime-hero-main {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.regime-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  flex: 0 0 auto;
  background: var(--muted);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--muted) 18%, transparent);
}
.regime-green .regime-dot { background: var(--up); box-shadow: 0 0 0 4px var(--up-soft); }
.regime-yellow .regime-dot { background: var(--regime-yellow); box-shadow: 0 0 0 4px color-mix(in srgb, var(--regime-yellow) 20%, transparent); }
.regime-orange .regime-dot { background: var(--regime-orange); box-shadow: 0 0 0 4px color-mix(in srgb, var(--regime-orange) 20%, transparent); }
.regime-red .regime-dot { background: var(--down); box-shadow: 0 0 0 4px var(--down-soft); }

.regime-hero-text { min-width: 0; margin-right: auto; }
.regime-hero-label {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.1;
  color: var(--ink);
}
.regime-hero-meta { color: var(--muted); font-size: 11.5px; margin-top: 2px; }
.regime-hero-badges { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.regime-overlay-badge {
  border: 1px solid color-mix(in srgb, var(--regime-yellow) 40%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--regime-yellow) 12%, var(--panel));
  color: var(--regime-yellow);
  padding: 3px 9px;
  font-size: 10px;
  font-weight: 700;
  text-transform: capitalize;
  white-space: nowrap;
}
.regime-action {
  margin: 0;
  color: var(--ink-2);
  font-size: 14px;
  font-weight: 650;
  line-height: 1.4;
}
.regime-playbook {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  border-top: 1px solid var(--line-soft);
  padding-top: 10px;
}
.regime-playbook span {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  font-size: 12.5px;
  font-weight: 650;
  color: var(--ink-2);
}
.regime-playbook em {
  font-style: normal;
  color: var(--muted);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
}

/* Rule checklist */
.rule-checklist { display: grid; }
.rule-row {
  display: grid;
  grid-template-columns: 20px minmax(120px, 1fr) 90px minmax(0, 2fr);
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-top: 1px solid var(--line-soft);
  font-size: 12.5px;
}
.rule-row:first-child { border-top: 0; }
.rule-icon { font-weight: 800; text-align: center; }
.rule-row.pass .rule-icon { color: var(--up); }
.rule-row.fail .rule-icon { color: var(--down); }
.rule-row.fail { background: color-mix(in srgb, var(--down) 5%, transparent); }
.rule-label { font-weight: 650; color: var(--ink); min-width: 0; }
.rule-value { font-family: var(--font-mono); font-weight: 700; text-align: right; }
.rule-value em { color: var(--muted); font-style: normal; font-weight: 500; }
.rule-detail { color: var(--muted); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rule-empty { margin: 0; padding: 12px; color: var(--muted); font-size: 12.5px; }

/* Timeline + flips */
.regime-history {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
  gap: 14px;
  align-items: start;
}
.regime-timeline {
  display: flex;
  gap: 1px;
  padding: 10px 12px 0;
  flex-wrap: nowrap;
  overflow: hidden;
}

/* Month axis under the strip: one slot per day, labels overflow their slot. */
.regime-timeline-axis {
  display: flex;
  gap: 1px;
  padding: 0 12px 8px;
  height: 18px;
  flex-wrap: nowrap;
  overflow: hidden;
}

.timeline-tick {
  flex: 1 1 0;
  min-width: 2px;
  position: relative;
}

.timeline-tick.has-label {
  border-left: 1px solid var(--line);
}

.timeline-tick em {
  position: absolute;
  top: 4px;
  left: 3px;
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 500;
  color: var(--muted);
  white-space: nowrap;
  line-height: 1;
}
.timeline-day { flex: 1 1 0; min-width: 2px; height: 34px; border-radius: 2px; background: var(--muted); }
.timeline-day.lvl-0, .regime-timeline-legend i.lvl-0 { background: var(--up); }
.timeline-day.lvl-1, .regime-timeline-legend i.lvl-1 { background: var(--regime-yellow); }
.timeline-day.lvl-2, .regime-timeline-legend i.lvl-2 { background: var(--regime-orange); }
.timeline-day.lvl-3, .regime-timeline-legend i.lvl-3 { background: var(--down); }

/* Pilot-window days: teal notch at the base of an orange/red bar — leaders
   breaking out ahead of the market's confirmation. */
.timeline-day.pilot,
.regime-timeline-legend i.pilot-swatch {
  background-image: linear-gradient(to top, var(--up) 30%, transparent 30%);
}
.regime-timeline-legend {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding: 0 12px 10px;
  font-size: 10.5px;
  color: var(--muted);
}
.regime-timeline-legend span { display: inline-flex; align-items: center; gap: 4px; }
.regime-timeline-legend i { width: 10px; height: 10px; border-radius: 2px; display: inline-block; }

.flips-log { display: grid; }
.flip-row {
  display: grid;
  grid-template-columns: 72px 92px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-top: 1px solid var(--line-soft);
  font-size: 11.5px;
}
.flip-row:first-child { border-top: 0; }
.flip-date { font-family: var(--font-mono); color: var(--muted); }
.flip-move { display: inline-flex; align-items: center; gap: 4px; font-weight: 700; }
.flip-move em { font-style: normal; text-transform: capitalize; }
.flip-trigger { color: var(--ink-2); min-width: 0; }
.regime-green { color: var(--up); }
.regime-yellow { color: var(--regime-yellow); }
.regime-orange { color: var(--regime-orange); }
.regime-red { color: var(--down); }
.regime-cell { text-transform: capitalize; font-weight: 650; }

/* Index panel */
.monitor-index { display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1.6fr); gap: 14px; }
.index-cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.index-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  background: var(--line-soft);
  border-top: 1px solid var(--line-soft);
}
.index-grid > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 12px;
  background: var(--panel);
}
/* Odd cell counts would otherwise expose the grid gutter as an empty box. */
.index-grid > div:last-child:nth-child(odd) {
  grid-column: 1 / -1;
}
.index-grid span { color: var(--muted); font-size: 10px; font-weight: 600; text-transform: uppercase; }
.index-grid strong { font-family: var(--font-mono); font-size: 13px; font-weight: 700; }
.index-grid .change.up { color: var(--up); }
.index-grid .change.down { color: var(--down); }

/* Delta arrows on metric cells */
.delta-arrow { font-size: 9.5px; font-weight: 700; margin-left: 5px; }
.delta-arrow.up { color: var(--up); }
.delta-arrow.down { color: var(--down); }

.monitor-setup-subordinate { opacity: 0.96; }
.setup-supply-note { margin: 0 2px; color: var(--muted); font-size: 11px; line-height: 1.35; }

@media (max-width: 860px) {
  .regime-history, .monitor-index { grid-template-columns: minmax(0, 1fr); }
  .index-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .regime-playbook { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rule-row { grid-template-columns: 18px minmax(0, 1fr) 76px; }
  .rule-detail { display: none; }
}

.monitor-signal-row .signal-pill {
  max-width: min(100%, 420px);
}

.monitor-signal-row .signal-pill strong {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.monitor-read {
  margin: 0;
  padding: 0 12px 10px;
  color: var(--ink-2);
  font-size: 13px;
  line-height: 1.4;
}

.monitor-strip {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.monitor-strip .metric-cell:nth-child(4n) {
  border-right: 1px solid var(--line-soft);
}

.monitor-strip .metric-cell:nth-child(5n) {
  border-right: 0;
}

.monitor-strip .metric-cell:nth-last-child(-n + 4) {
  border-bottom: 1px solid var(--line-soft);
}

.monitor-strip .metric-cell:nth-last-child(-n + 5) {
  border-bottom: 0;
}

.monitor-strip .metric-cell strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.metric-cell small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 500;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.monitor-note-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 1px solid var(--line-soft);
  background: var(--panel);
}

.monitor-note-grid section {
  min-width: 0;
  padding: 10px 12px 12px;
}

.monitor-note-grid section:first-child {
  border-right: 1px solid var(--line-soft);
}

.monitor-note-grid h3 {
  margin: 0 0 6px;
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
}

.monitor-note-grid p {
  margin: 0;
  padding: 6px 0;
  border-top: 1px solid var(--line-soft);
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.monitor-note-grid h3 + p {
  border-top: 0;
  padding-top: 0;
}

.monitor-note-grid .warnings p {
  color: var(--down);
}

.monitor-alert {
  border: 1px solid color-mix(in srgb, var(--down) 45%, transparent);
  border-radius: var(--radius);
  background: var(--down-soft);
  color: var(--down);
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.4;
  font-weight: 650;
}

.monitor-setup {
  display: grid;
  gap: 8px;
  padding: 0;
}

.monitor-setup .panel-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  padding: 0 2px;
}

.monitor-setup .panel-head h3 {
  margin: 0;
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
}

.monitor-setup .panel-head > span {
  color: var(--muted);
  font-size: 11.5px;
  line-height: 1.35;
  text-align: right;
}

.monitor-setup-summary {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 5px;
  min-width: 0;
}

.monitor-setup-summary .signal-pill {
  max-width: min(100%, 280px);
  background: var(--panel);
}

.monitor-setup-summary .signal-pill strong {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.setup-mode-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(260px, 100%), 1fr));
  gap: 10px;
}

.setup-mode {
  min-width: 0;
  min-height: 0;
}

.setup-mode-error {
  border-color: color-mix(in srgb, var(--down) 42%, transparent);
}

.setup-top-list span {
  border: 1px solid var(--line-soft);
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--muted);
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
}

.setup-top-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding: 8px 12px 10px;
  margin-top: 0;
  border-top: 1px solid var(--line-soft);
  background: var(--panel-2);
}

.setup-top-list span {
  color: var(--ink-2);
}

.setup-top-list b {
  margin-left: 5px;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}

.setup-mode p {
  margin: 0;
  padding: 8px 12px 10px;
  border-top: 1px solid var(--line-soft);
  background: var(--panel-2);
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.monitor-chart-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.monitor-chart-card {
  min-height: 0;
}

.monitor-chart-canvas {
  width: 100%;
  height: 190px;
  margin-top: 0;
  border-top: 1px solid var(--line-soft);
}

.monitor-table-wrap {
  min-height: 0;
  overflow: auto;
}

.monitor-table-wrap .card-head {
  border-bottom: 1px solid var(--line-soft);
}

.monitor-table {
  width: 100%;
  min-width: 900px;
  border-collapse: collapse;
  font-size: 12px;
}

.monitor-table th,
.monitor-table td {
  border-bottom: 1px solid var(--line-soft);
  padding: 8px 9px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.monitor-table th:first-child,
.monitor-table td:first-child {
  text-align: left;
}

.monitor-table th {
  background: var(--bg-soft);
  color: var(--ink-2);
  font-size: 11px;
  text-transform: uppercase;
}

.monitor-table .cell-good {
  background: var(--up-soft);
  color: var(--up);
  font-weight: 800;
}

.monitor-table .cell-bad {
  background: var(--down-soft);
  color: var(--down);
  font-weight: 800;
}

@media (max-width: 880px) {
  .app,
  .app.sidebar-collapsed {
    grid-template-columns: 44px 1fr;
  }

  .sidebar {
    grid-column: 1;
    grid-row: 1;
    width: 340px;
    max-width: calc(100vw - 24px);
    height: 100vh;
    max-height: none;
    border-right: 0;
    border-bottom: 0;
    box-shadow: 12px 0 30px rgb(var(--shadow-rgb) / 0.18);
    z-index: 40;
  }

  .sidebar-collapsed .sidebar {
    width: 44px;
    box-shadow: none;
    z-index: 6;
  }

  .main {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
  }

  .app:not(.sidebar-collapsed) .main {
    pointer-events: none;
  }

  .topbar {
    z-index: 4;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 6px 12px;
  }

  .topbar-primary {
    width: 100%;
    min-height: 36px;
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }

  .topbar-actions {
    display: none;
  }

  .topbar.topbar-mobile-open .topbar-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    width: 100%;
    min-width: 0;
    padding-top: 8px;
    margin-top: 6px;
    border-top: 1px solid var(--line);
  }

  .topbar .topbar-mobile-toggle {
    width: 32px;
    height: 32px;
    display: inline-flex;
    margin-left: auto;
    flex-shrink: 0;
  }

  .topbar .topbar-mobile-toggle svg {
    display: block;
  }

  .topbar-mobile-title {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 14px;
  }

  .topbar-actions > .topbar-title,
  .topbar-actions .topbar-spacer {
    display: none;
  }

  .topbar-actions .mode-selector {
    max-width: 100%;
  }

  .topbar-actions .mode-current {
    max-width: 100%;
  }

  .topbar-actions .mode-current .mode-pill {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .topbar-actions .snapshot-picker {
    flex: 1 1 auto;
    min-width: 0;
  }

  .topbar-actions .snapshot-picker select {
    flex: 1;
    min-width: 92px;
  }

  .topbar-actions .search {
    flex: 1 1 100%;
    width: 100%;
    max-width: none;
  }

  .billing-banner {
    align-items: flex-start;
    flex-direction: column;
  }

  .billing-banner-actions {
    width: 100%;
    flex-wrap: wrap;
  }

  .data-trust-strip {
    padding: 7px 14px;
  }

  .symbol-search {
    width: 100%;
  }

  .monitor-note-grid,
  .setup-mode-grid,
  .monitor-chart-grid {
    grid-template-columns: 1fr;
  }

  .monitor-note-grid section:first-child {
    border-right: 0;
    border-bottom: 1px solid var(--line-soft);
  }

  .monitor-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .monitor-strip .metric-cell:nth-child(n) {
    border-right: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
  }

  .monitor-strip .metric-cell:nth-child(2n) {
    border-right: 0;
  }

  .monitor-strip .metric-cell:nth-last-child(-n + 2) {
    border-bottom: 0;
  }

  .monitor-setup .panel-head {
    display: grid;
    align-items: start;
  }

  .monitor-setup .panel-head > span {
    text-align: left;
  }

  .monitor-setup-summary {
    justify-content: flex-start;
  }

  .monitor-setup-summary .signal-pill {
    max-width: 100%;
  }

  .monitor-signal-row .signal-pill {
    max-width: 100%;
  }
}
