/* ============================================================
   FXBias v2 — Single source of truth
   Theme switch: <html data-theme="dark"> | <html data-theme="light">
   ============================================================ */

* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Pastel accent palette (dusty, non-CRT) — same in both themes */
  --bull: #7dd3ae;
  --bull-glow: rgba(125,211,174,0.45);
  --bull-stroke-l: #6ba88b;
  --bear: #e89a8e;
  --bear-glow: rgba(232,154,142,0.45);
  --bear-stroke-l: #c47467;
  --neutral: #a5acba;
  --neutral-glow: rgba(165,172,186,0.30);
  --warm-amber: #e8b87a;
  --warm-amber-glow: rgba(232,184,122,0.55);

  /* Status colors */
  --status-live: var(--bull);
  --status-partial: var(--warm-amber);
}

/* DARK THEME (default) */
:root,
:root[data-theme="dark"] {
  --bg: #1a1a1c;
  --stage: #1a1a1c;
  --card: linear-gradient(155deg, #1f1f24 0%, #1a1a1d 100%);
  --card-solid: #1f1f24;
  --text: #f0f0f3;
  --text-muted: rgba(240,240,243,0.55);
  --text-faint: rgba(240,240,243,0.38);
  --border: rgba(255,255,255,0.05);
  --ring-bg: #28282d;
  --shadow-out: -3px -3px 7px rgba(255,255,255,0.025), 5px 5px 14px rgba(0,0,0,0.6);

  /* Pulse — mint in dark */
  --pulse-color: var(--bull);
  --pulse-glow: var(--bull-glow);
  --pulse-deep: var(--bull);

  /* Bias label colors */
  --strong-bull-c: var(--bull);
  --bull-c: var(--bull);
  --neutral-bull-c: var(--bull);
  --neutral-c: var(--neutral);
  --neutral-bear-c: var(--bear);
  --bear-c: var(--bear);
  --strong-bear-c: var(--bear);
}

/* LIGHT THEME (lavender-teal gradient) */
:root[data-theme="light"] {
  --bg: linear-gradient(160deg, #e8e1ed 0%, #d4d1e3 28%, #b8c5d6 55%, #a5c0c8 80%, #c8d4d2 100%);
  --stage: #e8e1ed;
  --card: rgba(255,255,255,0.65);
  --card-solid: #ffffff;
  --text: #2e2940;
  --text-muted: rgba(46,41,64,0.55);
  --text-faint: rgba(46,41,64,0.38);
  --border: rgba(255,255,255,0.7);
  --ring-bg: rgba(255,255,255,0.96);
  --shadow-out: 0 12px 32px rgba(46,41,64,0.12), inset 0 1px 0 rgba(255,255,255,0.9);

  --pulse-color: #9a8bbf;
  --pulse-glow: rgba(154,139,191,0.55);
  --pulse-deep: #6a5a91;

  --strong-bull-c: var(--bull-stroke-l);
  --bull-c: var(--bull-stroke-l);
  --neutral-bull-c: var(--bull-stroke-l);
  --neutral-c: var(--neutral);
  --neutral-bear-c: var(--bear-stroke-l);
  --bear-c: var(--bear-stroke-l);
  --strong-bear-c: var(--bear-stroke-l);
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, 'SF Pro Display', BlinkMacSystemFont, system-ui, sans-serif;
  min-height: 100vh;
  min-height: 100dvh;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}

button {
  font-family: inherit;
  color: inherit;
  background: none;
  border: none;
  cursor: pointer;
}

/* ============================================================
   LAYOUT — page container
   ============================================================ */
.app {
  max-width: 1280px;
  margin: 0 auto;
  padding: 22px 22px 110px;
  min-height: 100vh;
}
@media (max-width: 900px) {
  .app { padding: 14px 12px 120px; }
}

/* ============================================================
   TOP NAV (desktop only — hidden on mobile)
   ============================================================ */
.topnav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px;
  position: relative;
  z-index: 50;
  gap: 12px;
}
@media (max-width: 900px) {
  .topnav { display: none; }
}

.topnav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 12px;
}

/* Mode toggle (Intraday / Swing) — iba na Bias tab */
.mode-toggle {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  background: linear-gradient(145deg, #18181b, #232328);
  border-radius: 999px;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.4), 0 1px 0 rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.04);
}
body:not([data-page="bias"]) .mode-toggle {
  visibility: hidden;
  pointer-events: none;
}
:root[data-theme="light"] .mode-toggle {
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(30px);
  box-shadow: inset 0 2px 4px rgba(46,41,64,0.10), 0 1px 0 rgba(255,255,255,0.5);
  border: 1px solid rgba(255,255,255,0.7);
}
.mode-toggle__opt {
  padding: 6px 13px;
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
  color: rgba(240,240,243,0.4);
  border-radius: 999px;
  transition: all 0.3s cubic-bezier(0.16,1,0.3,1);
}
:root[data-theme="light"] .mode-toggle__opt { color: rgba(46,41,64,0.45); }
.mode-toggle__opt.is-active {
  background: linear-gradient(145deg, #36363e, #232328);
  color: var(--warm-amber);
  box-shadow: 0 1px 4px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05);
}
.mode-toggle__opt.is-active[data-mode="intraday"] { color: var(--bull); }
:root[data-theme="light"] .mode-toggle__opt.is-active {
  background: rgba(255,255,255,0.92);
  color: #b8741a;
  box-shadow: 0 1px 4px rgba(46,41,64,0.10), inset 0 1px 0 rgba(255,255,255,0.95);
}
:root[data-theme="light"] .mode-toggle__opt.is-active[data-mode="intraday"] { color: var(--bull-stroke-l); }

/* Brand dropdown (center) */
.brand-dropdown {
  position: relative;
}
.brand-dropdown__trigger {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 20px;
  background: linear-gradient(145deg, #232328, #18181b);
  border-radius: 999px;
  box-shadow: var(--shadow-out);
  cursor: pointer;
  min-width: 170px;
  justify-content: center;
  border: 1px solid rgba(255,255,255,0.04);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.4px;
  color: var(--text);
}
:root[data-theme="light"] .brand-dropdown__trigger {
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(30px);
  box-shadow: 0 8px 24px rgba(46,41,64,0.10), inset 0 1px 0 rgba(255,255,255,0.85);
  border: 1px solid rgba(255,255,255,0.7);
}
.brand-dropdown__arrow {
  font-size: 10px;
  color: var(--text-muted);
  transition: transform 0.22s;
}
.brand-dropdown.is-open .brand-dropdown__arrow {
  transform: rotate(180deg);
}
.brand-dropdown__menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 200px;
  background: linear-gradient(155deg, #1f1f24, #1a1a1d);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  box-shadow: 0 20px 56px rgba(0,0,0,0.7);
  padding: 8px;
  z-index: 60;
  animation: dropFade 0.22s cubic-bezier(0.16,1,0.3,1);
}
:root[data-theme="light"] .brand-dropdown__menu {
  background: rgba(255,255,255,0.96);
  border-color: rgba(255,255,255,0.85);
  box-shadow: 0 20px 56px rgba(46,41,64,0.22);
}
@keyframes dropFade {
  from { opacity: 0; transform: translateX(-50%) translateY(-6px); }
  to { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.brand-dropdown__item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13px;
  color: var(--text);
  text-align: left;
  transition: background 0.18s;
}
.brand-dropdown__item:hover {
  background: rgba(255,255,255,0.05);
}
:root[data-theme="light"] .brand-dropdown__item:hover {
  background: rgba(46,41,64,0.06);
}
.brand-dropdown__item.is-active {
  color: var(--bull);
}
:root[data-theme="light"] .brand-dropdown__item.is-active {
  color: var(--bull-stroke-l);
}
.brand-dropdown__item-letter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: rgba(255,255,255,0.05);
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
}
:root[data-theme="light"] .brand-dropdown__item-letter {
  background: rgba(46,41,64,0.06);
}

/* Status badge (LIVE) */
.status-badge {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 16px 8px 13px;
  background: linear-gradient(145deg, #232328, #18181b);
  border-radius: 999px;
  box-shadow: var(--shadow-out);
  border: 1px solid rgba(255,255,255,0.04);
  font-size: 11px;
  letter-spacing: 1.4px;
  font-weight: 600;
  color: var(--text);
}
:root[data-theme="light"] .status-badge {
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(30px);
  box-shadow: 0 8px 24px rgba(46,41,64,0.10), inset 0 1px 0 rgba(255,255,255,0.85);
  border: 1px solid rgba(255,255,255,0.7);
}
.status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--status-live);
  box-shadow: 0 0 9px var(--bull-glow);
  animation: statusPulse 2.4s ease-in-out infinite;
}
.status-dot.is-partial {
  background: var(--status-partial);
  box-shadow: 0 0 9px var(--warm-amber-glow);
}
@keyframes statusPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.45; }
}

/* Theme toggle (v6 pattern — single warm-white disc, knob slides to reveal/cover it)
   Light: knob left, disc fully visible on right WITH rays (= sun)
   Dark:  knob right (overlapping disc), only right side of disc visible (= crescent moon)
   Scaled ~50% from mockup: frame 80x34, knob 28x28, disc 20x20 */
.theme-toggle {
  width: auto;
  height: auto;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  display: inline-flex;
  align-items: center;
}
.theme-toggle:hover { transform: none; }

.theme-toggle__frame {
  width: 80px;
  height: 34px;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  background: #16161a;
  box-shadow: inset 0 2px 6px rgba(0,0,0,0.55), 0 1px 0 rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.03);
  display: block;
  cursor: pointer;
  transition: background 0.4s;
}
:root[data-theme="light"] .theme-toggle__frame {
  background: #d8d2e6;
  box-shadow: inset 0 2px 6px rgba(46,41,64,0.18), 0 1px 0 rgba(255,255,255,0.5);
  border-color: rgba(46,41,64,0.06);
}

