

/* ── 1. TOKENS · LIGHT (default) ─────────────────────────── */
:root {
  --bg:          #f3f5f9;
  --bg2:         #fafbfd;
  --bg3:         #e8edf5;
  --card:        #ffffff;
  --border:      #dde4ee;
  --border2:     #b9c6d8;
  --accent:      #3b6ef6;
  --accent-2:    #6d8efb;
  --accent-dim:  rgba(59,110,246,0.10);
  --accent-glow: rgba(59,110,246,0.25);
  --text:        #16243a;
  --text2:       #51637d;
  --text3:       #7d8da3;
  --green:       #18935f;
  --green-dim:   rgba(24,147,95,0.11);
  --red:         #d3496a;
  --red-dim:     rgba(211,73,106,0.11);
  --yellow:      #c08a2d;

  /* novos tokens v2 (usáveis nas fases seguintes) */
  --radius:      14px;
  --radius-sm:   9px;
  --shadow-1:    0 1px 2px rgba(22,36,58,0.05), 0 1px 1px rgba(22,36,58,0.03);
  --shadow-2:    0 4px 14px rgba(22,36,58,0.08), 0 1px 3px rgba(22,36,58,0.05);
  --shadow-3:    0 12px 32px rgba(22,36,58,0.13);
  --ease:        cubic-bezier(.22,.8,.36,1);
}

/* ── 2. TOKENS · DARK ─────────────────────────────────────── */
[data-theme="dark"] {
  --bg:          #0e1320;
  --bg2:         #131a2b;
  --bg3:         #1a2336;
  --card:        #161e30;
  --border:      #232f47;
  --border2:     #34425f;
  --accent:      #5b86ff;
  --accent-2:    #7fa1ff;
  --accent-dim:  rgba(91,134,255,0.14);
  --accent-glow: rgba(91,134,255,0.30);
  --text:        #e6ecf7;
  --text2:       #9fafc8;
  --text3:       #6e7f9b;
  --green:       #34c98a;
  --green-dim:   rgba(52,201,138,0.13);
  --red:         #f1648b;
  --red-dim:     rgba(241,100,139,0.13);
  --yellow:      #e0a93f;
  --shadow-1:    0 1px 2px rgba(0,0,0,0.35);
  --shadow-2:    0 4px 14px rgba(0,0,0,0.45);
  --shadow-3:    0 12px 32px rgba(0,0,0,0.55);
  color-scheme: dark;
}
[data-theme="dark"] img,
[data-theme="dark"] svg { filter: none; }

/* ── 3. BASE ──────────────────────────────────────────────── */
html, body { background: var(--bg); transition: background .25s var(--ease); }
::selection { background: var(--accent-dim); }

* { scrollbar-width: thin; scrollbar-color: var(--border2) transparent; }
*::-webkit-scrollbar { width: 9px; height: 9px; }
*::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 8px; border: 2px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-track { background: transparent; }

:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }

/* ── 4. SIDEBAR ───────────────────────────────────────────── */
#sidebar {
  background: var(--bg2);
  border-right: 1px solid var(--border);
}
#sidebar .sidebar-logo { border-bottom: 1px solid var(--border); }
#sidebar .logo-mark {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  border-radius: 9px;
  box-shadow: 0 2px 8px var(--accent-glow);
}
#sidebar .nav-label {
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--text3); font-weight: 700;
}
#sidebar .nav-item {
  border-radius: 10px;
  margin: 1px 8px;
  padding: 8px 10px;
  color: var(--text2);
  transition: background .15s var(--ease), color .15s var(--ease), transform .15s var(--ease);
  position: relative;
}
#sidebar .nav-item:hover {
  background: var(--bg3);
  color: var(--text);
  transform: translateX(2px);
}
#sidebar .nav-item.active {
  background: var(--accent-dim);
  color: var(--accent);
  font-weight: 600;
}
#sidebar .nav-item.active::before {
  content: '';
  position: absolute; left: -8px; top: 20%; bottom: 20%;
  width: 3px; border-radius: 3px;
  background: var(--accent);
}
#sidebar .nav-item svg { width: 16px; height: 16px; flex-shrink: 0; opacity: .85; }
#sidebar .nav-item .nav-importance {
  font-size: 8px; color: var(--yellow); opacity: .55; margin-left: auto;
  letter-spacing: -1px;
}
#sidebar .nav-item.active .nav-importance { opacity: .8; }

