/* Ativa shared tokens, base animations, and layout rules that are 100%
   identical between live.html and historico.html. File-specific rules
   (live-pill, health-bar, shopping-row, custom-dates, pagination,
   dismiss-btn, toast, action form, kpi-strip grid, etc.) stay inline
   per file. */

:root {
  --bg: #121518; --card: #1a1d23; --card-hover: #22262d; --border: #2e3339;
  --text: #e8ebf0; --muted: #8a919c;
  --red: #e8605a; --red-bg: rgba(232,96,90,0.12);
  --orange: #dc8c42; --orange-bg: rgba(220,140,66,0.12);
  --yellow: #d4a84a; --yellow-bg: rgba(212,168,74,0.10);
  --green: #4db87a; --green-bg: rgba(77,184,122,0.10);
  --accent: #00bcd4; --accent-light: #00d4ef; --accent-dark: #00838f;
  --gray: #718096; --gray-bg: rgba(113,128,150,0.15);
  --purple: #a78bfa; --purple-bg: rgba(167,139,250,0.14);
  --shadow: 0 1px 3px rgba(0,0,0,0.3), 0 1px 2px rgba(0,0,0,0.2);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.4), 0 2px 4px rgba(0,0,0,0.25);
  --surface-tint: rgba(255,255,255,0.02);
  --surface-tint-strong: rgba(255,255,255,0.04);
  --overlay-bg: rgba(0,0,0,0.7);
  --sans: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mono-display: 'Space Grotesk', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --fs-2xs: 7px;
  --fs-xs: 10px;
  --fs-sm: 11px;
  --fs-base: 12px;
  --fs-md: 13px;
  --fs-lg: 14px;
  --fs-xl: 15px;
  --fs-2xl: 18px;
  --fs-3xl: 22px;
  --lh-tight: 1.2;
  --lh-body: 1.5;
  --lh-heading: 1.3;
  --card-pad-y: 14px;
  --card-pad-x: 16px;
}

html[data-theme="light"] {
  --bg: #e2e8f0; --card: #ffffff; --card-hover: #f8fafc; --border: #cbd5e1;
  --text: #0f172a; --muted: #475569;
  --red: #c43d37; --red-bg: rgba(196,61,55,0.10);
  --orange: #d97706; --orange-bg: rgba(217,119,6,0.12);
  --yellow: #ca8a04; --yellow-bg: rgba(202,138,4,0.12);
  --green: #1f9154; --green-bg: rgba(31,145,84,0.10);
  --accent: #00838f; --accent-light: #00a7bd; --accent-dark: #006976; --accent-strong: #00bcd4;
  --gray: #334155; --gray-bg: rgba(51,65,85,0.10);
  --purple: #7c5cd6; --purple-bg: rgba(124,92,214,0.10);
  --shadow: 0 1px 3px rgba(15,23,42,0.06), 0 1px 2px rgba(15,23,42,0.04);
  --shadow-md: 0 6px 18px rgba(15,23,42,0.08), 0 2px 6px rgba(15,23,42,0.04);
  --surface-tint: rgba(15,23,42,0.02);
  --surface-tint-strong: rgba(15,23,42,0.04);
  --overlay-bg: rgba(15,23,42,0.45);
  color-scheme: light;
}

/* Reset + base */
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family: var(--sans); background: var(--bg); color: var(--text); min-height:100vh; -webkit-font-smoothing: antialiased; }
.container { max-width: 920px; margin: 0 auto; padding: 8px 20px 40px; }

/* Top row shared structure */
.top-row { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; font-size: var(--fs-base); color: var(--muted); margin-bottom: 28px; gap: 12px; }
.top-row .logo { height: 41px; width: auto; display: block; justify-self: start; }
.top-row .nav-tabs { justify-self: center; }
#clock { font-variant-numeric: tabular-nums; }

/* Nav tabs */
.nav-tabs { display: flex; gap: 4px; padding: 3px; background: var(--card); border-radius: 20px; }
.nav-tab { padding: 5px 12px; font-size: var(--fs-base); font-weight: 600; letter-spacing: 0.02em; color: var(--muted); text-decoration: none; border-radius: 16px; transition: all 0.15s; }
.nav-tab:hover:not(.active) { color: var(--text); background: var(--surface-tint-strong); }
.nav-tab.active { background: var(--accent); color: #fff; box-shadow: 0 2px 8px rgba(0,188,212,0.25); }
.nav-tab.active:hover { background: var(--accent-light); }

/* Theme toggle shared bits. File-specific positioning stays inline because
   live puts it in .utility-stack-row and historico anchors it absolutely. */
.theme-toggle { background: transparent; border: 1px solid var(--border); color: var(--muted); border-radius: 999px; width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: transform 0.15s ease, background 0.15s, border-color 0.15s, color 0.15s; padding: 0; }
.theme-stack:hover .theme-toggle { color: var(--accent-light); border-color: var(--accent); background: rgba(0,188,212,0.08); transform: scale(1.08); }
.theme-toggle svg { width: 10px; height: 10px; }
.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: block; }
html[data-theme="light"] .theme-toggle .icon-sun { display: block; }
html[data-theme="light"] .theme-toggle .icon-moon { display: none; }
.theme-label { font-size: var(--fs-2xs); color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; transition: color 0.15s; white-space: nowrap; text-align: center; }
.theme-stack:hover .theme-label { color: var(--text); }
@media (max-width: 520px) { .theme-label { display: none; } .theme-stack { min-width: auto; } }