/* Single warm-white disc — always on right, always visible (knob covers it in dark) */
.theme-toggle__disc {
  position: absolute;
  right: 7px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  /* Same warm-white gradient as v6 moon disc */
  background: radial-gradient(circle at 60% 50%, #ffffff 0%, #f8f5ec 35%, #ede5d0 80%, #cdc3a8 100%);
  box-shadow:
    0 0 14px rgba(255,250,235,1),
    0 0 28px rgba(255,245,220,0.85),
    0 0 48px rgba(255,238,200,0.55),
    0 0 70px rgba(255,230,180,0.30);
  z-index: 1;
}
/* In light mode the disc tints slightly warmer (sun feel) — same shape */
:root[data-theme="light"] .theme-toggle__disc {
  background: radial-gradient(circle at 35% 35%, #fffbe0 0%, #ffd97a 35%, #f4a020 100%);
  box-shadow:
    0 0 12px rgba(255,200,80,1),
    0 0 24px rgba(255,180,60,0.85),
    0 0 42px rgba(255,160,50,0.55),
    0 0 60px rgba(255,140,40,0.30);
}

/* Rays — visible only in light theme (sun), hidden in dark (moon) */
.theme-toggle__rays {
  position: absolute;
  right: 7px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
}
:root[data-theme="light"] .theme-toggle__rays { opacity: 1; }
.theme-toggle__ray {
  position: absolute;
  width: 4px;
  height: 1.5px;
  background: #ffc850;
  border-radius: 1px;
  top: 50%;
  left: 50%;
  transform-origin: center;
  box-shadow: 0 0 4px rgba(255,200,80,1);
}

/* Knob — slides between left edge (light, disc fully revealed) and overlap-disc (dark, crescent) */
.theme-toggle__knob {
  position: absolute;
  top: 3px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #38383e 0%, #1c1c20 100%);
  box-shadow:
    0 4px 10px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 -2px 4px rgba(0,0,0,0.5);
  z-index: 2;     /* above disc — overlaps it in dark mode */
  right: 13px;    /* dark: knob over-laps left ~10px of disc → crescent on right */
  left: auto;
  transition: right 0.4s cubic-bezier(0.16,1,0.3,1), left 0.4s cubic-bezier(0.16,1,0.3,1);
}
:root[data-theme="light"] .theme-toggle__knob {
  left: 3px;
  right: auto;
  background: radial-gradient(circle at 35% 35%, #ffffff 0%, #e8e2f0 100%);
  box-shadow:
    0 3px 8px rgba(106,90,145,0.30),
    inset 0 1px 0 rgba(255,255,255,0.95),
    inset 0 -2px 4px rgba(154,139,191,0.20);
}

/* ============================================================
   GROUP (instrument category section)
   ============================================================ */
.group {
  margin-bottom: 26px;
}
.group__label {
  font-size: 10px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  margin-bottom: 12px;
  padding-left: 6px;
}

.bias-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
@media (max-width: 900px) {
  .bias-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
  }
}
@media (max-width: 560px) {
  .bias-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   BIAS CARD
   ============================================================ */
.bias-card {
  position: relative;
  background: var(--card);
  border-radius: 20px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-out);
  padding: 18px;
  isolation: isolate;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 240px;
  transition: box-shadow 0.2s;
}
:root[data-theme="light"] .bias-card {
  backdrop-filter: blur(20px);
}

.bias-card__corner-glow {
  position: absolute;
  top: -30%;
  right: -25%;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  filter: blur(32px);
  pointer-events: none;
  opacity: 0.85;
  z-index: 0;
  transition: opacity 0.3s ease;
}
.bias-card:hover .bias-card__corner-glow {
  opacity: 1;
}
.bias-card--bull .bias-card__corner-glow {
  background: radial-gradient(circle, rgba(125,211,174,0.75) 0%, rgba(125,211,174,0.25) 35%, transparent 70%);
}
.bias-card--bear .bias-card__corner-glow {
  background: radial-gradient(circle, rgba(232,154,142,0.75) 0%, rgba(232,154,142,0.25) 35%, transparent 70%);
}
.bias-card--neutral .bias-card__corner-glow {
  background: radial-gradient(circle, rgba(165,172,186,0.45) 0%, rgba(165,172,186,0.15) 35%, transparent 70%);
}

.bias-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  z-index: 2;
  gap: 10px;
}
.bias-card__head-left {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.bias-card__head-right {
  display: flex;
  align-items: center;
  gap: 6px;
}

.bias-card__top-conviction {
  font-size: 8px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--warm-amber);
  opacity: 0.85;
}
:root[data-theme="light"] .bias-card__top-conviction { color: #b8741a; }

.bias-card__symbol {
  font-size: 17px;
  font-weight: 400;
  letter-spacing: 0.3px;
  color: var(--text);
}

.bias-card__tag {
  font-size: 9px;
  letter-spacing: 1.6px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 6px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
}
:root[data-theme="light"] .bias-card__tag {
  background: rgba(255,255,255,0.5);
  border-color: rgba(255,255,255,0.6);
}
.bias-card--bull .bias-card__tag { color: var(--bull-c); }
.bias-card--bear .bias-card__tag { color: var(--bear-c); }
.bias-card--neutral .bias-card__tag { color: var(--neutral-c); }

.bias-card__plan-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 3px 8px;
  background: rgba(154,139,191,0.14);
  color: #b3a3d6;
  border-radius: 6px;
  border: 1px solid rgba(154,139,191,0.28);
  cursor: pointer;
  transition: all 0.18s;
}
:root[data-theme="light"] .bias-card__plan-badge {
  background: rgba(154,139,191,0.18);
  color: var(--pulse-deep);
  border-color: rgba(154,139,191,0.40);
}
.bias-card__plan-badge:hover {
  background: rgba(154,139,191,0.22);
}

.bias-card__conflict-tri {
  font-size: 14px;
  color: var(--warm-amber);
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 5px;
  line-height: 1;
  transition: all 0.18s;
}
:root[data-theme="light"] .bias-card__conflict-tri { color: #b8741a; }
.bias-card__conflict-tri:hover {
  background: rgba(232,184,122,0.14);
  transform: scale(1.1);
}

/* Ring */
.bias-card__ring-wrap {
  position: relative;
  width: 130px;
  height: 130px;
  margin: 12px auto 0;
  cursor: pointer;
  z-index: 2;
  transition: transform 0.32s cubic-bezier(0.16,1,0.3,1);
}
.bias-card.is-override-open .bias-card__ring-wrap {
  transform: translateX(-38%);
}
@media (max-width: 560px) {
  .bias-card.is-override-open .bias-card__ring-wrap {
    transform: translateX(-32%) scale(0.78);
  }
}

.bias-card__ring-glow {
  position: absolute;
  inset: -14px;
  border-radius: 50%;
  filter: blur(20px);
  z-index: 0;
  pointer-events: none;
  opacity: 0.8;
  transition: opacity 0.3s ease, filter 0.3s ease;
}
.bias-card:hover .bias-card__ring-glow {
  opacity: 1;
  filter: blur(24px);
}
.bias-card--bull .bias-card__ring-glow {
  background: radial-gradient(circle, rgba(125,211,174,0.95) 0%, rgba(125,211,174,0.35) 40%, transparent 70%);
}
.bias-card--bear .bias-card__ring-glow {
  background: radial-gradient(circle, rgba(232,154,142,0.95) 0%, rgba(232,154,142,0.35) 40%, transparent 70%);
}
.bias-card--neutral .bias-card__ring-glow {
  background: radial-gradient(circle, rgba(165,172,186,0.65) 0%, rgba(165,172,186,0.20) 40%, transparent 70%);
}

.bias-card__ring-svg {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.bias-card__ring-track {
  fill: var(--ring-bg);
  stroke: none;
}
.bias-card__ring-progress {
  fill: none;
  stroke-width: 5;
  stroke-linecap: round;
  transition: stroke-dashoffset 0.6s cubic-bezier(0.16,1,0.3,1), filter 0.3s ease;
}
.bias-card--bull .bias-card__ring-progress {
  stroke: var(--bull);
  filter: drop-shadow(0 0 6px rgba(125,211,174,0.9)) drop-shadow(0 0 12px rgba(125,211,174,0.45));
}
.bias-card--bear .bias-card__ring-progress {
  stroke: var(--bear);
  filter: drop-shadow(0 0 6px rgba(232,154,142,0.9)) drop-shadow(0 0 12px rgba(232,154,142,0.45));
}
.bias-card--neutral .bias-card__ring-progress {
  stroke: var(--neutral);
  filter: drop-shadow(0 0 4px rgba(165,172,186,0.5));
}
.bias-card:hover .bias-card__ring-progress {
  stroke-width: 5.5;
}

.bias-card__ring-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 2;
}
.bias-card__ring-value {
  font-size: 30px;
  font-weight: 200;
  letter-spacing: -1.2px;
  line-height: 1;
}
.bias-card__ring-value sup {
  font-size: 13px;
  opacity: 0.4;
  font-weight: 300;
  margin-left: 1px;
}
.bias-card__ring-label {
  font-size: 8px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 4px;
}

/* TOP CONVICTION heartbeat */
.bias-card.is-top .bias-card__symbol {
  animation: heartbeat 1.4s ease-in-out infinite;
  text-shadow: 0 0 14px var(--bull);
}
.bias-card.is-top.bias-card--bear .bias-card__symbol {
  text-shadow: 0 0 14px var(--bear);
}
@keyframes heartbeat {
  0%, 70%, 100% { opacity: 1; transform: scale(1); }
  10% { opacity: 0.5; transform: scale(0.96); }
  20% { opacity: 1; transform: scale(1.02); }
  30% { opacity: 0.7; transform: scale(0.98); }
  40% { opacity: 1; transform: scale(1); }
}

/* Override panel — inline inside card */
.bias-card__override {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  width: 128px;
  background: linear-gradient(155deg, #26262c 0%, #1a1a1d 100%);
  border-radius: 12px;
  padding: 8px 7px;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 20px 56px rgba(0,0,0,0.7);
  z-index: 5;
  animation: slideIn 0.3s cubic-bezier(0.16,1,0.3,1);
}
:root[data-theme="light"] .bias-card__override {
  background: rgba(255,255,255,0.96);
  border-color: rgba(255,255,255,0.85);
  box-shadow: 0 20px 56px rgba(46,41,64,0.22);
}
@keyframes slideIn {
  from { opacity: 0; transform: translate(8px, -50%); }
  to { opacity: 1; transform: translate(0, -50%); }
}
@media (max-width: 560px) {
  .bias-card__override {
    width: 122px;
    right: 8px;
  }
}

.override__title {
  font-size: 8px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--text-muted);
  margin-bottom: 5px;
  text-align: center;
}
.override__opt {
  display: block;
  width: 100%;
  padding: 3px 7px;
  margin-bottom: 1px;
  font-size: 10.5px;
  font-weight: 500;
  text-align: left;
  border-radius: 5px;
  background: transparent;
  color: var(--text);
  transition: all 0.18s;
  line-height: 1.25;
}
.override__opt:hover {
  background: rgba(255,255,255,0.05);
}
:root[data-theme="light"] .override__opt:hover {
  background: rgba(46,41,64,0.06);
}
.override__opt--strong-bull,
.override__opt--bull,
.override__opt--neutral-bull { color: var(--bull-c); }
.override__opt--neutral { color: var(--neutral-c); }
.override__opt--neutral-bear,
.override__opt--bear,
.override__opt--strong-bear { color: var(--bear-c); }
.override__opt.is-selected {
  background: rgba(255,255,255,0.06);
  font-weight: 600;
}
:root[data-theme="light"] .override__opt.is-selected {
  background: rgba(46,41,64,0.08);
}

.override__revert {
  display: block;
  width: 100%;
  padding: 4px 7px;
  margin-top: 3px;
  font-size: 9px;
  letter-spacing: 0.3px;
  color: var(--warm-amber);
  border-radius: 5px;
  background: rgba(232,184,122,0.10);
  border: 1px solid rgba(232,184,122,0.25);
  transition: all 0.18s;
  line-height: 1.25;
}
:root[data-theme="light"] .override__revert {
  color: #b8741a;
  background: rgba(232,184,122,0.16);
}
.override__revert:hover {
  background: rgba(232,184,122,0.18);
}

.override__divider {
  height: 1px;
  background: rgba(255,255,255,0.06);
  margin: 5px 0;
}
:root[data-theme="light"] .override__divider {
  background: rgba(46,41,64,0.10);
}

.override__plan {
  display: block;
  width: 100%;
  padding: 5px 7px;
  font-size: 10.5px;
  font-weight: 500;
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border: 1px solid rgba(125,211,174,0.25);
  border-radius: 6px;
  transition: all 0.18s;
  line-height: 1.25;
}
.override__plan:hover {
  background: rgba(125,211,174,0.18);
}

/* Pillars (optional, prefs.showPillars) */
.bias-card__pillars {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
  margin-top: 12px;
  position: relative;
  z-index: 2;
}
.bias-card__pillar {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 5px 2px;
  background: rgba(255,255,255,0.02);
  border-radius: 7px;
}
.bias-card__pillar.is-disabled {
  opacity: 0.35;
}
.bias-card__pillar.is-disabled .pillar__val {
  color: var(--text-faint);
}
.pillar__lbl {
  font-size: 8px;
  letter-spacing: 0.8px;
  color: var(--text-faint);
  text-transform: uppercase;
}
.pillar__val {
  font-size: 10px;
  font-family: 'SF Mono', monospace;
  font-weight: 600;
  color: var(--text);
  margin-top: 1px;
}

/* ============================================================
   MONDAY BRIEF
   ============================================================ */
.brief {
  background: var(--card);
  border-radius: 22px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-out);
  overflow: hidden;
  margin-bottom: 22px;
}
:root[data-theme="light"] .brief { backdrop-filter: blur(20px); }

.brief__header {
  width: 100%;
  padding: 14px 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: transparent;
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
}
.brief__chevron {
  font-size: 11px;
  color: var(--text-muted);
  transition: transform 0.22s;
}
.brief.is-open .brief__chevron {
  transform: rotate(180deg);
}

.brief__section {
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
}
.brief__section:last-child { border-bottom: none; }

.brief__sec-title {
  font-size: 10px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 14px;
}

.cot-block { margin-bottom: 14px; }
.cot-block:last-child { margin-bottom: 0; }
.cot-block__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 7px;
}
.cot-block--long .cot-block__label { color: var(--bull-c); }
.cot-block--short .cot-block__label { color: var(--bear-c); }
.cot-block--neutral .cot-block__label { color: var(--text-muted); }

.cot-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.03);
  border-radius: 9px;
  margin-bottom: 5px;
}
:root[data-theme="light"] .cot-row {
  background: rgba(255,255,255,0.40);
  border-color: rgba(255,255,255,0.55);
}
.cot-row:last-child { margin-bottom: 0; }
.cot-row__ccy {
  font-family: 'SF Mono', monospace;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.5px;
  min-width: 38px;
}
.cot-row__pct {
  color: var(--text-muted);
  font-family: 'SF Mono', monospace;
  font-size: 10.5px;
  min-width: 48px;
}
.cot-row__desc {
  color: var(--text);
  font-size: 11px;
  flex: 1;
  opacity: 0.85;
}

.day-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 8px 12px 8px 14px;
  margin-bottom: 5px;
  border-radius: 9px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.03);
  border-left: 3px solid transparent;
}
:root[data-theme="light"] .day-row {
  background: rgba(255,255,255,0.40);
  border-color: rgba(255,255,255,0.55);
  border-left-color: transparent;
}
.day-row:last-child { margin-bottom: 0; }
.day-row--high { border-left-color: var(--bear); }
.day-row--med  { border-left-color: var(--warm-amber); }
.day-row--low  { border-left-color: var(--neutral); }
.day-row--none { border-left-color: rgba(255,255,255,0.06); }
:root[data-theme="light"] .day-row--high { border-left-color: var(--bear-stroke-l); }
:root[data-theme="light"] .day-row--med  { border-left-color: #b8741a; }
:root[data-theme="light"] .day-row--low  { border-left-color: rgba(46,41,64,0.30); }
:root[data-theme="light"] .day-row--none { border-left-color: rgba(46,41,64,0.08); }

.day-row__name {
  font-weight: 600;
  min-width: 75px;
  font-size: 12px;
}
.day-row__events {
  font-family: 'SF Mono', monospace;
  font-size: 10.5px;
  color: var(--text-muted);
  letter-spacing: 0.1px;
  flex: 1;
  line-height: 1.55;
}

.ev-major {
  display: inline-block;
  padding: 1px 6px;
  margin: 0 3px;
  background: rgba(232,184,122,0.14);
  color: var(--warm-amber);
  border: 1px solid rgba(232,184,122,0.30);
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.6px;
  font-family: -apple-system, sans-serif;
  vertical-align: middle;
}
:root[data-theme="light"] .ev-major { color: #b8741a; }

.divergence-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 8px 12px;
  margin-bottom: 5px;
  background: rgba(255,255,255,0.025);
  border-radius: 9px;
  border: 1px solid rgba(255,255,255,0.03);
}
:root[data-theme="light"] .divergence-row {
  background: rgba(255,255,255,0.40);
  border-color: rgba(255,255,255,0.55);
}
.divergence-row:last-child { margin-bottom: 0; }
.divergence__sym {
  font-family: 'SF Mono', monospace;
  font-size: 11.5px;
  font-weight: 700;
  min-width: 75px;
}
.divergence__pct {
  font-family: 'SF Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  min-width: 60px;
}
.divergence__pct--bull { color: var(--bull); }
.divergence__pct--bear { color: var(--bear); }
:root[data-theme="light"] .divergence__pct--bull { color: var(--bull-stroke-l); }
:root[data-theme="light"] .divergence__pct--bear { color: var(--bear-stroke-l); }
.divergence__note {
  flex: 1;
  font-size: 11px;
  color: var(--text);
  opacity: 0.85;
}

.brief__empty {
  font-size: 11.5px;
  color: var(--text-muted);
  font-style: italic;
  padding: 4px 2px;
}

/* Floating mobile mode toggle (Intraday/Swing) — TOP-LEFT (mirror of LIVE badge top-right)
   Visible only on mobile, at same vertical level as status badge
   ============================================================ */
.mobile-mode-toggle {
  position: fixed;
  top: max(14px, env(safe-area-inset-top, 14px));
  left: 14px;
  z-index: 997;
  display: none;
  align-items: center;
  gap: 2px;
  padding: 3px;
  background: linear-gradient(145deg, #232328, #18181b);
  border-radius: 999px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.45);
  border: 1px solid rgba(255,255,255,0.05);
}
@media (max-width: 900px) {
  .mobile-mode-toggle { display: inline-flex; }
}
body:not([data-page="bias"]) .mobile-mode-toggle {
  visibility: hidden;
  pointer-events: none;
}
:root[data-theme="light"] .mobile-mode-toggle {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(20px);
  box-shadow: 0 4px 14px rgba(46,41,64,0.18), inset 0 1px 0 rgba(255,255,255,0.7);
  border-color: rgba(255,255,255,0.7);
}
.mobile-mode-toggle__opt {
  padding: 5px 11px;
  font-size: 9px;
  letter-spacing: 1.2px;
  font-weight: 700;
  text-transform: uppercase;
  color: rgba(240,240,243,0.4);
  border-radius: 999px;
  transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
}
:root[data-theme="light"] .mobile-mode-toggle__opt { color: rgba(46,41,64,0.45); }
.mobile-mode-toggle__opt.is-active {
  background: linear-gradient(145deg, #36363e, #232328);
  color: var(--bull);
  box-shadow: 0 1px 4px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05);
}
:root[data-theme="light"] .mobile-mode-toggle__opt.is-active {
  background: rgba(255,255,255,0.95);
  color: var(--bull-stroke-l);
  box-shadow: 0 1px 4px rgba(46,41,64,0.10), inset 0 1px 0 rgba(255,255,255,0.95);
}
.mobile-mode-toggle__opt.is-active[data-mode="swing"] {
  color: var(--warm-amber);
}
:root[data-theme="light"] .mobile-mode-toggle__opt.is-active[data-mode="swing"] {
  color: #b8741a;
}

/* On mobile, push main content down so floating top elements don't overlap Monday Brief */
@media (max-width: 900px) {
  .app {
    padding-top: 64px;
  }
}

/* Floating mobile LIVE badge — top-right, always visible on mobile */
.mobile-status {
  position: fixed;
  top: max(14px, env(safe-area-inset-top, 14px));
  right: 14px;
  z-index: 997;
  display: none;
  align-items: center;
  gap: 7px;
  padding: 6px 13px 6px 11px;
  background: linear-gradient(145deg, #232328, #18181b);
  border-radius: 999px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.45);
  border: 1px solid rgba(255,255,255,0.04);
  font-size: 10px;
  letter-spacing: 1.3px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
}
@media (max-width: 900px) {
  .mobile-status { display: inline-flex; }
}
:root[data-theme="light"] .mobile-status {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(20px);
  box-shadow: 0 4px 14px rgba(46,41,64,0.18), inset 0 1px 0 rgba(255,255,255,0.7);
  border-color: rgba(255,255,255,0.7);
}
.mobile-status__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--status-live);
  box-shadow: 0 0 7px var(--bull-glow);
  animation: statusPulse 2.4s ease-in-out infinite;
}
.mobile-status__dot.is-partial {
  background: var(--status-partial);
  box-shadow: 0 0 7px var(--warm-amber-glow);
}