/* badges do menu (substituem os inline styles antigos) */
.nav-badge {
  font-size: 8px; font-weight: 700; letter-spacing: .06em;
  padding: 1px 6px; border-radius: 5px; margin-left: auto;
  border: 1px solid transparent;
}
.nav-badge--new  { background: rgba(99,102,241,.12);  color: #6366f1; border-color: rgba(99,102,241,.25); }
.nav-badge--lab  { background: rgba(168,85,247,.12);  color: #a855f7; border-color: rgba(168,85,247,.25); }
.nav-badge--test { background: rgba(0,212,170,.12);   color: #00b894; border-color: rgba(0,212,170,.25); }
.nav-badge--risk { background: rgba(239,68,68,.10);   color: #dc2626; border-color: rgba(239,68,68,.25); }
.nav-badge--count { background: var(--red); color: #fff; border-radius: 8px; font-size: 9px; }
[data-theme="dark"] .nav-badge--new  { color: #8b8ffb; }
[data-theme="dark"] .nav-badge--test { color: #2dd4ab; }
[data-theme="dark"] .nav-badge--risk { color: #f87171; }

/* ── 5. TOPBAR ────────────────────────────────────────────── */
#topbar, .topbar, header.topbar {
  background: color-mix(in srgb, var(--bg2) 82%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

/* botão de toggle de tema (injectado por theme-toggle.js) */
.theme-toggle-btn {
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--text2); cursor: pointer;
  width: 32px; height: 32px; border-radius: 9px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .18s var(--ease);
  font-size: 14px; line-height: 1;
}
.theme-toggle-btn:hover { color: var(--accent); border-color: var(--accent); transform: rotate(12deg); }

/* ── 6. CARDS ─────────────────────────────────────────────── */
.card, .panel, .tool-card, .dash-card, .stat-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  transition: box-shadow .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
}
.card:hover, .tool-card:hover, .dash-card:hover {
  box-shadow: var(--shadow-2);
  border-color: var(--border2);
}
.card-title, .panel-title, h3.card-header {
  font-weight: 700; letter-spacing: -.01em;
}

/* ── 7. TABELAS ───────────────────────────────────────────── */
table { border-collapse: separate; border-spacing: 0; }
thead th {
  background: var(--bg2);
  color: var(--text3);
  font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  border-bottom: 1px solid var(--border);
}
tbody tr { transition: background .12s var(--ease); }
tbody tr:hover { background: var(--accent-dim); }
tbody tr:nth-child(even):not(:hover) { background: color-mix(in srgb, var(--bg2) 50%, transparent); }
tbody td { border-bottom: 1px solid color-mix(in srgb, var(--border) 60%, transparent); }
.ticker-cell { color: var(--accent); font-weight: 700; cursor: pointer; }
.ticker-cell:hover { text-decoration: underline; }

/* ── 8. BOTÕES & INPUTS ───────────────────────────────────── */
.btn, button.btn {
  border-radius: var(--radius-sm);
  font-weight: 600;
  transition: all .16s var(--ease);
}
.btn-primary, .btn.btn-primary {
  background: var(--accent);
  border: 1px solid var(--accent);
  color: #fff;
  box-shadow: 0 1px 4px var(--accent-glow);
}
.btn-primary:hover { background: var(--accent-2); transform: translateY(-1px); box-shadow: 0 4px 12px var(--accent-glow); }
.btn-primary:active { transform: translateY(0); }
.btn-ghost, .btn.btn-ghost {
  background: transparent;
  border: 1px solid var(--border2);
  color: var(--text2);
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-dim); }

input, select, textarea, .form-input {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  transition: border-color .15s var(--ease), box-shadow .15s var(--ease);
}
input:focus, select:focus, textarea:focus, .form-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
  outline: none;
}

/* ── 9. ESTADOS / PILLS / KPIs ───────────────────────────── */
.pill, .tag, .badge {
  border-radius: 999px;
  font-weight: 600;
}
.pill-green, .tag-green, .text-green { color: var(--green); }
.pill-red,   .tag-red,   .text-red   { color: var(--red); }
.bg-green-dim { background: var(--green-dim); }
.bg-red-dim   { background: var(--red-dim); }

/* skeleton loading (disponível p/ fases seguintes) */
@keyframes skeleton-pulse { 0%,100% { opacity: .45; } 50% { opacity: .9; } }
.skeleton {
  background: var(--bg3);
  border-radius: var(--radius-sm);
  animation: skeleton-pulse 1.4s var(--ease) infinite;
}

/* transição suave entre páginas */
@keyframes page-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
#content > * { animation: page-in .22s var(--ease); }

/* ── 10. MOBILE ───────────────────────────────────────────── */
@media (max-width: 900px) {
  #sidebar .nav-item { padding: 11px 12px; }
  .card, .panel { border-radius: 12px; }
}

/* ============================================================
   PAGE OVERRIDES — Fases seguintes acrescentam blocos AQUI,
   um por página, marcados com o número da fase:

   /* —— FASE 1 · market —— * /
   /* —— FASE 2 · analysis-outlook —— * /
   ...
   Nunca editar as secções 1-10 acima nas fases de página.
   ============================================================ */

/* —— FASE 1 · market (v22-0-1616) —— */
.pulse-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.pulse-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.pulse-label {
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--text3);
}
.pulse-value {
  font-size: 22px; font-weight: 800; letter-spacing: -.02em;
  font-family: 'DM Mono', monospace; line-height: 1.2;
}
.pulse-sub { font-size: 11px; color: var(--text3); }
.pulse-card--actions .pulse-actions {
  display: flex; gap: 6px; flex-wrap: wrap; margin-top: 2px;
}
.pulse-card--actions .btn { padding: 4px 10px; font-size: 11px; }

/* heatmap cells: ligeiro polish sobre o v1606 */
.heat-cell { border-radius: var(--radius-sm); transition: transform .14s var(--ease), box-shadow .14s var(--ease); cursor: default; }
.heat-cell:hover { transform: scale(1.04); box-shadow: var(--shadow-2); z-index: 1; }

/* hero cards: hover + pill refinado */
.hero-card { border-radius: var(--radius); transition: box-shadow .18s var(--ease), transform .18s var(--ease); }
.hero-card:hover { box-shadow: var(--shadow-2); transform: translateY(-1px); }
.hero-pill { border-radius: 999px; font-weight: 700; }

@media (max-width: 900px) {
  .pulse-strip { grid-template-columns: repeat(2, 1fr); }
  .pulse-card--actions { grid-column: 1 / -1; }
}

/* —— FASE 2 · analysis-outlook (v22-0-1616) —— */
/* snapshot hero */
.ao-snapshot {
  background: linear-gradient(135deg, var(--card), color-mix(in srgb, var(--accent-dim) 40%, var(--card)));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.ao-snap-ticker { font-weight: 800; letter-spacing: -.02em; }

/* score cards com barra de acento */
.ao-score-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  position: relative; overflow: hidden;
  transition: box-shadow .18s var(--ease), transform .18s var(--ease);
}
.ao-score-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--accent); opacity: .6;
}
.ao-score-card[data-k="risk"]::before, .ao-score-risk::before { background: var(--red); }
.ao-score-card:hover { box-shadow: var(--shadow-2); transform: translateY(-1px); }
.ao-score-value { font-family: 'DM Mono', monospace; font-weight: 700; }

/* painéis */
.ao-panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.ao-panel-title { font-weight: 700; letter-spacing: -.01em; }

/* layout 2 colunas em ecrãs largos: análise + outlook lado a lado */
@media (min-width: 1280px) {
  .ao-result { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
  .ao-result > .ao-snapshot,
  .ao-result > .ao-scores,
  .ao-result > .ao-tech-gates,
  .ao-result > #ao-panel-tech-gates,
  .ao-result > .ao-cases,
  .ao-result > #ao-lists { grid-column: 1 / -1; }
}

/* barras de componentes da confluência (Fase 2) */
.conf-bars {
  margin-top: 12px; padding: 12px 14px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.conf-bars-head {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--text3); margin-bottom: 10px;
}
.conf-bar-row {
  display: grid; grid-template-columns: 120px 1fr 56px;
  gap: 10px; align-items: center; margin-bottom: 6px;
}
.conf-bar-label { font-size: 11.5px; color: var(--text2); }
.conf-bar-track {
  position: relative; height: 8px; border-radius: 4px;
  background: var(--bg3); overflow: visible;
}
.conf-bar-mid {
  position: absolute; left: 50%; top: -2px; bottom: -2px; width: 1px;
  background: var(--border2);
}
.conf-bar-fill {
  position: absolute; top: 0; bottom: 0; border-radius: 4px;
  transition: width .35s var(--ease);
}
.conf-bar-pos { left: 50%; background: var(--green); }
.conf-bar-neg { right: 50%; background: var(--red); }
.conf-bar-val { font-family: 'DM Mono', monospace; font-size: 11.5px; text-align: right; }
.conf-bar-val.pos { color: var(--green); }
.conf-bar-val.neg { color: var(--red); }

/* plano de risco (Fase 2) */
.risk-plan {
  margin-top: 12px; padding: 12px 14px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.risk-plan-head {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--text3); margin-bottom: 10px;
}
.risk-plan-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px;
}
.risk-cell {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 8px 10px;
  display: flex; flex-direction: column; gap: 2px;
}
.risk-cell b { font-family: 'DM Mono', monospace; font-size: 14px; }
.risk-k { font-size: 9.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--text3); }
.risk-s { font-size: 10px; color: var(--text3); }
.risk-cell--stop { border-color: color-mix(in srgb, var(--red) 40%, var(--border)); }
.risk-cell--stop b { color: var(--red); }
.risk-cell--size { border-color: color-mix(in srgb, var(--accent) 40%, var(--border)); }
.risk-plan-note { margin-top: 8px; font-size: 11px; color: var(--yellow); }

@media (max-width: 700px) {
  .conf-bar-row { grid-template-columns: 90px 1fr 48px; }
}

/* —— FASE 3 · scanners (v22-0-1617) —— */
/* tabs de modo do scanner como segmented control */
div:has(> #btn-next-leaders) {
  display: inline-flex !important;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 4px;
  gap: 4px !important;
  box-shadow: var(--shadow-1);
}
div:has(> #btn-next-leaders) .btn {
  border-radius: 9px;
  border: none;
  padding: 7px 16px;
  font-size: 12.5px;
}
div:has(> #btn-next-leaders) .btn-ghost {
  background: transparent;
  color: var(--text2);
}
div:has(> #btn-next-leaders) .btn-ghost:hover {
  background: var(--bg3); color: var(--text);
}
div:has(> #btn-next-leaders) .btn-primary {
  box-shadow: 0 1px 6px var(--accent-glow);
}

/* tabs de perfis (Orion, Pantheon, …) como pills */
.ps-tech-tab, .ps-fund-tab {
  border-radius: 999px !important;
  border: 1px solid var(--border) !important;
  background: var(--bg2) !important;
  color: var(--text2) !important;
  transition: all .15s var(--ease);
}
.ps-tech-tab:hover, .ps-fund-tab:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}
.ps-tab-active {
  background: var(--accent-dim) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  font-weight: 700;
}

