/* ═══════════════════════════════════════════════════════
   TradeDesk — Light Theme Overrides
   Loaded LAST. All rules scoped under :root[data-theme="light"]
   for decorative gradients, hardcoded colors, and AI cards
   that can't be handled via token swaps alone.
   ═══════════════════════════════════════════════════════ */

/* Native form-control internals must render in the light color-scheme. Without
   this, on a dark-OS machine Chromium paints number-input values (e.g. Label Size)
   invisibly in the light theme even though `color` is set. */
:root[data-theme="light"] { color-scheme: light; }

/* ─── AI Analyst / Insight Card (purple gradient) ─────────
   Used by Statistics, Drawdown, Report, Cycles, Stats-Insights.
   Classes: stm-ai-*, rpt-ai-*, dd-ai-*.
   On light bg, the original rgba(88,28,135,.45)+violet gradient
   is too pale → darken it; the title (light-purple gradient text)
   becomes invisible → switch to deeper purple gradient.      */

:root[data-theme="light"] .stm-ai-header,
:root[data-theme="light"] .rpt-ai-header,
:root[data-theme="light"] .dd-ai-header {
  background:
    linear-gradient(135deg, rgba(109, 40, 217, .14) 0%, rgba(79, 70, 229, .10) 45%, rgba(37, 99, 235, .08) 100%),
    radial-gradient(120% 140% at 0% 0%, rgba(167, 139, 250, .12), transparent 60%);
  border-bottom-color: rgba(124, 58, 237, .22);
}
:root[data-theme="light"] .stm-ai-header::after,
:root[data-theme="light"] .rpt-ai-header::after,
:root[data-theme="light"] .dd-ai-header::after {
  background: linear-gradient(90deg, transparent, rgba(124, 58, 237, .5), transparent);
}