/* Diagnostic modal (opened from mobile status badge or status-badge click) */
.diag-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10,10,12,0.78);
  backdrop-filter: blur(8px);
  z-index: 9998;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 14px;
}
:root[data-theme="light"] .diag-overlay {
  background: rgba(46,41,64,0.40);
}
.diag-card {
  background: linear-gradient(155deg, #1f1f24 0%, #1a1a1d 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  box-shadow: 0 30px 70px rgba(0,0,0,0.7);
  max-width: 360px;
  width: 100%;
  padding: 22px 20px;
}
:root[data-theme="light"] .diag-card {
  background: rgba(255,255,255,0.96);
  border-color: rgba(255,255,255,0.85);
  box-shadow: 0 30px 70px rgba(46,41,64,0.30);
}
.diag-title {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.diag-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 12px;
}
:root[data-theme="light"] .diag-row {
  border-bottom-color: rgba(46,41,64,0.08);
}
.diag-row:last-child { border-bottom: none; }
.diag-row__label { color: var(--text-muted); }
.diag-row__value {
  font-weight: 600;
  font-family: 'SF Mono', monospace;
}
.diag-row__value--ok { color: var(--bull); }
.diag-row__value--fail { color: var(--bear); }
.diag-row__value--warn { color: var(--warm-amber); }
.diag-close {
  font-size: 22px;
  color: var(--text-muted);
  width: 28px;
  height: 28px;
  border-radius: 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.diag-close:hover {
  background: rgba(232,154,142,0.10);
  color: var(--bear);
}

/* ============================================================
   PULSE BTN (mobile only)
   ============================================================ */
.pulse-btn {
  position: fixed;
  bottom: max(28px, env(safe-area-inset-bottom, 28px));
  left: 50%;
  transform: translateX(-50%);
  z-index: 998;
  width: 56px;
  height: 56px;
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  transition: opacity 0.28s, transform 0.32s cubic-bezier(0.16,1,0.3,1);
}
@media (min-width: 901px) { .pulse-btn { display: none; } }
.pulse-btn.is-hidden {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(20px) scale(0.85);
}

.pulse-btn__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  opacity: 0;
  animation: pulseRing 2.6s ease-out infinite;
  pointer-events: none;
  background: radial-gradient(circle, var(--pulse-glow) 0%, transparent 70%);
}
.pulse-btn__ring:nth-child(1) { animation-delay: 0s; }
.pulse-btn__ring:nth-child(2) { animation-delay: 0.87s; }
.pulse-btn__ring:nth-child(3) { animation-delay: 1.74s; }
@keyframes pulseRing {
  0% { opacity: 0.75; transform: scale(1); }
  100% { opacity: 0; transform: scale(2.6); }
}

.pulse-btn__core {
  position: absolute;
  inset: 6px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #34343c 0%, #1c1c20 100%);
  border: 1px solid var(--pulse-color);
  box-shadow: 0 0 16px var(--pulse-glow), 0 8px 22px rgba(0,0,0,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
}
:root[data-theme="light"] .pulse-btn__core {
  background: radial-gradient(circle at 35% 30%, #fff, #e8e1f5);
  border-color: var(--pulse-color);
  box-shadow: 0 0 18px var(--pulse-glow), 0 8px 22px rgba(106,90,145,0.25);
}

.pulse-btn__letter {
  font-size: 22px;
  font-weight: 300;
  letter-spacing: -0.5px;
  color: var(--text);
  text-shadow: 0 0 10px var(--pulse-glow);
}
:root[data-theme="light"] .pulse-btn__letter {
  color: var(--pulse-deep);
}

/* RADIAL menu */
.radial {
  position: fixed;
  top: 75%;
  left: 50%;
  width: 0;
  height: 0;
  z-index: 1001;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.18s;
}
.radial.is-open {
  visibility: visible;
  opacity: 1;
}

.radial__item {
  position: absolute;
  top: 0;
  left: 0;
  width: 64px;
  height: 64px;
  margin: -32px 0 0 -32px;
  border-radius: 50%;
  background: var(--card);
  border: 1.5px solid var(--pulse-color);
  box-shadow: 0 8px 22px rgba(0,0,0,0.55);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  transition: box-shadow 0.18s;
}
:root[data-theme="dark"] .radial__item {
  background: linear-gradient(155deg, #1f1f24 0%, #1a1a1d 100%);
}
:root[data-theme="light"] .radial__item {
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(20px);
}
.radial__item.is-hover {
  box-shadow:
    0 0 0 6px rgba(125,211,174,0.20),
    0 0 30px rgba(125,211,174,0.70),
    0 8px 22px rgba(0,0,0,0.55);
  z-index: 12;
}
:root[data-theme="light"] .radial__item.is-hover {
  box-shadow:
    0 0 0 6px rgba(154,139,191,0.22),
    0 0 30px rgba(154,139,191,0.65),
    0 8px 22px rgba(46,41,64,0.25);
}

.radial__letter {
  font-size: 17px;
  font-weight: 500;
  color: var(--text);
  pointer-events: none;
}
.radial__label {
  font-size: 8px;
  letter-spacing: 0.9px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 3px;
  font-weight: 600;
  pointer-events: none;
}

.radial__hint {
  position: absolute;
  top: 0;
  left: 0;
  margin: -22px 0 0 -55px;
  width: 110px;
  text-align: center;
  font-size: 11px;
  color: var(--text-muted);
  pointer-events: none;
}

.radial-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(10,10,12,0.55);
  backdrop-filter: blur(10px);
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}
:root[data-theme="light"] .radial-backdrop {
  background: rgba(46,41,64,0.45);
}
.radial-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

body.is-radial-active,
body.is-radial-active * {
  -webkit-user-select: none !important;
  user-select: none !important;
  -webkit-touch-callout: none !important;
}

/* ============================================================
   PLAN MODAL (Journal)
   ============================================================ */
.jm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10,10,12,0.78);
  backdrop-filter: blur(8px);
  z-index: 9998;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 24px 12px;
  overflow-y: auto;
}
:root[data-theme="light"] .jm-overlay {
  background: rgba(46,41,64,0.40);
}

.jm-card {
  background: var(--card-solid);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: 0 30px 70px rgba(0,0,0,0.7);
  max-width: 520px;
  width: 100%;
  padding: 26px 24px;
  animation: pop 0.28s cubic-bezier(0.16,1,0.3,1);
}
:root[data-theme="dark"] .jm-card {
  background: linear-gradient(155deg, #1f1f24 0%, #1a1a1d 100%);
}
:root[data-theme="light"] .jm-card {
  box-shadow: 0 30px 70px rgba(46,41,64,0.30);
}
@keyframes pop {
  from { opacity: 0; transform: scale(0.96) translateY(8px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

.jm-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 22px;
}
.jm-title {
  font-size: 16px;
  font-weight: 500;
  color: var(--bull);
}
:root[data-theme="light"] .jm-title { color: var(--bull-stroke-l); }
.jm-close {
  color: var(--text-muted);
  font-size: 24px;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.jm-close:hover {
  background: rgba(232,154,142,0.10);
  color: var(--bear);
}

.jm-field { margin-bottom: 16px; }
.jm-label {
  display: block;
  font-size: 10px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 7px;
}

.jm-input,
select.jm-input,
textarea.jm-input {
  width: 100%;
  padding: 11px 13px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 11px;
  font-size: 13px;
  font-family: inherit;
  transition: all 0.18s;
  outline: none;
}
:root[data-theme="light"] .jm-input,
:root[data-theme="light"] select.jm-input,
:root[data-theme="light"] textarea.jm-input {
  background: rgba(255,255,255,0.65);
  border-color: rgba(255,255,255,0.7);
}
.jm-input:focus {
  border-color: var(--bull);
  box-shadow: 0 0 0 3px rgba(125,211,174,0.10);
}
.jm-input--textarea {
  resize: vertical;
  min-height: 90px;
}

.jm-dir-row { display: flex; gap: 8px; }
.jm-dir-opt {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 11px;
  cursor: pointer;
  font-size: 12.5px;
  transition: all 0.18s;
}
:root[data-theme="light"] .jm-dir-opt {
  background: rgba(255,255,255,0.55);
}
.jm-dir-opt input[type=radio] {
  margin: 0;
  accent-color: var(--bull);
}
.jm-dir-opt:hover {
  background: rgba(125,211,174,0.08);
  border-color: rgba(125,211,174,0.20);
}
.jm-dir-opt.is-selected.jm-dir-opt--watch {
  background: rgba(154,139,191,0.15);
  border-color: rgba(154,139,191,0.40);
  color: #b3a3d6;
}
:root[data-theme="light"] .jm-dir-opt.is-selected.jm-dir-opt--watch {
  color: var(--pulse-deep);
}
.jm-dir-opt.is-selected.jm-dir-opt--long {
  background: rgba(125,211,174,0.15);
  border-color: rgba(125,211,174,0.40);
  color: var(--bull-c);
}
.jm-dir-opt.is-selected.jm-dir-opt--short {
  background: rgba(232,154,142,0.15);
  border-color: rgba(232,154,142,0.40);
  color: var(--bear-c);
}

.jm-actions {
  display: flex;
  gap: 8px;
  margin-top: 22px;
}

/* Plan list rows (when modal shows existing plans for instrument) */
.jm-plan-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-bottom: 14px;
  max-height: 380px;
  overflow-y: auto;
}
.jm-plan-row {
  padding: 11px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 12px;
}
:root[data-theme="light"] .jm-plan-row {
  background: rgba(255,255,255,0.55);
  border-color: rgba(255,255,255,0.7);
}
.jm-plan-row__head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.jm-plan-row__dir {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 6px;
  letter-spacing: 0.2px;
}
.jm-plan-row__dir--watch {
  background: rgba(154,139,191,0.15);
  border: 1px solid rgba(154,139,191,0.35);
  color: #b3a3d6;
}
:root[data-theme="light"] .jm-plan-row__dir--watch { color: var(--pulse-deep); }
.jm-plan-row__dir--long {
  background: rgba(125,211,174,0.15);
  border: 1px solid rgba(125,211,174,0.35);
  color: var(--bull-c);
}
.jm-plan-row__dir--short {
  background: rgba(232,154,142,0.15);
  border: 1px solid rgba(232,154,142,0.35);
  color: var(--bear-c);
}
.jm-plan-row__date {
  font-size: 11.5px;
  color: var(--text-muted);
  flex: 1;
}
.jm-plan-row__actions {
  display: flex;
  gap: 4px;
}
.jm-plan-row__actions button {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  font-size: 13px;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.18s;
}
.jm-plan-row__actions button:hover {
  background: rgba(255,255,255,0.06);
  color: var(--text);
}
.jm-plan-row__actions .jm-plan-delete:hover {
  background: rgba(232,154,142,0.14);
  color: var(--bear);
}
:root[data-theme="light"] .jm-plan-row__actions button:hover {
  background: rgba(46,41,64,0.07);
}
.jm-plan-row__trigger {
  font-size: 11.5px;
  color: var(--text-muted);
  margin-top: 6px;
  font-style: italic;
}
.jm-plan-row__plan {
  font-size: 12px;
  color: var(--text);
  margin-top: 5px;
  opacity: 0.85;
  white-space: pre-wrap;
  line-height: 1.45;
}
.jm-btn {
  flex: 1;
  padding: 11px 18px;
  border-radius: 11px;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.4px;
  transition: all 0.18s;
}
.jm-btn--primary {
  background: linear-gradient(155deg, rgba(125,211,174,0.30), rgba(125,211,174,0.15));
  color: var(--bull-c);
  border: 1px solid rgba(125,211,174,0.40);
}
.jm-btn--primary:hover {
  background: linear-gradient(155deg, rgba(125,211,174,0.40), rgba(125,211,174,0.22));
  box-shadow: 0 0 16px rgba(125,211,174,0.25);
}
.jm-btn--ghost {
  background: rgba(255,255,255,0.04);
  color: var(--text);
  border: 1px solid var(--border);
}
:root[data-theme="light"] .jm-btn--ghost {
  background: rgba(255,255,255,0.55);
}
.jm-btn--ghost:hover {
  background: rgba(255,255,255,0.08);
}

/* ============================================================
   TRADING FREEZE BANNER
   ============================================================ */
.trading-freeze {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  background: linear-gradient(155deg, rgba(232,154,142,0.14), rgba(232,154,142,0.08));
  border: 1px solid rgba(232,154,142,0.40);
  border-radius: 14px;
  margin-bottom: 12px;
  color: var(--bear-c);
  font-size: 12.5px;
  font-weight: 500;
  flex-wrap: wrap;
}
:root[data-theme="light"] .trading-freeze {
  background: rgba(232,154,142,0.16);
}
.trading-freeze__icon {
  font-size: 14px;
  flex-shrink: 0;
}
.trading-freeze__title {
  font-weight: 700;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  font-size: 11px;
}
.trading-freeze__sep {
  color: var(--text-muted);
  opacity: 0.5;
}
.trading-freeze__event,
.trading-freeze__event-time,
.trading-freeze__end {
  color: var(--text);
  opacity: 0.92;
}

/* ============================================================
   UPCOMING EVENTS (8h)
   ============================================================ */
.upcoming {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 14px 18px 16px;
  margin-bottom: 22px;
  box-shadow: var(--shadow-out);
}
:root[data-theme="light"] .upcoming { backdrop-filter: blur(20px); }

.upcoming__title {
  font-size: 10px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
  padding-bottom: 9px;
  margin-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

.upcoming__list {
  display: flex;
  flex-direction: column;
}
.upcoming__row {
  display: grid;
  grid-template-columns: 56px 44px 1fr auto auto auto;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  font-size: 12px;
  border-bottom: 1px dashed rgba(255,255,255,0.04);
}
:root[data-theme="light"] .upcoming__row {
  border-bottom-color: rgba(46,41,64,0.08);
}
.upcoming__row:last-child { border-bottom: none; }
.upcoming__row--past { opacity: 0.45; }
.upcoming__row--freeze .upcoming__name { color: var(--bear-c); }
.upcoming__row--freeze-active {
  background: rgba(232,154,142,0.06);
  border-radius: 8px;
  padding-left: 8px;
  padding-right: 8px;
  margin-left: -8px;
  margin-right: -8px;
}

.upcoming__time {
  font-family: 'SF Mono', monospace;
  color: var(--text-muted);
  font-size: 11.5px;
  font-variant-numeric: tabular-nums;
}
.upcoming__ccy {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  font-size: 11px;
  color: var(--warm-amber);
  letter-spacing: 0.3px;
}
:root[data-theme="light"] .upcoming__ccy { color: #b8741a; }
.upcoming__name {
  color: var(--text);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.upcoming__freeze-pill {
  font-size: 9px;
  letter-spacing: 0.5px;
  font-weight: 700;
  text-transform: lowercase;
  padding: 2px 7px;
  background: rgba(232,154,142,0.16);
  color: var(--bear-c);
  border: 1px solid rgba(232,154,142,0.36);
  border-radius: 5px;
}
.upcoming__forecast {
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.upcoming__countdown {
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  color: var(--warm-amber);
  min-width: 70px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
:root[data-theme="light"] .upcoming__countdown { color: #b8741a; }

@media (max-width: 560px) {
  .upcoming { padding: 12px 14px 14px; }
  .upcoming__row {
    grid-template-columns: 46px 32px 1fr auto;
    gap: 6px;
    font-size: 11px;
  }
  /* On mobile drop forecast column to save space, keep time/ccy/name/countdown */
  .upcoming__forecast { display: none; }
  .upcoming__freeze-pill { font-size: 8px; padding: 1px 5px; }
  .upcoming__countdown { min-width: 56px; font-size: 10px; }
  .trading-freeze {
    font-size: 11.5px;
    padding: 10px 14px;
  }
}

/* ============================================================
   LOADING / EMPTY STATES
   ============================================================ */
.loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  color: var(--text-muted);
  font-size: 13px;
  letter-spacing: 0.4px;
}
.loading::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 10px;
  border: 2px solid var(--border);
  border-top-color: var(--bull);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}

.error-banner {
  padding: 12px 16px;
  margin-bottom: 18px;
  background: rgba(232,154,142,0.10);
  border: 1px solid rgba(232,154,142,0.30);
  border-radius: 12px;
  color: var(--bear-c);
  font-size: 12px;
}

/* ============================================================
   MACRO TAB
   ============================================================ */

/* Week scrubber */
.week-scrubber {
  display: flex;
  gap: 8px;
  margin-bottom: 18px;
  padding: 4px;
  background: linear-gradient(145deg, #18181b, #232328);
  border-radius: 999px;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.4), 0 1px 0 rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.04);
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
:root[data-theme="light"] .week-scrubber {
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(30px);
  box-shadow: inset 0 2px 4px rgba(46,41,64,0.10), 0 1px 0 rgba(255,255,255,0.5);
  border: 1px solid rgba(255,255,255,0.7);
}
.week-pill {
  padding: 8px 18px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.1px;
  text-transform: uppercase;
  color: rgba(240,240,243,0.45);
  border-radius: 999px;
  transition: all 0.3s cubic-bezier(0.16,1,0.3,1);
  white-space: nowrap;
}
:root[data-theme="light"] .week-pill { color: rgba(46,41,64,0.50); }
.week-pill:hover { color: var(--text); }
.week-pill.is-active {
  background: linear-gradient(145deg, #36363e, #232328);
  color: var(--bull);
  box-shadow: 0 1px 4px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05);
}
:root[data-theme="light"] .week-pill.is-active {
  background: rgba(255,255,255,0.95);
  color: var(--bull-stroke-l);
  box-shadow: 0 1px 4px rgba(46,41,64,0.10), inset 0 1px 0 rgba(255,255,255,0.95);
}
.week-pill.is-weekend.is-active {
  color: var(--warm-amber);
}
:root[data-theme="light"] .week-pill.is-weekend.is-active {
  color: #b8741a;
}

/* Day card */
.day-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow-out);
  padding: 22px 22px 14px;
  isolation: isolate;
  overflow: hidden;
  margin-bottom: 22px;
}
:root[data-theme="light"] .day-card { backdrop-filter: blur(20px); }

.day-card-glow {
  position: absolute;
  top: -30%;
  right: -20%;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  filter: blur(32px);
  pointer-events: none;
  z-index: 0;
  opacity: 0.55;
}
.day-card-glow--hawkish {
  background: radial-gradient(circle, var(--bull-glow) 0%, transparent 60%);
}
.day-card-glow--dovish {
  background: radial-gradient(circle, var(--bear-glow) 0%, transparent 60%);
}
.day-card-glow--mixed {
  background: radial-gradient(circle, var(--neutral-glow) 0%, transparent 60%);
  opacity: 0.4;
}
.day-card-glow--pending {
  background: radial-gradient(circle, rgba(165,172,186,0.18) 0%, transparent 60%);
  opacity: 0.3;
}

.day-card-loading {
  padding: 80px 20px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
  letter-spacing: 0.4px;
}
.day-card-loading::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 10px;
  border: 2px solid var(--border);
  border-top-color: var(--bull);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  vertical-align: middle;
}

/* Day card head */
.day-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  position: relative;
  z-index: 2;
  margin-bottom: 16px;
}
.day-card-head-left {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.day-name-row {
  display: flex;
  align-items: baseline;
  gap: 11px;
  flex-wrap: wrap;
}
.day-name {
  font-size: 22px;
  font-weight: 400;
  letter-spacing: 0.2px;
  color: var(--text);
}
.day-date {
  font-size: 12px;
  color: var(--text-muted);
  font-family: 'SF Mono', monospace;
  letter-spacing: 0.2px;
}

.day-bias-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.1px;
  text-transform: uppercase;
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.day-bias-label--hawkish { color: var(--bull-c); }
.day-bias-label--dovish { color: var(--bear-c); }
.day-bias-label--mixed { color: var(--text-muted); }
.day-bias-label--pending {
  color: var(--text-faint);
  font-style: italic;
  text-transform: none;
  letter-spacing: 0.2px;
  font-weight: 500;
}
.day-bias-detail {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.4px;
  text-transform: none;
  color: var(--text-muted);
  font-family: 'SF Mono', monospace;
}

/* Day stats */
.day-stats {
  display: flex;
  gap: 14px;
  flex-shrink: 0;
}
.day-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 40px;
}
.day-stat-val {
  font-size: 22px;
  font-weight: 200;
  letter-spacing: -0.5px;
  color: var(--text);
  line-height: 1;
}
.day-stat-val.is-high { color: var(--bear-c); }
.day-stat-val.is-done { color: var(--bull-c); }
.day-stat-label {
  font-size: 9px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-top: 5px;
  font-weight: 600;
  text-align: center;
}

/* Event list */
.event-list {
  position: relative;
  z-index: 2;
}
.event-empty {
  padding: 40px 20px;
  text-align: center;
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
}

.event-row {
  position: relative;
  border-radius: 11px;
  margin-bottom: 4px;
  background: rgba(255,255,255,0.015);
  border-left: 3px solid transparent;
  transition: background 0.18s;
}
:root[data-theme="light"] .event-row {
  background: rgba(255,255,255,0.32);
}
.event-row.impact-high { border-left-color: var(--bear); }
.event-row.impact-med { border-left-color: var(--warm-amber); }
.event-row.impact-low { border-left-color: var(--neutral); }

/* Released events — actual value published, event is in the past.
   Subtle dimming distinguishes "behind us" from "still waiting". */
.event-row.is-released {
  opacity: 0.62;
}
.event-row.is-released:hover {
  opacity: 0.92;
}
.event-row.is-released.is-expanded {
  opacity: 1;  /* never dim when user actively opened it */
}
:root[data-theme="light"] .event-row.is-released {
  background: rgba(255,255,255,0.18);
}

.event-row:hover {
  background: rgba(255,255,255,0.035);
}
:root[data-theme="light"] .event-row:hover {
  background: rgba(255,255,255,0.50);
}

.ev-main {
  display: grid;
  grid-template-columns: 50px 36px 1fr auto 12px 24px 22px;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  cursor: pointer;
}

.ev-time {
  font-family: 'SF Mono', monospace;
  font-size: 11.5px;
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
}
.ev-currency {
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  color: var(--warm-amber);
  letter-spacing: 0.4px;
}
:root[data-theme="light"] .ev-currency { color: #b8741a; }
.ev-name {
  font-size: 12.5px;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ev-values {
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.ev-forecast { color: var(--text-muted); }
.ev-arrow { color: var(--text-faint); font-size: 10px; }
.ev-actual { font-weight: 600; }
.ev-actual--beat { color: var(--bull-c); }
.ev-actual--miss { color: var(--bear-c); }
.ev-actual--inline { color: var(--text); }
.ev-pending {
  color: var(--text-faint);
  font-style: italic;
  font-size: 10.5px;
}

.ev-impact-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.ev-impact-dot--high { background: var(--bear); box-shadow: 0 0 6px var(--bear-glow); }
.ev-impact-dot--med { background: var(--warm-amber); box-shadow: 0 0 6px var(--warm-amber-glow); }
.ev-impact-dot--low { background: var(--neutral); }

/* Static × hide button — visible on both desktop and mobile (always) */
.ev-hide {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  font-size: 14px;
  color: var(--text-faint);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.18s;
}
.ev-hide:hover {
  background: rgba(232,154,142,0.14);
  color: var(--bear);
}

/* Plan link button — opens journal modal with this event prelinked */
.ev-plan-btn {
  width: 24px;
  height: 22px;
  border-radius: 6px;
  font-size: 14px;
  color: var(--text-faint);
  background: transparent;
  border: 1px solid var(--border);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: all 0.18s;
}
.ev-plan-btn:hover {
  background: rgba(125,211,174,0.14);
  color: var(--bull-c);
  border-color: rgba(125,211,174,0.4);
}

/* Event expanded body */
.event-row.is-expanded {
  background: rgba(255,255,255,0.04);
  margin: 8px 0;
}
:root[data-theme="light"] .event-row.is-expanded {
  background: rgba(255,255,255,0.55);
}

.ev-expand-body {
  padding: 4px 14px 14px;
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 18px;
  align-items: start;
}

.ev-details-text {
  font-size: 12px;
  line-height: 1.65;
  color: rgba(240,240,243,0.78);
}
:root[data-theme="light"] .ev-details-text { color: rgba(46,41,64,0.78); }
.ev-details-text strong {
  color: var(--text);
  font-weight: 600;
}
.ev-details-text .bull { color: var(--bull-c); font-weight: 600; }
.ev-details-text .bear { color: var(--bear-c); font-weight: 600; }

.surprise-meter {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 14px;
  background: rgba(0,0,0,0.18);
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.04);
}
:root[data-theme="light"] .surprise-meter {
  background: rgba(46,41,64,0.05);
  border-color: rgba(46,41,64,0.08);
}
.surprise-label {
  font-size: 9px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 600;
}
.surprise-bar {
  position: relative;
  height: 6px;
  background: linear-gradient(90deg,
    var(--bear-glow) 0%,
    rgba(255,255,255,0.06) 50%,
    var(--bull-glow) 100%);
  border-radius: 3px;
}
.surprise-bar-zero {
  position: absolute;
  left: 50%;
  top: -3px;
  bottom: -3px;
  width: 1px;
  background: rgba(255,255,255,0.20);
}
:root[data-theme="light"] .surprise-bar-zero {
  background: rgba(46,41,64,0.30);
}
.surprise-marker {
  position: absolute;
  top: -3px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  transform: translateX(-50%);
  border: 2px solid var(--card-solid);
  box-shadow: 0 0 8px rgba(0,0,0,0.4);
}
.surprise-marker--beat { background: var(--bull); box-shadow: 0 0 10px var(--bull-glow); }
.surprise-marker--miss { background: var(--bear); box-shadow: 0 0 10px var(--bear-glow); }
.surprise-marker--inline { background: var(--neutral); box-shadow: 0 0 6px var(--neutral-glow); }
.surprise-scale {
  display: flex;
  justify-content: space-between;
  font-size: 9px;
  letter-spacing: 0.6px;
  color: var(--text-faint);
  text-transform: uppercase;
  font-weight: 600;
}
.surprise-stat {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
}
.surprise-stat-label {
  font-size: 9px;
  letter-spacing: 1.1px;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 600;
}
.surprise-stat-val {
  font-family: 'SF Mono', monospace;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.surprise-stat-val--beat { color: var(--bull-c); }
.surprise-stat-val--miss { color: var(--bear-c); }
.surprise-stat-val--inline { color: var(--text); }

/* Hidden chip */
.hidden-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  margin: 10px 0;
  font-size: 11.5px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.03);
  border-radius: 10px;
}
:root[data-theme="light"] .hidden-chip {
  background: rgba(255,255,255,0.45);
  border-color: rgba(255,255,255,0.55);
}
.hidden-chip-icon {
  color: var(--bull);
  font-size: 11px;
}
.hidden-chip strong { color: var(--text); font-weight: 600; }
.hidden-chip-action {
  margin-left: auto;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.4px;
  color: var(--bull-c);
  padding: 4px 10px;
  background: rgba(125,211,174,0.08);
  border: 1px solid rgba(125,211,174,0.22);
  border-radius: 7px;
  transition: all 0.18s;
}
.hidden-chip-action:hover {
  background: rgba(125,211,174,0.16);
}

/* Day navigator */
.day-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  gap: 10px;
}
.day-nav-arrow {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  background: rgba(255,255,255,0.03);
  font-size: 14px;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.18s;
}
:root[data-theme="light"] .day-nav-arrow {
  background: rgba(255,255,255,0.55);
}
.day-nav-arrow:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text);
}
.day-dots {
  display: flex;
  gap: 4px;
  justify-content: center;
  flex: 1;
}
.day-dot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 7px 9px;
  border-radius: 9px;
  background: transparent;
  transition: all 0.18s;
}
.day-dot:hover {
  background: rgba(255,255,255,0.04);
}
.day-dot.is-active {
  background: rgba(125,211,174,0.10);
}
:root[data-theme="light"] .day-dot.is-active {
  background: rgba(125,211,174,0.16);
}
.day-dot-label {
  font-size: 9.5px;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
}
.day-dot.is-active .day-dot-label {
  color: var(--bull-c);
}
.day-dot-marker {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}
.day-dot-marker--high { background: var(--bear); box-shadow: 0 0 4px var(--bear-glow); }
.day-dot-marker--med { background: var(--warm-amber); box-shadow: 0 0 4px var(--warm-amber-glow); }
.day-dot-marker--low { background: var(--neutral); }
.day-dot-marker--none { background: transparent; border: 1px solid var(--text-faint); }

/* Weekend body */
.weekend-body {
  padding: 30px 20px 20px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
  line-height: 1.7;
}
.weekend-icon {
  font-size: 36px;
  margin-bottom: 14px;
  opacity: 0.4;
}
.weekend-text {
  max-width: 480px;
  margin: 0 auto;
}
.weekend-text strong { color: var(--warm-amber); font-weight: 600; }
:root[data-theme="light"] .weekend-text strong { color: #b8741a; }

/* Mobile responsive */
@media (max-width: 700px) {
  .day-card { padding: 16px 14px 12px; }
  .day-card-head {
    flex-direction: column;
    gap: 12px;
  }
  .day-stats {
    width: 100%;
    justify-content: space-around;
    gap: 8px;
  }
  .day-name { font-size: 18px; }
  .day-date { font-size: 11px; }

  .ev-main {
    grid-template-columns: 44px 32px 1fr 8px 22px;
    grid-template-rows: auto auto;
    gap: 7px;
    padding: 8px 10px;
  }
  .ev-time { grid-column: 1; grid-row: 1; }
  .ev-currency { grid-column: 2; grid-row: 1; }
  .ev-name { grid-column: 3; grid-row: 1; font-size: 11px; }
  .ev-impact-dot { grid-column: 4; grid-row: 1; }
  .ev-hide { grid-column: 5; grid-row: 1; }
  .ev-values { grid-column: 1 / -1; grid-row: 2; font-size: 10.5px; margin-top: 2px; }

  .ev-expand-body {
    grid-template-columns: 1fr;
    padding: 4px 12px 12px;
  }

  .week-pill { padding: 7px 12px; font-size: 10px; }

  .day-dot { padding: 5px 6px; }
  .day-dot-label { font-size: 9px; }
}

/* ============================================================
   NEWS TAB
   ============================================================ */

.news-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.news-header__left { flex: 1; min-width: 0; }
.news-header__title {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.2px;
  margin: 0 0 6px;
}
.news-header__meta {
  font-size: 12px;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.news-header__meta strong { color: var(--text); font-weight: 600; }
.news-header__meta-sep { opacity: 0.4; }

.news-refresh {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 16px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.4px;
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border: 1px solid rgba(125,211,174,0.28);
  border-radius: 9px;
  transition: all 0.18s;
}
.news-refresh:hover { background: rgba(125,211,174,0.18); }
.news-refresh.is-loading { opacity: 0.5; cursor: wait; }
.news-refresh__icon {
  font-size: 14px;
  display: inline-block;
  transition: transform 0.6s;
}
.news-refresh.is-loading .news-refresh__icon {
  animation: spin 0.8s linear infinite;
}

/* Conflicts section */
.news-conflicts {
  background: linear-gradient(155deg, rgba(232,184,122,0.08), rgba(232,184,122,0.04));
  border: 1px solid rgba(232,184,122,0.32);
  border-radius: 14px;
  padding: 14px 18px;
  margin-bottom: 18px;
}
:root[data-theme="light"] .news-conflicts {
  background: rgba(232,184,122,0.12);
}
.news-conflicts__title {
  font-size: 11px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--warm-amber);
  font-weight: 700;
  margin: 0 0 10px;
}
:root[data-theme="light"] .news-conflicts__title { color: #b8741a; }
.news-conflicts__list { display: flex; flex-direction: column; gap: 6px; }
.news-conflict-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-size: 12px;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(232,184,122,0.18);
}
.news-conflict-row:last-child { border-bottom: none; }
.news-conflict-inst {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  letter-spacing: 0.3px;
  min-width: 72px;
  color: var(--text);
}
.news-conflict-detail { color: var(--text-muted); flex: 1; }
.news-conflict-dir { font-weight: 700; }
.news-conflict-dir--bullish, .news-conflict-dir--UP { color: var(--bull-c); }
.news-conflict-dir--bearish, .news-conflict-dir--DOWN { color: var(--bear-c); }
.news-conflict-count {
  color: var(--text-faint);
  font-size: 11px;
  margin-left: 4px;
}

/* Currency sentiment overview */
.news-overview {
  margin-bottom: 18px;
}
.news-overview__title {
  font-size: 10px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  margin: 0 0 10px;
}
.news-overview__grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.news-ov-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 13px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.03);
}
:root[data-theme="light"] .news-ov-item { background: rgba(255,255,255,0.45); }
.news-ov-item--bull { border-left: 3px solid var(--bull); }
.news-ov-item--bear { border-left: 3px solid var(--bear); }
.news-ov-item--neutral { border-left: 3px solid var(--neutral); }
.news-ov-ccy {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.4px;
}
.news-ov-counts {
  display: flex;
  align-items: baseline;
  gap: 6px;
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}
.news-ov-count--bull { color: var(--bull-c); font-weight: 600; }
.news-ov-count--bear { color: var(--bear-c); font-weight: 600; }