/* tabela de resultados do scanner */
#scanner-table thead th { position: sticky; top: 0; z-index: 2; }
#scanner-table tbody tr { cursor: default; }

/* tabela de gates (Fase 3) */
.gates-table thead th { white-space: nowrap; }
.gate-row--warn { opacity: .72; }
.gate-dir {
  font-size: 9.5px; font-weight: 800; letter-spacing: .07em;
  padding: 2px 8px; border-radius: 5px;
}
.gate-dir--long    { background: var(--green-dim); color: var(--green); }
.gate-dir--short   { background: var(--red-dim);   color: var(--red); }
.gate-dir--neutral { background: var(--bg3);       color: var(--text3); }
.ao-good { color: var(--green); font-weight: 700; }
.ao-warn { color: var(--yellow); font-weight: 700; }

/* badges genéricos usados nas tabelas do scanner */
.badge { border-radius: 6px; font-weight: 700; font-size: 10px; padding: 2px 8px; }
.badge-green  { background: var(--green-dim);  color: var(--green); }
.badge-red    { background: var(--red-dim);    color: var(--red); }
.badge-yellow { background: rgba(192,138,45,.13); color: var(--yellow); }
.badge-blue   { background: var(--accent-dim); color: var(--accent); }

/* sliders */
#panel-profile-search input[type="range"],
#panel-standard-scanner input[type="range"] { accent-color: var(--accent); }

/* —— FASE 3.1 + 4 · page-hero partilhado (v22-0-1617) —— */
.page-hero {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 18px; padding: 18px 20px;
  background: linear-gradient(135deg, var(--card), color-mix(in srgb, var(--accent-dim) 35%, var(--card)));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.page-hero-title {
  font-size: 21px; font-weight: 800; letter-spacing: -.02em;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  margin: 0 0 4px;
}
.page-hero-tag {
  font-size: 9px; font-weight: 800; letter-spacing: .09em;
  padding: 3px 9px; border-radius: 6px;
  background: var(--accent-dim); color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
}
.page-hero-tag--green { background: var(--green-dim); color: var(--green); border-color: color-mix(in srgb, var(--green) 30%, transparent); }
.page-hero-sub { font-size: 12.5px; color: var(--text2); margin: 0; max-width: 720px; }
.page-hero-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.page-hero-meta { font-size: 11px; color: var(--text3); }

/* —— FASE 4 · bots IA: unifica pm-* (todas as páginas pm-page) —— */
.pm-page .pm-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.pm-page .pm-card-header h3 { font-weight: 700; letter-spacing: -.01em; }

/* subtabs como segmented control */
.pm-subtabs {
  display: inline-flex; flex-wrap: wrap;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 4px; gap: 4px;
  box-shadow: var(--shadow-1);
  margin-bottom: 16px;
}
.pm-subtab {
  border: none; border-radius: 9px;
  background: transparent; color: var(--text2);
  padding: 7px 14px; font-size: 12px; font-weight: 600;
  cursor: pointer;
  transition: background .15s var(--ease), color .15s var(--ease);
}
.pm-subtab:hover { background: var(--bg3); color: var(--text); }
.pm-subtab.active {
  background: var(--accent); color: #fff;
  box-shadow: 0 1px 6px var(--accent-glow);
}

/* KPIs no estilo dos pulse cards */
.pm-kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px; margin-bottom: 16px;
}
.pm-kpi {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: 13px 15px;
  transition: box-shadow .18s var(--ease), transform .18s var(--ease);
}
.pm-kpi:hover, .sbd-kpi-click:hover {
  box-shadow: var(--shadow-2); transform: translateY(-1px); cursor: pointer;
}
.pm-kpi-val { font-family: 'DM Mono', monospace; font-weight: 700; }