:root[data-theme="light"] .stm-ai-title,
:root[data-theme="light"] .rpt-ai-title,
:root[data-theme="light"] .dd-ai-title {
  background: linear-gradient(135deg, #6d28d9 0%, #4f46e5 45%, #2563eb 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

:root[data-theme="light"] .stm-ai-sub,
:root[data-theme="light"] .rpt-ai-sub,
:root[data-theme="light"] .dd-ai-sub {
  color: rgba(79, 70, 229, .82);
}

:root[data-theme="light"] .stm-ai-stars,
:root[data-theme="light"] .stm-ai-stars .stm-star-big,
:root[data-theme="light"] .stm-ai-stars .stm-star-small,
:root[data-theme="light"] .rpt-ai-stars,
:root[data-theme="light"] .rpt-ai-stars path,
:root[data-theme="light"] .dd-ai-stars,
:root[data-theme="light"] .dd-ai-stars path {
  fill: #6d28d9;
}
:root[data-theme="light"] .stm-ai-stars .stm-star-big,
:root[data-theme="light"] .stm-ai-stars .stm-star-small {
  filter: drop-shadow(0 0 3px rgba(109, 40, 217, .35));
}

/* AI loading / typing placeholder */
:root[data-theme="light"] .ai-typing-dot,
:root[data-theme="light"] .stm-ai-loading-dot { color: #6d28d9; }

/* AI Typing — animated stars "Generando insight…" (ai-typing.js)
   Default stars are fill:#f3e8ff (invisible on white). Switch to purple. */
:root[data-theme="light"] .aiTt-star {
  fill: #7c3aed;
  filter: drop-shadow(0 0 6px rgba(124, 58, 237, .35))
          drop-shadow(0 0 14px rgba(197, 165, 101, .25));
}
:root[data-theme="light"] .aiTt-label { color: var(--text-bright); }

/* ─── AI sidebar button (purple accent) ───────────────── */
:root[data-theme="light"] .rsb-icon-ai { color: #7c3aed; }
:root[data-theme="light"] .rsb-icon-ai:hover { color: #6d28d9; }
:root[data-theme="light"] .rsb-icon-ai.active {
  color: #5b21b6;
  background: rgba(124, 58, 237, .12);
}
:root[data-theme="light"] .rsb-icon-ai.active:hover {
  color: #6d28d9;
  background: var(--panel);
}

/* ─── Body background for light ───────────────────────── */
:root[data-theme="light"] body {
  color: var(--text);
}

/* Card elevation on light (subtle shadow for separation) */
:root[data-theme="light"] .rsb-panel.open,
:root[data-theme="light"] .cycles-panel,
:root[data-theme="light"] .seasonality-panel,
:root[data-theme="light"] .stats-panel {
  box-shadow: -2px 0 8px rgba(15, 23, 42, .06);
}

/* ─── Generic: #fff text buttons that must flip on light ── */
:root[data-theme="light"] .tb-group-panel .tb-btn:hover span {
  color: var(--text-bright);
}

/* ─── Chart logo / top-left brand — gold on light ───────
   Text uses gold accent; icon.svg is hardcoded white monochrome,
   so we use a filter chain to remap white → #C5A565 gold. */
:root[data-theme="light"] #chartLogo span {
  color: #C5A565;
}
:root[data-theme="light"] #chartLogo img {
  filter: brightness(0) saturate(100%)
          invert(69%) sepia(22%) saturate(716%)
          hue-rotate(358deg) brightness(93%) contrast(86%);
}

/* ─── Watchlist & list row borders (ensure separation) ── */
:root[data-theme="light"] .wl-item,
:root[data-theme="light"] .wl-screener-item {
  border-bottom-color: rgba(15, 23, 42, .06);
}

/* ─── Chart canvas wrap inside modals — white CARD on gray body ───
   Breadth light-theme pattern: body/panel = gray, cards = white.
   Cards explicitly use var(--card) so they stand out against the bg. */
:root[data-theme="light"] .stm-canvas-wrap,
:root[data-theme="light"] .stm-canvas-section .stm-canvas-wrap,
:root[data-theme="light"] .ddm-card,
:root[data-theme="light"] .cot-chart-area,
:root[data-theme="light"] .cot-chart-wrap {
  background: var(--card);
}
:root[data-theme="light"] .ddm-card {
  border-color: var(--border);
}

/* Modal body containers stay on the panel bg (gray) so inner cards pop. */
:root[data-theme="light"] .stm-modal-body,
:root[data-theme="light"] .sn-dash-body,
:root[data-theme="light"] .cy-dash-body,
:root[data-theme="light"] .stm-modal-content,
:root[data-theme="light"] .ddm-body,
:root[data-theme="light"] .stm-body {
  background: var(--panel);
}

/* ─── LWC watermark on light — the chart init bakes CA.watermark
       at creation time, so a stale instance shows white on white.
       This SVG text selector catches the LWC-rendered watermark. */
:root[data-theme="light"] .lwc-watermark text,
:root[data-theme="light"] g.tv-lightweight-charts text[fill^="rgba(255"] {
  fill: rgba(0, 0, 0, .045) !important;
}

/* ─── Card elevation — breadth light-theme style ─────────
   White cards on white/gray bg need a subtle drop shadow to be
   visually distinguishable. Matches breadth: two stacked shadows. */
:root[data-theme="light"] .inst-fund-card,
:root[data-theme="light"] .inst-stat-card,
:root[data-theme="light"] .stealth-hero-card,
:root[data-theme="light"] .stealth-detail-card,
:root[data-theme="light"] .sector-trend-card,
:root[data-theme="light"] .ov-card,
:root[data-theme="light"] .overview-card,
:root[data-theme="light"] .cp-card,
:root[data-theme="light"] .cot-chat-widget,
:root[data-theme="light"] .stm-canvas-wrap,
:root[data-theme="light"] .stm-action-box,
:root[data-theme="light"] .cy-card,
:root[data-theme="light"] .sn-card,
:root[data-theme="light"] .pc-card,
:root[data-theme="light"] .rpt-section,
:root[data-theme="light"] .stats-card,
:root[data-theme="light"] .breadth-insight-panel,
:root[data-theme="light"] .ai-chat-container {
  box-shadow: 0 1px 3px rgba(0, 0, 0, .08),
              0 1px 2px rgba(0, 0, 0, .04);
}

/* ─── Sidebar "glass" inner cards — breadth pattern ──────
   On dark theme these are subtle raised surfaces (white alpha on dark bg).
   On light theme the token (rgba(0,0,0,.x)) becomes a DARKER gray on light bg
   — the opposite of the breadth pattern where inner cards are WHITE on gray.
   Flip to --card (white) + subtle shadow so they read as "raised" cards. */
:root[data-theme="light"] .sn-glass,
:root[data-theme="light"] .cy-glass,
:root[data-theme="light"] .st-glass {
  background: var(--card);
  border-color: var(--border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, .06),
              0 1px 2px rgba(0, 0, 0, .03);
}

/* ─── Range slider thumbs (cycles smooth, etc.) ─────────
   Dark theme uses rgba(255,255,255,.6) — invisible on white cards. */
:root[data-theme="light"] .cy-range {
  background: #e5e7eb;
}
:root[data-theme="light"] .cy-range::-webkit-slider-thumb {
  background: #C5A565;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .2);
}
:root[data-theme="light"] .cy-range::-moz-range-thumb {
  background: #C5A565;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .2);
}

/* ─── Seasonality dual-range slider handle — stronger shadow on light ─── */
:root[data-theme="light"] .sn-slider-handle {
  background: #ffffff;
  border: 2px solid #C5A565;
  box-shadow: 0 2px 6px rgba(15, 23, 42, .18);
}

/* ─── Seasonality chip ALL/active — match breadth gold pill style ───
   Default active uses blue-strong→purple-dim gradient which on light
   renders as a muddy gold/purple mix — inconsistent with the gold theme. */
:root[data-theme="light"] .sn-v-chip.active {
  background: #C5A565;
  border-color: #C5A565;
  color: #ffffff;
}
:root[data-theme="light"] .sn-v-chip:hover {
  background: rgba(197, 165, 101, .12);
  border-color: rgba(197, 165, 101, .4);
}

/* ─── Chart container backgrounds — WHITE on light theme ─────
   Breadth pattern: charts sit in white cards on gray body bg.
   Covers seasonality/cycles/cot/options dashboard chart areas. */
:root[data-theme="light"] .sn-dash-chart-top,
:root[data-theme="light"] .sn-dash-chart,
:root[data-theme="light"] .sn-dash-bt-area,
:root[data-theme="light"] .sn-dash-bt-body,
:root[data-theme="light"] .sn-dash-bt-chart,
:root[data-theme="light"] .sn-bt-chart-wrap,
:root[data-theme="light"] .sn-bt-chart,
:root[data-theme="light"] .cy-dash-chart-top,
:root[data-theme="light"] .cy-dash-chart,
:root[data-theme="light"] .cy-dash-bt-area,
:root[data-theme="light"] .cy-dash-bt-body,
:root[data-theme="light"] .cy-dash-bt-chart,
:root[data-theme="light"] .cy-bt-chart-wrap,
:root[data-theme="light"] .cy-bt-chart,
:root[data-theme="light"] .cot-chart-area,
:root[data-theme="light"] .cot-chart-wrap,
:root[data-theme="light"] .opt-chart-wrap,
:root[data-theme="light"] .pc-chart-wrap,
:root[data-theme="light"] .sp-chart-wrap,
:root[data-theme="light"] .dd-chart-wrap,
:root[data-theme="light"] .stm-chart-wrap {
  background: #ffffff;
}

/* Chart header/toolbar strips above charts — also white so the
   header and chart read as a single white card. */
:root[data-theme="light"] .sn-dash-chart-header,
:root[data-theme="light"] .sn-dash-bt-header,
:root[data-theme="light"] .cy-dash-chart-header,
:root[data-theme="light"] .cy-dash-bt-header {
  background: #ffffff;
}

/* ─── Chart tooltips — light variant ───
   Dark bg (rgba(16,18,25,.92)) is unreadable in light mode. Flip to
   white with dark text and subtle shadow for clean light-theme look. */
:root[data-theme="light"] .sn-dash-bt-tooltip,
:root[data-theme="light"] .cy-dash-bt-tooltip {
  background: rgba(255, 255, 255, .98);
  border-color: rgba(15, 23, 42, .12);
  color: var(--text-bright);
  box-shadow: 0 4px 14px rgba(15, 23, 42, .12);
}

/* ─── Detrend/Depricing settings popover — light fix ───
   Backdrop-filter blur + dark inset highlight carry over the dark
   styling. Force solid white with light shadow. !important used because
   the original rule bakes blur/shadow inline-priority. */
:root[data-theme="light"] .sn-settings-pop {
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, .14),
              0 2px 6px rgba(15, 23, 42, .08) !important;
}
:root[data-theme="light"] .sn-pop-row {
  border-bottom-color: #e5e7eb !important;
}
:root[data-theme="light"] .sn-pop-row span {
  color: #111827 !important;
  font-weight: 600;
}
/* iOS toggle off-state — visible muted gray on white bg */
:root[data-theme="light"] .sn-ios-toggle {
  background: #cbd5e1 !important;
}
:root[data-theme="light"] .sn-ios-toggle.on {
  background: #16a34a !important;
}
:root[data-theme="light"] .sn-ios-toggle::after {
  box-shadow: 0 1px 3px rgba(15, 23, 42, .25) !important;
}

/* ─── Seasonality DASHBOARD gear popup (separate from sidebar popover) ───
   `.sn-dash-gear-popup` uses `var(--overlay-bg)` which on light is
   `rgba(15,23,42,.35)` → renders as a dark transparent overlay on white.
   Force solid white with light shadow, same look as the sidebar popover. */
:root[data-theme="light"] .sn-dash-gear-popup {
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, .14),
              0 2px 6px rgba(15, 23, 42, .08) !important;
}
:root[data-theme="light"] .sn-dash-gear-row {
  color: #111827 !important;
  font-weight: 600;
}
:root[data-theme="light"] .sn-dash-gear-row + .sn-dash-gear-row {
  border-top-color: #e5e7eb !important;
}

/* ─── iOS toggle knob — always WHITE regardless of theme ───
   `.cy-ios-toggle::after` uses `var(--text-bright)` which on light
   is `#111827` (dark) → knob is invisible/black. Force pure white. */
:root[data-theme="light"] .cy-ios-toggle {
  background: #cbd5e1 !important;
}
:root[data-theme="light"] .cy-ios-toggle.on {
  background: #16a34a !important;
}
:root[data-theme="light"] .cy-ios-toggle::after {
  background: #ffffff !important;
  box-shadow: 0 1px 3px rgba(15, 23, 42, .25) !important;
}

/* Hover lift for interactive cards */
:root[data-theme="light"] .inst-fund-card:hover {
  background: #ffffff;
  border-color: var(--border-hi);
  box-shadow: 0 4px 12px rgba(0, 0, 0, .10),
              0 2px 4px rgba(0, 0, 0, .06);
  transform: translateY(-1px);
  transition: box-shadow var(--ease), transform var(--ease), border-color var(--ease);
}

/* ─── Seasonality year list — bar track needs more contrast on white ─ */
:root[data-theme="light"] .sn-yl-bar-track {
  background: #e5e7eb;
}
:root[data-theme="light"] .sn-yl-row:hover {
  background: #f3f4f6;
}
:root[data-theme="light"] .sn-yl-row.pinned {
  background: rgba(197, 165, 101, .14);
}

/* Year-list custom checkbox — dark theme draws border + checkmark in
   rgba(255,255,255,.9) which disappears on a white light-theme panel.
   Flip both to the light-theme text color for contrast. */
:root[data-theme="light"] .sn-yl-cb {
  border-color: var(--border-hi);
}
:root[data-theme="light"] .sn-yl-cb.on {
  border-color: var(--text-bright);
}
:root[data-theme="light"] .sn-yl-cb.on::after {
  border-color: var(--text-bright);
}
/* Native checkbox (year-picker) — accent must also be visible on white */
:root[data-theme="light"] .sn-yp-cb {
  accent-color: var(--text-bright);
}

/* Any other rail/progress track patterns that use hover-subtle on light bg */
:root[data-theme="light"] .stealth-bar-track,
:root[data-theme="light"] .st-bar-track,
:root[data-theme="light"] .cp-analyst-bar-track,
:root[data-theme="light"] .dd-bar-track {
  background: #e5e7eb;
}

/* ─── Segmented Pill Controls — light theme fix ─────────
   Many pill/tab groups use rgba(0,0,0,.25-.35) as their container bg
   which on light theme renders as an ugly mid-gray box. We override
   the containers with a subtle light-gray, active pill = white with
   shadow (breadth style), inactive pills = muted dark text. */

/* Container backgrounds */
:root[data-theme="light"] .cy-dash-sb-tabs,
:root[data-theme="light"] .sn-dash-sb-tabs,
:root[data-theme="light"] .sn-bp-mode-wrap,
:root[data-theme="light"] .sn-bp-toggle-wrap {
  background: #e5e7eb;
  border-color: #d1d5db;
}

/* Sliding indicator (cycles + seasonality tabs) → white pill w/ subtle shadow */
:root[data-theme="light"] .cy-dash-sb-pill,
:root[data-theme="light"] .sn-dash-sb-pill {
  background: #ffffff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .1),
              0 1px 3px rgba(0, 0, 0, .06);
}

/* Active tab text — dark on white pill */
:root[data-theme="light"] .cy-dash-sb-tab.active,
:root[data-theme="light"] .sn-dash-sb-tab.active,
:root[data-theme="light"] .sn-bp-toggle.active {
  color: var(--text-bright);
}
:root[data-theme="light"] .sn-bp-toggle.active {
  background: #ffffff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .08),
              0 1px 3px rgba(0, 0, 0, .05);
}

/* Bull/Bear active — punchier tints on white */
:root[data-theme="light"] .sn-bp-toggle.sn-bp-toggle-bull.active {
  background: rgba(22, 163, 74, .16);
  color: #15803d;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .06);
}
:root[data-theme="light"] .sn-bp-toggle.sn-bp-toggle-bear.active {
  background: rgba(220, 38, 38, .14);
  color: #b91c1c;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .06);
}

/* sn-bp-mode.active already uses --pill-active-bg (gold) — just soften shadow */
:root[data-theme="light"] .sn-bp-mode.active {
  box-shadow: 0 1px 3px rgba(0, 0, 0, .12),
              0 1px 2px rgba(0, 0, 0, .06);
}

/* Any similar segmented button group — generic hover */
:root[data-theme="light"] .cy-dash-sb-tab:hover,
:root[data-theme="light"] .sn-dash-sb-tab:hover,
:root[data-theme="light"] .sn-bp-mode:hover,
:root[data-theme="light"] .sn-bp-toggle:hover {
  color: var(--text-bright);
}

/* ─── Best Periods: invert bg/card pattern (breadth style) ───
   Dark: container = raised surface (slightly lighter), card = faint overlay.
   Light: container should be GRAY, cards should be WHITE with shadow. */
:root[data-theme="light"] .sn-bp-container {
  background: #f3f4f6;
  border-color: #e5e7eb;
}
:root[data-theme="light"] .sn-bp-settings-card {
  background: #ffffff;
  border-color: var(--border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, .06),
              0 1px 2px rgba(0, 0, 0, .03);
}
:root[data-theme="light"] .sn-bp-card {
  background: #ffffff;
  border-color: var(--border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, .06),
              0 1px 2px rgba(0, 0, 0, .03);
}
:root[data-theme="light"] .sn-bp-card:hover {
  background: #ffffff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, .08),
              0 1px 3px rgba(0, 0, 0, .04);
}
:root[data-theme="light"] .sn-bp-card.sn-bp-active {
  background: rgba(197, 165, 101, .08);
  border-color: rgba(197, 165, 101, .5);
}

/* ─── Status/COT/Seasonality tab bars — also use dark bg containers ─ */
:root[data-theme="light"] .cot-dropdown-btn,
:root[data-theme="light"] .cot-report-select,
:root[data-theme="light"] .cot-source-tabs {
  background: #f3f4f6;
  border-color: #e5e7eb;
}

/* ─── Button drop-shadow normalization on light ─────────
   Any button with box-shadow using rgba(0,0,0,>=.2) is too dark on light.
   Use --shadow-soft/strong which are theme-aware. */
:root[data-theme="light"] .sn-bp-mode-wrap,
:root[data-theme="light"] .sn-bp-toggle-wrap,
:root[data-theme="light"] .cy-dash-sb-tabs {
  box-shadow: inset 0 0 0 1px #e5e7eb;
}

/* ─── Seasonality Scanner AI card — softer purple on light ───
   Original gradient (#3b0764 → #a855f7) is too dark/heavy on white bg.
   Lighter gradient keeps the AI identity but feels airy. */
:root[data-theme="light"] .scr-land-card-ai {
  background: linear-gradient(135deg, #a78bfa, #8b5cf6, #c084fc, #a855f7, #a78bfa) !important;
  background-size: 300% 300% !important;
  border-color: rgba(139, 92, 246, .35) !important;
}
:root[data-theme="light"] .scr-land-card-ai:hover {
  border-color: rgba(124, 58, 237, .55) !important;
}
:root[data-theme="light"] .scr-land-card-ai .scr-land-card-title,
:root[data-theme="light"] .scr-land-card-ai .scr-land-card-desc {
  color: #ffffff;
}
:root[data-theme="light"] .scr-land-card-ai .scr-land-card-desc {
  color: rgba(255, 255, 255, .85);
}
:root[data-theme="light"] .scr-land-icon-ai {
  background: rgba(255, 255, 255, .22) !important;
  border-color: rgba(255, 255, 255, .35) !important;
}
/* Glow animation softer on light */
@keyframes scr-ai-glow-light {
  0%, 100% { box-shadow: 0 4px 14px rgba(139, 92, 246, .22), 0 2px 6px rgba(109, 40, 217, .1); }
  50%      { box-shadow: 0 6px 20px rgba(168, 85, 247, .32), 0 3px 10px rgba(139, 92, 246, .14); }
}
:root[data-theme="light"] .scr-land-card-ai {
  animation: scr-ai-gradient 5s ease infinite, scr-ai-glow-light 3s ease-in-out infinite;
}

/* ─── Seasonality dashboard Filters dropdown — hardcoded dark bg ───
   .sn-dash-filter-menu uses background:#1c1c20 (hardcoded), so on light
   theme its dark bg sits under dark token text → unreadable. Flip to a
   white card like the other light-theme popovers. */
:root[data-theme="light"] .sn-dash-filter-menu {
  background: #ffffff;
  border-color: #e5e7eb;
  box-shadow: 0 10px 30px rgba(15, 23, 42, .14),
              0 2px 6px rgba(15, 23, 42, .08);
}
:root[data-theme="light"] .sn-dash-fm-item:hover {
  background: #f3f4f6;
  color: var(--text-bright);
}
:root[data-theme="light"] .sn-dash-fm-group + .sn-dash-fm-group {
  border-top-color: #e5e7eb;
}

/* ─── Backtest IN SAMPLE / OOS zone labels — white on white ───
   .sn-bt-oos-zone-label is rgba(255,255,255,.3) → invisible on the white
   light-theme chart. Dark slate for "IN SAMPLE"; keep OOS amber but darker
   so it reads on white. (OOS rule is later → wins for the .--oos element.) */
:root[data-theme="light"] .sn-bt-oos-zone-label {
  color: rgba(15, 23, 42, .42);
}
:root[data-theme="light"] .sn-bt-oos-zone-label-oos {
  color: rgba(180, 83, 9, .9);
}
/* OOS boundary dashed line — bright amber .6 is faint on white; deepen it. */
:root[data-theme="light"] .sn-bt-oos-line {
  border-left-color: rgba(217, 119, 6, .7);
}