/* Filters */
.news-filters {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 18px;
  padding: 12px 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 13px;
}
:root[data-theme="light"] .news-filters { backdrop-filter: blur(12px); }
.news-filter-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.news-filter-label {
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-faint);
  min-width: 70px;
}
.news-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.news-filter-pill {
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 7px;
  transition: all 0.18s;
}
:root[data-theme="light"] .news-filter-pill { background: rgba(255,255,255,0.55); }
.news-filter-pill:hover {
  color: var(--text);
  background: rgba(255,255,255,0.08);
}
:root[data-theme="light"] .news-filter-pill:hover { background: rgba(255,255,255,0.75); }
.news-filter-pill.is-active {
  background: linear-gradient(155deg, rgba(125,211,174,0.20), rgba(125,211,174,0.10));
  border-color: rgba(125,211,174,0.45);
  color: var(--bull-c);
}
.news-filter-pill--bull.is-active {
  background: linear-gradient(155deg, rgba(125,211,174,0.22), rgba(125,211,174,0.10));
  border-color: rgba(125,211,174,0.45);
  color: var(--bull-c);
}
.news-filter-pill--bear.is-active {
  background: linear-gradient(155deg, rgba(232,154,142,0.22), rgba(232,154,142,0.10));
  border-color: rgba(232,154,142,0.45);
  color: var(--bear-c);
}
.news-filter-pill--conflict {
  margin-left: auto;
  color: var(--warm-amber);
  border-color: rgba(232,184,122,0.30);
  background: rgba(232,184,122,0.08);
}
:root[data-theme="light"] .news-filter-pill--conflict { color: #b8741a; }
.news-filter-pill--conflict.is-active {
  background: rgba(232,184,122,0.22);
  border-color: rgba(232,184,122,0.50);
}

/* Article list */
.news-list { display: flex; flex-direction: column; gap: 10px; }
.news-empty {
  padding: 60px 20px;
  text-align: center;
  font-size: 13px;
  color: var(--text-muted);
  font-style: italic;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
}

.news-article {
  background: var(--card);
  border: 1px solid var(--border);
  border-left-width: 3px;
  border-radius: 14px;
  padding: 13px 16px;
  transition: background 0.18s;
}
:root[data-theme="light"] .news-article { backdrop-filter: blur(12px); }
.news-article--bull { border-left-color: var(--bull); }
.news-article--bear { border-left-color: var(--bear); }
.news-article--neutral { border-left-color: var(--neutral); }

.news-article__head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 7px;
  flex-wrap: wrap;
}
.news-article__sentiment {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.4px;
  padding: 2px 8px;
  border-radius: 5px;
}
.news-article__sentiment--bull {
  color: var(--bull-c);
  background: rgba(125,211,174,0.14);
  border: 1px solid rgba(125,211,174,0.30);
}
.news-article__sentiment--bear {
  color: var(--bear-c);
  background: rgba(232,154,142,0.14);
  border: 1px solid rgba(232,154,142,0.30);
}
.news-article__sentiment--neutral {
  color: var(--neutral);
  background: rgba(165,172,186,0.10);
  border: 1px solid rgba(165,172,186,0.25);
}