/* stat strip do validado no mesmo estilo */
.pm-stats-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px; margin-bottom: 16px;
}
.pm-stat-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: 13px 15px;
}
.pm-stat-value { font-family: 'DM Mono', monospace; font-weight: 700; }
.pm-stat-balance { border-left: 3px solid var(--accent); }

/* botões pm */
.pm-btn {
  border-radius: var(--radius-sm);
  font-weight: 600;
  transition: all .16s var(--ease);
}

/* equity chart maior em ecrãs largos (Fase 4) */
@media (min-width: 1280px) {
  .vp-equity-compact { height: 320px !important; max-height: 320px !important; }
}

/* tabelas pm herdam o estilo base; afina densidade */
.pm-page table tbody td { padding-top: 8px; padding-bottom: 8px; }

/* —— FASE 5-CAL · economic-calendar + vision (v22-0-1618) —— */
.ecal-hero { margin-bottom: 14px; }
.ecal-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 14px; background: var(--bg2, rgba(0,0,0,.04)); padding: 4px; border-radius: 12px; width: fit-content; }
.ecal-tab { border: none; background: transparent; padding: 7px 14px; border-radius: 9px; font-size: 12.5px; font-weight: 700; color: var(--text2, #667); cursor: pointer; transition: all .15s ease; }
.ecal-tab:hover { color: var(--text, #112); }
.ecal-tab.active { background: var(--accent, #2563eb); color: #fff; box-shadow: 0 2px 8px color-mix(in srgb, var(--accent, #2563eb) 35%, transparent); }
.ecal-pulse { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 10px; margin-bottom: 16px; }
.ecal-pulse-card { background: var(--card, #fff); border: 1px solid var(--border, #e3e8ef); border-radius: 13px; padding: 12px 14px; display: flex; flex-direction: column; gap: 4px; transition: transform .15s ease, box-shadow .15s ease; }
.ecal-pulse-card:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,.07); }
.ecal-pulse-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text3, #8a95a5); }
.ecal-pulse-value { font-family: 'DM Mono', monospace; font-size: 17px; font-weight: 700; }
.ecal-day { background: var(--card, #fff); border: 1px solid var(--border, #e3e8ef); border-radius: 14px; margin-bottom: 12px; overflow: hidden; }
.ecal-day-head { display: flex; align-items: center; justify-content: space-between; padding: 11px 16px; font-weight: 800; font-size: 13px; background: color-mix(in srgb, var(--accent, #2563eb) 5%, var(--card, #fff)); border-bottom: 1px solid var(--border, #e3e8ef); }
.ecal-day-count { font-family: 'DM Mono', monospace; font-size: 11px; background: var(--bg2, rgba(0,0,0,.05)); border-radius: 99px; padding: 2px 9px; }
.ecal-row { display: flex; align-items: center; gap: 10px; padding: 9px 16px; border-bottom: 1px solid color-mix(in srgb, var(--border, #e3e8ef) 55%, transparent); font-size: 12.5px; flex-wrap: wrap; }
.ecal-row:last-child { border-bottom: none; }
.ecal-row:hover { background: color-mix(in srgb, var(--accent, #2563eb) 4%, transparent); }
.ecal-time { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--text3, #8a95a5); min-width: 52px; }
.ecal-flag { font-size: 14px; }
.ecal-imp { font-size: 9.5px; font-weight: 800; letter-spacing: .05em; border-radius: 99px; padding: 2px 8px; }
.ecal-imp-high { background: color-mix(in srgb, var(--red, #dc2626) 14%, transparent); color: var(--red, #dc2626); }
.ecal-imp-med  { background: color-mix(in srgb, var(--yellow, #d97706) 16%, transparent); color: var(--yellow, #b45309); }
.ecal-imp-low  { background: var(--bg2, rgba(0,0,0,.05)); color: var(--text3, #8a95a5); }
.ecal-imp-earn { background: color-mix(in srgb, var(--accent, #2563eb) 14%, transparent); color: var(--accent, #2563eb); }
.ecal-event { flex: 1; min-width: 180px; font-weight: 600; }
.ecal-nums { display: flex; gap: 12px; font-family: 'DM Mono', monospace; font-size: 11px; color: var(--text2, #667); }
.ecal-ticker { color: var(--accent, #2563eb); font-weight: 800; cursor: pointer; }
.ecal-ticker:hover { text-decoration: underline; }
.ecal-mine { background: color-mix(in srgb, var(--green, #059669) 5%, transparent); }
.ecal-mine-badge { font-size: 10px; color: var(--green, #059669); font-weight: 800; }
.ecal-loading, .ecal-empty { text-align: center; padding: 36px; color: var(--text3, #8a95a5); }
[data-theme=dark] .ecal-day-head { background: color-mix(in srgb, var(--accent, #3b82f6) 9%, var(--card, #16202e)); }

.vision-card { background: var(--card, #fff); border: 1px solid var(--border, #e3e8ef); border-radius: 14px; padding: 18px; margin-top: 16px; }
.vision-title { margin: 0 0 4px; font-size: 15px; }
.vision-sub { margin: 0 0 12px; font-size: 12px; color: var(--text2, #667); max-width: 720px; }
.vision-drop { border: 2px dashed color-mix(in srgb, var(--accent, #2563eb) 35%, var(--border, #e3e8ef)); border-radius: 12px; padding: 22px; text-align: center; cursor: pointer; transition: all .15s ease; }
.vision-drop.vision-over { border-color: var(--accent, #2563eb); background: color-mix(in srgb, var(--accent, #2563eb) 6%, transparent); }
.vision-drop-icon { display: block; font-size: 22px; opacity: .5; margin-bottom: 4px; }
.vision-drop a { color: var(--accent, #2563eb); font-weight: 700; cursor: pointer; }
.vision-preview { max-width: 100%; max-height: 320px; border-radius: 8px; margin: 0 auto; display: block; }
.vision-actions { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.vision-prompt { flex: 1; min-width: 220px; border: 1px solid var(--border, #e3e8ef); border-radius: 9px; padding: 8px 12px; font-size: 12.5px; background: var(--bg, #fff); color: var(--text, #112); }
.vision-result { margin-top: 14px; border-top: 1px solid var(--border, #e3e8ef); padding-top: 14px; }
.vision-provider { font-size: 10px; text-transform: uppercase; letter-spacing: .06em; color: var(--text3, #8a95a5); font-weight: 700; margin-bottom: 8px; }
.vision-text { font-size: 13px; line-height: 1.65; }
.vision-text h4 { margin: 12px 0 4px; font-size: 13px; }
.vision-loading { color: var(--text3, #8a95a5); padding: 10px 0; }
.vision-error { color: var(--red, #dc2626); font-weight: 600; }
.vision-note { font-size: 11px; color: var(--text3, #8a95a5); margin: 12px 0 0; }

/* —— v22-0-1619 · vision verdict + captura —— */
.vision-capture-btn { margin-top: 8px; border: 1px solid var(--border, #e3e8ef); border-radius: 9px; padding: 7px 14px; font-size: 12px; font-weight: 700; background: var(--card, #fff); cursor: pointer; }
.vision-capture-btn:hover { border-color: var(--accent, #2563eb); color: var(--accent, #2563eb); }
.vision-verdict-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-bottom: 14px; }
.vision-verdict { font-size: 20px; font-weight: 900; letter-spacing: .02em; border-radius: 12px; padding: 10px 22px; }
.vision-v-buy { background: color-mix(in srgb, var(--green, #059669) 14%, transparent); color: var(--green, #059669); }
.vision-v-sell { background: color-mix(in srgb, var(--red, #dc2626) 14%, transparent); color: var(--red, #dc2626); }
.vision-v-neutral { background: var(--bg2, rgba(0,0,0,.05)); color: var(--text2, #667); }
.vision-prob { flex: 1; min-width: 220px; }
.vision-prob-bar { height: 8px; border-radius: 99px; background: color-mix(in srgb, var(--red, #dc2626) 18%, transparent); overflow: hidden; }
.vision-prob-fill { height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--green, #059669), color-mix(in srgb, var(--green, #059669) 70%, var(--accent, #2563eb))); transition: width .6s cubic-bezier(.22,1,.36,1); }
.vision-prob-label { font-size: 11px; color: var(--text2, #667); display: block; margin-top: 4px; }
.vision-plan { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 10px; margin-bottom: 12px; }
.vision-plan-cell { background: var(--bg2, rgba(0,0,0,.03)); border: 1px solid var(--border, #e3e8ef); border-radius: 11px; padding: 10px 12px; display: flex; flex-direction: column; gap: 3px; }
.vision-plan-cell span { font-size: 9.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--text3, #8a95a5); }
.vision-plan-cell b { font-family: 'DM Mono', monospace; font-size: 15px; }
.vision-plan-sl { border-left: 3px solid var(--red, #dc2626); }
.vision-plan-tp { border-left: 3px solid var(--green, #059669); }
.vision-pats { margin-bottom: 10px; display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.vision-pat { font-size: 10.5px; font-weight: 800; border-radius: 99px; padding: 3px 10px; }
.vision-pat-bullish { background: color-mix(in srgb, var(--green, #059669) 13%, transparent); color: var(--green, #059669); }
.vision-pat-bearish { background: color-mix(in srgb, var(--red, #dc2626) 13%, transparent); color: var(--red, #dc2626); }
.vision-pat-neutral { background: var(--bg2, rgba(0,0,0,.05)); color: var(--text2, #667); }
.vision-levels { display: flex; gap: 18px; flex-wrap: wrap; font-size: 12px; margin-bottom: 10px; font-family: 'DM Mono', monospace; }
.vision-sect { font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--text3, #8a95a5); margin: 10px 0 4px; }
.vision-sect-warn { color: var(--yellow, #b45309); }
.vision-ul { margin: 0; padding-left: 18px; font-size: 12.5px; line-height: 1.6; }
.vision-ul-warn { color: var(--text2, #667); }

/* —— v22-0-1620 · news-hub reestruturado —— */
.nh-hero { margin-bottom: 14px; }
.nh-hero .nh-controls { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.nh-pulse { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 10px; margin-bottom: 8px; }
.nh-pulse-card { background: var(--card, #fff); border: 1px solid var(--border, #e3e8ef); border-radius: 13px; padding: 12px 14px; display: flex; flex-direction: column; gap: 4px; transition: transform .15s ease, box-shadow .15s ease; }
.nh-pulse-card:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,.08); }
.nh-pulse-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text3, #8a95a5); }
.nh-pulse-value { font-family: 'DM Mono', monospace; font-size: 19px; font-weight: 800; }
.nh-ai-status { min-height: 20px; font-size: 11.5px; margin-bottom: 10px; }
.nh-ai-running { color: var(--accent, #2563eb); }
.nh-ai-done { color: var(--green, #059669); }
.nh-ai-err { color: var(--yellow, #b45309); }

/* —— FASE 5 · Portfolio & Risco (v22-0-1621) —— */
.prisk-hero, .port-hero, .rlab-hero { margin-bottom: 14px; }
.prisk-controls { display: flex; gap: 10px; align-items: flex-end; }
.prisk-cap-label { display: flex; flex-direction: column; gap: 4px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--text3, #8a95a5); }
.prisk-cap-label input { width: 120px; border: 1px solid var(--border, #e3e8ef); border-radius: 9px; padding: 8px 10px; font-family: 'DM Mono', monospace; font-size: 13px; background: var(--card, #fff); color: var(--text, #112); }
.prisk-loading, .prisk-empty { text-align: center; padding: 32px; color: var(--text3, #8a95a5); }
.prisk-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 10px; margin-bottom: 18px; }
.prisk-kpi { background: var(--card, #fff); border: 1px solid var(--border, #e3e8ef); border-radius: 13px; padding: 13px 15px; display: flex; flex-direction: column; gap: 3px; border-left: 3px solid var(--border, #e3e8ef); transition: transform .15s ease, box-shadow .15s ease; }
.prisk-kpi:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,.08); }
.prisk-kpi-label { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--text3, #8a95a5); }
.prisk-kpi-value { font-family: 'DM Mono', monospace; font-size: 20px; font-weight: 800; }
.prisk-kpi-sub { font-size: 11px; color: var(--text2, #667); }
.prisk-kpi.prisk-bad { border-left-color: var(--red, #dc2626); } .prisk-kpi.prisk-bad .prisk-kpi-value { color: var(--red, #dc2626); }
.prisk-kpi.prisk-warn { border-left-color: var(--yellow, #d97706); } .prisk-kpi.prisk-warn .prisk-kpi-value { color: var(--yellow, #b45309); }
.prisk-kpi.prisk-mid { border-left-color: var(--accent, #2563eb); }
.prisk-kpi.prisk-good { border-left-color: var(--green, #059669); } .prisk-kpi.prisk-good .prisk-kpi-value { color: var(--green, #059669); }
.prisk-section-h { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; margin: 16px 0 10px; }
.prisk-note { font-size: 10.5px; font-weight: 500; text-transform: none; letter-spacing: 0; color: var(--text3, #8a95a5); }
.hm-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.hm-tile { min-width: 168px; border-radius: 13px; padding: 12px 13px; cursor: pointer; border: 1px solid transparent; transition: transform .14s ease, box-shadow .14s ease; }
.hm-tile:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(0,0,0,.13); }
.hm-sg { background: color-mix(in srgb, var(--green, #059669) 22%, var(--card, #fff)); border-color: color-mix(in srgb, var(--green, #059669) 40%, transparent); }
.hm-g  { background: color-mix(in srgb, var(--green, #059669) 11%, var(--card, #fff)); border-color: color-mix(in srgb, var(--green, #059669) 25%, transparent); }
.hm-y  { background: color-mix(in srgb, var(--yellow, #d97706) 13%, var(--card, #fff)); border-color: color-mix(in srgb, var(--yellow, #d97706) 28%, transparent); }
.hm-r  { background: color-mix(in srgb, var(--red, #dc2626) 14%, var(--card, #fff)); border-color: color-mix(in srgb, var(--red, #dc2626) 30%, transparent); }
.hm-tile-top { display: flex; justify-content: space-between; align-items: baseline; font-size: 14px; }
.hm-w { font-family: 'DM Mono', monospace; font-size: 10.5px; color: var(--text3, #8a95a5); }
.hm-gain { font-family: 'DM Mono', monospace; font-size: 19px; font-weight: 800; margin: 2px 0; }
.hm-sg .hm-gain, .hm-g .hm-gain { color: var(--green, #047857); }
.hm-y .hm-gain { color: var(--yellow, #b45309); }
.hm-r .hm-gain { color: var(--red, #dc2626); }
.hm-meta { font-size: 10.5px; color: var(--text2, #667); margin-bottom: 6px; }
.hm-risk { font-size: 9.5px; font-weight: 800; border-radius: 99px; padding: 2px 8px; background: var(--card, #fff); }
.hm-risk.prisk-bad { color: var(--red, #dc2626); } .hm-risk.prisk-warn { color: var(--yellow, #b45309); }
.hm-risk.prisk-mid { color: var(--accent, #2563eb); } .hm-risk.prisk-good { color: var(--green, #059669); }
.hm-stop { margin-top: 7px; font-size: 9.5px; color: var(--text2, #667); }
.hm-stop-track { height: 4px; border-radius: 99px; background: rgba(0,0,0,.09); overflow: hidden; margin-bottom: 3px; }
.hm-stop-fill { height: 100%; border-radius: 99px; }
.hm-stop-tight { background: var(--red, #dc2626); }
.hm-stop-mid { background: var(--yellow, #d97706); }
.hm-stop-wide { background: var(--green, #059669); }
.hm-stop-na { opacity: .55; }
.prisk-secs { display: flex; flex-direction: column; gap: 7px; max-width: 560px; }
.prisk-sec { display: flex; align-items: center; gap: 10px; font-size: 12px; }
.prisk-sec span { min-width: 130px; }
.prisk-sec-track { flex: 1; height: 7px; border-radius: 99px; background: var(--bg2, rgba(0,0,0,.06)); overflow: hidden; }
.prisk-sec-fill { height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--accent, #2563eb), color-mix(in srgb, var(--accent, #2563eb) 60%, var(--green, #059669))); }
.prisk-sec b { font-family: 'DM Mono', monospace; font-size: 11px; min-width: 48px; text-align: right; }
.prisk-corr-warn { margin-top: 14px; padding: 10px 14px; border-radius: 11px; background: color-mix(in srgb, var(--yellow, #d97706) 10%, transparent); color: var(--yellow, #92600a); font-size: 12px; font-weight: 600; }
/* Portfolio shell tabs → segmented moderno */
.port-nav-card { padding: 10px 12px !important; border-radius: 14px !important; }
.port-nav-row-primary { background: var(--bg2, rgba(0,0,0,.04)); border-radius: 11px; padding: 4px; display: inline-flex; gap: 4px; flex-wrap: wrap; }
.port-nav-row .system-tab { border: none; background: transparent; border-radius: 8px; padding: 7px 16px; font-weight: 700; font-size: 12.5px; color: var(--text2, #667); transition: all .14s ease; }
.port-nav-row .system-tab:hover { color: var(--text, #112); }
.port-nav-row .system-tab.active { background: var(--accent, #2563eb); color: #fff; box-shadow: 0 2px 8px color-mix(in srgb, var(--accent, #2563eb) 35%, transparent); }
[data-theme=dark] .hm-stop-track { background: rgba(255,255,255,.12); }

/* —— FASE 6 · páginas restantes (v22-0-1622) —— */
/* SMC/ICT e outras com .page-header → mesmo look do page-hero */
.page-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 18px; padding: 18px 20px;
  background: linear-gradient(135deg, var(--card), color-mix(in srgb, var(--accent-dim) 35%, var(--card)));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.page-header h1 { font-size: 21px; font-weight: 800; letter-spacing: -.02em; margin: 2px 0 4px; }
.page-kicker {
  font-size: 9px; font-weight: 800; letter-spacing: .09em; text-transform: uppercase;
  color: var(--accent);
}
.page-subtitle { font-size: 12.5px; color: var(--text2); margin: 0; max-width: 720px; }
.page-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* ai-costs / trading test / lab com .pm-page-header → hero look */
.pm-page-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 18px; padding: 18px 20px;
  background: linear-gradient(135deg, var(--card), color-mix(in srgb, var(--accent-dim) 35%, var(--card)));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.pm-page-header h1 { font-size: 21px; font-weight: 800; letter-spacing: -.02em; margin: 0 0 4px; }
.pm-page-header p { font-size: 12.5px; color: var(--text2); margin: 0; }

/* pills do market-intel */
.mi-pill {
  border-radius: 999px !important;
  border: 1px solid var(--border) !important;
  background: var(--bg2) !important;
  color: var(--text2) !important;
  padding: 6px 14px; font-size: 12px; font-weight: 600; cursor: pointer;
  transition: all .15s var(--ease);
}
.mi-pill:hover { border-color: var(--accent) !important; color: var(--accent) !important; }
.mi-pill-active {
  background: var(--accent-dim) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  font-weight: 700;
}

/* tools command center: alinhar ao tema */
.tools-command-hero {
  background: linear-gradient(135deg, var(--card), color-mix(in srgb, var(--accent-dim) 35%, var(--card))) !important;
  border-radius: var(--radius) !important;
}
.tools-eyebrow { color: var(--accent) !important; }

/* hero inputs/selects compactos dentro do hero-actions */
.page-hero-actions select,
.page-hero-actions input[type="text"] {
  background: var(--bg2); border: 1px solid var(--border);
  color: var(--text); padding: 6px 10px; border-radius: var(--radius-sm);
  font-size: 12px;
}
.page-hero-actions label {
  display: flex; align-items: center; gap: 6px;
  background: var(--bg2); border: 1px solid var(--border);
  color: var(--text2); padding: 6px 10px; border-radius: var(--radius-sm);
  font-size: 12px; white-space: nowrap;
}
.page-hero-actions input[type="checkbox"] { accent-color: var(--accent); }

/* FASE 6b: headers de páginas geridas por módulo → hero look via CSS */
.ait-header, .lab-header, .ao-header {
  background: linear-gradient(135deg, var(--card), color-mix(in srgb, var(--accent-dim) 35%, var(--card))) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-1) !important;
  padding: 18px 20px !important;
  margin-bottom: 18px !important;
}
.ao-header .ao-title, .ait-header h1, .lab-header h1 {
  font-weight: 800; letter-spacing: -.02em;
}

/* —— FASE 7 · news-hub regenerado + ligação calendário (v22-0-1623) —— */
/* mata a paleta dark hardcoded do v1434: nh-* passa aos tokens do tema */
.nh-root {
  --nhbg:   var(--bg)   !important;
  --nhsurf: var(--card) !important;
  --nhline: var(--border) !important;
  --nhtxt:  var(--text)  !important;
  --nhtxt2: var(--text2) !important;
  --nhtxt3: var(--text3) !important;
  --nhacc:  var(--accent) !important;
  --nhacc2: var(--accent-2) !important;
  background: transparent !important;
  color: var(--text) !important;
}
.nh-root .nh-card {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-1);
  backdrop-filter: none !important;
}
.nh-root .nh-input {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
}
.nh-root .page-hero-title { color: var(--text) !important; -webkit-text-fill-color: var(--text); background: none !important; }

/* layout feed-protagonista */
.nh-main { display: grid; grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr); gap: 14px; align-items: start; }
.nh-col-rail { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 12px; }
.nh-card-feed { min-height: 400px; }
.nh-card-hint { font-size: 10px; font-weight: 500; color: var(--text3); margin-left: 8px; text-transform: none; letter-spacing: 0; }
@media (max-width: 1100px) {
  .nh-main { grid-template-columns: 1fr; }
  .nh-col-rail { position: static; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
}

/* chip de evento de calendário ligado a uma notícia */
.nh-cal-chip {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 9.5px; font-weight: 700; letter-spacing: .04em;
  padding: 2px 8px; border-radius: 6px; cursor: pointer;
  background: color-mix(in srgb, var(--yellow) 14%, transparent);
  color: var(--yellow);
  border: 1px solid color-mix(in srgb, var(--yellow) 30%, transparent);
  transition: all .14s var(--ease);
}
.nh-cal-chip:hover { background: color-mix(in srgb, var(--yellow) 24%, transparent); }
.nh-cal-chip--high { background: var(--red-dim); color: var(--red); border-color: color-mix(in srgb, var(--red) 30%, transparent); }

/* botão "ver notícias" nas linhas do calendário */
.ecal-news-link {
  font-size: 10px; font-weight: 700; color: var(--accent);
  cursor: pointer; white-space: nowrap; opacity: .85;
}
.ecal-news-link:hover { text-decoration: underline; opacity: 1; }

/* callout de screenshot na Análise quando faltam dados */
.ao-vision-callout {
  margin-top: 12px; padding: 14px 16px;
  background: color-mix(in srgb, var(--accent-dim) 60%, var(--card));
  border: 1px dashed color-mix(in srgb, var(--accent) 45%, transparent);
  border-radius: var(--radius-sm);
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px; flex-wrap: wrap;
}
.ao-vision-callout-txt { font-size: 12px; color: var(--text2); max-width: 640px; }
.ao-vision-callout-txt b { color: var(--text); }
.ao-vision-callout-txt ul { margin: 6px 0 0 16px; padding: 0; }
.ao-vision-callout-txt li { margin-bottom: 2px; }

/* pulse do vision card quando chamado pela Análise */
@keyframes vision-pulse { 0%,100% { box-shadow: var(--shadow-1); } 50% { box-shadow: 0 0 0 4px var(--accent-glow); } }
.vision-card--pulse { animation: vision-pulse .8s var(--ease) 2; }

/* —— FASE 8 · macro-intelligence (v22-0-1625) —— */
.macro-regime-banner {
  display: grid; grid-template-columns: 1.4fr auto 1fr;
  gap: 22px; align-items: center;
  padding: 20px 22px; margin-bottom: 16px;
  background: linear-gradient(135deg, var(--card), color-mix(in srgb, var(--accent-dim) 40%, var(--card)));
  border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-1);
}
.macro-regime-label, .macro-score-label {
  font-size: 9.5px; font-weight: 800; letter-spacing: .1em; color: var(--text3); margin-bottom: 4px;
}
.macro-regime-value { font-size: 28px; font-weight: 800; letter-spacing: -.02em; }
.macro-regime-note { font-size: 11px; color: var(--text3); margin-top: 4px; }
.macro-score-block { text-align: center; }
.macro-score-value { font-family: 'DM Mono', monospace; font-size: 34px; font-weight: 700; line-height: 1.1; }
.macro-score-scale { font-size: 9.5px; color: var(--text3); }
.macro-riskmeter-head { display: flex; justify-content: space-between; font-size: 9.5px; color: var(--text3); font-weight: 700; margin-bottom: 5px; }
.macro-riskmeter-track {
  position: relative; height: 12px; border-radius: 6px;
  background: linear-gradient(90deg, var(--red-dim), var(--bg3) 50%, var(--green-dim));
  border: 1px solid var(--border);
}
.macro-riskmeter-fill { position: absolute; left: 0; top: 0; bottom: 0; border-radius: 6px; background: linear-gradient(90deg, transparent, var(--accent-dim)); }
.macro-riskmeter-pin {
  position: absolute; top: -3px; bottom: -3px; width: 4px; border-radius: 2px;
  background: var(--accent); transform: translateX(-50%);
  box-shadow: 0 0 6px var(--accent-glow); transition: left .5s var(--ease);
}
.macro-riskmeter-val { font-size: 10.5px; color: var(--text2); margin-top: 5px; text-align: center; font-family: 'DM Mono', monospace; }

.macro-comp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; margin-bottom: 16px; }
.macro-comp-card {
  background: var(--card); border: 1px solid var(--border);
  border-left: 3px solid var(--border2);
  border-radius: var(--radius); box-shadow: var(--shadow-1); padding: 12px 14px;
}
.macro-comp-card .mc-k { font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--text3); }
.macro-comp-card .mc-v { font-family: 'DM Mono', monospace; font-size: 22px; font-weight: 700; margin: 3px 0; }
.macro-comp-card .mc-n { font-size: 10px; color: var(--text3); line-height: 1.4; }

.macro-2col { display: grid; grid-template-columns: 1fr 1.3fr; gap: 14px; align-items: start; }
.macro-mkt-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 8px; }
.macro-mkt-cell {
  background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 8px 10px; display: flex; flex-direction: column; gap: 1px;
}
.macro-mkt-cell .mk-k { font-size: 9px; text-transform: uppercase; letter-spacing: .06em; color: var(--text3); }
.macro-mkt-cell b { font-family: 'DM Mono', monospace; font-size: 14px; }
.macro-mkt-cell.mk-warn { border-color: color-mix(in srgb, var(--red) 40%, var(--border)); }

.macro-sur-row, .macro-up-row {
  display: flex; gap: 10px; align-items: center;
  padding: 7px 4px; border-bottom: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
  font-size: 12px;
}
.macro-sur-date, .macro-up-date { font-family: 'DM Mono', monospace; font-size: 10.5px; color: var(--text3); white-space: nowrap; }
.macro-sur-event, .macro-up-event { flex: 1; color: var(--text); }
.macro-sur-cat { font-size: 9px; font-weight: 700; text-transform: uppercase; padding: 1px 7px; border-radius: 5px; background: var(--accent-dim); color: var(--accent); }
.macro-sur-vals, .macro-up-prev { font-family: 'DM Mono', monospace; font-size: 10.5px; color: var(--text2); white-space: nowrap; }
.macro-sur-signed { font-family: 'DM Mono', monospace; font-weight: 700; min-width: 36px; text-align: right; }
.macro-up-note { font-size: 11px; color: var(--yellow); padding: 10px 4px 2px; }
.macro-disclaimer { font-size: 11px; color: var(--text3); margin-top: 14px; padding: 0 4px; line-height: 1.5; }

@media (max-width: 1000px) {
  .macro-regime-banner { grid-template-columns: 1fr; gap: 14px; }
  .macro-2col { grid-template-columns: 1fr; }
}

/* —— FASE 9 · data-health (v22-0-1626) —— */
.dh-3col { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 14px; }
.dh-rec { display: flex; gap: 10px; align-items: flex-start; padding: 9px 4px; font-size: 12.5px; color: var(--text); border-bottom: 1px solid color-mix(in srgb, var(--border) 60%, transparent); line-height: 1.5; }
.dh-rec-sev { font-size: 9px; font-weight: 800; letter-spacing: .07em; padding: 2px 8px; border-radius: 5px; white-space: nowrap; margin-top: 2px; }
.dh-rec--high .dh-rec-sev { background: var(--red-dim); color: var(--red); }
.dh-rec--med .dh-rec-sev { background: rgba(192,138,45,.13); color: var(--yellow); }
.dh-prov-row { display: flex; gap: 10px; align-items: center; padding-top: 8px; font-size: 12.5px; }
.dh-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.dh-dot--ok { background: var(--green); box-shadow: 0 0 5px color-mix(in srgb, var(--green) 50%, transparent); }
.dh-dot--fail { background: var(--red); box-shadow: 0 0 5px color-mix(in srgb, var(--red) 50%, transparent); }
.dh-prov-name { font-weight: 700; min-width: 180px; }
.dh-prov-detail { flex: 1; color: var(--text2); font-size: 11.5px; }
.dh-prov-ms { font-family: 'DM Mono', monospace; font-size: 10px; color: var(--text3); }
.dh-prov-covers { font-size: 10px; color: var(--text3); padding: 1px 0 7px 19px; border-bottom: 1px solid color-mix(in srgb, var(--border) 50%, transparent); }
.dh-cov-row { display: grid; grid-template-columns: 130px 1fr 44px 50px; gap: 8px; align-items: center; padding: 4px 0; font-size: 12px; }
.dh-cov-name { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--text2); }
.dh-cov-track { height: 8px; border-radius: 4px; background: var(--bg3); overflow: hidden; }
.dh-cov-fill { height: 100%; border-radius: 4px; transition: width .4s var(--ease); }
.dh-cov-pct { font-family: 'DM Mono', monospace; font-weight: 700; font-size: 11px; text-align: right; }
.dh-cov-n { font-family: 'DM Mono', monospace; font-size: 10px; color: var(--text3); text-align: right; }
.dh-cov-na { font-size: 10px; color: var(--text3); }
.dh-backfill-bar { height: 10px; border-radius: 5px; background: var(--bg3); border: 1px solid var(--border); overflow: hidden; }
.dh-backfill-fill { height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width .5s var(--ease); }
.dh-kv { display: flex; gap: 8px; align-items: baseline; padding: 4px 0; font-size: 12px; border-bottom: 1px solid color-mix(in srgb, var(--border) 50%, transparent); }
.dh-kv span { flex: 1; color: var(--text2); }
.dh-kv b { font-family: 'DM Mono', monospace; font-size: 11px; }
.dh-kv i { font-size: 10px; color: var(--text3); font-style: normal; }
@media (max-width: 1000px) { .dh-3col { grid-template-columns: 1fr; } }