/* Header typography */
.headline { font-family: var(--mono-display); font-size: var(--fs-2xl); font-weight: 700; margin: 4px 0 6px; letter-spacing: -0.02em; line-height: 1.3; }
.subtitle { font-size: var(--fs-md); color: var(--muted); letter-spacing: 0.01em; line-height: var(--lh-body); }
.status-bar { display: flex; gap: 14px; font-size: var(--fs-sm); color: var(--muted); margin-top: 10px; flex-wrap: wrap; line-height: var(--lh-body); }

/* Degraded / info banner */
.degraded-banner { background: var(--orange-bg); border: 1px solid var(--orange); color: var(--orange); padding: 10px 14px; border-radius: 10px; margin-bottom: 16px; font-size: var(--fs-md); display: none; }
.degraded-banner.show { display: block; }
.degraded-banner.info { background: rgba(113,128,150,0.10); border-color: var(--border); color: var(--muted); }
.degraded-banner.info strong { color: var(--text); }

/* KPI card base (the grid, .kpi-strip, stays inline per file) */
.kpi-card { background: var(--card); border-radius: 12px; padding: var(--card-pad-y) var(--card-pad-x); position: relative; overflow: hidden; box-shadow: var(--shadow); }
.kpi-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; border-radius: 10px 10px 0 0; background: var(--accent); }
.kpi-card.red::before { background: var(--red); }
.kpi-card.orange::before { background: var(--orange); }
.kpi-card.green::before { background: var(--green); }
.kpi-card.accent::before { background: var(--accent); }
.kpi-label { font-size: var(--fs-xs); color: var(--muted); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; margin-bottom: 6px; }
.kpi-value { font-family: var(--mono-display); font-size: var(--fs-3xl); font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: -0.03em; line-height: 1.1; }
.kpi-sub { font-size: var(--fs-sm); color: var(--muted); margin-top: 5px; font-weight: 500; }