.news-article__currencies {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.news-article__ccy {
  font-family: 'SF Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  color: var(--warm-amber);
  background: rgba(232,184,122,0.08);
  border: 1px solid rgba(232,184,122,0.22);
  padding: 1px 6px;
  border-radius: 4px;
  letter-spacing: 0.3px;
}
:root[data-theme="light"] .news-article__ccy { color: #b8741a; }

.news-article__meta {
  margin-left: auto;
  display: flex;
  align-items: baseline;
  gap: 7px;
  font-size: 10.5px;
  color: var(--text-faint);
}
.news-article__source {
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}
.news-article__time { font-family: 'SF Mono', monospace; }

.news-article__title {
  font-size: 13.5px;
  font-weight: 500;
  line-height: 1.45;
  margin: 0 0 5px;
  color: var(--text);
}
.news-article__desc {
  font-size: 12px;
  line-height: 1.55;
  color: var(--text-muted);
  margin: 0 0 7px;
}
.news-article__link {
  display: inline-block;
  font-size: 11px;
  color: var(--bull-c);
  text-decoration: none;
  letter-spacing: 0.3px;
  font-weight: 600;
  transition: color 0.18s;
}
.news-article__link:hover { color: var(--bull); }

/* ============================================================
   COT TAB
   ============================================================ */

.cot-header { margin-bottom: 14px; }
.cot-header__title {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.2px;
  margin: 0 0 6px;
}
.cot-header__meta {
  font-size: 12px;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.cot-header__meta strong { color: var(--text); font-weight: 600; }
.cot-header__sep { opacity: 0.4; }

.cot-legend {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  padding: 9px 14px;
  margin-bottom: 18px;
  font-size: 10.5px;
  color: var(--text-muted);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 11px;
}
.cot-legend-item {
  display: flex;
  align-items: center;
  gap: 7px;
}
.cot-legend-swatch {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 3px;
}
.cot-legend-swatch--bull { background: var(--bull); }
.cot-legend-swatch--bear { background: var(--bear); }
.cot-legend-swatch--neutral { background: var(--neutral); }
.cot-legend-item--note {
  margin-left: auto;
  font-style: italic;
  font-size: 10px;
  opacity: 0.6;
}

.cot-empty-card {
  padding: 60px 20px;
  text-align: center;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
}
.cot-empty-icon { font-size: 36px; opacity: 0.4; margin-bottom: 12px; }
.cot-empty-title { font-size: 15px; font-weight: 500; margin-bottom: 6px; }
.cot-empty-text { font-size: 12px; color: var(--text-muted); }

.cot-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 14px;
}

.cot-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow-out);
  padding: 14px 16px 12px;
  transition: transform 0.18s;
}
:root[data-theme="light"] .cot-card { backdrop-filter: blur(18px); }
.cot-card--bull { border-top: 2px solid var(--bull); }
.cot-card--bear { border-top: 2px solid var(--bear); }
.cot-card--neutral { border-top: 2px solid rgba(165,172,186,0.4); }
.cot-card.is-insufficient { opacity: 0.78; }

.cot-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  gap: 10px;
}
.cot-card__head-left {
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}
.cot-card__ccy {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.4px;
  font-family: 'SF Mono', monospace;
  margin: 0;
}
.cot-card__warn {
  font-size: 9px;
  letter-spacing: 0.6px;
  color: var(--warm-amber);
  background: rgba(232,184,122,0.12);
  border: 1px solid rgba(232,184,122,0.28);
  padding: 1px 6px;
  border-radius: 5px;
  font-weight: 600;
}
:root[data-theme="light"] .cot-card__warn { color: #b8741a; }

.cot-card__signal {
  text-align: right;
  flex-shrink: 0;
}
.cot-card__signal-label {
  display: block;
  font-size: 9px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 1px;
}
.cot-card__signal-val {
  font-family: 'SF Mono', monospace;
  font-size: 13px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.cot-card__signal--bull .cot-card__signal-label,
.cot-card__signal--bull .cot-card__signal-val { color: var(--bull-c); }
.cot-card__signal--bear .cot-card__signal-label,
.cot-card__signal--bear .cot-card__signal-val { color: var(--bear-c); }
.cot-card__signal--neutral .cot-card__signal-label,
.cot-card__signal--neutral .cot-card__signal-val { color: var(--text-muted); }

/* Heat bar */
.cot-card__heatbar { margin-bottom: 14px; }
.cot-card__heatbar-track {
  position: relative;
  height: 8px;
  background: linear-gradient(90deg,
    rgba(232,154,142,0.40) 0%,
    rgba(232,154,142,0.20) 28%,
    rgba(165,172,186,0.20) 50%,
    rgba(125,211,174,0.20) 72%,
    rgba(125,211,174,0.40) 100%);
  border-radius: 4px;
  margin-bottom: 16px;
}
.cot-card__heatbar-marker {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid var(--card-solid);
  box-shadow: 0 0 8px rgba(0,0,0,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cot-card__heatbar-marker--bull { background: var(--bull); box-shadow: 0 0 10px var(--bull-glow); }
.cot-card__heatbar-marker--bear { background: var(--bear); box-shadow: 0 0 10px var(--bear-glow); }
.cot-card__heatbar-marker--neutral { background: var(--neutral); }
.cot-card__heatbar-pct {
  position: absolute;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
}
.cot-card__heatbar-scale {
  display: flex;
  justify-content: space-between;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  color: var(--text-faint);
  font-weight: 600;
}

/* Sparkline */
.cot-card__sparkline {
  height: 50px;
  margin-bottom: 12px;
  padding: 0 2px;
}
.cot-spark {
  width: 100%;
  height: 100%;
  display: block;
}
.cot-spark-line {
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cot-spark--bull .cot-spark-line { stroke: var(--bull); }
.cot-spark--bear .cot-spark-line { stroke: var(--bear); }
.cot-spark--neutral .cot-spark-line { stroke: var(--neutral); }
.cot-spark-dot {
  fill: var(--text);
}
.cot-spark--bull .cot-spark-dot { fill: var(--bull); }
.cot-spark--bear .cot-spark-dot { fill: var(--bear); }
.cot-spark-zero {
  stroke: rgba(255,255,255,0.10);
  stroke-width: 1;
  stroke-dasharray: 2,2;
}
:root[data-theme="light"] .cot-spark-zero { stroke: rgba(46,41,64,0.18); }
.cot-spark-empty {
  text-align: center;
  font-size: 10px;
  color: var(--text-faint);
  font-style: italic;
  padding: 18px 0;
}

/* Stats grid */
.cot-card__stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px 14px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.cot-stat {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.cot-stat__label {
  font-size: 9.5px;
  letter-spacing: 1.1px;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 600;
}
.cot-stat__val {
  font-family: 'SF Mono', monospace;
  font-size: 11.5px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.cot-stat__val--bull { color: var(--bull-c); }
.cot-stat__val--bear { color: var(--bear-c); }
.cot-stat__val--neutral { color: var(--text); }

/* Mobile responsive */
@media (max-width: 700px) {
  .news-header { flex-direction: column; align-items: stretch; }
  .news-refresh { align-self: flex-end; }
  .news-overview__grid { gap: 6px; }
  .news-ov-item { padding: 6px 10px; }
  .news-article { padding: 12px 14px; }
  .news-filter-row { flex-direction: column; align-items: flex-start; gap: 6px; }
  .news-filter-label { min-width: 0; }
  .news-filter-pill--conflict { margin-left: 0; }

  .cot-grid { grid-template-columns: 1fr; }
  .cot-card__head { flex-wrap: wrap; }
  .cot-legend { gap: 10px; padding: 8px 12px; }
  .cot-legend-item--note { display: none; }
}

/* ============================================================
   DEPLOY 3.1 ADDITIONS
   ============================================================ */

/* News header — simpler v1-like (title + refresh only) */
.news-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
}
.news-header__title {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.3px;
  margin: 0;
}
.news-refresh {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  transition: all 0.18s;
}
:root[data-theme="light"] .news-refresh { background: rgba(255,255,255,0.55); }
.news-refresh:hover {
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border-color: rgba(125,211,174,0.28);
}
.news-refresh.is-loading { cursor: wait; }
.news-refresh.is-loading .news-refresh__icon {
  animation: spin 0.8s linear infinite;
  display: inline-block;
}
.news-refresh__icon { font-weight: 700; }

/* Conflict rows — now clickable buttons */
.news-conflict-row {
  width: 100%;
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-size: 12px;
  padding: 8px 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 9px;
  text-align: left;
  cursor: pointer;
  transition: all 0.18s;
}
.news-conflict-row:hover {
  background: rgba(232,184,122,0.06);
  border-color: rgba(232,184,122,0.22);
}
.news-conflict-row.is-active {
  background: rgba(232,184,122,0.14);
  border-color: rgba(232,184,122,0.42);
}

/* Active filter chip */
.news-active-filter {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  margin-bottom: 14px;
  font-size: 12px;
  color: var(--bull-c);
  background: rgba(125,211,174,0.08);
  border: 1px solid rgba(125,211,174,0.28);
  border-radius: 9px;
}
.news-active-filter strong { color: var(--text); font-weight: 600; }
.news-active-filter__clear {
  margin-left: auto;
  font-size: 11px;
  color: var(--bear-c);
  padding: 3px 9px;
  background: transparent;
  border: 1px solid rgba(232,154,142,0.30);
  border-radius: 6px;
  transition: all 0.18s;
}
.news-active-filter__clear:hover {
  background: rgba(232,154,142,0.12);
}

/* Article card — v1-like layout */
.news-article__sentiment {
  font-family: 'SF Mono', monospace;
}
.news-article__instruments {
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 0.4px;
}
.news-article__source-icon { opacity: 0.6; margin-right: 2px; }

/* Article footer with translate button */
.news-article__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 4px;
}
.news-article__translate {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 7px;
  letter-spacing: 0.3px;
  transition: all 0.18s;
}
:root[data-theme="light"] .news-article__translate { background: rgba(255,255,255,0.55); }
.news-article__translate:hover:not([disabled]) {
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border-color: rgba(125,211,174,0.30);
}
.news-article__translate[disabled] {
  opacity: 0.5;
  cursor: wait;
}

/* COT status hláška */
.cot-card__status {
  margin-top: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 9px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
:root[data-theme="light"] .cot-card__status { background: rgba(255,255,255,0.45); }
.cot-card__status--bull { border-left: 2px solid var(--bull); }
.cot-card__status--bear { border-left: 2px solid var(--bear); }
.cot-card__status--neutral { border-left: 2px solid var(--neutral); }
.cot-status-line {
  display: flex;
  align-items: baseline;
  gap: 6px;
  font-size: 11.5px;
  color: var(--text);
  flex-wrap: wrap;
}
.cot-status-icon { font-size: 12px; flex-shrink: 0; }
.cot-status-line strong { font-weight: 600; }
.cot-status-pct {
  font-family: 'SF Mono', monospace;
  font-size: 10.5px;
  color: var(--text-faint);
  font-variant-numeric: tabular-nums;
}
.cot-status-sep { color: var(--text-faint); opacity: 0.5; }
.cot-status-bias { color: var(--text-muted); font-style: italic; }

/* ============================================================
   DEPLOY 4.0 — (Sticky LIVE badge removed in 4.2, scrolls with topnav)
   ============================================================ */

/* Old floating fixed badge — removed (kept selector dead in case markup leaks) */
.status-badge--fixed { display: none !important; }

/* ============================================================
   JOURNAL TAB
   ============================================================ */
.jt-header { margin-bottom: 14px; }
.jt-title {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.3px;
  margin: 0 0 5px;
}
.jt-meta {
  display: flex;
  align-items: baseline;
  gap: 6px;
  font-size: 12px;
  color: var(--text-muted);
  flex-wrap: wrap;
}
.jt-meta strong { color: var(--text); font-weight: 600; }
.jt-meta-item--active strong { color: var(--bull-c); }
.jt-meta-item--expired strong { color: var(--warm-amber); }
:root[data-theme="light"] .jt-meta-item--expired strong { color: #b8741a; }
.jt-meta-sep { opacity: 0.4; }

.jt-filters {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 18px;
  padding: 12px 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 13px;
}
:root[data-theme="light"] .jt-filters { backdrop-filter: blur(12px); }
.jt-filter-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.jt-filter-label {
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-faint);
  min-width: 82px;
}
.jt-filter-pills { display: flex; flex-wrap: wrap; gap: 5px; }
.jt-filter-pill {
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 7px;
  transition: all 0.18s;
}
:root[data-theme="light"] .jt-filter-pill { background: rgba(255,255,255,0.55); }
.jt-filter-pill:hover {
  color: var(--text);
  background: rgba(255,255,255,0.08);
}
:root[data-theme="light"] .jt-filter-pill:hover { background: rgba(255,255,255,0.75); }
.jt-filter-pill.is-active {
  background: linear-gradient(155deg, rgba(125,211,174,0.20), rgba(125,211,174,0.10));
  border-color: rgba(125,211,174,0.45);
  color: var(--bull-c);
}

.jt-list { display: flex; flex-direction: column; gap: 11px; }

.jt-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-left-width: 3px;
  border-radius: 15px;
  padding: 13px 16px;
  transition: background 0.18s;
}
:root[data-theme="light"] .jt-card { backdrop-filter: blur(14px); }
.jt-card--dir-long { border-left-color: var(--bull); }
.jt-card--dir-short { border-left-color: var(--bear); }
.jt-card--dir-watch { border-left-color: rgba(154,139,191,0.50); }
.jt-card--closed { opacity: 0.66; }
.jt-card--expired { opacity: 0.55; }
.jt-card--expired { border-left-color: var(--warm-amber); }

.jt-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.jt-card__head-left {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.jt-card__inst {
  font-family: 'SF Mono', monospace;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.4px;
}
.jt-card__dir {
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 5px;
  letter-spacing: 0.3px;
}
.jt-card__dir--long {
  color: var(--bull-c);
  background: rgba(125,211,174,0.14);
  border: 1px solid rgba(125,211,174,0.30);
}
.jt-card__dir--short {
  color: var(--bear-c);
  background: rgba(232,154,142,0.14);
  border: 1px solid rgba(232,154,142,0.30);
}
.jt-card__dir--watch {
  color: rgba(179,163,214,0.95);
  background: rgba(154,139,191,0.14);
  border: 1px solid rgba(154,139,191,0.30);
}
.jt-card__days {
  font-size: 11px;
  color: var(--warm-amber);
  font-weight: 600;
  letter-spacing: 0.3px;
}
:root[data-theme="light"] .jt-card__days { color: #b8741a; }
.jt-card__status-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 5px;
  letter-spacing: 0.3px;
}
.jt-card__status-badge--closed {
  color: var(--bull-c);
  background: rgba(125,211,174,0.14);
  border: 1px solid rgba(125,211,174,0.30);
}
.jt-card__status-badge--expired {
  color: var(--warm-amber);
  background: rgba(232,184,122,0.14);
  border: 1px solid rgba(232,184,122,0.30);
}
:root[data-theme="light"] .jt-card__status-badge--expired { color: #b8741a; }

.jt-card__trigger,
.jt-card__plan {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.55;
  margin: 4px 0;
}
.jt-card__trigger strong { color: var(--text); font-weight: 600; }
.jt-card__plan {
  white-space: pre-wrap;
  color: var(--text);
  opacity: 0.85;
}
.jt-card__meta {
  font-size: 10.5px;
  color: var(--text-faint);
  margin: 8px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.jt-card__meta-sep { opacity: 0.5; }

/* Linked events + AI report context block */
.jt-card__linked {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 8px 0;
  padding: 9px 11px;
  background: rgba(255,255,255,0.025);
  border: 1px dashed var(--border);
  border-radius: 8px;
}
:root[data-theme="light"] .jt-card__linked {
  background: rgba(46,41,64,0.04);
}
.jt-link-title {
  font-size: 10.5px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 600;
  margin-bottom: 4px;
}
.jt-link-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.jt-link-item {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 8px;
  align-items: center;
  font-size: 11.5px;
  padding: 3px 0;
}
.jt-link-ccy {
  font-family: 'SF Mono', monospace;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--bull-c);
  letter-spacing: 0.3px;
}
.jt-link-name {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.jt-link-dt {
  font-family: 'SF Mono', monospace;
  font-size: 10.5px;
  font-variant-numeric: tabular-nums;
  color: var(--text-faint);
}
.jt-link-icon {
  font-size: 14px;
}
.jt-card__report {
  display: grid;
  grid-template-columns: 24px 1fr auto 28px;
  gap: 8px;
  align-items: center;
  font-size: 11.5px;
  padding: 5px 8px;
  background: rgba(125,211,174,0.05);
  border: 1px solid rgba(125,211,174,0.18);
  border-radius: 6px;
}
:root[data-theme="light"] .jt-card__report {
  background: rgba(125,211,174,0.08);
}
.jt-card__report--missing {
  background: rgba(255,255,255,0.02);
  border-color: var(--border);
}
.jt-link-missing {
  color: var(--text-faint);
  font-style: italic;
}
.jt-link-open {
  background: transparent;
  border: 1px solid rgba(125,211,174,0.32);
  border-radius: 5px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  color: var(--bull-c);
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: all 0.18s;
}
.jt-link-open:hover {
  background: rgba(125,211,174,0.15);
  border-color: rgba(125,211,174,0.5);
}

.jt-card__actions {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px dashed var(--border);
  margin-top: 4px;
}
.jt-action {
  padding: 5px 11px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  color: var(--text-muted);
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 7px;
  transition: all 0.18s;
}
.jt-action:hover { background: rgba(255,255,255,0.06); color: var(--text); }
:root[data-theme="light"] .jt-action:hover { background: rgba(46,41,64,0.07); }
.jt-action--complete:hover {
  background: rgba(125,211,174,0.12);
  border-color: rgba(125,211,174,0.35);
  color: var(--bull-c);
}
.jt-action--reopen:hover {
  background: rgba(154,139,191,0.12);
  border-color: rgba(154,139,191,0.35);
  color: rgba(179,163,214,0.95);
}
.jt-action--delete:hover {
  background: rgba(232,154,142,0.12);
  border-color: rgba(232,154,142,0.35);
  color: var(--bear-c);
}

.jt-empty {
  padding: 60px 20px;
  text-align: center;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
}
.jt-empty-icon { font-size: 36px; opacity: 0.4; margin-bottom: 12px; }
.jt-empty-title { font-size: 15px; font-weight: 500; margin-bottom: 6px; }
.jt-empty-text { font-size: 12px; color: var(--text-muted); }

.jt-new-wrap {
  margin-top: 18px;
  display: flex;
  justify-content: center;
}
.jt-new {
  padding: 11px 28px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.4px;
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border: 1px solid rgba(125,211,174,0.35);
  border-radius: 10px;
  transition: all 0.18s;
}
.jt-new:hover {
  background: rgba(125,211,174,0.20);
}

/* ============================================================
   COT LEGEND BUTTON + MODAL
   ============================================================ */
.cot-legend-wrap {
  margin-bottom: 18px;
}
.cot-legend-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.3px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: all 0.18s;
}
:root[data-theme="light"] .cot-legend-btn { background: rgba(255,255,255,0.55); }
.cot-legend-btn:hover {
  color: var(--bull-c);
  background: rgba(125,211,174,0.08);
  border-color: rgba(125,211,174,0.25);
}
.cot-legend-btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(125,211,174,0.20);
  color: var(--bull-c);
  font-size: 11px;
  font-weight: 700;
  font-style: italic;
}

.cot-legend-card {
  max-width: 520px;
}
.cot-legend-body {
  max-height: 60vh;
  overflow-y: auto;
  padding-right: 8px;
}
.cot-legend-section {
  padding: 10px 0;
  border-bottom: 1px dashed var(--border);
}
.cot-legend-section:last-of-type { border-bottom: none; }
.cot-legend-term {
  font-size: 13px;
  margin-bottom: 4px;
  color: var(--text);
}
.cot-legend-def {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.55;
}
.cot-legend-note {
  margin-top: 14px;
  padding: 10px 12px;
  font-size: 11.5px;
  color: var(--warm-amber);
  background: rgba(232,184,122,0.08);
  border: 1px solid rgba(232,184,122,0.28);
  border-radius: 9px;
  line-height: 1.55;
}
:root[data-theme="light"] .cot-legend-note { color: #b8741a; }

/* Mobile responsive — Journal */
@media (max-width: 700px) {
  .jt-card { padding: 12px 14px; }
  .jt-card__head { gap: 6px; }
  .jt-card__inst { font-size: 14px; }
  .jt-filter-row { flex-direction: column; align-items: flex-start; gap: 6px; }
  .jt-filter-label { min-width: 0; }
  .jt-card__actions { gap: 5px; }
  .jt-action { padding: 4px 9px; font-size: 10px; }
}

/* ============================================================
   DEPLOY 4.1 — Swing hint, inline COT info icon, cleanup
   ============================================================ */

/* Swing mode hint — Mon-Tue 14:00 CET banner */
.swing-hint {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  margin-bottom: 14px;
  background: linear-gradient(155deg, rgba(154,139,191,0.14), rgba(154,139,191,0.06));
  border: 1px solid rgba(154,139,191,0.32);
  border-radius: 14px;
  flex-wrap: wrap;
}
:root[data-theme="light"] .swing-hint {
  background: rgba(154,139,191,0.18);
}
.swing-hint__icon { font-size: 22px; flex-shrink: 0; }
.swing-hint__body { flex: 1; min-width: 0; }
.swing-hint__title {
  font-size: 10px;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  font-weight: 700;
  color: rgba(179,163,214,0.95);
  margin-bottom: 3px;
}
:root[data-theme="light"] .swing-hint__title { color: #6a5a91; }
.swing-hint__text {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--text);
}
.swing-hint__btn {
  flex-shrink: 0;
  padding: 7px 14px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.4px;
  color: rgba(179,163,214,1);
  background: rgba(154,139,191,0.18);
  border: 1px solid rgba(154,139,191,0.45);
  border-radius: 9px;
  transition: all 0.18s;
}
:root[data-theme="light"] .swing-hint__btn { color: #6a5a91; }
.swing-hint__btn:hover {
  background: rgba(154,139,191,0.30);
}

/* Inline ⓘ info icon next to COT title */
.cot-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  margin-left: 6px;
  font-size: 13px;
  font-style: italic;
  font-weight: 700;
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border: 1px solid rgba(125,211,174,0.30);
  border-radius: 50%;
  vertical-align: middle;
  cursor: pointer;
  transition: all 0.18s;
  line-height: 1;
}
.cot-info-icon:hover {
  background: rgba(125,211,174,0.22);
  transform: scale(1.05);
}

/* Remove old cot-legend-wrap if still in DOM (defensive) */
.cot-legend-wrap { display: none !important; }

/* Mobile responsive — swing hint stacks */
@media (max-width: 700px) {
  .swing-hint {
    padding: 10px 14px;
    gap: 10px;
  }
  .swing-hint__icon { font-size: 18px; }
  .swing-hint__text { font-size: 11.5px; }
  .swing-hint__btn {
    width: 100%;
    text-align: center;
  }
}

/* ============================================================
   DEPLOY 5 — SETTINGS TAB
   ============================================================ */

.settings-page {
  display: flex;
  flex-direction: column;
}
.settings-header {
  margin-bottom: 18px;
}
.settings-title {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.3px;
  margin: 0;
}

.settings-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 22px;
  align-items: start;
}

/* Left nav (desktop) */
.settings-nav {
  position: sticky;
  top: 12px;
}
.settings-nav-mobile { display: none; }
.settings-nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.settings-nav-item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 13px;
  font-size: 12.5px;
  color: var(--text-muted);
  background: transparent;
  border: 1px solid transparent;
  border-radius: 9px;
  text-align: left;
  transition: all 0.18s;
}
.settings-nav-item:hover {
  background: rgba(255,255,255,0.04);
  color: var(--text);
}
:root[data-theme="light"] .settings-nav-item:hover { background: rgba(46,41,64,0.05); }
.settings-nav-item.is-active {
  background: linear-gradient(155deg, rgba(125,211,174,0.16), rgba(125,211,174,0.08));
  border-color: rgba(125,211,174,0.36);
  color: var(--bull-c);
}
.settings-nav-item__icon { font-size: 14px; }
.settings-nav-item__label { font-weight: 600; letter-spacing: 0.2px; }

/* Content */
.settings-content {
  min-width: 0;
}

.settings-section {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 22px 24px;
  margin-bottom: 16px;
}
:root[data-theme="light"] .settings-section { backdrop-filter: blur(14px); }

.settings-section__title {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.3px;
  margin: 0 0 6px;
  color: var(--text);
}
.settings-section__desc {
  font-size: 12px;
  color: var(--text-muted);
  margin: 0 0 18px;
  line-height: 1.55;
}

.settings-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--border);
  flex-wrap: wrap;
}
.settings-row:last-child { border-bottom: none; }
.settings-row__label {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}
.settings-row__label strong {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.settings-row__hint {
  font-size: 11px;
  color: var(--text-faint);
  line-height: 1.4;
}
.settings-row__control { flex-shrink: 0; }

.settings-row--actions {
  display: flex;
  justify-content: flex-start;
  gap: 8px;
  flex-wrap: wrap;
  padding-top: 14px;
  border-bottom: none;
}

/* Switch */
.settings-switch {
  display: inline-block;
  cursor: pointer;
}
.settings-switch input { display: none; }
.settings-switch__track {
  position: relative;
  width: 44px;
  height: 24px;
  display: inline-block;
  background: rgba(255,255,255,0.08);
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: background 0.2s;
  vertical-align: middle;
}
:root[data-theme="light"] .settings-switch__track { background: rgba(46,41,64,0.10); }
.settings-switch__thumb {
  position: absolute;
  top: 50%;
  left: 3px;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: var(--text-muted);
  border-radius: 50%;
  transition: left 0.2s, background 0.2s;
}
.settings-switch.is-on .settings-switch__track {
  background: rgba(125,211,174,0.32);
  border-color: rgba(125,211,174,0.50);
}
.settings-switch.is-on .settings-switch__thumb {
  left: 23px;
  background: var(--bull);
}

/* Select */
.settings-select {
  padding: 7px 30px 7px 12px;
  font-size: 12px;
  font-family: inherit;
  color: var(--text);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 8px;
  appearance: none;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23999' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  min-width: 180px;
}
:root[data-theme="light"] .settings-select {
  background-color: rgba(255,255,255,0.65);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23666' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
}

/* Radio group */
.settings-radio-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.settings-radio {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 6px 11px;
  font-size: 12px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 7px;
  cursor: pointer;
  transition: all 0.18s;
}
:root[data-theme="light"] .settings-radio { background: rgba(255,255,255,0.55); }
.settings-radio input { margin: 0; accent-color: var(--bull); }
.settings-radio.is-active {
  background: rgba(125,211,174,0.10);
  border-color: rgba(125,211,174,0.32);
  color: var(--bull-c);
}

/* Theme picker */
.settings-theme-picker {
  display: flex;
  gap: 8px;
}
.settings-theme-opt {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 14px;
  font-size: 12px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 9px;
  transition: all 0.18s;
}
:root[data-theme="light"] .settings-theme-opt { background: rgba(255,255,255,0.55); }
.settings-theme-opt.is-active {
  background: rgba(125,211,174,0.12);
  border-color: rgba(125,211,174,0.36);
  color: var(--bull-c);
}
.settings-theme-swatch {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid var(--border);
}
.settings-theme-swatch--dark { background: #1a1a1c; }
.settings-theme-swatch--light { background: linear-gradient(155deg, #e8e1ed, #c8d4d2); }

/* Category grid */
.settings-category-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}
.settings-category-toggle {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 12px;
  font-size: 12px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.18s;
}
:root[data-theme="light"] .settings-category-toggle { background: rgba(255,255,255,0.55); }
.settings-category-toggle input { margin: 0; accent-color: var(--bull); }
.settings-category-toggle.is-active {
  background: rgba(125,211,174,0.08);
  border-color: rgba(125,211,174,0.28);
  color: var(--text);
}
.settings-category-label { font-weight: 500; }

/* Buttons */
.settings-btn {
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.3px;
  border-radius: 9px;
  transition: all 0.18s;
  font-family: inherit;
  cursor: pointer;
}
.settings-btn--ghost {
  color: var(--text-muted);
  background: transparent;
  border: 1px solid var(--border);
}
.settings-btn--ghost:hover {
  background: rgba(255,255,255,0.05);
  color: var(--text);
}
.settings-btn--secondary {
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border: 1px solid rgba(125,211,174,0.32);
}
.settings-btn--secondary:hover {
  background: rgba(125,211,174,0.20);
}
.settings-btn--danger {
  color: var(--bear-c);
  background: rgba(232,154,142,0.08);
  border: 1px solid rgba(232,154,142,0.32);
}
.settings-btn--danger:hover {
  background: rgba(232,154,142,0.18);
}

/* Info blocks */
.settings-info-block {
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 9px;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.65;
}
:root[data-theme="light"] .settings-info-block { background: rgba(255,255,255,0.45); }
.settings-info-block strong { color: var(--text); }
.settings-info-list {
  margin: 6px 0 0;
  padding-left: 18px;
}
.settings-info-list li {
  padding: 2px 0;
}

.settings-divider {
  height: 1px;
  background: var(--border);
  margin: 20px 0;
}

.settings-subtitle {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.3px;
  color: var(--bear-c);
  margin: 0 0 10px;
}

/* About */
.settings-about {
  text-align: center;
  padding: 14px 0;
}
.settings-about__logo {
  font-size: 28px;
  font-weight: 300;
  letter-spacing: 1.5px;
  margin-bottom: 4px;
}
.settings-about__logo span {
  color: var(--bull-c);
  font-weight: 500;
}
.settings-about__tagline {
  font-size: 11.5px;
  color: var(--text-muted);
  letter-spacing: 0.4px;
  margin-bottom: 22px;
}
.settings-about__details {
  text-align: left;
  max-width: 400px;
  margin: 0 auto 18px;
}
.settings-about__details .settings-row {
  flex-wrap: nowrap;
  font-size: 12px;
}
.settings-about__details .settings-row strong {
  color: var(--text-muted);
  font-weight: 600;
}
.settings-about__details a {
  color: var(--bull-c);
  text-decoration: none;
}
.settings-about__details a:hover { text-decoration: underline; }
.settings-about__note {
  font-size: 11px;
  color: var(--text-faint);
  font-style: italic;
  max-width: 400px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Mobile responsive */
@media (max-width: 900px) {
  .settings-layout {
    grid-template-columns: 1fr;
  }
  .settings-nav {
    position: static;
  }
  .settings-nav-list {
    display: none;
  }
  .settings-nav-mobile {
    display: block;
    width: 100%;
    padding: 10px 14px;
    font-size: 13px;
    font-family: inherit;
    color: var(--text);
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 9px;
    margin-bottom: 14px;
  }
  :root[data-theme="light"] .settings-nav-mobile { backdrop-filter: blur(12px); }
}
@media (max-width: 700px) {
  .settings-section { padding: 16px 18px; }
  .settings-row { flex-direction: column; align-items: stretch; }
  .settings-row__control { align-self: flex-start; }
  .settings-category-grid { grid-template-columns: 1fr; }
  .settings-select { width: 100%; }
  .settings-row--actions { flex-direction: column; }
  .settings-btn { width: 100%; text-align: center; }
}

/* ============================================================
   DEPLOY 5.1 — Settings polish (category examples, sync modal)
   ============================================================ */

/* Category toggle — now 2-line layout with examples */
.settings-category-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}
.settings-category-examples {
  font-size: 10px;
  color: var(--text-faint);
  font-style: italic;
  letter-spacing: 0.2px;
  line-height: 1.4;
}
.settings-category-toggle.is-active .settings-category-examples {
  color: var(--text-muted);
}

/* Settings subtitle — normal (non-danger) variant */
.settings-subtitle--normal {
  color: var(--text);
  margin-top: 4px;
}

/* Sync modal sizing */
.sync-modal {
  max-width: 600px;
  width: 92vw;
}
.sync-modal__desc {
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-muted);
  margin: 4px 0 14px;
}
.sync-modal__desc--warn {
  color: var(--bear-c);
  background: rgba(232,154,142,0.06);
  border: 1px solid rgba(232,154,142,0.25);
  border-radius: 9px;
  padding: 10px 14px;
}
.sync-modal__stats {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  color: var(--text-faint);
  font-family: 'SF Mono', monospace;
}
.sync-modal__textarea {
  width: 100%;
  min-height: 180px;
  max-height: 260px;
  padding: 12px 14px;
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  line-height: 1.4;
  color: var(--text);
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--border);
  border-radius: 10px;
  resize: vertical;
  box-sizing: border-box;
  word-break: break-all;
}
:root[data-theme="light"] .sync-modal__textarea {
  background: rgba(46,41,64,0.04);
  color: var(--text);
}
.sync-modal__textarea:focus {
  outline: none;
  border-color: rgba(125,211,174,0.45);
}
.sync-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 14px;
}

@media (max-width: 700px) {
  .sync-modal { width: 96vw; }
  .sync-modal__textarea { min-height: 140px; font-size: 10px; }
  .sync-modal__actions { flex-direction: column-reverse; }
  .sync-modal__actions .settings-btn { width: 100%; }
}

/* ============================================================
   DEPLOY 6 — ANALÝZA TAB (AI Reports)
   ============================================================ */

/* Header */
.az-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 22px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.az-header__left { min-width: 0; }
.az-title {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.3px;
  margin: 0 0 6px;
}
.az-header__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
}
.az-cooldown {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  font-size: 11px;
  color: var(--warm-amber);
  background: rgba(232,184,122,0.08);
  border: 1px solid rgba(232,184,122,0.28);
  border-radius: 6px;
  font-weight: 600;
}
:root[data-theme="light"] .az-cooldown { color: #b8741a; }
.az-cooldown--ready {
  color: var(--bull-c);
  background: rgba(125,211,174,0.08);
  border-color: rgba(125,211,174,0.28);
}
.az-header__right { flex-shrink: 0; min-width: 240px; }
.az-usage {
  padding: 10px 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
}
.az-usage__top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
}
.az-usage__label {
  font-size: 10px;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-faint);
}
.az-usage__val {
  font-family: 'SF Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.az-usage__val.is-caution { color: var(--warm-amber); }
.az-usage__val.is-warn { color: var(--bear-c); }
.az-usage__bar {
  height: 5px;
  background: rgba(255,255,255,0.06);
  border-radius: 3px;
  overflow: hidden;
}
:root[data-theme="light"] .az-usage__bar { background: rgba(46,41,64,0.07); }
.az-usage__fill {
  height: 100%;
  background: var(--bull);
  transition: width 0.3s, background 0.3s;
}
.az-usage__fill.is-caution { background: var(--warm-amber); }
.az-usage__fill.is-warn { background: var(--bear); }
.az-usage__warnings { margin-top: 8px; }
.az-warning {
  display: block;
  font-size: 10.5px;
  color: var(--bear-c);
  margin-top: 4px;
}

/* Generate panel */
.az-generate {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 18px 20px;
  margin-bottom: 18px;
}
:root[data-theme="light"] .az-generate { backdrop-filter: blur(14px); }

.az-section-title {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.3px;
  margin: 0 0 14px;
  color: var(--text);
}

.az-modes,
.az-instruments,
.az-context {
  margin-bottom: 14px;
}
.az-modes__label,
.az-instruments__label,
.az-context__label {
  display: block;
  font-size: 10.5px;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-faint);
  margin-bottom: 8px;
}

.az-modes__pills,
.az-instruments__list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.az-mode,
.az-inst-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 13px;
  font-size: 12px;
  color: var(--text-muted);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.18s;
}
:root[data-theme="light"] .az-mode,
:root[data-theme="light"] .az-inst-toggle { background: rgba(255,255,255,0.55); }
.az-mode input, .az-inst-toggle input { margin: 0; accent-color: var(--bull); }
.az-mode.is-active,
.az-inst-toggle.is-active {
  background: rgba(125,211,174,0.10);
  border-color: rgba(125,211,174,0.32);
  color: var(--bull-c);
}
.az-mode__name { font-weight: 600; }