/* Filter pills */
.filters-wrap { margin-bottom: 16px; }
.filter-row { display: flex; gap: 4px; flex-wrap: wrap; }
.pill { background: var(--card); border: 1px solid var(--border); color: var(--muted); padding: 3px 10px; border-radius: 16px; font-size: var(--fs-sm); font-weight: 500; cursor: pointer; transition: all 0.15s; letter-spacing: 0.02em; box-shadow: var(--shadow); user-select: none; }
.pill:hover { color: var(--text); border-color: var(--accent); }
.pill.active { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; box-shadow: 0 2px 12px rgba(0,188,212,0.35); }
.pill.critico.active { background: var(--red); box-shadow: 0 2px 12px rgba(232,96,90,0.35); }
.pill.atencao.active { background: var(--orange); box-shadow: 0 2px 12px rgba(220,140,66,0.35); }
.pill.oportunidade.active { background: var(--yellow); color: #121518; box-shadow: 0 2px 12px rgba(212,168,74,0.35); }
.pill.dim { opacity: 0.5; }
.pill.dim:hover { opacity: 0.85; }
html[data-theme="light"] .pill:not(.active) { background: rgba(0,188,212,0.10); border-color: rgba(0,188,212,0.22); color: var(--accent-dark); }
html[data-theme="light"] .pill:not(.active):hover { background: rgba(0,188,212,0.20); border-color: var(--accent); color: var(--accent-dark); }
html[data-theme="light"] .pill.active:not(.critico):not(.atencao):not(.oportunidade) { background: var(--accent-strong); border-color: var(--accent-strong); color: #fff; box-shadow: 0 2px 12px rgba(0,188,212,0.35); }
html[data-theme="light"] .nav-tab.active { background: var(--accent-strong); color: #fff; box-shadow: 0 2px 8px rgba(0,188,212,0.30); }
html[data-theme="light"] .nav-tab.active:hover { background: var(--accent-strong); filter: brightness(0.96); }

/* Alert cards */
.alert-list { display: flex; flex-direction: column; gap: 8px; }
.alert-card { background: var(--card); border-radius: 12px; padding: var(--card-pad-y) var(--card-pad-x); cursor: pointer; transition: all 0.2s ease, transform 0.25s ease, opacity 0.25s ease; box-shadow: var(--shadow); border-left: 3px solid var(--gray); position: relative; }
.alert-card:hover { background: var(--card-hover); box-shadow: var(--shadow-md); }
.alert-card.critico { border-left-color: var(--red); }
.alert-card.atencao { border-left-color: var(--orange); }
.alert-card.oportunidade { border-left-color: var(--yellow); }
.alert-row1 { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.alert-store { font-size: var(--fs-lg); font-weight: 600; letter-spacing: 0.01em; }
.alert-loss { font-family: var(--mono-display); font-weight: 700; font-variant-numeric: tabular-nums; font-size: var(--fs-xl); }
.alert-loss.critico { color: var(--red); }
.alert-loss.atencao { color: var(--orange); }
.alert-loss.oportunidade { color: var(--yellow); }
.alert-row2 { display: flex; justify-content: space-between; align-items: center; margin-top: 6px; font-size: var(--fs-base); color: var(--muted); gap: 10px; flex-wrap: wrap; }
.alert-state-chip { font-size: var(--fs-sm); font-weight: 600; letter-spacing: 0.01em; padding: 2px 8px; border-radius: 8px; display: inline-block; }
.alert-state-chip.externo { background: var(--red-bg); color: var(--red); }
.alert-state-chip.interno { background: var(--orange-bg); color: var(--orange); }
.alert-state-chip.duplo { background: var(--red-bg); color: var(--red); }
.alert-state-chip.oportunidade { background: var(--yellow-bg); color: var(--yellow); }
.alert-meta { font-variant-numeric: tabular-nums; }
.alert-brand { font-weight: 500; }

.empty { padding: 30px 10px; text-align: center; color: var(--muted); background: var(--card); border-radius: 12px; }

.footnote { margin-top: 24px; padding: 14px 16px; background: var(--card); border-radius: 10px; font-size: var(--fs-base); color: var(--muted); line-height: 1.5; border-left: 3px solid var(--accent); }
.footnote strong { color: var(--text); }

/* Detail overlay */
.overlay { position: fixed; inset: 0; background: var(--overlay-bg); backdrop-filter: blur(4px); display: none; align-items: flex-start; justify-content: center; z-index: 100; overflow-y: auto; padding: 40px 16px; }
.overlay.open { display: flex; }
.detail { background: var(--bg); border: 1px solid var(--border); border-radius: 16px; max-width: 640px; width: 100%; padding: 24px; box-shadow: var(--shadow-md); }
.detail-hdr { display: flex; justify-content: space-between; align-items: baseline; gap: 14px; margin-bottom: 14px; }
.detail-store { font-size: var(--fs-2xl); font-weight: 700; }
.close-btn { background: transparent; border: 1px solid var(--border); color: var(--muted); padding: 5px 12px; border-radius: 20px; font-size: var(--fs-base); cursor: pointer; }
.close-btn:hover { color: var(--text); border-color: var(--accent); }
.detail-section { margin-top: 16px; }
.detail-label { font-size: var(--fs-xs); color: var(--muted); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; margin-bottom: 4px; }
.detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.detail-cell { background: var(--card); border-radius: 10px; padding: 10px 12px; }
.detail-val { font-family: var(--mono-display); font-size: var(--fs-2xl); font-weight: 700; font-variant-numeric: tabular-nums; }
.detail-sub { font-size: var(--fs-sm); color: var(--muted); margin-top: 2px; }

.enrichment-list { list-style: none; padding: 0; margin: 0; }
.enrichment-list li { padding: 8px 0; font-size: var(--fs-md); border-bottom: 1px solid var(--border); display: flex; gap: 10px; align-items: baseline; flex-wrap: wrap; }
.enrichment-list li:last-child { border-bottom: none; }
.enrichment-source { font-weight: 600; color: var(--text); min-width: 64px; font-size: var(--fs-base); }
.enrichment-summary { flex: 1 1 220px; color: var(--muted); }
.enrichment-signal { font-size: var(--fs-xs); letter-spacing: 1px; text-transform: uppercase; font-weight: 700; padding: 2px 7px; border-radius: 3px; white-space: nowrap; }
.enrichment-signal.signal-forte { color: var(--red); background: var(--red-bg); }
.enrichment-signal.signal-medio { color: var(--accent); background: rgba(0,188,212,0.12); }
.enrichment-signal.signal-fraco { color: var(--muted); background: rgba(138,145,156,0.12); }

.peer-sub { font-size: var(--fs-sm); color: var(--muted); margin: 4px 0 10px; letter-spacing: 0.01em; }
.peer-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.peer-row { display: grid; grid-template-columns: minmax(110px, 1fr) minmax(0, 1.4fr) auto; gap: 10px; align-items: baseline; padding: 8px 10px; background: var(--surface-tint); border: 1px solid var(--border); border-radius: 8px; font-size: var(--fs-md); }
.peer-metric { color: var(--text); font-weight: 500; }
.peer-values { font-variant-numeric: tabular-nums; font-family: var(--mono-display); color: var(--muted); font-size: var(--fs-base); }
.peer-store-val { font-weight: 700; color: var(--text); margin-right: 6px; font-size: var(--fs-md); }
.peer-chip { font-size: var(--fs-xs); letter-spacing: 0.8px; text-transform: uppercase; font-weight: 700; padding: 3px 8px; border-radius: 4px; white-space: nowrap; }
.peer-chip.v-muito-abaixo { color: var(--red); background: var(--red-bg); }
.peer-chip.v-abaixo { color: var(--orange); background: var(--orange-bg); }
.peer-chip.v-na-média { color: var(--muted); background: rgba(138,145,156,0.12); }
.peer-chip.v-acima { color: var(--green); background: var(--green-bg); }
.peer-chip.v-muito-acima { color: var(--green); background: var(--green-bg); border: 1px solid rgba(77,184,122,0.5); }

.action-recorded { background: var(--card); border-left: 3px solid var(--green); border-radius: 10px; padding: 12px 14px; font-size: var(--fs-md); }
.action-recorded .action-recorded-type { font-weight: 600; color: var(--text); margin-bottom: 4px; }
.action-recorded .action-recorded-meta { font-size: var(--fs-sm); color: var(--muted); margin-top: 6px; font-variant-numeric: tabular-nums; }
.action-recorded .action-recorded-notes { font-size: var(--fs-base); color: var(--muted); margin-top: 6px; font-style: italic; }
.action-outcome { margin-top: 10px; padding: 8px 10px; border-radius: 8px; font-size: var(--fs-base); background: var(--surface-tint); border: 1px solid var(--border); }
.action-outcome-label { font-size: var(--fs-xs); color: var(--muted); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.action-outcome-verdict { font-weight: 600; color: var(--text); margin-top: 3px; }
.action-outcome-detail { font-size: var(--fs-sm); color: var(--muted); margin-top: 3px; font-variant-numeric: tabular-nums; }
.action-outcome.outcome-efetiva { background: rgba(34,197,94,0.10); border-color: rgba(34,197,94,0.35); }
.action-outcome.outcome-efetiva .action-outcome-verdict { color: var(--green); }
.action-outcome.outcome-parcial { background: rgba(234,179,8,0.10); border-color: rgba(234,179,8,0.35); }
.action-outcome.outcome-parcial .action-outcome-verdict { color: #facc15; }
.action-outcome.outcome-inefetiva { background: rgba(239,68,68,0.10); border-color: rgba(239,68,68,0.35); }
.action-outcome.outcome-inefetiva .action-outcome-verdict { color: var(--red); }
.action-outcome.outcome-inconclusiva, .action-outcome.outcome-pendente { background: rgba(148,163,184,0.08); border-color: rgba(148,163,184,0.25); }

.breakdown-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 760px) { .breakdown-grid { grid-template-columns: 1fr 1fr; } }
.breakdown-table { width: 100%; border-collapse: collapse; font-size: var(--fs-md); }
.breakdown-table th, .breakdown-table td { text-align: left; padding: 7px 6px; border-bottom: 1px solid var(--border); }
.breakdown-table th { font-size: var(--fs-xs); color: var(--muted); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.breakdown-table td.num { text-align: right; font-variant-numeric: tabular-nums; font-family: var(--mono-display); font-weight: 600; }
.breakdown-table td.brand { color: var(--muted); font-size: var(--fs-base); }

/* Skeleton + motion */
.skeleton { position: relative; background: var(--border); border-radius: 4px; overflow: hidden; display: block; }
.skeleton::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0%, var(--surface-tint-strong) 50%, transparent 100%); animation: skel-shimmer 1.4s ease-in-out infinite; }
@keyframes skel-shimmer { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }
.skel-line { height: 10px; margin: 6px 0; }
.skel-line-xs { width: 30%; height: 8px; }
.skel-line-sm { width: 45%; }
.skel-line-md { width: 60%; }
.skel-line-lg { width: 80%; height: 22px; margin: 8px 0; }
.skel-kpi { padding: var(--card-pad-y) var(--card-pad-x); }
.skel-alert { padding: var(--card-pad-y) var(--card-pad-x); display: flex; flex-direction: column; }

.alert-new { animation: alert-entrance 220ms ease-out, alert-pulse 1.8s ease-out 220ms; }
@keyframes alert-entrance {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes alert-pulse {
  0% { box-shadow: var(--shadow), -4px 0 14px var(--accent-strong, var(--accent)); }
  100% { box-shadow: var(--shadow); }
}