.az-context__input {
  width: 100%;
  padding: 10px 13px;
  font-size: 12px;
  font-family: inherit;
  line-height: 1.5;
  color: var(--text);
  background: rgba(0,0,0,0.20);
  border: 1px solid var(--border);
  border-radius: 9px;
  box-sizing: border-box;
  resize: vertical;
}
:root[data-theme="light"] .az-context__input { background: rgba(46,41,64,0.04); }
.az-context__input:focus {
  outline: none;
  border-color: rgba(125,211,174,0.40);
}

.az-generate__actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 18px;
}

.az-btn {
  padding: 9px 18px;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.3px;
  border-radius: 9px;
  transition: all 0.18s;
  font-family: inherit;
  cursor: pointer;
}
.az-btn--primary {
  color: #fff;
  background: linear-gradient(155deg, var(--bull), #5ec295);
  border: 1px solid rgba(125,211,174,0.55);
}
.az-btn--primary:hover:not([disabled]) {
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(125,211,174,0.30);
}
.az-btn--secondary {
  color: var(--bull-c);
  background: rgba(125,211,174,0.10);
  border: 1px solid rgba(125,211,174,0.32);
}
.az-btn--secondary:hover:not([disabled]) {
  background: rgba(125,211,174,0.20);
}
.az-btn--ghost {
  color: var(--text-muted);
  background: transparent;
  border: 1px solid var(--border);
}
.az-btn--ghost:hover:not([disabled]) {
  background: rgba(255,255,255,0.05);
  color: var(--text);
}
.az-btn[disabled], .az-btn.is-loading {
  opacity: 0.6;
  cursor: wait;
}

/* Empty state */
.az-empty {
  padding: 60px 20px;
  text-align: center;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  margin-bottom: 18px;
}
.az-empty__icon { font-size: 40px; opacity: 0.4; margin-bottom: 12px; }
.az-empty__title { font-size: 15px; font-weight: 500; margin-bottom: 6px; }
.az-empty__text {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 360px;
  margin: 0 auto;
}

/* Report viewer */
.az-viewer {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px 22px;
  margin-bottom: 18px;
}
:root[data-theme="light"] .az-viewer { backdrop-filter: blur(14px); }

.az-viewer__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 16px;
  flex-wrap: wrap;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--border);
}
.az-viewer__title {
  font-size: 15px;
  font-weight: 500;
  margin: 0 0 4px;
}
.az-viewer__meta {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 11px;
  color: var(--text-faint);
  flex-wrap: wrap;
}
.az-viewer__mode {
  font-family: 'SF Mono', monospace;
  color: var(--bull-c);
  background: rgba(125,211,174,0.08);
  padding: 1px 7px;
  border-radius: 4px;
}
.az-viewer__usage {
  font-family: 'SF Mono', monospace;
  font-variant-numeric: tabular-nums;
}

/* Signals table */
.az-signals {
  margin-bottom: 18px;
}
.az-signals__title {
  font-size: 11px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--text-faint);
  margin: 0 0 8px;
}
.az-signals__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.az-signals__table th {
  text-align: left;
  padding: 6px 10px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--text-faint);
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.025);
}
:root[data-theme="light"] .az-signals__table th { background: rgba(46,41,64,0.04); }
.az-signals__table td {
  padding: 8px 10px;
  border-bottom: 1px dashed var(--border);
}
.az-signals__table tr:last-child td { border-bottom: none; }
.az-signals__inst {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  letter-spacing: 0.3px;
}
.az-signals__score {
  font-family: 'SF Mono', monospace;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.az-signals__score--bull { color: var(--bull-c); }
.az-signals__score--bear { color: var(--bear-c); }
.az-signals__score--neutral { color: var(--text-muted); }
.az-signals__conf {
  font-size: 11px;
  color: var(--text-muted);
  text-transform: lowercase;
}
.az-signals__dir {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  width: 30px;
}
.az-signals__dir--bull { color: var(--bull-c); }
.az-signals__dir--bear { color: var(--bear-c); }
.az-signals__dir--neutral { color: var(--text-faint); }

/* Markdown rendered body */
.az-markdown {
  font-size: 13px;
  line-height: 1.65;
  color: var(--text);
}
.az-markdown .md-h {
  font-weight: 600;
  letter-spacing: 0.2px;
  margin: 18px 0 8px;
  line-height: 1.3;
}
.az-markdown .md-h1 { font-size: 18px; }
.az-markdown .md-h2 { font-size: 16px; }
.az-markdown .md-h3 { font-size: 14px; color: var(--bull-c); }
.az-markdown .md-h4 {
  font-size: 12.5px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
}
.az-markdown .md-p {
  margin: 0 0 10px;
}
.az-markdown .md-list {
  margin: 8px 0 12px;
  padding-left: 22px;
}
.az-markdown .md-list li {
  margin-bottom: 4px;
}
.az-markdown code {
  font-family: 'SF Mono', monospace;
  font-size: 11.5px;
  padding: 1px 6px;
  background: rgba(255,255,255,0.06);
  border-radius: 4px;
  color: var(--warm-amber);
}
:root[data-theme="light"] .az-markdown code {
  background: rgba(46,41,64,0.06);
  color: #b8741a;
}
.az-markdown pre.md-code {
  padding: 12px 14px;
  background: rgba(0,0,0,0.30);
  border: 1px solid var(--border);
  border-radius: 9px;
  overflow-x: auto;
  margin: 12px 0;
}
:root[data-theme="light"] .az-markdown pre.md-code {
  background: rgba(46,41,64,0.05);
}
.az-markdown pre.md-code code {
  background: transparent;
  padding: 0;
  color: var(--text);
  font-size: 11px;
  line-height: 1.5;
}
.az-markdown .md-quote {
  margin: 10px 0;
  padding: 8px 14px;
  font-style: italic;
  color: var(--text-muted);
  border-left: 3px solid rgba(125,211,174,0.40);
  background: rgba(125,211,174,0.04);
  border-radius: 0 6px 6px 0;
}
.az-markdown .md-hr {
  border: none;
  border-top: 1px dashed var(--border);
  margin: 18px 0;
}
.az-markdown strong { font-weight: 700; color: var(--text); }
.az-markdown em { font-style: italic; color: var(--text-muted); }
.az-markdown a {
  color: var(--bull-c);
  text-decoration: none;
  border-bottom: 1px dashed rgba(125,211,174,0.40);
}
.az-markdown a:hover {
  border-bottom-style: solid;
}

.az-warning-block {
  margin-top: 14px;
  padding: 10px 14px;
  font-size: 12px;
  color: var(--warm-amber);
  background: rgba(232,184,122,0.08);
  border: 1px solid rgba(232,184,122,0.28);
  border-radius: 9px;
}
:root[data-theme="light"] .az-warning-block { color: #b8741a; }

/* History */
.az-history {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 18px 20px;
}
.az-history__list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  max-height: 400px;
  overflow-y: auto;
}
.az-history-item {
  display: grid;
  grid-template-columns: 1.5fr 1fr 80px;
  gap: 12px;
  align-items: center;
  padding: 9px 13px;
  font-size: 11.5px;
  background: rgba(255,255,255,0.025);
  border: 1px solid transparent;
  border-radius: 8px;
  text-align: left;
  cursor: pointer;
  transition: all 0.18s;
}
:root[data-theme="light"] .az-history-item { background: rgba(255,255,255,0.55); }
.az-history-item:hover {
  background: rgba(255,255,255,0.05);
  border-color: var(--border);
}
:root[data-theme="light"] .az-history-item:hover { background: rgba(46,41,64,0.05); }
.az-history-item.is-active {
  background: rgba(125,211,174,0.10);
  border-color: rgba(125,211,174,0.30);
}
.az-history-item__date {
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.az-history-item__mode {
  font-size: 10.5px;
  color: var(--bull-c);
  font-family: 'SF Mono', monospace;
}
.az-history-item__stats {
  text-align: right;
  font-size: 10px;
  color: var(--text-faint);
}

/* AI settings inputs */
.settings-input {
  width: 80px;
  padding: 7px 10px;
  font-size: 12px;
  font-family: 'SF Mono', monospace;
  color: var(--text);
  background: rgba(0,0,0,0.20);
  border: 1px solid var(--border);
  border-radius: 7px;
  font-variant-numeric: tabular-nums;
  text-align: right;
}
:root[data-theme="light"] .settings-input { background: rgba(46,41,64,0.04); }
.settings-input:focus {
  outline: none;
  border-color: rgba(125,211,174,0.40);
}
.settings-input-suffix {
  display: inline-block;
  margin-left: 6px;
  font-size: 11px;
  color: var(--text-faint);
  letter-spacing: 0.4px;
}

/* Mobile responsive */
@media (max-width: 700px) {
  .az-header { flex-direction: column; }
  .az-header__right { min-width: 0; width: 100%; }
  .az-generate__actions { flex-direction: column-reverse; }
  .az-generate__actions .az-btn { width: 100%; text-align: center; }
  .az-modes__pills,
  .az-instruments__list { gap: 5px; }
  .az-mode, .az-inst-toggle { padding: 5px 10px; font-size: 11px; }
  .az-viewer { padding: 14px 16px; }
  .az-viewer__head { flex-direction: column; align-items: flex-start; }
  .az-signals__table { font-size: 11px; }
  .az-signals__table th, .az-signals__table td { padding: 6px 8px; }
  .az-history-item { grid-template-columns: 1fr; gap: 4px; padding: 10px 12px; }
  .az-history-item__stats { text-align: left; }
}

/* ════════════════════════════════════════════════════════════
   DEPLOY 9 — Journal modal linked sections + Event picker
   ═══════════════════════════════════════════════════════════ */

/* Journal modal: linked events + AI report sections */
.jm-link-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.jm-link-empty {
  font-size: 11.5px;
  color: var(--text-faint);
  padding: 10px 12px;
  text-align: center;
  background: rgba(255,255,255,0.025);
  border: 1px dashed var(--border);
  border-radius: 7px;
  font-style: italic;
}
.jm-linked-events {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.jm-link-row {
  display: grid;
  grid-template-columns: 40px 1fr auto 22px;
  gap: 8px;
  align-items: center;
  padding: 7px 10px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 7px;
  font-size: 11.5px;
}
:root[data-theme="light"] .jm-link-row {
  background: rgba(46,41,64,0.04);
}
.jm-link-ccy {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  color: var(--bull-c);
  letter-spacing: 0.3px;
}
.jm-link-evname {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.jm-link-dt {
  font-family: 'SF Mono', monospace;
  color: var(--text-faint);
  font-size: 10.5px;
  font-variant-numeric: tabular-nums;
}
.jm-link-remove {
  width: 22px;
  height: 22px;
  border-radius: 5px;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-faint);
  cursor: pointer;
  font-size: 14px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.18s;
}
.jm-link-remove:hover {
  background: rgba(232,154,142,0.14);
  color: var(--bear);
  border-color: rgba(232,154,142,0.4);
}
.jm-btn--small {
  padding: 4px 10px;
  font-size: 11px;
}
.jm-hint {
  margin-top: 5px;
  font-size: 11px;
  color: var(--text-faint);
  font-style: italic;
}

/* Event picker overlay (separate from journal modal) */
.jm-overlay--picker {
  z-index: 10001;
}
.jm-card--picker {
  max-width: 640px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
}
.jm-evpick__filter {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--border);
}
.jm-evpick__filter-btn {
  padding: 4px 10px;
  font-size: 11px;
  color: var(--text-muted);
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.18s;
}
.jm-evpick__filter-btn:hover {
  background: rgba(255,255,255,0.05);
  color: var(--text);
}
.jm-evpick__filter-btn.is-active {
  background: rgba(125,211,174,0.14);
  color: var(--bull-c);
  border-color: rgba(125,211,174,0.4);
}
.jm-evpick__list {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px;
  max-height: 50vh;
}
.jm-evpick {
  display: grid;
  grid-template-columns: 22px 40px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  margin-bottom: 4px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: 7px;
  cursor: pointer;
  font-size: 12px;
  transition: all 0.18s;
}
:root[data-theme="light"] .jm-evpick {
  background: rgba(46,41,64,0.04);
}
.jm-evpick:hover {
  background: rgba(125,211,174,0.06);
  border-color: rgba(125,211,174,0.2);
}
.jm-evpick--high { border-left-color: var(--bear); }
.jm-evpick--med { border-left-color: var(--warm-amber); }
.jm-evpick--linked {
  opacity: 0.55;
  cursor: not-allowed;
}
.jm-evpick input[type="checkbox"] {
  margin: 0;
  accent-color: var(--bull);
}
.jm-evpick__ccy {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  color: var(--bull-c);
}
.jm-evpick__name {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.jm-evpick__dt {
  font-family: 'SF Mono', monospace;
  color: var(--text-faint);
  font-size: 10.5px;
  font-variant-numeric: tabular-nums;
}

/* Analýza tab — quick select buttons */
.az-instruments__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.az-instruments__quick {
  display: flex;
  gap: 6px;
}
.az-quick-btn {
  padding: 3px 9px;
  font-size: 11px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.18s;
}
.az-quick-btn:hover {
  background: rgba(125,211,174,0.1);
  color: var(--bull-c);
  border-color: rgba(125,211,174,0.3);
}

/* Analýza tab — settings link in header */
.az-settings-link {
  font-size: 11.5px;
  color: var(--text-muted);
  text-decoration: none;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px dashed var(--border);
  transition: all 0.18s;
  white-space: nowrap;
}
.az-settings-link:hover {
  color: var(--bull-c);
  border-color: rgba(125,211,174,0.4);
  background: rgba(125,211,174,0.06);
}

/* Analýza cooldown warn variant */
.az-cooldown--warn {
  color: var(--bear-c);
  background: rgba(232,154,142,0.10);
  border-color: rgba(232,154,142,0.32);
}

/* ════════════════════════════════════════════════════════════
   DEPLOY 10 — Pillar toggles, glow modes, consensus, C5, Z1
   ═══════════════════════════════════════════════════════════ */

/* ── B1-B5: Pillar toggles in Settings ── */
.settings-subtitle {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin: 18px 0 4px;
}
.pillar-toggles {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.pillar-toggle {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 9px 13px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 9px;
  cursor: pointer;
  transition: all 0.18s;
  min-width: 92px;
}
:root[data-theme="light"] .pillar-toggle {
  background: rgba(46,41,64,0.04);
}
.pillar-toggle:hover {
  border-color: rgba(125,211,174,0.4);
  background: rgba(125,211,174,0.06);
}
.pillar-toggle__name {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
}
.pillar-toggle__state {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--text-faint);
}
.pillar-toggle.is-active {
  border-color: rgba(125,211,174,0.35);
}
.pillar-toggle.is-active .pillar-toggle__state {
  color: var(--bull-c);
}
.pillar-toggle.is-hidden {
  opacity: 0.7;
  border-style: dashed;
}
.pillar-toggle.is-hidden .pillar-toggle__state {
  color: var(--warm-amber);
}
.pillar-toggle.is-disabled {
  opacity: 0.6;
  border-color: rgba(232,154,142,0.35);
}
.pillar-toggle.is-disabled .pillar-toggle__state {
  color: var(--bear-c);
}

/* ── Pillar popup ── */
.pillar-popup {
  max-width: 460px;
}
.pillar-popup__desc {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0 0 14px;
}
.pillar-popup__opt {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  width: 100%;
  text-align: left;
  padding: 12px 14px;
  margin-bottom: 9px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.18s;
}
:root[data-theme="light"] .pillar-popup__opt {
  background: rgba(46,41,64,0.04);
}
.pillar-popup__opt:hover {
  border-color: rgba(125,211,174,0.4);
  background: rgba(125,211,174,0.06);
}
.pillar-popup__opt--warn:hover {
  border-color: rgba(232,154,142,0.4);
  background: rgba(232,154,142,0.06);
}
.pillar-popup__opt-title {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--text);
}
.pillar-popup__opt-desc {
  font-size: 11.5px;
  color: var(--text-muted);
  line-height: 1.45;
}
.pillar-popup__preview {
  margin-top: 10px;
  padding: 10px;
  width: 100%;
  background: rgba(0,0,0,0.18);
  border-radius: 7px;
}
:root[data-theme="light"] .pillar-popup__preview {
  background: rgba(46,41,64,0.06);
}
.pillar-popup__preview-title {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-faint);
  margin-bottom: 6px;
}
.pillar-popup__wrow {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  padding: 2px 0;
  color: var(--text);
}
.pillar-popup__wrow.is-removed {
  opacity: 0.4;
  text-decoration: line-through;
}
.pillar-popup__wval {
  font-family: 'SF Mono', monospace;
  font-weight: 600;
  color: var(--bull-c);
}

/* ── Pillar off mark on bias card ── */
.pillar__off {
  color: var(--bear-c);
  font-size: 9px;
}

/* ── E8: Ring glow intensity modes ── */
/* Glow opacity driven by --glow-intensity custom property set per-card */
.bias-card.glow-off .bias-card__ring-glow {
  opacity: 0 !important;
}
.bias-card.glow-off .bias-card__ring-progress {
  filter: none !important;
}
.bias-card.glow-dyn .bias-card__ring-glow,
.bias-card.glow-fix .bias-card__ring-glow {
  opacity: calc(var(--glow-intensity, 0.8) * 0.9);
}
.bias-card.glow-dyn .bias-card__corner-glow,
.bias-card.glow-fix .bias-card__corner-glow {
  opacity: calc(var(--glow-intensity, 0.8) * 0.85);
}
.bias-card.glow-off .bias-card__corner-glow {
  opacity: 0 !important;
}

/* ── C5: High-impact weekly preview in Monday Brief ── */
.hi-preview__summary {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 10px;
}
.hi-preview__total {
  font-size: 13px;
  font-weight: 700;
  color: var(--bear-c);
}
.hi-preview__heavy {
  font-size: 12px;
  color: var(--text-muted);
}
.hi-preview__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}
.hi-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  background: rgba(232,154,142,0.08);
  border: 1px solid rgba(232,154,142,0.2);
  border-radius: 20px;
  font-size: 11px;
}
.hi-chip__ccy {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  color: var(--text);
}
.hi-chip__n {
  color: var(--bear-c);
  font-weight: 600;
}
.hi-preview__next-title {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-faint);
  margin-bottom: 6px;
}
.hi-next-row {
  display: grid;
  grid-template-columns: 90px 40px 1fr;
  gap: 8px;
  font-size: 12px;
  padding: 4px 0;
  border-bottom: 1px solid var(--border-faint, rgba(255,255,255,0.04));
}
.hi-next-day {
  font-family: 'SF Mono', monospace;
  color: var(--text-muted);
  font-size: 11px;
}
.hi-next-ccy {
  font-family: 'SF Mono', monospace;
  font-weight: 700;
  color: var(--bull-c);
}
.hi-next-name {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.hi-preview__empty, .hi-preview__none {
  font-size: 12px;
  color: var(--text-faint);
  font-style: italic;
}

/* ── Z1: Upcoming events peek + expand ── */
.upcoming__head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.upcoming__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 18px;
  padding: 0 6px;
  background: rgba(125,211,174,0.12);
  border-radius: 9px;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--bull-c);
}
.upcoming__expand {
  width: 100%;
  margin-top: 6px;
  padding: 7px;
  background: transparent;
  border: 1px dashed var(--border);
  border-radius: 8px;
  color: var(--text-muted);
  font-size: 11.5px;
  cursor: pointer;
  transition: all 0.18s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.upcoming__expand:hover {
  background: rgba(125,211,174,0.06);
  color: var(--bull-c);
  border-color: rgba(125,211,174,0.3);
}
.upcoming__chevron {
  font-size: 12px;
}
.upcoming__expand--collapse:hover {
  color: var(--text-muted);
  border-color: var(--border);
  background: rgba(255,255,255,0.03);
}

/* ════════════════════════════════════════════════════════════
   DEPLOY 11 — AI section toggles + usage breakdown
   ═══════════════════════════════════════════════════════════ */
.ai-usage-block__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.ai-usage-block__breakdown {
  margin-top: 8px;
  font-size: 11px;
  color: var(--text-faint);
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ai-usage-block__sep {
  opacity: 0.5;
}
.az-manual-off {
  padding: 9px 12px;
  margin-bottom: 12px;
  background: rgba(232,154,142,0.08);
  border: 1px solid rgba(232,154,142,0.25);
  border-radius: 8px;
  font-size: 12px;
  color: var(--bear-c);
}

/* ════════════════════════════════════════════════════════════
   DEPLOY 14 — Watchlist pin + sort modes
   ═══════════════════════════════════════════════════════════ */
.bias-card__pin {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 15px;
  color: var(--text-faint);
  padding: 0 2px;
  line-height: 1;
  transition: color 0.18s, transform 0.18s;
}
.bias-card__pin:hover {
  color: var(--warm-amber);
  transform: scale(1.2);
}
.bias-card__pin.is-active {
  color: var(--warm-amber);
}
.bias-card.is-pinned {
  border-color: rgba(212,160,80,0.35);
}
.bias-card.is-pinned .bias-card__corner-glow {
  /* subtle warm tint for pinned cards */
  filter: blur(32px) saturate(1.1);
}

/* ════════════════════════════════════════════════════════════
   DEPLOY 15 — AI Chart Analyzátor
   ═══════════════════════════════════════════════════════════ */
.az-chart {
  margin: 18px 0;
  padding: 16px;
  background: var(--card-bg, rgba(255,255,255,0.02));
  border: 1px solid var(--border);
  border-radius: 12px;
}
.az-chart__intro {
  font-size: 12px;
  color: var(--text-muted);
  margin: 4px 0 14px;
  line-height: 1.5;
}
.az-chart__drop {
  border: 2px dashed var(--border);
  border-radius: 12px;
  padding: 32px 20px;
  text-align: center;
  cursor: pointer;
  transition: all 0.18s;
}
.az-chart__drop:hover, .az-chart__drop.is-dragover {
  border-color: rgba(125,211,174,0.5);
  background: rgba(125,211,174,0.05);
}
.az-chart__drop-icon { font-size: 30px; margin-bottom: 8px; }
.az-chart__drop-label { font-size: 13px; color: var(--text); font-weight: 600; }
.az-chart__drop-sub { font-size: 11px; color: var(--text-faint); margin-top: 3px; }
.az-chart__preview { position: relative; margin-bottom: 12px; }
.az-chart__img {
  width: 100%;
  max-height: 320px;
  object-fit: contain;
  border-radius: 9px;
  border: 1px solid var(--border);
  background: #000;
}
.az-chart__remove {
  position: absolute;
  top: 8px; right: 8px;
  background: rgba(0,0,0,0.7);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 11px;
  cursor: pointer;
}
.az-chart__remove:hover { background: rgba(232,154,142,0.85); }
.az-chart__fields {
  display: flex;
  gap: 12px;
  margin-bottom: 10px;
}
.az-chart__field { flex: 1; }
.az-chart__field label {
  display: block;
  font-size: 11px;
  color: var(--text-faint);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.az-chart__error {
  margin-top: 12px;
  padding: 9px 12px;
  background: rgba(232,154,142,0.1);
  border: 1px solid rgba(232,154,142,0.3);
  border-radius: 8px;
  font-size: 12px;
  color: var(--bear-c);
}
.az-chart__result {
  margin-top: 14px;
  padding: 14px;
  background: rgba(125,211,174,0.04);
  border: 1px solid rgba(125,211,174,0.15);
  border-radius: 10px;
}
.az-chart__result-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.az-chart__cost { color: var(--text-faint); font-weight: 400; font-family: 'SF Mono', monospace; }
.az-chart__result-body {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
}
