﻿/* OPRIX REBRAND — visual only */
:root {
  --oprix-bg: #020B1C;
  --oprix-bg-soft: #071326;
  --oprix-card: rgba(255,255,255,0.055);
  --oprix-card-strong: rgba(255,255,255,0.085);
  --oprix-border: rgba(255,255,255,0.11);
  --oprix-cyan: #35D6D0;
  --oprix-cyan-dark: #1AAFA9;
  --oprix-text: #F5F7FA;
  --oprix-muted: #A8B3C7;
  --oprix-muted-2: #748197;
  --oprix-silver: #D9DEE7;
  --oprix-warning: #F2C94C;
  --oprix-danger: #FF6B6B;
  --oprix-radius: 28px;
  --oprix-radius-sm: 16px;
  --oprix-shadow: 0 30px 80px rgba(0,0,0,0.35);
  --bg: var(--oprix-bg);
  --panel: var(--oprix-card);
  --panel-2: var(--oprix-card-strong);
  --text: var(--oprix-text);
  --muted: var(--oprix-muted);
  --muted-2: var(--oprix-muted-2);
  --line: var(--oprix-border);
  --brand: var(--oprix-cyan);
  --brand-2: var(--oprix-cyan-dark);
  --brand-3: var(--oprix-cyan);
  --warn: var(--oprix-warning);
  --danger: var(--oprix-danger);
  --ok: #16a34a;
  --ink: var(--oprix-text);
  --shadow: var(--oprix-shadow);
  --radius: var(--oprix-radius-sm);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { width: 100%; overflow-x: hidden; }
body {
  margin: 0;
  color-scheme: dark;
  background:
    radial-gradient(circle at 20% 0%, rgba(53,214,208,0.18), transparent 28%),
    radial-gradient(circle at 80% 10%, rgba(53,214,208,0.08), transparent 24%),
    linear-gradient(180deg, #020B1C 0%, #030713 52%, #020B1C 100%);
  color: var(--text);
  overflow-x: hidden;
}
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }

.auth-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
}
.admin-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
}
.admin-sidebar {
  border-right: 1px solid var(--line);
  background: rgba(7, 11, 22, .82);
  padding: 20px 14px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.admin-sidebar .nav {
  display: grid;
  gap: 8px;
}
.admin-auth .auth-hero {
  background:
    linear-gradient(135deg, rgba(7, 11, 22, .92), rgba(16, 24, 39, .86)),
    radial-gradient(circle at 24% 18%, rgba(47,124,255,.38), transparent 34%),
    radial-gradient(circle at 80% 20%, rgba(139,92,246,.20), transparent 30%);
}
.auth-hero {
  padding: 56px;
  background: linear-gradient(135deg, rgba(47,124,255,.92), rgba(139,92,246,.84)), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='900'%3E%3Crect width='1200' height='900' fill='%23050914'/%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='.16'%3E%3Cpath d='M0 690 C210 520 290 760 500 590 S880 330 1200 510'/%3E%3Cpath d='M0 380 C180 250 360 460 560 300 S860 90 1200 220'/%3E%3C/g%3E%3C/svg%3E") center/cover;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.auth-hero h1 { font-size: 48px; line-height: 1.02; max-width: 620px; margin: 0 0 20px; letter-spacing: 0; }
.auth-hero p { max-width: 620px; font-size: 18px; opacity: .9; }
.auth-panel {
  display: grid;
  align-content: center;
  padding: 48px;
  background: var(--panel);
}
.auth-card { max-width: 440px; width: 100%; margin: 0 auto; }
.brand { display: flex; align-items: center; gap: 12px; font-weight: 800; font-size: 19px; min-width: 0; }
.brand-action {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  text-align: left;
  cursor: pointer;
}
.brand-action:hover .brand-copy strong { color: var(--brand); }
.brand-copy { display: grid; gap: 2px; min-width: 0; line-height: 1.05; }
.brand-copy strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.brand-copy small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1.25;
}
.brand-mark {
  width: 38px; height: 38px; border-radius: var(--radius);
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-3) 38%, var(--brand-2) 100%);
  box-shadow: 0 12px 24px rgba(47,124,255,.28);
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 15px;
  letter-spacing: 0;
  overflow: hidden;
}
.brand-mark span { line-height: 1; }
.brand-logo-img {
  width: 44px;
  height: 44px;
  border-radius: 0;
  object-fit: contain;
  background: transparent;
  border: 0;
  box-shadow: none;
  filter: drop-shadow(0 12px 22px rgba(47,124,255,.32)) drop-shadow(0 4px 12px rgba(139,92,246,.22));
}
.brand-preview { display: grid; gap: 18px; align-content: start; }
.auth-tabs { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin: 28px 0 22px; }
.landing-shell {
  min-height: 100vh;
  padding: 22px;
  background:
    radial-gradient(circle at 15% 5%, rgba(47,124,255,.30), transparent 28%),
    radial-gradient(circle at 80% 18%, rgba(139,92,246,.18), transparent 24%),
    linear-gradient(135deg, #050914 0%, #0b1224 54%, #13091f 100%);
}
.landing-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  max-width: 1180px;
  margin: 0 auto 28px;
  padding: 14px 0;
}
.landing-hero,
.request-layout {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 34px;
  align-items: center;
  padding: 48px 0 34px;
}
.landing-hero h1,
.request-layout h1 {
  font-size: clamp(40px, 6vw, 72px);
  line-height: 1;
  margin: 12px 0 18px;
  letter-spacing: 0;
}
.landing-hero p,
.request-layout p {
  max-width: 680px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.55;
}
.landing-hero .lead {
  color: var(--text);
  font-size: 22px;
  font-weight: 800;
}
.landing-logo {
  display: block;
  width: min(300px, 82vw);
  height: auto;
  margin: 0 0 18px;
  filter:
    drop-shadow(0 18px 34px rgba(47,124,255,.26))
    drop-shadow(0 0 18px rgba(139,92,246,.20));
}
.eyebrow {
  display: inline-flex;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--brand-2);
  border-radius: 999px;
  padding: 7px 11px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.dashboard-preview {
  min-height: 430px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(16,24,39,.86), rgba(31,42,68,.68));
  box-shadow: var(--shadow);
  padding: 22px;
  display: grid;
  gap: 18px;
}
.preview-top,
.preview-kpis,
.preview-table { display: grid; gap: 12px; }
.preview-top { grid-template-columns: 1fr 1fr 1fr; }
.preview-top span,
.preview-table span {
  height: 42px;
  border-radius: 10px;
  background: rgba(255,255,255,.08);
}
.preview-kpis { grid-template-columns: repeat(3, 1fr); }
.preview-kpis b {
  display: grid;
  align-content: center;
  min-height: 78px;
  border-radius: 14px;
  padding: 14px;
  background: rgba(47,124,255,.13);
}
.preview-chart {
  min-height: 150px;
  border-radius: 14px;
  background:
    linear-gradient(165deg, transparent 52%, rgba(139,92,246,.46) 53%, rgba(47,124,255,.56) 56%, transparent 57%),
    linear-gradient(180deg, rgba(47,124,255,.18), rgba(255,255,255,.04));
}
.preview-table { grid-template-columns: 1fr; }
.landing-section,
.landing-grid {
  max-width: 1180px;
  margin: 26px auto;
}
.landing-section h2 { font-size: 32px; margin: 0 0 18px; }
.landing-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.landing-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.landing-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(16,24,39,.70);
  padding: 20px;
  box-shadow: var(--shadow);
}
.landing-card h3 { margin: 0 0 10px; }
.landing-card p { margin: 0; color: var(--muted); line-height: 1.5; }
.plan-card strong { display: block; font-size: 28px; margin: 10px 0; }
.cta-band {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(47,124,255,.18), rgba(139,92,246,.14));
  padding: 28px;
}
.request-shell .panel { background: rgba(16,24,39,.82); }
.request-form-stack {
  display: grid;
  gap: 14px;
}
.request-whatsapp-panel {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid rgba(125,153,199,.20);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(16,24,39,.72), rgba(47,124,255,.10));
  box-shadow: 0 18px 44px rgba(0, 0, 0, .18);
}
.request-whatsapp-panel span {
  color: #aebbd3;
  font-size: 13px;
  font-weight: 800;
}
.request-whatsapp-btn {
  width: 100%;
  justify-content: center;
  min-height: 48px;
  border-color: rgba(34,211,238,.26);
  background: linear-gradient(135deg, rgba(47,124,255,.22), rgba(124,58,237,.20));
  color: #f8fbff;
  font-weight: 900;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.request-whatsapp-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(34,211,238,.46);
  box-shadow: 0 18px 44px rgba(47,124,255,.22), inset 0 1px 0 rgba(255,255,255,.12);
}
.request-whatsapp-icon {
  width: 24px;
  height: 24px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(34,211,238,.14);
  color: #8ff7ff;
}
.demo-success-modal {
  display: grid;
  justify-items: center;
  gap: 14px;
  text-align: center;
  padding: 12px 8px 4px;
}
.demo-success-modal h2 {
  max-width: 620px;
  margin: 0;
  color: var(--text);
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.08;
}
.demo-success-modal p {
  max-width: 560px;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}
.demo-success-modal .btn {
  margin-top: 8px;
  min-width: min(100%, 280px);
  justify-content: center;
}
.demo-success-orb {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #dffcff;
  font-size: 25px;
  font-weight: 950;
  background: linear-gradient(135deg, #2f7cff, #8b5cf6);
  box-shadow: 0 16px 42px rgba(47,124,255,.38), 0 0 0 8px rgba(47,124,255,.10);
}
.trial-release-success {
  display: grid;
  gap: 12px;
}
.trial-release-success code {
  display: inline-flex;
  padding: 8px 10px;
  border: 1px solid rgba(34,211,238,.28);
  border-radius: 10px;
  background: rgba(47,124,255,.10);
  color: var(--text);
  font-weight: 900;
}
.trial-whatsapp-message {
  width: 100%;
  min-height: 170px;
  resize: vertical;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel-2) 80%, transparent);
  color: var(--text);
  padding: 12px;
  line-height: 1.45;
}

.aurix-public-landing {
  padding: 20px;
  background:
    radial-gradient(circle at 16% 8%, rgba(47,124,255,.32), transparent 30%),
    radial-gradient(circle at 82% 18%, rgba(139,92,246,.24), transparent 28%),
    radial-gradient(circle at 52% 72%, rgba(34,211,238,.12), transparent 35%),
    linear-gradient(135deg, #050914 0%, #080f1f 46%, #12091e 100%);
}
.aurix-public-nav {
  position: sticky;
  top: 12px;
  z-index: 20;
  max-width: 1220px;
  margin-bottom: 40px;
  padding: 12px 14px;
  border: 1px solid rgba(125,153,199,.20);
  border-radius: 18px;
  background: rgba(5, 9, 19, .72);
  backdrop-filter: blur(20px);
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
}
.aurix-public-nav nav {
  display: flex;
  gap: 18px;
  align-items: center;
}
.aurix-public-nav nav a {
  color: var(--muted);
  text-decoration: none;
  font-size: 13px;
  font-weight: 850;
}
.aurix-public-nav nav a:hover { color: var(--text); }
.aurix-public-hero {
  max-width: 1220px;
  grid-template-columns: minmax(0, .95fr) minmax(520px, 1.05fr);
  gap: 42px;
  padding: 34px 0 42px;
  align-items: center;
}
.aurix-public-hero h1 {
  max-width: 760px;
  font-size: clamp(42px, 5.7vw, 76px);
  line-height: .96;
  letter-spacing: 0;
  margin: 14px 0 20px;
}
.aurix-public-hero .lead {
  max-width: 690px;
  color: #c7d4ee;
  font-size: clamp(17px, 1.5vw, 21px);
  line-height: 1.55;
  font-weight: 650;
}
.hero-copy {
  display: grid;
  gap: 14px;
}
.hero-actions {
  align-items: center;
  margin-top: 8px;
}
.hero-microcopy {
  margin: 0;
  color: #91a2c1;
  font-size: 14px;
}
.trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 10px;
}
.trust-strip span,
.channel-cloud span,
.outcome-grid span,
.check-list span {
  border: 1px solid rgba(125,153,199,.22);
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  color: #b8c7e4;
  padding: 8px 11px;
  font-size: 12px;
  font-weight: 850;
}
.aurix-dashboard-mock {
  position: relative;
  min-height: 0;
  padding: 18px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035)),
    rgba(8, 14, 28, .88);
  box-shadow: 0 34px 100px rgba(0,0,0,.46), 0 0 54px rgba(47,124,255,.14);
  animation: landingFloat 5.8s ease-in-out infinite;
}
@keyframes landingFloat {
  50% { transform: translateY(-5px); }
}
.mock-topbar {
  display: grid;
  grid-template-columns: 10px 10px 10px 1fr auto;
  gap: 8px;
  align-items: center;
  min-height: 38px;
  padding: 0 4px 12px;
  color: var(--muted);
}
.mock-topbar span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #fb7185;
}
.mock-topbar span:nth-child(2) { background: #fbbf24; }
.mock-topbar span:nth-child(3) { background: #34d399; }
.mock-topbar strong {
  color: var(--text);
  margin-left: 8px;
}
.mock-topbar small { font-size: 11px; }
.mock-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.landing-mini-metric {
  border: 1px solid rgba(125,153,199,.22);
  border-radius: 16px;
  background: rgba(16, 24, 39, .68);
  padding: 14px;
  min-width: 0;
  overflow: hidden;
}
.landing-mini-metric span,
.landing-mini-metric small {
  display: block;
  color: #9fb0cb;
  font-size: 12px;
  font-weight: 750;
}
.landing-mini-metric strong {
  display: block;
  margin: 5px 0;
  color: #f8fbff;
  font-size: clamp(24px, 2.7vw, 38px);
  line-height: 1;
  overflow-wrap: anywhere;
}
.landing-mini-metric.bad {
  border-color: rgba(251, 113, 133, .38);
  background: linear-gradient(135deg, rgba(251,113,133,.12), rgba(16,24,39,.62));
}
.mock-main {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(150px, .65fr);
  gap: 12px;
  margin-top: 12px;
}
.mock-score {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  border: 1px solid rgba(34,211,238,.22);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(47,124,255,.14), rgba(34,211,238,.07));
  padding: 14px;
}
.mock-score h3 { margin: 0 0 6px; }
.mock-score p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.35; }
.score-ring {
  width: 108px;
  height: 108px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: conic-gradient(#38f0c8 calc(var(--score) * 1%), rgba(255,255,255,.08) 0);
  position: relative;
}
.score-ring::after {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: inherit;
  background: #081121;
  border: 1px solid rgba(255,255,255,.06);
}
.score-ring strong {
  position: relative;
  z-index: 1;
  font-size: 30px;
}
.mock-bars {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: end;
  gap: 8px;
  min-height: 150px;
  border: 1px solid rgba(125,153,199,.18);
  border-radius: 18px;
  padding: 12px;
  background: rgba(255,255,255,.035);
}
.mock-bars span {
  min-height: 42px;
  height: var(--h);
  border-radius: 10px 10px 6px 6px;
  background: linear-gradient(180deg, #60a5fa, #7c3aed);
  display: flex;
  align-items: end;
  justify-content: center;
  padding-bottom: 6px;
}
.mock-bars b {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 10px;
  color: rgba(255,255,255,.86);
}
.mock-line-chart {
  height: 92px;
  margin-top: 12px;
  border: 1px solid rgba(125,153,199,.18);
  border-radius: 18px;
  background:
    linear-gradient(180deg, transparent 24%, rgba(125,153,199,.10) 25%, transparent 26%, transparent 49%, rgba(125,153,199,.10) 50%, transparent 51%, transparent 74%, rgba(125,153,199,.10) 75%, transparent 76%),
    rgba(255,255,255,.03);
  position: relative;
  overflow: hidden;
}
.mock-line-chart::before {
  content: "";
  position: absolute;
  inset: 18px 14px;
  background: linear-gradient(135deg, transparent 47%, #38f0c8 48%, #60a5fa 52%, transparent 53%);
  filter: drop-shadow(0 0 12px rgba(56,240,200,.35));
}
.mock-funnel-compact,
.landing-funnel-large {
  display: grid;
  gap: 9px;
  margin-top: 12px;
}
.mock-funnel-compact span,
.landing-funnel-large div {
  min-height: 38px;
  border-radius: 12px;
  background: linear-gradient(90deg, rgba(47,124,255,.36), rgba(34,211,238,.12));
  border: 1px solid rgba(125,153,199,.18);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 12px;
  color: #e8f1ff;
  font-size: 13px;
  font-weight: 850;
}
.mock-funnel-compact .warn,
.landing-funnel-large .danger:nth-child(4) {
  background: linear-gradient(90deg, rgba(245,158,11,.36), rgba(255,255,255,.04));
}
.mock-funnel-compact .bad,
.landing-funnel-large .danger:nth-child(5) {
  background: linear-gradient(90deg, rgba(251,113,133,.42), rgba(255,255,255,.04));
}
.landing-alert-card {
  border: 1px solid rgba(34,211,238,.25);
  border-radius: 16px;
  background: rgba(34,211,238,.08);
  color: #c5f6ff;
  padding: 14px;
  font-weight: 800;
  line-height: 1.35;
}
.landing-alert-card.danger {
  border-color: rgba(251,113,133,.34);
  background: rgba(251,113,133,.10);
  color: #ffd4dc;
}
.landing-proof {
  padding-top: 10px;
}
.landing-metric-row {
  max-width: 1220px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.landing-section {
  max-width: 1220px;
  padding: 72px 0;
}
.landing-section-head {
  max-width: 850px;
  margin: 0 auto 28px;
  text-align: center;
}
.landing-section-head h2,
.big-copy h2,
.final-cta h2,
.ai-copy h2 {
  margin: 12px 0 14px;
  font-size: clamp(30px, 4vw, 54px);
  line-height: 1.04;
  letter-spacing: 0;
}
.landing-section-head p,
.big-copy p,
.final-cta p,
.ai-copy p {
  color: #aebbd3;
  font-size: 18px;
  line-height: 1.55;
}
.premium-card {
  min-height: 205px;
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.035)),
    rgba(11,18,33,.76);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.premium-card:hover {
  transform: translateY(-3px);
  border-color: rgba(47,124,255,.42);
  box-shadow: 0 24px 70px rgba(0,0,0,.34), 0 0 24px rgba(47,124,255,.10);
}
.landing-card-icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  margin-bottom: 16px;
  color: #93c5fd;
  background: rgba(47,124,255,.14);
  border: 1px solid rgba(47,124,255,.25);
  font-weight: 900;
}
.split-section,
.leak-grid,
.ai-section,
.final-cta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, .9fr);
  gap: 32px;
  align-items: center;
}
.check-list {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 18px;
}
.landing-decision-panel {
  display: grid;
  gap: 14px;
  padding: 20px;
  border-radius: 20px;
}
.channel-score-list {
  display: grid;
  gap: 12px;
}
.landing-score-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 48px 78px;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(125,153,199,.18);
  border-radius: 14px;
  background: rgba(255,255,255,.045);
  padding: 12px;
}
.landing-score-row span { font-weight: 900; }
.landing-score-row strong { font-size: 26px; text-align: right; }
.landing-score-row small { color: var(--muted); font-weight: 800; }
.landing-score-row i {
  grid-column: 1 / -1;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}
.landing-score-row i b {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: #38f0c8;
}
.landing-score-row.warn i b { background: #fbbf24; }
.landing-score-row.bad i b { background: #fb7185; }
.landing-funnel-large {
  border: 1px solid rgba(125,153,199,.20);
  border-radius: 24px;
  background: rgba(11,18,33,.72);
  padding: 22px;
  min-height: 360px;
  align-content: center;
}
.landing-funnel-large div {
  min-height: 58px;
  font-size: 16px;
}
.ai-section {
  border: 1px solid rgba(125,153,199,.20);
  border-radius: 24px;
  background:
    radial-gradient(circle at 16% 18%, rgba(124,58,237,.24), transparent 36%),
    linear-gradient(135deg, rgba(47,124,255,.12), rgba(255,255,255,.035));
  padding: 34px;
}
.ai-console {
  display: grid;
  gap: 12px;
}
.console-line {
  border: 1px solid rgba(125,153,199,.20);
  border-radius: 16px;
  background: rgba(5,9,19,.55);
  padding: 15px;
}
.console-line span {
  display: block;
  color: #93c5fd;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.console-line strong {
  color: #f8fbff;
  line-height: 1.35;
}
.channel-cloud,
.outcome-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 11px;
}
.channel-cloud span,
.outcome-grid span {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding: 0 15px;
}
.comparison-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.compare-box {
  border: 1px solid rgba(125,153,199,.20);
  border-radius: 22px;
  padding: 24px;
  background: rgba(11,18,33,.72);
}
.compare-box.bad { border-color: rgba(251,113,133,.28); background: rgba(251,113,133,.07); }
.compare-box.good { border-color: rgba(52,211,153,.26); background: rgba(52,211,153,.07); }
.compare-box h3 { margin-top: 0; font-size: 24px; }
.compare-box ul {
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}
.compare-box li {
  color: #c7d4ee;
  line-height: 1.35;
}
.compare-box li::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-right: 8px;
  background: currentColor;
}
.final-cta {
  border: 1px solid rgba(125,153,199,.22);
  border-radius: 26px;
  background:
    radial-gradient(circle at 70% 20%, rgba(34,211,238,.16), transparent 34%),
    linear-gradient(135deg, rgba(47,124,255,.18), rgba(124,58,237,.10));
  padding: 34px;
}
.final-cta small {
  display: block;
  margin-top: 14px;
  color: #91a2c1;
}
.cta-visual {
  display: grid;
  place-items: center;
  gap: 16px;
  min-height: 240px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 22px;
  background: rgba(255,255,255,.035);
}
.cta-visual img {
  width: 104px;
  filter: drop-shadow(0 0 28px rgba(47,124,255,.46));
}
.landing-footer {
  max-width: 1220px;
  margin: 20px auto 0;
  border-top: 1px solid rgba(125,153,199,.18);
  padding: 22px 0 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  color: var(--muted);
}
.section-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 14px;
  min-width: 0;
}
.panel p,
.card p,
.panel li,
.card li,
.panel small,
.card small,
.muted,
.section-title,
.page-head p,
.report-story,
.ai-report,
.strategy-block,
.notification-item,
.timeline-list {
  overflow-wrap: break-word;
  word-break: normal;
}
.intelligence-panel,
.decision-panel {
  background:
    linear-gradient(135deg, rgba(47,124,255,.12), rgba(139,92,246,.07)),
    var(--panel);
}
.insight-list,
.decision-grid,
.onboarding-items {
  display: grid;
  gap: 12px;
}
.insight-list {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.insight-item,
.decision-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
  padding: 14px;
  min-width: 0;
  overflow: hidden;
}
.insight-item p,
.decision-card p { margin: 8px 0 0; color: var(--muted); line-height: 1.45; overflow-wrap: break-word; }
.insight-item.ok { border-color: rgba(22, 163, 74, .35); }
.insight-item.warn,
.decision-card.média { border-color: rgba(245, 158, 11, .42); }
.insight-item.bad,
.decision-card.alta { border-color: rgba(229, 72, 77, .46); }
.decision-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.decision-card .segments.small {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}
.decision-card .segments.small .seg-btn {
  min-height: 32px;
  padding: 0 9px;
  font-size: 12px;
}
.quick-win-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  padding: 20px;
  transition: all 0.2s ease;
}
.quick-win-card:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(0,196,159,0.3);
}
.retention-page {
  display: grid;
  gap: 12px;
}
.retention-page .page-head {
  margin-bottom: 0;
}
.retention-filter-bar {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(12, 20, 36, .96), rgba(8, 14, 26, .94));
  display: grid;
  grid-template-columns: minmax(160px, 1.1fr) minmax(150px, .9fr) auto auto minmax(190px, auto) minmax(230px, auto);
  gap: 12px;
  align-items: end;
  padding: 12px 14px;
}
.retention-filter-bar label {
  display: grid;
  gap: 5px;
  min-width: 0;
}
.retention-filter-bar label span,
.retention-credit-inline span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}
.retention-filter-bar select,
.retention-filter-bar input {
  height: 38px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: rgba(9, 15, 28, .9);
  color: var(--text);
  padding: 0 12px;
}
.retention-comparison {
  align-self: center;
  color: var(--muted);
  font-size: 12px;
  white-space: nowrap;
}
.retention-credit-inline {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-height: 38px;
  white-space: nowrap;
}
.retention-credit-inline strong {
  color: var(--text);
}
.retention-top-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(300px, 1fr) minmax(300px, .92fr);
  gap: 12px;
}
.retention-action-grid,
.retention-bottom-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(300px, .95fr);
  gap: 12px;
}
.retention-bottom-left {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.retention-context-card,
.retention-alerts-card,
.retention-funnel-card,
.retention-actions-panel,
.retention-register-card,
.retention-timeline-card,
.retention-impact-card,
.retention-ai-panel {
  border-radius: 8px;
  padding: 14px;
  overflow: hidden;
}
.retention-context-body {
  display: grid;
  grid-template-columns: 92px 112px minmax(0, 1fr);
  align-items: center;
  gap: 18px;
  margin: 14px 0;
}
.retention-score-ring {
  width: 88px;
  height: 88px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  position: relative;
  background: conic-gradient(#36d6c9 calc(var(--score) * .35), #4b7cff calc(var(--score) * .7), #8b5cf6 var(--score), rgba(31, 43, 68, .9) 0);
}
.retention-score-ring::after {
  content: "";
  position: absolute;
  inset: 9px;
  border-radius: inherit;
  background: #0b1323;
}
.retention-score-ring strong,
.retention-score-ring span {
  position: relative;
  z-index: 1;
}
.retention-score-ring strong {
  font-size: 30px;
  line-height: 1;
}
.retention-score-ring span {
  color: var(--muted);
  font-size: 11px;
  margin-top: 32px;
  position: absolute;
}
.retention-context-status {
  display: grid;
  gap: 6px;
}
.retention-context-status strong,
.retention-context-status .good {
  color: #22c55e;
}
.retention-context-status .bad {
  color: #ff5b6b;
}
.retention-context-status b {
  font-size: 18px;
}
.retention-context-body p {
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
  border-left: 1px solid var(--line);
  padding-left: 18px;
}
.retention-alert-list,
.retention-impact-list,
.retention-timeline-list {
  display: grid;
  gap: 8px;
}
.retention-alert-item {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto auto auto auto;
  gap: 10px;
  align-items: center;
  min-height: 54px;
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 8px;
  padding: 8px;
  background: rgba(15, 23, 42, .55);
}
.retention-alert-item > span {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: grid;
  place-items: center;
}
.retention-alert-item.critical > span { color: #ff5b6b; background: rgba(239, 68, 68, .16); }
.retention-alert-item.warning > span { color: #f59e0b; background: rgba(245, 158, 11, .16); }
.retention-alert-item.ok > span { color: #22c55e; background: rgba(34, 197, 94, .16); }
.retention-alert-item strong,
.retention-alert-item small {
  display: block;
}
.retention-alert-item small {
  color: var(--muted);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.retention-alert-item em,
.retention-card-top span {
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}
.retention-alert-item.critical em,
.retention-action-card.high .retention-card-top span { color: #ff7b85; background: rgba(239, 68, 68, .18); }
.retention-alert-item.warning em,
.retention-action-card.medium .retention-card-top span { color: #fbbf24; background: rgba(245, 158, 11, .16); }
.retention-alert-item.ok em,
.retention-action-card.low .retention-card-top span { color: #4ade80; background: rgba(34, 197, 94, .16); }
.retention-funnel-list {
  display: grid;
  gap: 8px;
}
.retention-funnel-list > div {
  display: grid;
  grid-template-columns: 86px minmax(72px, auto) 76px minmax(120px, auto) minmax(90px, 1fr);
  gap: 10px;
  align-items: center;
  color: var(--muted);
}
.retention-funnel-list strong {
  color: var(--text);
  text-align: right;
}
.retention-funnel-list em {
  font-style: normal;
  font-size: 12px;
  text-align: right;
}
.retention-funnel-list em.good,
.retention-impact-list b.good { color: #22c55e; }
.retention-funnel-list em.bad,
.retention-impact-list b.bad { color: #ff5b6b; }
.retention-funnel-list i {
  height: 14px;
  border-radius: 999px;
  background: rgba(30, 41, 59, .85);
  overflow: hidden;
}
.retention-funnel-list i b {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #4f8cff, #7c3aed);
}
.retention-funnel-list .is-empty {
  opacity: .68;
}
.retention-connect-link {
  color: #60a5fa;
  font-size: 11px;
  font-weight: 800;
}
.retention-action-cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.retention-action-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(16, 27, 48, .92), rgba(10, 17, 31, .9));
  min-height: 190px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.retention-action-card h4 {
  margin: 0;
  font-size: 15px;
  line-height: 1.25;
}
.retention-action-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
  flex: 1;
}
.retention-action-card small {
  color: #8ab8ff;
}
.retention-card-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.retention-action-form {
  display: grid;
  gap: 10px;
}
.retention-action-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.retention-action-form select,
.retention-action-form input,
.retention-action-form textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(9, 15, 28, .92);
  color: var(--text);
  padding: 10px 12px;
}
.retention-action-form textarea {
  min-height: 86px;
  resize: vertical;
}
.retention-form-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.retention-timeline-list article {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 8px;
  padding: 10px;
  border-left: 3px solid rgba(148, 163, 184, .42);
}
.retention-timeline-list article.positive { border-left-color: #00C49F; }
.retention-timeline-list article.negative { border-left-color: #FF4444; }
.retention-timeline-metrics {
  display: grid;
  gap: 4px;
  margin-top: 8px;
  color: var(--muted);
  font-size: 11px;
}
.retention-timeline-metrics b {
  color: var(--text);
}
.retention-timeline-list time {
  display: grid;
  color: var(--muted);
  font-size: 11px;
}
.retention-timeline-list strong,
.retention-timeline-list small {
  display: block;
}
.retention-timeline-list small {
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.retention-timeline-list em {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 6px 8px;
  color: var(--text);
  font-style: normal;
  font-size: 11px;
}
.retention-impact-list article {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 42px 66px;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 8px;
  padding: 10px;
}
.retention-impact-list article > span {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(59, 130, 246, .12);
  color: #8ab8ff;
}
.retention-impact-list i {
  display: block;
  width: 80px;
  height: 20px;
  border-radius: 999px;
  background: linear-gradient(135deg, transparent 12%, currentColor 13% 18%, transparent 19% 38%, currentColor 39% 44%, transparent 45% 62%, currentColor 63% 68%, transparent 69%);
  opacity: .85;
}
.retention-impact-list i.good { color: #22c55e; }
.retention-impact-list i.bad { color: #ff5b6b; }
.retention-impact-list strong,
.retention-impact-list small {
  display: block;
}
.retention-impact-list strong {
  font-size: 12px;
}
.retention-impact-list small {
  color: var(--muted);
}
.retention-ai-panel {
  display: grid;
  gap: 12px;
  align-content: start;
}
.retention-ai-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 112px;
  gap: 12px;
  align-items: center;
}
.retention-ai-body ul {
  list-style: none;
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
}
.retention-ai-body li {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
}
.retention-ai-body li svg {
  color: #9d7cff;
}
.retention-ai-chip {
  width: 104px;
  height: 104px;
  border-radius: 26px;
  display: grid;
  place-items: center;
  color: white;
  font-size: 30px;
  font-weight: 900;
  background:
    radial-gradient(circle at 24% 20%, rgba(255,255,255,.18), transparent 28%),
    linear-gradient(135deg, #3b82f6, #7c3aed 62%, #a855f7);
  box-shadow: 0 0 42px rgba(124, 58, 237, .42);
}
.retention-ai-inline-notice {
  margin: 0;
  padding: 10px;
}
.retention-ai-inline-notice .ai-credit-notice-copy {
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
@media (max-width: 1180px) {
  .retention-filter-bar,
  .retention-top-grid,
  .retention-action-grid,
  .retention-bottom-grid {
    grid-template-columns: 1fr 1fr;
  }
  .overview-comparison-grid,
  .overview-rankings,
  .retention-client-scores > div {
    grid-template-columns: 1fr 1fr;
  }
  .retention-action-cards,
  .retention-bottom-left {
    grid-template-columns: 1fr 1fr;
  }
  .retention-register-card,
  .retention-ai-panel {
    grid-column: 1 / -1;
  }
}
@media (max-width: 760px) {
  .retention-filter-bar,
  .retention-top-grid,
  .retention-action-grid,
  .retention-bottom-grid,
  .retention-action-cards,
  .retention-bottom-left,
  .retention-context-body,
  .retention-form-split,
  .retention-ai-body {
    grid-template-columns: 1fr;
  }
  .retention-filter-bar {
    align-items: stretch;
  }
  .retention-credit-inline {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .retention-context-body p {
    border-left: 0;
    padding-left: 0;
  }
  .retention-alert-item,
  .retention-timeline-list article,
  .retention-impact-list article {
    grid-template-columns: 1fr;
    align-items: start;
  }
  .overview-comparison-grid,
  .overview-rankings,
  .retention-client-scores > div {
    grid-template-columns: 1fr;
  }
  .retention-funnel-list > div {
    grid-template-columns: 1fr;
  }
  .retention-funnel-list strong,
  .retention-funnel-list em {
    text-align: left;
  }
  .retention-ai-chip {
    width: 88px;
    height: 88px;
  }
}
.priority {
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  background: var(--panel-2);
  color: var(--muted);
}
.priority.alta { color: var(--danger); }
.priority.média { color: var(--warn); }
.priority.baixa { color: var(--ok); }
.onboarding-panel {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.onboarding-items {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.onboarding-items span,
.milestone-list span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 10px;
  color: var(--muted);
  background: var(--panel-2);
  font-weight: 800;
  font-size: 12px;
}
.onboarding-items span.done { color: var(--ok); }
.milestone-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}
.timeline-list {
  display: grid;
  gap: 12px;
  max-height: 420px;
  overflow: auto;
}
.timeline-list > div {
  border-left: 3px solid var(--brand);
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
  border-radius: var(--radius);
  padding: 12px 14px;
}
.timeline-list p { margin: 6px 0 0; color: var(--muted); line-height: 1.45; }
.timeline-list span,
.timeline-list small { display: block; color: var(--muted); margin-top: 4px; }
.presentation-shell {
  min-height: 100vh;
  background:
    radial-gradient(circle at 12% 10%, rgba(47,124,255,.26), transparent 28%),
    linear-gradient(135deg, #060913, #101a31 58%, #19091f);
  padding: 26px;
}
.presentation-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  max-width: 1280px;
  margin: 0 auto 22px;
}
.presentation-content {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 18px;
}
.presentation-content h1 { font-size: clamp(34px, 5vw, 64px); margin: 0; }
.blocked-access .auth-hero {
  background:
    linear-gradient(135deg, rgba(127, 29, 29, .86), rgba(16, 24, 39, .92)),
    radial-gradient(circle at 20% 18%, rgba(239, 68, 68, .35), transparent 32%);
}
.legal-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}
.legal-panel {
  width: min(980px, 100%);
}
.terms-box {
  max-height: 48vh;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(7, 11, 22, .36);
  padding: 18px;
  margin: 18px 0;
}
.terms-box h3 { margin: 18px 0 8px; }
.terms-box h3:first-child { margin-top: 0; }
.terms-box p { color: var(--muted); line-height: 1.55; }
.legal-accept {
  display: grid;
  gap: 14px;
}
.check-line {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: var(--text);
  font-weight: 800;
}
.terms-list {
  color: var(--muted);
  line-height: 1.55;
  padding-left: 22px;
}
.channel-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}
.channel-filter .segments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tab-btn, .seg-btn, .icon-btn, .btn {
  box-sizing: border-box;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  border-radius: var(--radius);
  min-height: 40px;
  padding: 0 16px;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  white-space: nowrap;
  transition: border-color .18s ease, background .18s ease, transform .18s ease, box-shadow .18s ease;
}
.tab-btn.active, .seg-btn.active { background: var(--ink); color: var(--panel); border-color: var(--ink); }
.seg-btn { font-weight: 800; }
.icon-btn {
  width: 40px;
  min-width: 40px;
  padding: 0;
  flex: 0 0 40px;
}
.icon-btn svg, .btn svg {
  width: 17px;
  height: 17px;
  stroke: currentColor;
  stroke-width: 2;
  flex: 0 0 auto;
}
.retention-ai-empty-body {
  display: grid;
  justify-items: center;
  gap: 12px;
  text-align: center;
  padding: 18px;
}
.retention-client-scores {
  display: grid;
  gap: 12px;
}
.retention-client-scores > div {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.retention-client-scores article {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 8px;
  padding: 10px;
}
.retention-client-scores article > span { color: #FF4444; }
.retention-client-scores article.warn > span { color: #FFBB28; }
.retention-client-scores article.good > span { color: #00C49F; }
.retention-client-scores small {
  grid-column: 2 / 4;
  color: var(--muted);
}
.retention-client-scores svg {
  grid-column: 1 / 4;
}
.field { display: grid; gap: 7px; margin-bottom: 14px; }
.field label { font-size: 13px; color: var(--muted); font-weight: 700; }
.field input, .field select, .field textarea {
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  border-radius: var(--radius);
  min-height: 40px;
  padding: 10px 12px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.02);
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: 2px solid color-mix(in srgb, var(--brand) 50%, transparent);
  outline-offset: 1px;
  border-color: color-mix(in srgb, var(--brand) 60%, var(--line));
}
.field textarea { min-height: 92px; resize: vertical; }
.secure-secret-field textarea[disabled] {
  color: color-mix(in srgb, var(--text) 72%, var(--muted));
  border-color: color-mix(in srgb, var(--ok) 38%, var(--line));
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--ok) 9%, transparent), transparent),
    color-mix(in srgb, var(--panel-2) 76%, var(--panel));
  cursor: default;
}
.secret-replace-box {
  border: 1px dashed color-mix(in srgb, var(--brand) 46%, var(--line));
  border-radius: 10px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--panel-2) 62%, transparent);
}
.secret-replace-box summary {
  cursor: pointer;
  font-weight: 900;
  color: var(--brand);
}
.secret-replace-box textarea {
  margin-top: 10px;
  width: 100%;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 800;
  white-space: normal;
  text-align: center;
  min-width: 0;
  line-height: 1.15;
}
.btn:hover, .seg-btn:hover, .icon-btn:hover { border-color: color-mix(in srgb, var(--brand) 55%, var(--line)); transform: translateY(-1px); box-shadow: 0 8px 18px rgba(0,0,0,.12); }
.btn.primary {
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  border-color: color-mix(in srgb, var(--brand) 70%, var(--brand-2));
  color: #fff;
  box-shadow: 0 10px 28px color-mix(in srgb, var(--brand) 32%, transparent);
}
.btn.good { background: var(--ok); border-color: var(--ok); color: #fff; }
.btn.warn { background: color-mix(in srgb, var(--warn) 18%, transparent); border-color: rgba(245, 158, 11, .42); color: var(--text); }
.btn.danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.btn.ghost { background: transparent; }
.btn.glow {
  box-shadow: 0 0 0 1px rgba(255,255,255,.04), 0 14px 34px color-mix(in srgb, var(--brand) 34%, transparent);
}
.w-full { width: 100%; }
.muted { color: var(--muted); }
.small { font-size: 12px; }

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 280px 1fr;
  position: relative;
}
.app-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(139, 92, 246, .07), transparent 28%),
    radial-gradient(circle at 88% 78%, rgba(229, 72, 77, .10), transparent 26%);
}
.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  background: var(--panel);
  border-right: 1px solid var(--line);
  padding: 20px 14px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: inset -1px 0 0 rgba(255,255,255,.03);
}
.sidebar-backdrop {
  position: fixed;
  inset: 0;
  z-index: 29;
  background: rgba(5, 9, 19, .52);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
}
.sidebar-backdrop.open {
  opacity: 1;
  pointer-events: auto;
}
.mobile-top-brand { display: none; }
.topbar-primary { flex-wrap: nowrap; }
.sidebar-version {
  margin-top: -10px;
  padding: 0 4px 2px;
  opacity: .85;
  font-weight: 700;
}
.version-preview {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  min-width: 84px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 68%, transparent);
}
.sidebar,
.topbar,
.panel,
.card,
.modal,
.notification-popover {
  backdrop-filter: blur(18px);
}
.nav {
  display: grid;
  gap: 14px;
  overflow: auto;
  overscroll-behavior: contain;
  scroll-behavior: smooth;
  flex: 1;
  min-height: 0;
  padding: 2px 4px 10px 0;
  scrollbar-gutter: stable;
}
.nav-section {
  display: grid;
  gap: 6px;
  padding: 4px 0 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 58%, transparent);
}
.nav-section:last-child { border-bottom: 0; }
.nav-title {
  padding: 0 12px 4px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .11em;
}
.nav-section.has-active .nav-title {
  color: color-mix(in srgb, var(--brand) 74%, var(--brand-2));
}
.nav button,
.nav a {
  border: 0;
  border-radius: var(--radius);
  background: transparent;
  color: var(--muted);
  min-height: 44px;
  padding: 0 12px;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 780;
  width: 100%;
  text-decoration: none;
  position: relative;
  outline: none;
}
.nav button.active,
.nav button:hover,
.nav a.active,
.nav a:hover,
.nav a:focus-visible {
  background: color-mix(in srgb, var(--panel-2) 78%, transparent);
  color: var(--text);
}
.nav a.active {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--brand) 18%, transparent);
}
.nav a.active::before,
.nav button.active::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 8px;
  bottom: 8px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--brand), var(--brand-2));
}
.nav-icon {
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  display: inline-grid;
  place-items: center;
  color: color-mix(in srgb, var(--brand) 72%, var(--brand-2));
  filter: drop-shadow(0 0 10px rgba(47, 124, 255, .22));
}
.nav-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}
.nav-label {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sidebar-alert-badge {
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 10px;
  background: #ff4444;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  margin-left: auto;
  box-shadow: 0 0 0 1px rgba(255,255,255,.14), 0 0 14px rgba(255,68,68,.34);
}
.nav a.active .nav-icon,
.nav button.active .nav-icon {
  color: var(--brand-3);
}
.nav a:hover .nav-icon,
.nav button:hover .nav-icon {
  color: color-mix(in srgb, var(--brand-3) 70%, var(--brand-2));
}
.btn:disabled {
  opacity: .55;
  cursor: not-allowed;
  filter: saturate(.65);
}
.main,
.admin-shell > main,
.content,
.panel,
.card,
.field,
.export-shell,
.export-grid,
.report-preview-grid,
.users-layout {
  min-width: 0;
}
.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  height: 70px;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter: blur(14px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 22px;
  gap: 12px;
}
.content {
  width: 100%;
  max-width: 100%;
  padding: 22px;
  display: grid;
  gap: 18px;
  overflow-x: hidden;
}
.page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.page-head h1 { margin: 0 0 5px; font-size: 28px; letter-spacing: 0; }
.page-head p { margin: 0; }
.actions { display: flex; flex-wrap: wrap; gap: 10px; min-width: 0; align-items: center; }
.page-head > .actions {
  justify-content: flex-end;
}
.topbar select,
#global-client {
  appearance: none;
  border: 1px solid color-mix(in srgb, var(--brand) 42%, var(--line));
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(47,124,255,.14), rgba(139,92,246,.07)),
    var(--panel-2);
  color: var(--text);
  min-height: 46px;
  max-width: min(320px, 42vw);
  padding: 0 42px 0 14px;
  font-weight: 850;
  box-shadow: 0 0 0 3px rgba(47,124,255,.10);
}
.topbar select:focus,
#global-client:focus {
  outline: 2px solid color-mix(in srgb, var(--brand) 65%, transparent);
  outline-offset: 2px;
}
.topbar select option,
#global-client option {
  background: var(--oprix-bg-soft);
  color: var(--text);
}
.notification-wrap { position: relative; }
.notification-btn { position: relative; min-width: 44px; }
.notification-count {
  position: absolute;
  top: -7px;
  right: -7px;
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  padding: 0 5px;
  font-size: 10px;
  font-weight: 900;
  color: #fff;
  border: 2px solid var(--bg);
}
.notification-count.ok { background: var(--ok); }
.notification-count.warn { background: var(--warn); }
.notification-count.bad { background: var(--danger); }
.notification-popover {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 30;
  width: min(380px, calc(100vw - 28px));
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 12px;
  max-height: min(70vh, 520px);
  overflow: hidden;
}
.notification-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.notification-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 8px;
}
.notification-list {
  display: grid;
  gap: 10px;
  max-height: 400px;
  overflow: auto;
  padding-top: 10px;
}
.notification-item {
  display: grid;
  grid-template-columns: 10px 1fr;
  gap: 10px;
  align-items: start;
}
.notification-item p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}
.notification-item.read {
  opacity: .68;
}
.link-btn {
  border: 0;
  background: transparent;
  color: var(--brand);
  padding: 6px 0 0;
  font-weight: 900;
  text-align: left;
}
.user-chip,
.avatar-card {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.user-chip {
  color: var(--muted);
  font-weight: 850;
}
.avatar-default {
  width: 34px;
  height: 34px;
  min-width: 34px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--brand) 48%, var(--line));
  background:
    radial-gradient(circle at 35% 22%, rgba(139,92,246,.30), transparent 28%),
    linear-gradient(135deg, rgba(47,124,255,.30), rgba(31,42,68,.76));
  color: var(--text);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .02em;
}
.avatar-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  padding: 12px;
}
.floating-whatsapp-wrap {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 40;
  width: 58px;
  height: 58px;
  transition: opacity .18s ease, transform .18s ease;
}
.floating-whatsapp-wrap.is-hiding {
  opacity: 0;
  transform: scale(.92);
  pointer-events: none;
}
.floating-whatsapp-close {
  position: absolute;
  top: -2px;
  right: -2px;
  z-index: 2;
  width: 14px;
  height: 14px;
  border: 0;
  border-radius: 999px;
  background: rgba(10, 14, 24, .18);
  backdrop-filter: blur(1.5px);
  color: rgba(255, 255, 255, .62);
  font-size: 12px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color .16s ease, background .16s ease;
}
.floating-whatsapp-close:hover,
.floating-whatsapp-close:focus-visible {
  color: rgba(255, 255, 255, .74);
  background: rgba(10, 14, 24, .28);
  outline: none;
}
.floating-whatsapp {
  position: relative;
  right: 0;
  bottom: 0;
  z-index: 1;
  width: 58px;
  height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, .24);
  border-radius: 999px;
  overflow: hidden;
  background: linear-gradient(135deg, #0B1220, #1C2B4A, #3B82F6, #7C3AED);
  color: #fff;
  box-shadow: 0 18px 44px rgba(59, 130, 246, .34), 0 0 24px rgba(124, 58, 237, .36);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.floating-whatsapp:hover {
  transform: scale(1.05);
  box-shadow: 0 22px 56px rgba(59, 130, 246, .44), 0 0 30px rgba(124, 58, 237, .48);
  filter: saturate(1.08);
}
.floating-whatsapp:active {
  transform: scale(.97);
}
.floating-whatsapp svg {
  width: 30px;
  height: 30px;
  fill: currentColor;
  flex: 0 0 auto;
}
.floating-whatsapp.static {
  position: static;
  width: max-content;
  height: auto;
  border-radius: 999px;
  padding: 0 16px;
  background: linear-gradient(135deg, #0B1220, #1C2B4A, #3B82F6, #7C3AED);
  box-shadow: none;
}
.floating-whatsapp.static svg {
  width: 18px;
  height: 18px;
}
.support-preview {
  display: grid;
  gap: 10px;
  align-content: start;
}
.integration-docs {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 78%, transparent);
  padding: 12px;
}
.integration-docs strong {
  display: block;
}
.docs-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.docs-links a {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--text);
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
}
.help-grid .card {
  display: grid;
  align-content: start;
  gap: 8px;
}
.grid { display: grid; gap: 16px; min-width: 0; }
.grid.kpis { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.panel, .card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.panel,
.card {
  box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.05);
}
.card.kpi {
  background:
    linear-gradient(135deg, rgba(18, 28, 48, .86), rgba(20, 31, 52, .62)),
    radial-gradient(circle at 100% 0, rgba(139, 92, 246, .12), transparent 32%);
}
.panel { padding: 16px; min-width: 0; overflow: hidden; }
.card { padding: 14px; min-width: 0; overflow: hidden; }
.platform-card {
  display: grid;
  gap: 12px;
  align-content: start;
  min-height: 230px;
}
.platform-card h3 { margin: 0; }
.checklist {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.55;
}
.code-box {
  width: 100%;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  color: var(--text);
  padding: 12px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
  line-height: 1.45;
  white-space: pre-wrap;
}
.integration-note {
  border-left: 4px solid var(--brand);
  background: var(--panel-2);
  border-radius: var(--radius);
  padding: 12px 14px;
  color: var(--muted);
  line-height: 1.42;
}
.breadcrumb {
  font-size: 13px;
  color: #8892a4;
  margin-bottom: 20px;
}
.breadcrumb button {
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  padding: 0;
}
.breadcrumb button:hover {
  color: var(--text);
}
.breadcrumb-active {
  color: #ffffff;
  font-weight: 600;
}
.breadcrumb-separator {
  margin: 0 8px;
  color: #4a5568;
}
.kpi .label { color: var(--muted); font-size: 13px; font-weight: 800; }
.metric-label-text {
  display: inline-flex;
  align-items: center;
  justify-content: inherit;
  gap: 5px;
}
.metric-tooltip-icon {
  display: inline-grid;
  place-items: center;
  width: 14px;
  height: 14px;
  padding: 0;
  border: 0;
  background: transparent;
  color: #8892a4;
  font: inherit;
  font-size: 11px;
  line-height: 1;
  cursor: help;
}
.metric-tooltip-icon:hover,
.metric-tooltip-icon:focus-visible {
  color: var(--text);
  outline: none;
}
.metric-tooltip {
  position: absolute;
  background: #1a2235;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 12px;
  line-height: 1.6;
  max-width: 280px;
  width: max-content;
  z-index: 9999;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  pointer-events: none;
}
.metric-tooltip[hidden] {
  display: none;
}
.metric-tooltip strong,
.metric-tooltip span,
.metric-tooltip em,
.metric-tooltip i {
  display: block;
}
.metric-tooltip strong {
  color: #fff;
  font-weight: 800;
}
.metric-tooltip span {
  color: #8892a4;
}
.metric-tooltip em {
  color: #8892a4;
  font-style: normal;
}
.metric-tooltip em.meta { color: #60a5fa; }
.metric-tooltip em.ga4 { color: #f59e0b; }
.metric-tooltip em.wbuy { color: #00C49F; }
.metric-tooltip i {
  color: #00C49F;
  font-style: italic;
}
.kpi .value {
  max-width: 100%;
  font-size: clamp(18px, 2.5vw, 28px);
  font-weight: 900;
  margin: 8px 0 6px;
  line-height: 1.04;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}
.kpi {
  min-width: 0;
  overflow: hidden;
  padding: 12px;
}
.card-value {
  font-weight: 700;
  line-height: 1.1;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
  font-variant-numeric: tabular-nums;
}
.kpi .delta,
.kpi .label {
  overflow-wrap: break-word;
}
.kpi .value { text-shadow: 0 0 22px rgba(47, 124, 255, .18); }
.delta { font-size: 12px; font-weight: 800; color: var(--ok); }
.delta.bad { color: var(--danger); }
.section-title { margin: 0 0 14px; font-size: 16px; }
.section-heading { margin: 6px 0 -4px; font-size: 18px; }
.filters { display: grid; grid-template-columns: repeat(5, minmax(150px, 1fr)); gap: 14px; align-items: end; }
.filters .field { margin: 0; }
.filters .field select,
.filters .field input,
.filters .btn { width: 100%; min-height: 54px; }
.filters .btn { align-self: end; display: inline-flex; justify-content: center; }
.table-wrap {
  overflow-x: auto;
  overflow-y: hidden;
  max-width: 100%;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  -webkit-overflow-scrolling: touch;
}
table { width: 100%; border-collapse: collapse; min-width: 760px; font-size: 13px; }
th, td { text-align: left; padding: 12px 13px; border-bottom: 1px solid var(--line); white-space: nowrap; }
th { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; }
tr:last-child td { border-bottom: 0; }
tbody tr:hover { background: color-mix(in srgb, var(--panel-2) 58%, transparent); }
.diag-cell {
  max-width: 360px;
  white-space: normal;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}
.status {
  display: inline-flex; align-items: center; gap: 7px;
  border-radius: 999px; padding: 4px 9px; font-size: 12px; font-weight: 800;
  background: var(--panel-2);
}
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--muted); }
.dot.ok { background: var(--ok); }
.dot.warn { background: var(--warn); }
.dot.bad { background: var(--danger); }
.status.smart.ok { color: var(--ok); }
.status.smart.warn { color: var(--warn); }
.status.smart.bad { color: var(--danger); }
.chart { width: 100%; height: 320px; display: block; }
.mini-chart { width: 100%; height: 190px; }
:root {
  --chart-bg: transparent;
  --chart-grid: rgba(255,255,255,0.04);
  --chart-axis-text: #8892a4;
  --chart-line-width: 2px;
  --chart-tooltip-bg: #1e2a3a;
  --chart-tooltip-border: rgba(255,255,255,0.08);
  --chart-animation: 400ms ease-out;
  --chart-border-radius: 12px;
}
.bi-chart-panel {
  display: grid;
  gap: 14px;
}
.bi-roas-area-chart,
.bi-weekly-compare-chart {
  width: 100%;
  min-height: 260px;
  border-radius: var(--chart-border-radius);
  background: var(--chart-bg);
  animation: chartReveal var(--chart-animation);
}
@keyframes chartReveal {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.bi-funnel-panel {
  display: grid;
  gap: 16px;
}
.bi-horizontal-funnel {
  display: grid;
  gap: 10px;
}
.bi-horizontal-funnel article {
  display: grid;
  grid-template-columns: minmax(150px, 220px) minmax(0, 1fr) 64px;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255,255,255,.03);
}
.bi-horizontal-funnel article.leak {
  background: rgba(255,68,68,0.3);
  border-color: rgba(255,68,68,.35);
}
.bi-funnel-label {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 2px 8px;
  align-items: center;
}
.bi-funnel-label span {
  grid-row: span 2;
  color: #0088FE;
}
.bi-funnel-label svg {
  width: 22px;
  height: 22px;
}
.bi-funnel-label small {
  color: var(--muted);
  font-size: .78rem;
}
.bi-funnel-label strong {
  color: var(--text);
  font-size: 1rem;
}
.bi-funnel-bar {
  height: 18px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.06);
}
.bi-funnel-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0088FE, #00C49F);
}
.bi-horizontal-funnel b {
  color: #00C49F;
  font-size: .86rem;
  text-align: right;
}
.bi-horizontal-funnel b.neutral {
  color: var(--muted);
}
.decision-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 14px;
}
.decision-brief {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, .6fr);
  gap: 18px;
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(47,124,255,.16), rgba(139,92,246,.09)),
    color-mix(in srgb, var(--panel) 92%, transparent);
}
.decision-brief h2 {
  margin: 12px 0 8px;
  font-size: clamp(24px, 3vw, 38px);
  letter-spacing: 0;
}
.next-action-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  background: rgba(255,255,255,.04);
  display: grid;
  align-content: center;
  gap: 8px;
}
.next-action-card small {
  color: var(--brand-2);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.next-action-card strong { font-size: 18px; }
.next-action-card p { margin: 0; color: var(--muted); line-height: 1.45; }
.overview-smart-card {
  display: grid;
  gap: 14px;
}
.mini-badge {
  display: inline-grid;
  place-items: center;
  min-width: 30px;
  height: 24px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--brand) 24%, transparent);
  color: #93c5fd;
  font-size: 12px;
  margin-left: 6px;
}
.smart-summary-list {
  display: grid;
  gap: 14px;
}
.smart-summary-item {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 12px;
  align-items: center;
}
.smart-summary-item span {
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: var(--brand);
  background: rgba(47,124,255,.09);
}
.smart-summary-item.ok span,
.smart-summary-item.action span { color: var(--ok); background: rgba(22,163,74,.08); }
.smart-summary-item.warn span { color: var(--warn); background: rgba(245,158,11,.08); }
.smart-summary-item.bad span { color: var(--danger); background: rgba(229,72,77,.08); }
.smart-summary-item p {
  margin: 0;
  color: var(--text);
  line-height: 1.45;
  font-weight: 750;
}
.overview-alerts-panel {
  display: grid;
  gap: 12px;
}
.overview-alerts-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.overview-alert-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 68%, transparent);
  padding: 14px;
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 12px;
  align-items: center;
  min-width: 0;
}
.overview-alert-card .alert-icon {
  width: 46px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-weight: 900;
  border: 1px solid currentColor;
}
.overview-alert-card strong { display: block; margin-bottom: 5px; color: var(--text); }
.overview-alert-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.35;
  font-size: 13px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.overview-alert-card > span {
  border-radius: 999px;
  padding: 6px 9px;
  background: var(--panel);
  font-size: 11px;
  font-weight: 900;
}
.overview-alert-card.high { color: #ef4444; }
.overview-alert-card.mid { color: #f59e0b; }
.overview-alert-card.low { color: #eab308; }
.chart-point { transition: r .16s ease, filter .16s ease; cursor: crosshair; }
.chart-point:hover { r: 9; filter: drop-shadow(0 0 10px currentColor); }
.period-segments {
  justify-content: flex-end;
}
.app-footer {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  padding: 18px 26px 24px;
  font-size: 12px;
  line-height: 1.45;
}
.app-footer strong {
  color: var(--text);
}
.decision-kpi {
  min-height: 124px;
  background:
    linear-gradient(135deg, rgba(47,124,255,.12), rgba(139,92,246,.07)),
    var(--panel);
}
.kpi-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.kpi-top span {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: var(--panel-2);
  color: var(--brand);
}
.kpi-top span svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.overview-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(320px, .65fr);
  gap: 16px;
  align-items: stretch;
}
.hero-chart-panel,
.decision-side,
.efficiency-panel,
.next-sync-panel {
  min-width: 0;
}
.chart-toggles {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.decision-chart {
  min-height: 360px;
}
.decision-side {
  display: grid;
  gap: 16px;
}
.efficiency-panel {
  display: grid;
  gap: 18px;
}
.efficiency-row {
  border: 0;
  background: transparent;
  color: var(--text);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 7px 12px;
  text-align: left;
  padding: 8px 0;
}
.efficiency-row span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.efficiency-row strong {
  font-size: 18px;
}
.efficiency-row small {
  grid-column: 1 / -1;
  color: var(--muted);
}
.efficiency-row i {
  grid-column: 1 / -1;
  display: block;
  height: 8px;
  border-radius: 999px;
  background: var(--panel-2);
  overflow: hidden;
  border: 1px solid var(--line);
}
.efficiency-row b {
  display: block;
  height: 100%;
  border-radius: inherit;
}
.efficiency-row.blue b { background: #2f7dff; }
.efficiency-row.pink b { background: #e12b86; }
.efficiency-row.green b { background: #22d3ee; }
.next-sync-panel {
  display: grid;
  gap: 10px;
  align-content: start;
}
.sync-countdown {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  color: #60a5fa;
  background: var(--panel-2);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 20px;
}
.overview-exec-page {
  display: grid;
  gap: 18px;
}
.overview-exec-page .page-head {
  align-items: start;
  row-gap: 12px;
}
.overview-exec-page .page-head h1 {
  margin-bottom: 10px;
}
.overview-exec-page .page-head p {
  color: var(--text-muted, var(--muted));
  font-size: .875rem;
  line-height: 1.5;
}
.view-toggle {
  display: flex;
  gap: 4px;
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  padding: 4px;
  margin-bottom: 20px;
  width: fit-content;
  max-width: 100%;
  overflow-x: auto;
}
.view-toggle-btn {
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s ease;
  color: #8892a4;
  background: transparent;
  border: none;
  white-space: nowrap;
}
.view-toggle-btn.active {
  background: rgba(255,255,255,0.08);
  color: #ffffff;
  font-weight: 600;
}
.view-toggle-btn:hover,
.view-toggle-btn:focus-visible {
  color: #ffffff;
  outline: none;
}
.app-shell:has(.overview-exec-page) .topbar-primary > strong {
  color: var(--text-muted, var(--muted));
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .03em;
  text-transform: uppercase;
  opacity: .84;
}
.overview-exec-page svg {
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.overview-top-grid {
  display: grid;
  grid-template-columns: minmax(320px, .66fr) minmax(0, 1fr);
  gap: 18px;
}
.overview-score-card,
.overview-main-alert,
.active-connections-bar,
.overview-exec-kpi,
.overview-funnel-panel,
.overview-performance-panel,
.overview-ai-panel,
.overview-channel-panel,
.overview-action-plan,
.overview-integrations-panel,
.overview-exec-page .next-sync-panel {
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(15, 27, 48, .92), rgba(8, 14, 27, .84)),
	    radial-gradient(circle at 90% 10%, rgba(59,130,246,.14), transparent 32%);
}
.active-connections-bar {
  display: flex;
  align-items: center;
  gap: 18px;
  min-height: 74px;
  padding: 14px 16px;
  border: 1px solid rgba(75, 111, 180, .36);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 18px 44px rgba(2,8,23,.18);
}
.active-connections-title {
  display: grid;
  gap: 6px;
  min-width: 156px;
}
.active-connections-title strong {
  color: #f8fbff;
  font-size: 13px;
  font-weight: 800;
}
.active-connections-title small {
  color: #8fa4c5;
  font-size: 11px;
}
.active-connection-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  min-width: 0;
}
.active-connections-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex: 1;
  min-width: 0;
}
.overview-period-filter {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-left: auto;
  min-width: max-content;
}
.overview-period-filter > span {
  color: #9fb0ca;
  font-size: 11px;
  font-weight: 800;
}
.overview-period-chips {
  justify-content: flex-end;
}
.overview-period-chip {
  min-width: max-content;
}
.connection-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 42px;
  padding: 0 14px;
  border: 1px solid rgba(90, 123, 190, .36);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(12, 22, 39, .92), rgba(16, 27, 49, .72));
  color: #dbe8ff;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.connection-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(96, 165, 250, .7);
  box-shadow: 0 0 0 1px rgba(59,130,246,.14), 0 12px 30px rgba(37, 99, 235, .18);
}
.connection-chip:active {
  transform: scale(.98);
}
.connection-chip.active {
  color: #fff;
  border-color: rgba(96, 165, 250, .8);
  background:
    linear-gradient(135deg, rgba(44, 93, 210, .38), rgba(124, 58, 237, .24)),
    linear-gradient(135deg, rgba(14, 27, 52, .96), rgba(11, 18, 32, .88));
  box-shadow: 0 0 0 1px rgba(59,130,246,.18), 0 0 26px rgba(59,130,246,.18);
}
.connection-chip-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  color: #3b82f6;
}
.connection-chip.all .connection-chip-icon {
  color: #c7d2fe;
}
.connection-chip-icon svg {
  width: 21px;
  height: 21px;
}
.connection-active-dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 12px rgba(34,197,94,.9);
}
.overview-score-card {
  position: relative;
  min-height: 214px;
  overflow: hidden;
}
.overview-score-card h3,
.overview-funnel-panel h3,
.overview-performance-panel h3,
.overview-ai-panel h3,
.overview-channel-panel h3,
.overview-action-plan h3,
.overview-integrations-panel h3 {
  display: flex;
  align-items: center;
  gap: 7px;
}
.overview-score-card h3 svg,
.overview-funnel-panel h3 svg,
.overview-performance-panel h3 svg,
.overview-ai-panel h3 svg,
.overview-channel-panel h3 svg,
.overview-action-plan h3 svg,
.overview-integrations-panel h3 svg {
  width: 15px;
  height: 15px;
  color: var(--muted);
}
.overview-score-wrap {
  display: flex;
  align-items: center;
  gap: 22px;
  margin-top: 18px;
}
.overview-score-donut {
  position: relative;
  isolation: isolate;
  width: 142px;
  height: 142px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  align-content: center;
  background:
    radial-gradient(circle, #101a30 0 53%, transparent 54%),
    conic-gradient(#38bdf8 0deg, #6366f1 calc(var(--score-angle) * .78), #7c3aed var(--score-angle), rgba(148,163,184,.16) var(--score-angle) 360deg);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06), 0 0 26px rgba(59,130,246,.12);
}
.overview-score-donut strong {
  position: relative;
  z-index: 1;
  display: block;
  color: #f8fbff;
  text-shadow: 0 0 20px rgba(59,130,246,.24);
  font-size: clamp(2.5rem, 4vw, 3.125rem);
  font-weight: 700;
  line-height: .92;
}
.overview-score-donut span {
  position: relative;
  z-index: 1;
  display: block;
  font-size: .85rem;
  line-height: 1.1;
}
.overview-score-donut span,
.overview-score-copy span,
.overview-score-copy small {
  color: var(--muted);
}
.overview-score-copy {
  display: grid;
  gap: 6px;
}
.overview-score-copy strong {
  font-size: 22px;
}
.overview-score-copy strong.excellent,
.overview-score-copy strong.good { color: #facc15; }
.overview-score-copy strong.warn { color: #f59e0b; }
.overview-score-copy strong.critical { color: #fb7185; }
.overview-score-copy b {
  color: #22c55e;
  font-size: 30px;
}
.overview-score-copy b.bad { color: #fb7185; }
.overview-mini-line {
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 170px;
  height: 58px;
  color: #38bdf8;
}
.overview-mini-line path {
  fill: none;
}
.overview-main-alert {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  align-items: center;
  min-height: 214px;
  overflow: hidden;
  border-color: rgba(244, 63, 94, .48);
  background:
    radial-gradient(circle at 88% 50%, rgba(244,63,94,.10), transparent 34%),
    linear-gradient(135deg, rgba(17, 21, 38, .97), rgba(10, 16, 31, .9));
  box-shadow: 0 0 28px rgba(244, 63, 94, .08);
}
.overview-main-alert span {
  color: #fb7185;
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .08em;
}
.overview-main-alert > div:first-child {
  position: relative;
  z-index: 2;
}
.overview-main-alert h2 {
  max-width: 520px;
  margin: 16px 0 12px;
  font-size: clamp(26px, 3vw, 34px);
  line-height: 1.16;
  color: #f8fbff;
}
.overview-main-alert p {
  margin: 0 0 18px;
  color: #cbd5e1;
}
.danger-outline {
  border-color: rgba(244,63,94,.55);
  color: #fb7185;
  background: rgba(244,63,94,.08);
}
.overview-alert-illustration {
  position: relative;
  z-index: 0;
  opacity: .78;
  width: 132px;
  height: 132px;
  justify-self: center;
  display: grid;
  place-items: center;
  border: 1px solid rgba(244,63,94,.54);
  border-radius: 999px;
  color: #fff;
  background: radial-gradient(circle at 48% 44%, rgba(244,63,94,.38), rgba(87,21,43,.72));
  box-shadow: 0 0 46px rgba(244,63,94,.22);
}
.overview-alert-illustration svg {
  width: 66px;
  height: 66px;
}
.overview-alert-illustration i {
  position: absolute;
  right: -10px;
  bottom: 18px;
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  background: #ff4d5f;
  font-style: normal;
  font-weight: 950;
}
.overview-exec-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.overview-exec-kpi {
  min-width: 0;
  min-height: 160px;
  display: grid;
  gap: 10px;
  padding: 18px;
  overflow: hidden;
  text-align: center;
}
.overview-exec-kpi .kpi-top {
  display: grid;
  justify-items: center;
  gap: 10px;
  align-items: start;
}
.overview-exec-kpi .kpi-top > div {
  display: grid;
  gap: 6px;
  justify-items: center;
  align-content: start;
}
.overview-exec-kpi .kpi-top > div small {
  display: block;
  margin: 0;
}
.overview-exec-kpi .kpi-top > div strong {
  margin-top: 0;
}
.overview-exec-kpi .kpi-top > span {
  width: 40px;
  height: 40px;
  border-radius: 8px;
}
.overview-exec-kpi .kpi-top > span.blue { color: #60a5fa; background: rgba(37,99,235,.12); }
.overview-exec-kpi .kpi-top > span.green,
.overview-exec-kpi .kpi-top > span.emerald { color: #22c55e; background: rgba(34,197,94,.12); }
.overview-exec-kpi .kpi-top > span.pink { color: #ec4899; background: rgba(236,72,153,.12); }
.overview-exec-kpi small {
  color: var(--muted);
  font-weight: 900;
}
.overview-exec-kpi strong {
  display: block;
  margin-top: 7px;
  font-size: clamp(23px, 2.2vw, 31px);
  line-height: 1.04;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.overview-exec-kpi b {
  justify-self: center;
  color: #22c55e;
  font-size: 12px;
}
.overview-exec-kpi b.bad { color: #fb7185; }
.overview-exec-kpi svg {
  width: 100%;
  height: 34px;
  color: #38bdf8;
}
.overview-exec-kpi svg path { fill: none; }
.overview-exec-kpi p {
  margin: 0;
  color: var(--text-muted, var(--muted));
  font-size: .75rem;
  font-style: italic;
  line-height: 1.45;
}
.overview-comparison-panel {
  display: grid;
  gap: 14px;
}
.overview-comparison-toggle {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.overview-comparison-toggle button {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  padding: 8px 12px;
  font-weight: 800;
}
.overview-comparison-toggle button.active {
  color: white;
  border-color: rgba(0,196,159,.45);
  background: rgba(0,196,159,.14);
}
.overview-comparison-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.overview-dual-kpi {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(148,163,184,.14);
  border-radius: 10px;
  padding: 14px;
  background: rgba(10,17,31,.62);
}
.overview-dual-kpi > div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 12px;
}
.overview-dual-kpi strong { color: var(--text); }
.overview-dual-kpi b.good { color: #00C49F; }
.overview-dual-kpi b.bad { color: #FF4444; }
.overview-dual-kpi b.neutral { color: var(--muted); }
.overview-rankings {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.overview-rankings h3 {
  margin: 0 0 12px;
  font-size: 15px;
}
.overview-campaign-rank-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}
.overview-campaign-rank-list li {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  color: var(--muted);
}
.overview-ai-today-output {
  display: grid;
  gap: 12px;
  line-height: 1.6;
}
.overview-reconciliation {
  display: grid;
  gap: 16px;
  padding: 18px;
}
.overview-manager-context {
  display: grid;
  gap: 18px;
  padding: 24px;
}
.overview-manager-context h2 {
  margin: 0;
  color: var(--text);
  font-size: clamp(20px, 2vw, 30px);
  letter-spacing: .01em;
}
.overview-manager-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.overview-manager-grid article {
  display: grid;
  gap: 8px;
  min-height: 120px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.04);
}
.overview-manager-grid small,
.overview-manager-grid span {
  color: var(--text-muted, var(--muted));
}
.overview-manager-grid small {
  font-size: .78rem;
  font-weight: 850;
}
.overview-manager-grid strong {
  color: var(--text);
  font-size: clamp(20px, 2.2vw, 34px);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.overview-manager-footer {
  display: grid;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.overview-manager-footer p {
  margin: 0;
  color: var(--muted);
}
.overview-manager-footer b,
.overview-manager-footer strong {
  color: var(--text);
}
.overview-analytic-density {
  display: grid;
  gap: 14px;
  padding: 20px;
}
.overview-analytic-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}
.overview-analytic-grid .kpi {
  min-height: 128px;
  padding: 18px;
  background: rgba(255,255,255,.04);
}
.reconciliation-title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #8892a4;
  text-transform: uppercase;
  margin: 0;
}
.reconciliation-source-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.reconciliation-source-card,
.reconciliation-ratio-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,0.04);
}
.reconciliation-source-card {
  display: grid;
  gap: 6px;
  padding: 16px;
}
.reconciliation-source-card span {
  color: var(--text);
  font-weight: 900;
}
.reconciliation-source-card span::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-right: 8px;
  border-radius: 999px;
  vertical-align: middle;
}
.reconciliation-source-card.meta span::before { background: #60a5fa; }
.reconciliation-source-card.ga4 span::before { background: #FFBB28; }
.reconciliation-source-card.wbuy span::before { background: #00C49F; }
.reconciliation-source-card small,
.reconciliation-source-card em {
  color: var(--muted);
}
.reconciliation-source-card strong {
  color: var(--text);
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.05;
  font-variant-numeric: tabular-nums;
}
.reconciliation-source-card em {
  font-style: normal;
  font-size: .78rem;
}
.reconciliation-source-card.muted {
  opacity: .55;
}
.reconciliation-flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  align-items: center;
  color: var(--line);
}
.reconciliation-flow span {
  position: relative;
  height: 22px;
  border-bottom: 1px solid currentColor;
}
.reconciliation-flow span::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 1px;
  height: 22px;
  background: currentColor;
}
.reconciliation-flow span::after {
  content: "";
  position: absolute;
  left: calc(50% - 5px);
  bottom: -2px;
  width: 9px;
  height: 9px;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(45deg);
}
.reconciliation-delta {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,0.04);
  padding: 18px;
}
.reconciliation-delta strong {
  color: var(--text);
  font-size: .96rem;
}
.reconciliation-gauge {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
}
.reconciliation-gauge i {
  display: block;
  height: 100%;
  border-radius: inherit;
}
.reconciliation-delta.healthy .reconciliation-gauge i { background: #00C49F; }
.reconciliation-delta.warn .reconciliation-gauge i { background: #FFBB28; }
.reconciliation-delta.danger .reconciliation-gauge i { background: #FF4444; }
.reconciliation-delta.healthy p { color: #00C49F; }
.reconciliation-delta.warn p { color: #FFBB28; }
.reconciliation-delta.danger p { color: #FF4444; }
.reconciliation-delta p {
  margin: 0;
  font-weight: 800;
}
.reconciliation-ratios {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.reconciliation-ratio-card {
  display: grid;
  gap: 8px;
  padding: 14px;
}
.reconciliation-ratio-card small {
  color: var(--muted);
  font-weight: 900;
}
.reconciliation-ratio-card strong {
  color: var(--text);
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.reconciliation-weekly-chart {
  display: grid;
  gap: 10px;
  padding-top: 8px;
}
.reconciliation-weekly-chart h4 {
  margin: 0;
  color: var(--text);
  font-size: .92rem;
}
.overview-funnel-panel {
  display: grid;
  gap: 18px;
}
.overview-funnel-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}
.overview-funnel-step {
  position: relative;
  min-height: 108px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 7px;
  padding: 14px 18px;
  border: 1px solid rgba(59,130,246,.52);
  color: #e2e8f0;
  background: linear-gradient(135deg, rgba(30,64,175,.28), rgba(15,23,42,.78));
  clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%, 18px 50%);
}
.overview-funnel-step:not(:last-child)::after {
  content: "";
  position: absolute;
  z-index: 2;
  right: -3px;
  top: 50%;
  width: 16px;
  height: 16px;
  border-top: 2px solid rgba(203, 213, 225, .68);
  border-right: 2px solid rgba(203, 213, 225, .68);
  transform: translateY(-50%) rotate(45deg);
  pointer-events: none;
}
.overview-funnel-step:first-child {
  clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%);
}
.overview-funnel-step.leak {
  border-color: #f43f5e;
  background: linear-gradient(135deg, rgba(244,63,94,.28), rgba(58,14,35,.86));
  box-shadow: inset 0 0 0 1px rgba(244,63,94,.25), 0 0 22px rgba(244,63,94,.14);
}
.overview-funnel-step span {
  color: #93c5fd;
}
.overview-funnel-step svg {
  width: 18px;
  height: 18px;
}
.overview-funnel-step small {
  color: #cbd5e1;
  font-weight: 850;
}
.overview-funnel-step strong {
  font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.overview-funnel-step b {
  display: inline-grid;
  place-items: center;
  min-width: 46px;
  min-height: 24px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(244,63,94,.12);
  color: #fb7185;
  font-size: 13px;
}
.overview-funnel-step b.neutral {
  color: #cbd5e1;
  background: rgba(148,163,184,.16);
}
.overview-funnel-note {
  margin: 0;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  text-align: center;
  color: #cbd5e1;
}
.overview-funnel-note svg {
  width: 18px;
  height: 18px;
  color: #93c5fd;
}
.overview-funnel-note:before {
  content: "!";
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  margin-right: 8px;
  border-radius: 999px;
  border: 1px solid #f59e0b;
  color: #f59e0b;
  font-weight: 950;
  font-size: 11px;
}
.overview-funnel-note.empty:before {
  display: none;
}
.overview-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .48fr);
  gap: 16px;
  align-items: stretch;
}
.overview-performance-panel {
  position: relative;
  min-width: 0;
}
.overview-performance-panel .section-row {
  align-items: start;
}
.overview-performance-panel p {
  margin: 8px 0 0;
  color: #cbd5e1;
  line-height: 1.45;
}
.overview-performance-panel .decision-chart {
  min-height: 300px;
  margin-top: 4px;
}
.overview-performance-panel .outline-purple {
  position: absolute;
  right: 28px;
  bottom: 30px;
  border-color: rgba(124,58,237,.75);
  color: #a78bfa;
}
.overview-performance-empty {
  min-height: 300px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  margin-top: 8px;
  padding: 32px;
  border: 1px dashed rgba(148, 163, 184, .32);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 0%, rgba(59,130,246,.10), transparent 40%),
    rgba(15,23,42,.28);
  text-align: center;
}
.overview-performance-empty svg {
  width: 42px;
  height: 42px;
  color: #60a5fa;
  opacity: .9;
}
.overview-performance-empty strong {
  color: var(--text);
  font-size: 1rem;
}
.overview-performance-empty p {
  max-width: 480px;
  margin: 0;
  color: var(--text-muted, var(--muted));
  font-size: .875rem;
}
.overview-ai-panel {
  display: grid;
  gap: 12px;
  align-content: start;
}
.overview-ai-panel article {
  display: grid;
  gap: 8px;
  min-height: 112px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
}
.overview-ai-panel article.red { border-color: rgba(244,63,94,.62); background: linear-gradient(135deg, rgba(244,63,94,.18), rgba(15,23,42,.76)); }
.overview-ai-panel article.yellow { border-color: rgba(245,158,11,.62); background: linear-gradient(135deg, rgba(245,158,11,.14), rgba(15,23,42,.76)); }
.overview-ai-panel article.green { border-color: rgba(34,197,94,.58); background: linear-gradient(135deg, rgba(34,197,94,.13), rgba(15,23,42,.76)); }
.overview-ai-panel small {
  font-weight: 950;
  letter-spacing: .06em;
}
.overview-ai-panel .red small { color: #fb7185; }
.overview-ai-panel .yellow small { color: #fbbf24; }
.overview-ai-panel .green small { color: #4ade80; }
.overview-ai-panel strong {
  font-size: 18px;
}
.overview-ai-panel p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}
.overview-ai-panel article button {
  justify-self: start;
  border: 0;
  background: transparent;
  color: inherit;
  font-weight: 900;
}
.overview-ai-panel .ai-credit-notice {
  margin-top: 2px;
}
.overview-channel-panel {
  display: grid;
  gap: 16px;
}
.overview-channel-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.overview-channel-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background: rgba(15,23,42,.55);
  color: var(--text);
  text-align: left;
  cursor: pointer;
}
.overview-channel-card > div {
  display: flex;
  align-items: center;
  gap: 9px;
  font-weight: 900;
}
.overview-channel-card > div span {
  color: #60a5fa;
}
.overview-channel-card svg {
  width: 22px;
  height: 22px;
}
.overview-channel-card section {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  gap: 4px 12px;
  margin: 18px 0 8px;
}
.overview-channel-card b {
  font-size: 36px;
  line-height: .95;
}
.overview-channel-card section small {
  color: var(--muted);
  align-self: end;
}
.overview-channel-card i {
  justify-self: end;
  width: 58px;
  height: 58px;
  border-radius: 999px;
  background: radial-gradient(circle, #101827 0 52%, transparent 53%), conic-gradient(currentColor 0 var(--score-angle), rgba(148,163,184,.16) var(--score-angle) 360deg);
}
.overview-channel-card.excellent,
.overview-channel-card.good { color: #22c55e; }
.overview-channel-card.warn { color: #facc15; }
.overview-channel-card.critical { color: #fb7185; }
.overview-channel-card em {
  display: inline-flex;
  padding: 4px 7px;
  border-radius: 6px;
  background: color-mix(in srgb, currentColor 20%, transparent);
  font-size: 11px;
  font-style: normal;
  font-weight: 950;
}
.overview-channel-card p {
  margin: 9px 0 0;
  color: #cbd5e1;
  font-size: 12px;
}
.overview-alerts-panel.executive .overview-alert-card {
  min-height: 112px;
  background: linear-gradient(135deg, rgba(15,23,42,.78), rgba(35,22,32,.74));
}
.overview-alert-card small {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  line-height: 1.35;
}
.overview-alert-card.high {
  border-color: rgba(244,63,94,.6);
  background: linear-gradient(135deg, rgba(244,63,94,.16), rgba(15,23,42,.78));
}
.overview-alert-card.mid {
  border-color: rgba(245,158,11,.62);
}
.overview-alert-card.low {
  border-color: rgba(59,130,246,.42);
}
.overview-action-plan {
  overflow: hidden;
}
.overview-plan-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) 190px;
  gap: 14px;
  align-items: stretch;
}
.overview-plan-grid article {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background: rgba(15,23,42,.58);
}
.overview-plan-grid article strong {
  display: flex;
  gap: 8px;
  align-items: center;
  color: #93c5fd;
}
.overview-plan-grid article.green strong { color: #4ade80; }
.overview-plan-grid article.purple strong { color: #a78bfa; }
.overview-plan-grid article svg {
  width: 15px;
  height: 15px;
}
.overview-plan-grid p {
  display: flex;
  gap: 9px;
  margin: 0;
  color: #cbd5e1;
  font-size: 13px;
}
.overview-plan-grid p span {
  color: #4ade80;
}
.overview-plan-grid article div {
  height: 7px;
  border-radius: 999px;
  background: rgba(148,163,184,.16);
  overflow: hidden;
}
.overview-plan-grid article i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #3b82f6, #7c3aed);
}
.overview-plan-grid small {
  color: var(--muted);
}
.overview-target-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 150px;
}
.overview-target-visual span {
  width: 138px;
  height: 138px;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(15,23,42,1) 0 17%, rgba(124,58,237,.42) 18% 27%, transparent 28% 38%, rgba(124,58,237,.38) 39% 47%, transparent 48% 58%, rgba(124,58,237,.3) 59% 67%, transparent 68%),
    radial-gradient(circle, rgba(59,130,246,.22), transparent 70%);
  box-shadow: 0 0 38px rgba(124,58,237,.24);
}
.overview-target-visual b {
  position: absolute;
  width: 92px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, #60a5fa, #7c3aed);
  transform: rotate(-42deg) translate(8px, -6px);
}
.overview-sync-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .72fr);
  gap: 14px;
}
.overview-integrations-panel {
  display: grid;
  gap: 16px;
}
.overview-integrations-panel > div {
  display: grid;
  grid-template-columns: repeat(7, minmax(92px, 1fr));
  gap: 10px;
}
.overview-integrations-panel article,
.overview-add-integration {
  min-height: 74px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(15,23,42,.58);
  color: var(--text);
  text-align: center;
}
.overview-integrations-panel article span {
  color: #60a5fa;
}
.overview-integrations-panel article svg {
  width: 22px;
  height: 22px;
}
.overview-integrations-panel article strong {
  font-size: 12px;
}
.overview-integrations-panel article small {
  color: #22c55e;
  font-size: 11px;
}
.overview-integrations-panel article.pending small {
  color: #f59e0b;
}
.overview-add-integration {
  font-size: 24px;
  color: var(--muted);
}
.overview-exec-page .next-sync-panel {
  grid-template-columns: 1fr auto;
  align-items: center;
}
.overview-exec-page .next-sync-panel strong,
.overview-exec-page .next-sync-panel p,
.overview-exec-page .next-sync-panel .sync-countdown {
  grid-column: 1;
}
.overview-exec-page .next-sync-panel .sync-countdown {
  border: 0;
  padding: 0;
  background: transparent;
  color: #38bdf8;
}
.overview-exec-page .next-sync-panel .sync-countdown:after {
  content: "";
  display: block;
  width: min(260px, 100%);
  height: 6px;
  margin-top: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, #38bdf8 0 46%, rgba(59,130,246,.18) 46% 100%);
}
.overview-exec-page .next-sync-panel .btn {
  grid-column: 2;
  grid-row: 1 / span 3;
}
.meta-auto-sync-strip {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px 16px;
  margin: 0 0 18px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 82%, transparent);
  color: var(--muted);
  font-size: 12px;
}
.meta-auto-sync-strip strong {
  color: var(--text);
  font-size: 12px;
}
.meta-auto-sync-strip span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.meta-auto-sync-strip b {
  color: #38bdf8;
  font-weight: 800;
}
.auto-sync-modal-body {
  display: grid;
  gap: 10px;
  color: var(--muted);
  line-height: 1.55;
}
.overview-exec-page.manager-mode .overview-performance-panel,
.overview-exec-page.manager-mode .overview-channel-panel {
  opacity: .72;
}
.overview-exec-page.manager-mode .overview-ai-panel,
.overview-exec-page.manager-mode .overview-alerts-panel,
.overview-exec-page.manager-mode .overview-action-plan {
  border-color: rgba(124,58,237,.58);
  box-shadow: 0 0 0 1px rgba(124,58,237,.16), 0 18px 46px rgba(124,58,237,.08);
}
.alerts-command-page {
  display: grid;
  gap: 24px;
}
.alerts-command-page svg {
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.alerts-summary-panel,
.alerts-top-impact-card,
.alerts-critical-channel-card,
.alerts-active-panel,
.alerts-finance-panel,
.alerts-channel-panel,
.alerts-actions-panel,
.alerts-ai-strip {
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(15, 27, 48, .92), rgba(8, 14, 27, .84)),
    radial-gradient(circle at 92% 8%, rgba(59,130,246,.12), transparent 30%);
  padding: 24px;
}
.alerts-filter-bar {
  display: flex;
  gap: 32px;
  align-items: center;
  margin-bottom: 24px;
}
.alerts-filter-bar .channel-filter {
  flex: 1;
  justify-content: flex-start;
  gap: 18px;
  padding: 20px 24px;
}
.alerts-filter-bar .channel-filter > div:first-child {
  display: flex;
  align-items: center;
  min-width: max-content;
}
.alerts-filter-bar .channel-filter strong {
  color: var(--text-muted, var(--muted));
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.alerts-filter-bar .channel-filter p {
  display: none;
}
.filter-info {
  display: none;
  color: var(--text-muted, var(--muted));
  cursor: help;
  font-size: .8rem;
  letter-spacing: 0;
  text-transform: none;
}
.alerts-filter-bar .filter-info {
  display: inline;
}
.alerts-filter-bar .seg-btn,
.alerts-tabs button {
  min-height: 34px;
  border: 1px solid var(--border-color, var(--line));
  border-radius: 6px;
  padding: 6px 14px;
  background: transparent;
  color: var(--text-muted, var(--muted));
  font-size: .85rem;
  font-weight: 800;
}
.alerts-filter-bar .seg-btn.active,
.alerts-tabs button.active {
  background: var(--primary, var(--brand));
  border-color: var(--primary, var(--brand));
  color: #fff;
}
.alerts-summary-panel {
  display: grid;
  gap: 16px;
}
.alerts-summary-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}
.alerts-summary-card {
  min-width: 0;
  min-height: 112px;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background: rgba(15,23,42,.56);
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.alerts-summary-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, currentColor 55%, var(--line));
}
.alerts-summary-card > span {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 999px;
  background: color-mix(in srgb, currentColor 18%, transparent);
}
.alerts-summary-card svg {
  width: 28px;
  height: 28px;
}
.alerts-summary-card small,
.alerts-summary-card p {
  color: var(--muted);
  font-weight: 850;
}
.alerts-summary-card strong {
  display: block;
  margin: 4px 0;
  font-size: clamp(26px, 3vw, 38px);
  line-height: .95;
}
.alerts-summary-card p {
  margin: 0;
  font-size: 12px;
}
.alerts-summary-card.critical { color: #fb7185; border-color: rgba(244,63,94,.42); background: linear-gradient(135deg, rgba(244,63,94,.16), rgba(15,23,42,.72)); }
.alerts-summary-card.warning { color: #f59e0b; border-color: rgba(245,158,11,.42); background: linear-gradient(135deg, rgba(245,158,11,.14), rgba(15,23,42,.72)); }
.alerts-summary-card.info { color: #60a5fa; border-color: rgba(59,130,246,.42); background: linear-gradient(135deg, rgba(59,130,246,.14), rgba(15,23,42,.72)); }
.alerts-summary-card.resolved { color: #22c55e; border-color: rgba(34,197,94,.36); background: linear-gradient(135deg, rgba(34,197,94,.12), rgba(15,23,42,.72)); }
.alerts-summary-card.total { color: #cbd5e1; }
.alerts-impact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .96fr);
  gap: 14px;
}
.alerts-top-impact-card,
.alerts-critical-channel-card {
  min-height: 112px;
  display: grid;
  align-content: center;
  gap: 10px;
}
.alerts-top-impact-card {
  border-color: rgba(244,63,94,.36);
  background: linear-gradient(135deg, rgba(244,63,94,.12), rgba(15,23,42,.86));
}
.alerts-top-impact-card small,
.alerts-critical-channel-card small {
  color: var(--muted);
  font-weight: 900;
}
.alerts-top-impact-card div {
  display: flex;
  align-items: center;
  gap: 18px;
}
.alerts-top-impact-card strong {
  color: #ff4d5f;
  font-size: clamp(30px, 4vw, 42px);
  line-height: 1;
}
.alerts-top-impact-card span,
.alerts-critical-channel-card strong {
  color: var(--text);
  font-weight: 950;
}
.alerts-top-impact-card p,
.alerts-top-impact-card b,
.alerts-critical-channel-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}
.alerts-top-impact-card b {
  color: #fda4af;
}
.alerts-critical-channel-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}
.alerts-critical-channel-card small,
.alerts-critical-channel-card div,
.alerts-critical-channel-card p {
  grid-column: 1;
}
.alerts-critical-channel-card div {
  display: flex;
  align-items: center;
  gap: 12px;
}
.alerts-critical-channel-card div span {
  color: #3b82f6;
}
.alerts-critical-channel-card div svg {
  width: 42px;
  height: 42px;
}
.alerts-critical-channel-card button {
  grid-column: 2;
  grid-row: 1 / span 3;
}
.alerts-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, .88fr);
  gap: 14px;
  align-items: start;
}
.alerts-side-stack {
  display: grid;
  gap: 14px;
  min-width: 0;
}
.alerts-active-panel {
  display: grid;
  gap: 16px;
  min-width: 0;
}
.alerts-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.alerts-tabs button {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 12px;
  background: rgba(15,23,42,.7);
  color: var(--muted);
  font-weight: 900;
}
.alerts-tabs button.active {
  color: #bfdbfe;
  border-color: rgba(59,130,246,.5);
  background: rgba(59,130,246,.16);
}
.alerts-active-list {
  display: grid;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
}
.alert-impact-card {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr) minmax(150px, auto);
  gap: 14px;
  align-items: center;
  min-width: 0;
  padding: 16px;
  border-bottom: 1px solid var(--line);
  background: rgba(15,23,42,.42);
}
.alert-impact-card:last-child {
  border-bottom: 0;
}
.alert-impact-card.critical { background: linear-gradient(90deg, rgba(244,63,94,.14), rgba(15,23,42,.46)); }
.alert-impact-card.warning { background: linear-gradient(90deg, rgba(245,158,11,.12), rgba(15,23,42,.46)); }
.alert-impact-card.info { background: linear-gradient(90deg, rgba(59,130,246,.10), rgba(15,23,42,.46)); }
.alert-impact-card.resolved { background: linear-gradient(90deg, rgba(34,197,94,.10), rgba(15,23,42,.46)); }
.alert-impact-icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  color: currentColor;
  background: color-mix(in srgb, currentColor 18%, transparent);
}
.alert-impact-card.critical { color: #fb7185; }
.alert-impact-card.warning { color: #f59e0b; }
.alert-impact-card.info { color: #60a5fa; }
.alert-impact-card.resolved { color: #22c55e; }
.alert-impact-icon svg {
  width: 24px;
  height: 24px;
}
.alert-impact-copy {
  min-width: 0;
}
.alert-impact-copy strong {
  display: block;
  color: var(--text);
  font-size: 15px;
}
.alert-impact-copy p {
  margin: 5px 0 8px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}
.alert-impact-copy div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.alert-impact-copy b,
.alert-impact-copy em {
  display: inline-flex;
  border-radius: 6px;
  padding: 4px 7px;
  background: color-mix(in srgb, currentColor 16%, transparent);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}
.alert-impact-meta {
  display: grid;
  justify-items: end;
  gap: 9px;
  color: var(--muted);
}
.alert-impact-meta span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #cbd5e1;
  font-weight: 850;
}
.alert-impact-meta svg {
  width: 18px;
  height: 18px;
}
.alert-impact-meta button {
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 24px;
}
.alerts-empty {
  padding: 30px;
  text-align: center;
}
.alerts-finance-panel,
.alerts-channel-panel,
.alerts-actions-panel {
  display: grid;
  gap: 14px;
}
.alerts-donut-wrap {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  align-items: center;
  gap: 20px;
}
.alerts-donut {
  width: 210px;
  height: 210px;
  display: grid;
  place-items: center;
  align-content: center;
  border-radius: 999px;
  background:
    radial-gradient(circle, #101827 0 54%, transparent 55%),
    conic-gradient(#f43f5e 0 var(--a1), #f59e0b var(--a1) var(--a2), #3b82f6 var(--a2) 100%);
}
.alerts-donut strong {
  font-size: 24px;
}
.alerts-donut span {
  color: var(--muted);
  font-size: 12px;
}
.alerts-donut-legend {
  display: grid;
  gap: 14px;
}
.alerts-donut-legend p {
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr);
  gap: 5px 10px;
  margin: 0;
}
.alerts-donut-legend i {
  grid-row: span 2;
  width: 12px;
  height: 12px;
  margin-top: 3px;
  border-radius: 4px;
}
.alerts-donut-legend i.red { background: #f43f5e; }
.alerts-donut-legend i.yellow { background: #f59e0b; }
.alerts-donut-legend i.blue { background: #3b82f6; }
.alerts-donut-legend span {
  color: #cbd5e1;
  font-weight: 900;
}
.alerts-donut-legend b {
  color: var(--muted);
  font-size: 13px;
}
.alerts-channel-panel > div {
  display: grid;
  gap: 12px;
}
.alerts-channel-panel article {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto auto;
  gap: 12px;
  align-items: center;
}
.alerts-channel-panel article > span {
  color: #60a5fa;
}
.alerts-channel-panel svg {
  width: 22px;
  height: 22px;
}
.alerts-channel-panel strong {
  display: block;
  margin-bottom: 7px;
  font-size: 13px;
}
.alerts-channel-panel i {
  display: block;
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(148,163,184,.18);
}
.alerts-channel-panel i b {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #f43f5e, #f59e0b, #3b82f6);
}
.alerts-channel-panel small {
  color: var(--muted);
  white-space: nowrap;
}
.alerts-channel-panel em {
  color: var(--text);
  font-style: normal;
  font-weight: 950;
}
.alerts-actions-panel > div {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.alerts-actions-panel article {
  display: grid;
  gap: 9px;
  align-content: start;
  min-height: 156px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background: rgba(15,23,42,.58);
}
.alerts-actions-panel article.critical { border-color: rgba(244,63,94,.48); background: linear-gradient(135deg, rgba(244,63,94,.14), rgba(15,23,42,.72)); }
.alerts-actions-panel article.warning { border-color: rgba(245,158,11,.48); background: linear-gradient(135deg, rgba(245,158,11,.12), rgba(15,23,42,.72)); }
.alerts-actions-panel article.info { border-color: rgba(59,130,246,.42); background: linear-gradient(135deg, rgba(59,130,246,.12), rgba(15,23,42,.72)); }
.alerts-actions-panel article > span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  color: currentColor;
  background: color-mix(in srgb, currentColor 18%, transparent);
}
.alerts-actions-panel article.critical { color: #fb7185; }
.alerts-actions-panel article.warning { color: #f59e0b; }
.alerts-actions-panel article.info { color: #60a5fa; }
.alerts-actions-panel article strong {
  color: var(--text);
}
.alerts-actions-panel article p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}
.alerts-actions-panel article small {
  color: currentColor;
  font-weight: 900;
}
.alerts-actions-panel article .btn {
  justify-self: start;
}
.alerts-ai-strip {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 14px;
  border-color: rgba(124,58,237,.42);
  background: linear-gradient(135deg, rgba(37,99,235,.72), rgba(124,58,237,.72));
}
.alerts-ai-strip p {
  margin: 4px 0 0;
  color: rgba(255,255,255,.82);
}
.alerts-ai-strip .ai-credit-notice {
  grid-column: 1 / -1;
  background: color-mix(in srgb, var(--panel) 82%, transparent);
}

.overview-operational-header {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.overview-operational-header article,
.overview-operational-grid article {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
}

.overview-operational-header small,
.overview-operational-grid small {
  display: block;
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 4px;
}

.overview-operational-header strong,
.overview-operational-grid strong {
  display: block;
  font-size: 13px;
  color: var(--text);
}

.overview-operational-status {
  margin-bottom: 12px;
}

.overview-operational-status .status.smart.ok {
  background: rgba(34, 197, 94, .12);
  color: #86efac;
}

.overview-operational-status .status.smart.warn {
  background: rgba(245, 158, 11, .12);
  color: #fcd34d;
}

.overview-operational-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.overview-universal-empty {
  margin-bottom: 12px;
  border-left: 4px solid rgba(245, 158, 11, .65);
}

.overview-universal-empty strong {
  display: block;
  font-size: 14px;
  margin-bottom: 4px;
}

.overview-universal-empty p {
  margin: 0;
  color: var(--muted);
}

.overview-confidence-layer {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
}

.overview-confidence-layer span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
}

.overview-operational-score {
  margin-bottom: 12px;
}

.overview-operational-score-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.overview-operational-score-badges {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.overview-operational-score-main {
  display: grid;
  gap: 4px;
  margin-bottom: 10px;
}

.overview-operational-score-main small {
  color: var(--muted);
  font-size: 11px;
}

.overview-operational-score-main strong {
  font-size: 28px;
  line-height: 1;
}

.overview-operational-score-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 10px;
}

.overview-operational-score-grid article {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--panel-2) 68%, transparent);
}

.overview-operational-score-grid small {
  display: block;
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 4px;
}

.overview-operational-score-grid strong {
  display: block;
  font-size: 13px;
}

.overview-operational-score-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 10px;
}

.overview-operational-score-list small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  margin-bottom: 6px;
}

.overview-operational-score-list ul {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.overview-operational-score-list li {
  color: var(--text);
  font-size: 12px;
  line-height: 1.4;
}

.overview-operational-score-breakdown {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.overview-operational-score-breakdown span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
}

.overview-operational-score-skeleton {
  display: grid;
  gap: 8px;
}

.overview-operational-score-skeleton i {
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(148, 163, 184, .2), rgba(148, 163, 184, .35), rgba(148, 163, 184, .2));
  background-size: 220% 100%;
  animation: shimmer 1.3s linear infinite;
}

.overview-operational-score-skeleton i:nth-child(1) { width: 64%; }
.overview-operational-score-skeleton i:nth-child(2) { width: 85%; }
.overview-operational-score-skeleton i:nth-child(3) { width: 58%; }

.overview-operational-score.is-error {
  border-left: 4px solid rgba(245, 158, 11, .65);
}

.overview-operational-score.is-degraded {
  border-left: 4px solid rgba(56, 189, 248, .55);
}

.technical-ops-page {
  display: grid;
  gap: 14px;
}

.technical-ops-summary {
  border-color: rgba(56, 189, 248, .24);
  background: linear-gradient(135deg, rgba(56, 189, 248, .08), rgba(15, 23, 42, .72));
}

.technical-ops-guard {
  border-color: rgba(148, 163, 184, .22);
}

@keyframes shimmer {
  from { background-position: 220% 0; }
  to { background-position: -220% 0; }
}

.overview-progressive-details {
  margin: 12px 0;
}

.overview-progressive-details > summary {
  list-style: none;
  cursor: pointer;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 700;
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
}

.overview-progressive-details > summary::-webkit-details-marker {
  display: none;
}

.overview-progressive-details > summary::before {
  content: "▸";
  margin-right: 8px;
}

.overview-progressive-details[open] > summary::before {
  content: "▾";
}

.overview-progressive-body {
  margin-top: 10px;
}

.kpi-card__helper {
  display: block;
  margin: 2px 0 2px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}

@media (max-width: 1024px) {
  .overview-operational-header {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .overview-operational-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .overview-operational-score-grid,
  .overview-operational-score-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .overview-operational-header,
  .overview-operational-grid {
    grid-template-columns: 1fr;
  }
  .overview-operational-score-grid,
  .overview-operational-score-list {
    grid-template-columns: 1fr;
  }
  .overview-operational-score-head {
    flex-direction: column;
    align-items: flex-start;
  }
}

.alerts-summary-card {
  grid-template-columns: 42px minmax(0, 1fr);
  padding: 20px;
}
.alerts-summary-card > span {
  width: 42px;
  height: 42px;
  border-radius: 8px;
}
.alerts-summary-card strong {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
}
.alerts-summary-card p {
  margin-top: 4px;
  color: var(--text-muted, var(--muted));
  font-size: .72rem;
}
.alerts-summary-card.critical { color: #ef4444; border-color: rgba(239,68,68,.2); background: rgba(239,68,68,.08); }
.alerts-summary-card.warning { color: #f59e0b; border-color: rgba(245,158,11,.2); background: rgba(245,158,11,.08); }
.alerts-summary-card.info { color: #6366f1; border-color: rgba(99,102,241,.2); background: rgba(99,102,241,.08); }
.alerts-summary-card.resolved { color: #22c55e; border-color: rgba(34,197,94,.2); background: rgba(34,197,94,.08); }
.alerts-summary-card.total { color: #cbd5e1; border-color: rgba(148,163,184,.2); background: rgba(148,163,184,.08); }
.alerts-impact-grid,
.alerts-main-grid {
  gap: 24px;
}
.alerts-side-stack {
  gap: 24px;
}
.alerts-top-impact-card strong {
  font-size: 1rem;
}
.alerts-top-impact-card.has-impact strong {
  display: inline-flex;
  border-radius: 4px;
  padding: 2px 8px;
  background: rgba(239,68,68,.12);
  color: #ef4444;
  font-size: .72rem;
}
.alerts-top-impact-card.is-empty strong,
.alerts-top-impact-card.is-empty b {
  color: var(--text-muted, var(--muted));
}
.alerts-critical-channel-card p.is-clear {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--success, #22c55e);
  font-weight: 900;
}
.alerts-critical-channel-card p.is-clear svg {
  width: 20px;
  height: 20px;
}
.alerts-tabs button {
  min-height: 34px;
  border: 1px solid var(--border-color, var(--line));
  border-radius: 6px;
  padding: 6px 14px;
  background: transparent;
  color: var(--text-muted, var(--muted));
  font-size: .85rem;
}
.alerts-tabs button.active {
  background: var(--primary, var(--brand));
  border-color: var(--primary, var(--brand));
  color: #fff;
}
.alert-impact-card {
  padding: 20px;
}
.alert-impact-card.critical { color: var(--error, #ef4444); }
.alert-impact-card.warning { color: var(--warning, #f59e0b); }
.alert-impact-card.info { color: var(--info, #6366f1); }
.alert-impact-copy b,
.alert-impact-copy em {
  border: 1px solid var(--border-color, var(--line));
  border-radius: 4px;
  padding: 2px 8px;
  background: transparent;
  font-size: .72rem;
}
.alert-impact-meta small {
  color: var(--text-muted, var(--muted));
  font-size: .75rem;
  white-space: nowrap;
}
.alert-impact-meta button {
  min-width: 32px;
  min-height: 32px;
  border-radius: 6px;
  cursor: pointer;
}
.alert-impact-meta button:hover {
  background: rgba(255,255,255,.06);
  color: var(--text);
}
.alert-impact-card {
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 12px;
  padding: 20px 20px 20px 18px;
  border-left: 4px solid var(--alert-color, #00c49f);
  color: var(--text);
}
.alert-impact-card.critical {
  --alert-color: #ff4444;
  background: rgba(255,68,68,.06);
  color: var(--text);
}
.alert-impact-card.high {
  --alert-color: #ff8c00;
  background: rgba(255,140,0,.06);
  color: var(--text);
}
.alert-impact-card.medium,
.alert-impact-card.warning {
  --alert-color: #ffbb28;
  background: rgba(255,187,40,.06);
  color: var(--text);
}
.alert-impact-card.info {
  --alert-color: #00c49f;
  background: rgba(0,196,159,.06);
  color: var(--text);
}
.alert-impact-card.seen {
  opacity: .78;
}
.alert-card-head,
.alert-impact-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.alert-card-head small {
  color: var(--text-muted, var(--muted));
  font-size: .75rem;
  white-space: nowrap;
}
.alert-severity-label {
  color: var(--alert-color);
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .08em;
}
.alert-impact-copy {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}
.alert-impact-copy > div {
  display: block;
}
.alert-impact-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  color: var(--alert-color);
  background: color-mix(in srgb, var(--alert-color) 14%, transparent);
}
.alert-impact-copy strong {
  font-size: .98rem;
}
.alert-impact-source {
  margin: 4px 0 8px;
  color: var(--text-muted, var(--muted));
  font-size: .78rem;
}
.alert-impact-action {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  color: var(--text);
  font-weight: 750;
}
.alert-impact-action svg {
  width: 16px;
  height: 16px;
  color: var(--alert-color);
}
.alert-impact-actions {
  justify-content: flex-start;
}
.alert-impact-actions .btn {
  min-height: 34px;
  padding: 7px 14px;
  border-radius: 6px;
}
.alerts-finance-panel.is-empty .alerts-donut {
  background:
    radial-gradient(circle, #101827 0 54%, transparent 55%),
    conic-gradient(var(--border-color, var(--line)) 0 100%);
}
.alerts-finance-panel.is-empty .alerts-donut span {
  color: var(--text-muted, var(--muted));
  font-size: .75rem;
}
.alerts-donut-legend {
  gap: 8px;
}
.alerts-donut-legend p {
  font-size: .8rem;
}
.alerts-donut-legend i {
  min-width: 10px;
  min-height: 10px;
}
.alerts-channel-panel article.is-empty i b {
  opacity: .25;
}
.alerts-channel-panel em {
  color: var(--text-muted, var(--muted));
}
.alerts-actions-panel > div {
  gap: 16px;
}
.alerts-actions-panel article {
  flex: 1;
  padding: 20px;
}
.alerts-actions-panel article small {
  justify-self: start;
  border-radius: 4px;
  padding: 2px 8px;
  background: rgba(245,158,11,.1);
  color: #f59e0b;
  font-size: .72rem;
  font-weight: 500;
}
.alerts-actions-panel article .btn {
  border: 1px solid var(--primary, var(--brand));
  border-radius: 6px;
  padding: 8px 20px;
  background: transparent;
  color: var(--primary, var(--brand));
}
.alerts-actions-panel article .btn:hover {
  background: var(--primary, var(--brand));
  color: #fff;
}
.alerts-ai-strip .btn {
  min-height: 40px;
}
.alerts-ai-strip .btn:not(.primary) {
  border: 1px solid rgba(255,255,255,.3);
  background: transparent;
  color: #fff;
}
.alerts-ai-strip .btn:not(.primary):hover {
  background: rgba(255,255,255,.1);
}
.alerts-ai-strip .ai-credit-notice {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding: 0;
  border: 0;
  background: transparent;
  font-size: .75rem;
  opacity: .7;
}
.alerts-ai-strip .ai-credit-notice-icon {
  width: 20px;
  height: 20px;
}
.alerts-ai-strip .ai-credit-notice-copy p {
  margin: 0;
  font-size: .75rem;
}
.analytics-command-page {
  display: grid;
  gap: 32px;
  align-items: start;
}
.analytics-command-page svg {
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.analytics-filter-rail {
  position: sticky;
  top: 82px;
}
.analytics-filters-panel,
.analytics-executive-summary,
.analytics-kpi-card,
.analytics-commerce-panel,
.analytics-score-panel,
.analytics-funnel-panel,
.analytics-performance-panel,
.analytics-insights-panel,
.analytics-alerts-panel,
.analytics-actions-panel,
.analytics-manager-panel,
.analytics-evolution-panel,
.analytics-work-panel {
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(15, 27, 48, .92), rgba(8, 14, 27, .84)),
    radial-gradient(circle at 94% 8%, rgba(59,130,246,.12), transparent 30%);
}
.analytics-command-main {
  display: grid;
  gap: 32px;
  min-width: 0;
}
.analytics-filters-panel {
  display: grid;
  grid-template-columns: minmax(160px, 1.1fr) minmax(138px, .8fr) minmax(138px, .8fr) minmax(132px, .72fr) minmax(150px, .82fr) auto;
  gap: 12px;
  align-items: end;
  padding: 24px;
  border: 1px solid rgba(75, 111, 180, .34);
}
.analytics-filters-panel h3 {
  margin: 0;
}
.analytics-filters-panel .field.compact label {
  display: grid;
  gap: 6px;
  color: #94a3b8;
  font-size: 11px;
  font-weight: 900;
}
.analytics-filters-panel .field.compact select,
.analytics-filters-panel .field.compact input {
  min-height: 42px;
  font-size: .85rem;
  border-radius: 8px;
  border: 1px solid rgba(80, 112, 170, .42);
  background: rgba(10, 18, 32, .78);
  color: #f8fbff;
  font-weight: 800;
}
.analytics-filter-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: max-content;
}
.analytics-filter-actions .btn {
  min-height: 42px;
  white-space: nowrap;
}
.analytics-filter-actions .btn:first-child {
  border-color: transparent;
  background: transparent;
  color: var(--text-muted, var(--muted));
  box-shadow: none;
}
.analytics-filter-actions .btn:first-child:hover {
  border-color: transparent;
  background: transparent;
  color: var(--text-primary, var(--text));
}
.analytics-hero-grid {
  display: grid;
  grid-template-columns: minmax(320px, .78fr) minmax(0, 1.22fr);
  gap: 32px;
  align-items: stretch;
}
.analytics-executive-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  align-items: start;
  min-height: 100%;
  padding: 24px;
}
.analytics-summary-empty-icon {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  margin-bottom: 14px;
  color: var(--text-muted, var(--muted));
  opacity: .9;
}
.analytics-summary-empty-icon svg {
  width: 48px;
  height: 48px;
}
.analytics-executive-summary span {
  display: block;
  color: var(--muted);
  font-weight: 900;
  margin-bottom: 8px;
}
.analytics-executive-summary h2 {
  max-width: 980px;
  margin: 0;
  font-size: clamp(17px, 1.35vw, 24px);
  line-height: 1.34;
}
.analytics-executive-summary p {
  margin: 10px 0 0;
  color: var(--muted);
}
.analytics-executive-summary .btn {
  align-self: end;
  justify-self: end;
  margin-top: auto;
}
.analytics-kpi-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(150px, 1fr));
  gap: 12px;
}
.analytics-kpi-card {
  min-width: 0;
  min-height: 144px;
  display: grid;
  gap: 8px;
  padding: 24px;
  overflow: hidden;
}
.analytics-kpi-card > div {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 10px;
}
.analytics-kpi-card small {
  color: var(--muted);
  font-weight: 900;
}
.analytics-kpi-card span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 9px;
  color: #93c5fd;
  background: rgba(59,130,246,.16);
}
.analytics-kpi-card span.icon-revenue,
.analytics-kpi-card span.icon-profit {
  color: #22c55e;
  background: rgba(34,197,94,.12);
}
.analytics-kpi-card span.icon-spend,
.analytics-kpi-card span.icon-cpa {
  color: #ef4444;
  background: rgba(239,68,68,.12);
}
.analytics-kpi-card span.icon-roas,
.analytics-kpi-card span.icon-conversions {
  color: #6366f1;
  background: rgba(99,102,241,.12);
}
.analytics-kpi-card span svg {
  width: 18px;
  height: 18px;
}
.analytics-kpi-card small .metric-label-text {
  display: inline-flex;
  place-items: initial;
  width: auto;
  height: auto;
  border-radius: 0;
  background: transparent;
  color: inherit;
}
.analytics-kpi-card small .metric-tooltip-icon {
  width: 14px;
  height: 14px;
  background: transparent;
  color: #8892a4;
}
.analytics-kpi-card strong {
  font-size: clamp(18px, 1.45vw, 28px);
  line-height: 1.08;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  overflow-wrap: normal;
  font-variant-numeric: tabular-nums;
}
.analytics-kpi-card b {
  color: #22c55e;
  font-size: 12px;
}
.analytics-kpi-card.bad b {
  color: #fb7185;
}
.analytics-kpi-card p {
  margin: 0;
  color: var(--text-muted, var(--muted));
  font-size: .72rem;
  line-height: 1.35;
}
.meta-hierarchy-panel {
  display: grid;
  gap: 16px;
}
.meta-view-toggle {
  display: flex;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.03);
}
.meta-view-toggle button {
  border: 0;
  border-radius: 6px;
  padding: 7px 12px;
  background: transparent;
  color: var(--muted);
  font-size: .8rem;
  font-weight: 850;
}
.meta-view-toggle button.active {
  background: var(--brand);
  color: #fff;
}
.meta-summary-kpis {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
.meta-heatmap-panel {
  display: grid;
  gap: 14px;
}
.meta-heatmap {
  display: grid;
  grid-template-columns: 42px repeat(24, minmax(18px, 1fr));
  gap: 4px;
  overflow-x: auto;
}
.meta-heatmap-hours,
.meta-heatmap-row {
  display: contents;
}
.meta-heatmap-hours::before {
  content: "";
}
.meta-heatmap-hours span {
  min-width: 18px;
  color: var(--chart-axis-text);
  font-size: 10px;
  text-align: center;
}
.meta-heatmap-row strong {
  color: var(--chart-axis-text);
  font-size: 11px;
  align-self: center;
}
.meta-heatmap-row i {
  display: block;
  min-width: 18px;
  height: 18px;
  border-radius: 4px;
  background: #1a2235;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.meta-drill-table-panel {
  display: grid;
  gap: 14px;
}
.meta-drill-fade {
  animation: metaFadeIn .2s ease;
}
@keyframes metaFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}
.meta-drill-table {
  min-width: 860px;
}
.meta-drill-table tbody tr {
  cursor: pointer;
}
.meta-drill-table tbody tr.danger { background: rgba(255,68,68,0.08); }
.meta-drill-table tbody tr.warn { background: rgba(255,187,40,0.08); }
.meta-drill-table tbody tr.good { background: rgba(0,196,159,0.08); }
.meta-drill-table tbody tr:hover {
  background: rgba(255,255,255,.08);
}
.meta-treemap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 320px;
}
.meta-treemap article {
  min-width: 160px;
  min-height: 118px;
  flex-basis: 18%;
  display: grid;
  align-content: end;
  gap: 6px;
  overflow: hidden;
  padding: 14px;
  border-radius: 12px;
  color: #06111f;
}
.meta-treemap article.danger { background: #FF4444; }
.meta-treemap article.warn { background: #FFBB28; }
.meta-treemap article.good { background: #00C49F; }
.meta-treemap article.best {
  background: #0088FE;
  color: #fff;
}
.meta-treemap strong {
  color: inherit;
  font-size: .92rem;
  line-height: 1.2;
}
.meta-treemap span,
.meta-treemap small {
  color: inherit;
  opacity: .88;
  font-weight: 850;
}
.meta-item-name {
  max-width: 320px;
  border: 0;
  background: transparent;
  color: var(--text);
  font-weight: 900;
  text-align: left;
  white-space: normal;
}
.meta-item-name:hover {
  color: var(--brand);
}
.meta-score-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px 10px;
  background: rgba(255,255,255,.04);
  font-size: 12px;
  font-weight: 900;
}
.meta-score-badge.high { color: #00C49F; }
.meta-score-badge.medium { color: #FFBB28; }
.meta-score-badge.low { color: #FF4444; }
.meta-score-badge.health-high { color: #00C49F; background: rgba(0,196,159,.1); border-color: rgba(0,196,159,.28); }
.meta-score-badge.health-medium { color: #FFBB28; background: rgba(255,187,40,.1); border-color: rgba(255,187,40,.28); }
.meta-score-badge.health-low { color: #FF4444; background: rgba(255,68,68,.1); border-color: rgba(255,68,68,.28); }
.meta-sparkline,
.meta-roas-chart-line {
  width: 88px;
  height: 26px;
  color: #00C49F;
}
.meta-sparkline.down {
  color: #FF4444;
}
.meta-sparkline path,
.meta-roas-chart-line path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
}
.meta-detail-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(0,0,0,0.5);
}
.meta-detail-drawer {
  position: absolute;
  top: 0;
  right: 0;
  width: min(420px, 100vw);
  height: 100%;
  display: grid;
  align-content: start;
  gap: 18px;
  overflow: auto;
  padding: 26px;
  border-left: 1px solid var(--line);
  background: var(--panel);
  box-shadow: -16px 0 44px rgba(0,0,0,.42);
  transform: translateX(0);
  animation: metaDrawerIn .3s ease;
}
@keyframes metaDrawerIn {
  from { transform: translateX(100%); }
  to { transform: translateX(0); }
}
.meta-detail-close {
  justify-self: end;
}
.meta-detail-drawer h2 {
  margin: 0;
}
.meta-detail-metrics {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.meta-detail-chart {
  display: grid;
  gap: 12px;
}
.meta-roas-chart-line {
  width: 100%;
  height: 150px;
}
.analytics-commerce-panel {
  display: grid;
  gap: 16px;
  padding: 24px;
}
.analytics-commerce-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}
.analytics-commerce-grid article {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  background: rgba(15,23,42,.55);
}
.analytics-commerce-grid small,
.analytics-commerce-grid span {
  display: block;
  color: var(--muted);
  font-weight: 900;
}
.analytics-commerce-grid small {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: .75rem;
}
.analytics-commerce-grid strong {
  display: block;
  margin: 10px 0 7px;
  font-size: clamp(22px, 2.2vw, 30px);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.analytics-commerce-grid article:not(.bad) span {
  color: var(--text-muted, var(--muted));
  font-size: .72rem;
}
.analytics-commerce-grid article.bad span {
  color: var(--text-muted, var(--muted));
  font-size: .72rem;
}
.analytics-score-panel,
.analytics-insights-panel,
.analytics-actions-panel {
  display: grid;
  gap: 16px;
  padding: 24px;
}
.analytics-insights-panel .ai-credit-notice {
  margin-top: 2px;
}
.analytics-score-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.analytics-hero-grid .analytics-score-panel {
  min-height: 100%;
}
.analytics-hero-grid .analytics-score-card {
  padding: 24px;
}
.analytics-hero-grid .analytics-score-card b {
  font-size: 32px;
}
.analytics-hero-grid .analytics-score-card i {
  width: 46px;
  height: 46px;
}
.analytics-score-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  background: rgba(15,23,42,.56);
  color: var(--text);
  cursor: pointer;
}
.analytics-score-card > div {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 950;
}
.analytics-score-card > div span {
  color: #60a5fa;
}
.analytics-score-card svg {
  width: 22px;
  height: 22px;
}
.analytics-score-card section {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  gap: 4px 12px;
  margin: 18px 0 8px;
}
.analytics-score-card b {
  font-size: 38px;
  line-height: .95;
}
.analytics-score-card section small {
  color: var(--muted);
  align-self: end;
}
.analytics-score-card i {
  justify-self: end;
  width: 56px;
  height: 56px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  background: radial-gradient(circle, #101827 0 52%, transparent 53%), conic-gradient(currentColor 0 var(--score-angle), rgba(148,163,184,.16) var(--score-angle) 360deg);
}
.analytics-score-card.excellent { color: #22c55e; }
.analytics-score-card.good { color: #38bdf8; }
.analytics-score-card.warn { color: #f59e0b; }
.analytics-score-card.critical { color: #fb7185; }
.analytics-score-card em {
  display: inline-flex;
  padding: 4px 7px;
  border-radius: 6px;
  background: color-mix(in srgb, currentColor 18%, transparent);
  font-style: normal;
  font-size: 11px;
  font-weight: 950;
}
.analytics-score-card p {
  margin: 9px 0 0;
  color: #cbd5e1;
  font-size: 12px;
  line-height: 1.4;
}
.analytics-funnel-panel {
  display: grid;
  gap: 16px;
  padding: 24px;
}
.analytics-funnel-steps {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}
.analytics-funnel-steps article {
  min-width: 0;
  min-height: 104px;
  display: grid;
  align-content: center;
  gap: 8px;
  border: 1px solid rgba(59,130,246,.38);
  border-radius: 8px;
  padding: 12px 8px;
  background: linear-gradient(135deg, rgba(30,64,175,.22), rgba(15,23,42,.72));
  scroll-snap-align: start;
}
.analytics-funnel-steps article.leak {
  border-color: rgba(244,63,94,.68);
  background: linear-gradient(135deg, rgba(244,63,94,.22), rgba(58,14,35,.76));
}
.analytics-funnel-steps small {
  color: #cbd5e1;
  font-weight: 900;
}
.analytics-funnel-steps strong {
  font-size: clamp(20px, 2vw, 28px);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.analytics-funnel-steps span {
  color: #fb7185;
  font-weight: 950;
}
.analytics-funnel-steps span.neutral {
  color: var(--text-muted, var(--muted));
  font-size: .85rem;
}
.analytics-funnel-panel > p {
  margin: 0;
  color: #cbd5e1;
}
.analytics-performance-panel {
  min-width: 0;
  padding: 24px;
}
.analytics-performance-panel .section-row {
  align-items: start;
}
.analytics-performance-panel p {
  margin: 7px 0 0;
  color: #cbd5e1;
}
.analytics-performance-panel .decision-chart {
  min-height: 300px;
}
.analytics-performance-panel .chart-toggles .seg-btn {
  border-radius: 6px;
  border: 1px solid var(--border-color, var(--line));
  background: transparent;
  color: var(--text-muted, var(--muted));
}
.analytics-performance-panel .chart-toggles .seg-btn.active {
  background: var(--primary, var(--brand));
  border-color: var(--primary, var(--brand));
  color: #fff;
}
.analytics-performance-empty {
  min-height: 300px;
  align-content: center;
  gap: 12px;
}
.analytics-performance-empty svg {
  width: 64px;
  height: 64px;
  color: var(--text-muted, var(--muted));
}
.analytics-performance-empty p {
  max-width: 480px;
  margin: 0;
  color: var(--text-muted, var(--muted));
}
.analytics-insights-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 12px;
  align-items: start;
}
.analytics-insights-grid .insight-card {
  min-width: 220px;
  min-height: 0;
  height: auto;
  overflow: visible;
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--border, var(--line));
  border-radius: 12px;
  padding: 20px;
  background: var(--bg-surface, var(--panel));
}
.analytics-insights-grid article.ok { border-color: rgba(34,197,94,.38); }
.analytics-insights-grid article.warn { border-color: rgba(245,158,11,.48); }
.analytics-insights-grid article.bad { border-color: rgba(244,63,94,.48); }
.analytics-insights-grid .insight-card__icon {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 9px;
  color: var(--accent);
  background: rgba(59,130,246,.16);
}
.analytics-insights-grid .insight-card__title {
  margin-top: 12px;
  color: var(--text-primary, var(--text));
  font-size: 15px;
  font-weight: 800;
  line-height: 1.35;
}
.analytics-insights-grid .insight-card__label {
  margin-top: 16px;
  color: var(--text-muted, var(--muted));
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1.2;
  text-transform: uppercase;
}
.analytics-insights-grid .insight-card__label--action {
  margin-top: 12px;
}
.analytics-insights-grid .insight-card__body {
  display: block;
  margin: 4px 0 0;
  color: var(--text-secondary, var(--text));
  font-size: 13px;
  font-weight: 400;
  line-height: 1.6;
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
  overflow: visible;
}
.analytics-two-col {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .9fr);
  gap: 32px;
}
.analytics-alerts-panel,
.analytics-actions-panel {
  align-content: start;
}
.analytics-alerts-panel > div:not(.section-row),
.analytics-actions-panel > div {
  display: grid;
  gap: 10px;
}
.analytics-alerts-panel article {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  background: rgba(15,23,42,.48);
}
.analytics-alerts-panel article.critical { border-color: rgba(244,63,94,.5); }
.analytics-alerts-panel article.warning { border-color: rgba(245,158,11,.5); }
.analytics-alerts-panel article span { color: #fb7185; }
.analytics-alerts-panel article p,
.analytics-alerts-panel article small {
  margin: 4px 0 0;
  color: var(--muted);
  line-height: 1.35;
}
.analytics-alerts-panel article em {
  align-self: center;
  color: #fb7185;
  font-style: normal;
  font-weight: 950;
  font-size: 12px;
}
.analytics-actions-panel article {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  background: rgba(15,23,42,.48);
}
.analytics-actions-panel article.priority { border-color: rgba(244,63,94,.5); }
.analytics-actions-panel article.secondary { border-color: rgba(245,158,11,.5); }
.analytics-actions-panel article.opportunity { border-color: rgba(34,197,94,.42); }
.analytics-actions-panel small,
.analytics-actions-panel span {
  color: var(--muted);
  font-weight: 900;
}
.analytics-actions-panel p {
  margin: 0;
  color: var(--muted);
  text-transform: none;
}
.analytics-actions-panel .segments.small .seg-btn {
  border: 1px solid var(--border-color, var(--line));
  border-radius: 6px;
  padding: 6px 14px;
  font-size: .8rem;
}
.analytics-actions-panel .segments.small .seg-btn.active {
  background: var(--primary, var(--brand));
  color: #fff;
  font-weight: 600;
}
.analytics-manager-panel textarea {
  min-height: 96px;
  resize: vertical;
}
.analytics-manager-panel {
  padding: 24px;
}
.analytics-manager-panel .form-grid {
  align-items: start;
}
.analytics-manager-panel textarea {
  grid-column: 1 / -1;
}
.analytics-manager-panel .btn.primary {
  width: auto;
  justify-self: end;
  padding: 12px 32px;
}
.analytics-evolution-panel,
.analytics-work-panel {
  min-width: 0;
  padding: 24px;
}
.analytics-evolution-chart-wrap {
  position: relative;
}
.analytics-evolution-panel.is-empty .chart g {
  opacity: .15;
}
.analytics-chart-empty-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--text-muted, var(--muted));
  font-size: .875rem;
  pointer-events: none;
}
.analytics-register-action-btn {
  border: 1px solid var(--primary, var(--brand));
  color: var(--primary, var(--brand));
  background: transparent;
}
.analytics-register-action-btn span {
  display: inline-grid;
  place-items: center;
  width: 14px;
  height: 14px;
  margin-right: 7px;
  font-weight: 900;
}
.analytics-register-action-btn:hover {
  background: var(--primary, var(--brand));
  color: #fff;
}
.analytics-empty-state {
  display: grid;
  place-items: center;
  min-height: 240px;
  border: 1px dashed var(--line);
  border-radius: 8px;
  padding: 24px;
  text-align: center;
  color: var(--muted);
}
.analytics-empty-state strong {
  color: var(--text);
}
.dashboard-sync-warning {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding-right: 42px;
}
.dashboard-sync-warning p {
  min-width: 0;
  margin: 0;
}
.inline-sync-link {
  appearance: none;
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--primary, var(--brand));
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}
.inline-sync-link:hover {
  color: var(--text-primary, var(--text));
}
.integration-note-close {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--text-muted, var(--muted));
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}
.integration-note-close:hover {
  color: var(--text-primary, var(--text));
  background: rgba(255,255,255,.06);
}
.briefing-command-page {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.briefing-progress-panel,
.briefing-card-section,
.briefing-ai-preview {
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(15, 27, 48, .92), rgba(8, 14, 27, .84)),
    radial-gradient(circle at 92% 8%, rgba(124,58,237,.12), transparent 30%);
}
.briefing-ai-preview .ai-credit-notice {
  margin-top: 2px;
}
.briefing-progress-panel {
  position: sticky;
  top: 82px;
  display: grid;
  gap: 16px;
}
.briefing-progress-ring {
  width: 148px;
  height: 148px;
  display: grid;
  place-items: center;
  align-content: center;
  justify-self: center;
  border-radius: 999px;
  background:
    radial-gradient(circle, #101827 0 54%, transparent 55%),
    conic-gradient(#3b82f6 0 var(--briefing-progress), rgba(124,58,237,.95) var(--briefing-progress), rgba(148,163,184,.16) var(--briefing-progress) 360deg);
}
.briefing-progress-ring strong {
  font-size: 34px;
  line-height: 1;
}
.briefing-progress-ring span,
.briefing-progress-panel p {
  color: var(--muted);
}
.briefing-progress-panel h3 {
  margin: 0;
  text-align: center;
}
.briefing-progress-panel p {
  margin: 0;
  text-align: center;
  line-height: 1.45;
}
.briefing-progress-bar {
  height: 8px;
  border-radius: 999px;
  background: rgba(148,163,184,.16);
  overflow: hidden;
}
.briefing-progress-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #3b82f6, #7c3aed);
}
.briefing-state {
  justify-self: start;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(59,130,246,.14);
  color: #93c5fd;
  font-size: 12px;
  font-weight: 950;
}
.briefing-state.filled { background: rgba(34,197,94,.14); color: #4ade80; }
.briefing-state.partial,
.briefing-state.started { background: rgba(245,158,11,.14); color: #fbbf24; }
.briefing-state.empty { background: rgba(148,163,184,.14); color: var(--muted); }
.briefing-strategy-form {
  display: grid;
  gap: 16px;
  min-width: 0;
}
.briefing-card-section {
  display: grid;
  gap: 16px;
}
.briefing-card-head h3 {
  margin: 0 0 6px;
}
.briefing-card-head p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}
.briefing-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.briefing-field,
.briefing-import-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: rgba(15,23,42,.56);
}
.briefing-field.span-2 {
  grid-column: span 2;
}
.briefing-field span,
.briefing-import-card small {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
}
.briefing-field span i {
  display: inline-grid;
  place-items: center;
  width: 17px;
  height: 17px;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: #93c5fd;
  font-style: normal;
  font-size: 11px;
}
.briefing-field input,
.briefing-field textarea,
.briefing-import-card input {
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 8px;
  background: rgba(5,9,19,.52);
  color: var(--text);
  padding: 12px 13px;
  outline: 0;
}
.briefing-field textarea {
  min-height: 120px;
  resize: vertical;
}
.briefing-field input:focus,
.briefing-field textarea:focus,
.briefing-import-card input:focus {
  border-color: rgba(59,130,246,.72);
  box-shadow: 0 0 0 3px rgba(59,130,246,.12);
}
.briefing-validation {
  border-radius: 7px;
  padding: 7px 9px;
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
}
.briefing-validation.ok {
  color: #4ade80;
  background: rgba(34,197,94,.12);
}
.briefing-validation.warn {
  color: #fbbf24;
  background: rgba(245,158,11,.12);
}
.briefing-validation.danger {
  color: #fb7185;
  background: rgba(244,63,94,.12);
}
.briefing-performance-section {
  border-color: rgba(59,130,246,.34);
}
.briefing-import-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.briefing-import-card strong {
  font-size: clamp(20px, 2vw, 28px);
}
.briefing-import-card span {
  color: #60a5fa;
  font-size: 12px;
  font-weight: 900;
}
.briefing-ai-preview {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  border-color: rgba(124,58,237,.45);
  background: linear-gradient(135deg, rgba(37,99,235,.18), rgba(124,58,237,.18)), rgba(15,23,42,.82);
}
.briefing-ai-preview span {
  color: #a78bfa;
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.briefing-ai-preview h3 {
  margin: 8px 0;
  font-size: clamp(22px, 2.4vw, 32px);
}
.briefing-ai-preview p {
  margin: 0;
  color: #cbd5e1;
  line-height: 1.55;
}
@media (max-width: 1439px) {
  .analytics-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .meta-summary-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 1280px) {
  .analytics-filters-panel {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  .analytics-filters-panel .field.compact {
    flex: 1 1 calc(33.333% - 8px);
    min-width: 190px;
  }
  .analytics-filter-actions {
    flex: 1 1 calc(66.666% - 8px);
  }
}
@media (max-width: 1180px) {
  .active-connections-bar {
    align-items: flex-start;
    flex-direction: column;
  }
  .active-connections-main {
    align-items: flex-start;
    flex-direction: column;
    width: 100%;
  }
  .overview-period-filter {
    justify-content: flex-start;
    margin-left: 0;
    min-width: 0;
    width: 100%;
  }
  .overview-top-grid,
  .overview-main-grid,
  .overview-sync-grid {
    grid-template-columns: 1fr;
  }
  .overview-exec-kpis,
  .overview-channel-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .reconciliation-source-grid {
    grid-template-columns: 1fr;
  }
  .overview-manager-grid,
  .overview-analytic-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .bi-horizontal-funnel article {
    grid-template-columns: 1fr;
  }
  .bi-horizontal-funnel b {
    text-align: left;
  }
  .reconciliation-flow {
    display: none;
  }
  .overview-plan-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .overview-target-visual {
    display: none;
  }
  .overview-integrations-panel > div {
    grid-template-columns: repeat(4, minmax(92px, 1fr));
  }
  .alerts-summary-grid,
  .alerts-actions-panel > div {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .alerts-impact-grid,
  .alerts-main-grid {
    grid-template-columns: 1fr;
  }
  .analytics-command-page,
  .analytics-hero-grid,
  .analytics-two-col {
    grid-template-columns: 1fr;
  }
  .analytics-filters-panel {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .analytics-filter-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .analytics-filter-rail {
    position: static;
  }
  .analytics-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .analytics-score-grid,
  .analytics-insights-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .analytics-commerce-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .analytics-funnel-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .briefing-command-page {
    grid-template-columns: 1fr;
  }
  .briefing-progress-panel {
    position: static;
  }
  .briefing-import-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .active-connections-bar {
    gap: 12px;
    padding: 12px;
    overflow: hidden;
  }
  .active-connections-title {
    min-width: 0;
  }
  .overview-period-filter {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }
  .active-connection-chips {
    width: 100%;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: thin;
  }
  .overview-period-chips {
    justify-content: flex-start;
  }
  .connection-chip {
    min-width: max-content;
  }
  .overview-score-wrap,
  .overview-main-alert {
    grid-template-columns: 1fr;
  }
  .overview-score-wrap {
    align-items: flex-start;
  }
  .overview-main-alert {
    gap: 20px;
  }
  .overview-alert-illustration {
    justify-self: start;
    width: 104px;
    height: 104px;
  }
  .overview-exec-kpis,
  .overview-channel-grid,
  .overview-plan-grid {
    grid-template-columns: 1fr;
  }
  .reconciliation-ratios {
    grid-template-columns: 1fr;
  }
  .overview-manager-grid,
  .overview-analytic-grid {
    grid-template-columns: 1fr;
  }
  .view-toggle {
    width: 100%;
  }
  .view-toggle-btn {
    flex: 1 0 auto;
  }
  .overview-funnel-steps {
    grid-template-columns: 1fr;
  }
  .overview-funnel-step,
  .overview-funnel-step:first-child {
    clip-path: none;
  }
  .overview-funnel-step:not(:last-child)::after {
    display: none;
  }
  .meta-summary-kpis {
    grid-template-columns: 1fr;
  }
  .meta-view-toggle {
    width: 100%;
  }
  .meta-view-toggle button {
    flex: 1;
  }
  .meta-treemap article {
    flex-basis: 45%;
    min-width: 135px;
  }
  .overview-performance-panel .section-row,
  .overview-exec-page .next-sync-panel {
    display: grid;
    grid-template-columns: 1fr;
  }
  .overview-performance-panel .outline-purple {
    position: static;
    width: 100%;
    margin-top: 10px;
  }
  .overview-performance-panel .decision-chart {
    min-height: 240px;
  }
  .overview-integrations-panel > div {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .overview-exec-page .next-sync-panel .btn {
    grid-column: 1;
    grid-row: auto;
    width: 100%;
  }
  .alerts-summary-grid,
  .alerts-actions-panel > div {
    grid-template-columns: 1fr;
  }
  .alerts-critical-channel-card,
  .alert-impact-card,
  .alerts-donut-wrap,
  .alerts-ai-strip {
    grid-template-columns: 1fr;
  }
  .alerts-critical-channel-card button {
    grid-column: 1;
    grid-row: auto;
    width: 100%;
  }
  .alert-impact-meta {
    justify-items: start;
  }
  .alerts-donut {
    width: 190px;
    height: 190px;
  }
  .alerts-channel-panel article {
    grid-template-columns: 28px minmax(0, 1fr) auto;
  }
  .alerts-channel-panel article small {
    grid-column: 2 / -1;
    white-space: normal;
  }
  .alerts-ai-strip .btn {
    width: 100%;
  }
  .alerts-ai-strip .ai-credit-notice {
    grid-column: 1;
  }
  .analytics-executive-summary,
  .analytics-filters-panel,
  .analytics-kpi-grid,
  .analytics-score-grid,
  .analytics-insights-grid,
  .analytics-commerce-grid,
  .analytics-funnel-steps {
    grid-template-columns: 1fr;
  }
  .analytics-filters-panel {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    padding-bottom: 12px;
    scrollbar-width: thin;
  }
  .analytics-filters-panel .field.compact,
  .analytics-filter-actions {
    flex: 1 1 100%;
    min-width: 0;
  }
  .analytics-filter-actions {
    align-items: end;
  }
  .analytics-filter-actions .btn {
    flex: 1;
  }
  .analytics-funnel-steps {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: thin;
  }
  .analytics-funnel-steps article {
    flex: 0 0 170px;
  }
  .dashboard-sync-warning p {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .analytics-executive-summary .btn,
  .analytics-score-panel .actions,
  .analytics-score-panel .btn,
  .analytics-insights-panel .btn {
    width: 100%;
  }
  .analytics-performance-panel .section-row {
    display: grid;
    grid-template-columns: 1fr;
  }
  .analytics-performance-panel .decision-chart {
    min-height: 240px;
  }
  .analytics-alerts-panel article {
    grid-template-columns: 34px minmax(0, 1fr);
  }
  .analytics-alerts-panel article em {
    grid-column: 2;
  }
  .briefing-card-grid,
  .briefing-import-grid,
  .briefing-ai-preview {
    grid-template-columns: 1fr;
  }
  .briefing-field.span-2 {
    grid-column: auto;
  }
  .briefing-ai-preview .btn {
    width: 100%;
  }
  .ai-credit-notice,
  .ai-notice {
    grid-template-columns: 28px minmax(0, 1fr);
  }
  .ai-credit-notice-icon {
    width: 28px;
    height: 28px;
  }
  .ai-credit-notice-copy {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .ai-credit-notice-link {
    align-self: flex-start;
  }
}
.strategy-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(220px, .65fr);
  gap: 18px;
  align-items: center;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(47,124,255,.18), rgba(139,92,246,.12)),
    color-mix(in srgb, var(--panel) 92%, transparent);
}
.strategy-hero h2 {
  margin: 12px 0 10px;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.04;
  letter-spacing: 0;
}
.strategy-hero p {
  max-width: 780px;
  line-height: 1.55;
}
.strategy-orbit {
  position: relative;
  min-height: 210px;
  display: grid;
  place-items: center;
}
.strategy-orbit::before,
.strategy-orbit::after {
  content: "";
  position: absolute;
  border: 1px solid rgba(96, 165, 250, .32);
  border-radius: 999px;
}
.strategy-orbit::before {
  width: 180px;
  height: 180px;
  animation: spin 18s linear infinite;
}
.strategy-orbit::after {
  width: 118px;
  height: 118px;
  border-color: rgba(139, 92, 246, .34);
  animation: spin 12s linear infinite reverse;
}
.strategy-orbit span,
.strategy-orbit i,
.strategy-orbit b {
  position: absolute;
  border-radius: 999px;
  display: block;
}
.strategy-orbit span {
  width: 74px;
  height: 74px;
  background: radial-gradient(circle, rgba(139,92,246,.90), rgba(47,124,255,.30));
  box-shadow: 0 0 46px rgba(139,92,246,.28);
}
.strategy-orbit i {
  width: 14px;
  height: 14px;
  background: #60a5fa;
  transform: translate(92px, -42px);
}
.strategy-orbit b {
  width: 11px;
  height: 11px;
  background: #e12b86;
  transform: translate(-82px, 56px);
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
.strategy-layout {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.strategy-filter-card {
  align-items: center;
  gap: 12px 16px;
  background:
    linear-gradient(135deg, rgba(47,124,255,.08), rgba(34,211,238,.04)),
    color-mix(in srgb, var(--panel) 92%, transparent);
}
.strategy-filter-card > div:first-child {
  display: grid;
  gap: 4px;
}
.strategy-filter-card strong {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text);
}
.strategy-filter-card .muted.small {
  color: color-mix(in srgb, var(--muted) 88%, #cbd5e1);
}
.strategy-segments {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}
.strategy-filter-card .seg-btn {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(53,214,208,.26);
  background: rgba(53,214,208,.09);
  color: #8fe8e5;
  font-weight: 700;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
}
.strategy-filter-card .seg-btn:hover,
.strategy-filter-card .seg-btn:focus-visible {
  border-color: rgba(53,214,208,.44);
  background: rgba(53,214,208,.14);
  color: #baf5f2;
  box-shadow: 0 8px 18px rgba(7, 19, 38, .38);
}
.strategy-filter-card .seg-btn.active {
  background: linear-gradient(135deg, rgba(53,214,208,.30), rgba(26,175,169,.28));
  border-color: rgba(53,214,208,.62);
  color: #e8fffe;
  box-shadow: 0 10px 24px rgba(26,175,169,.28);
}
.strategy-tools {
  display: grid;
  gap: 12px;
  align-content: start;
}
.strategy-tool {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  color: var(--text);
  padding: 14px;
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 4px 12px;
  text-align: left;
  align-items: center;
  min-height: 92px;
}
.strategy-tool span {
  grid-row: span 2;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(47,124,255,.12);
  color: #60a5fa;
}
.strategy-tool small {
  color: var(--muted);
  line-height: 1.35;
}
.strategy-tool:hover {
  border-color: color-mix(in srgb, var(--brand) 55%, var(--line));
  background: color-mix(in srgb, var(--brand) 10%, var(--panel));
}
.strategy-workspace {
  min-height: 640px;
  display: grid;
  align-content: start;
  gap: 18px;
  overflow: hidden;
}
.strategy-workspace-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
}
.mini-context {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
  padding-bottom: 14px;
}
.mini-context span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--muted);
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
}
.strategy-empty,
.strategy-loading {
  min-height: 420px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 16px;
  text-align: center;
}
.strategy-empty .insight-list {
  width: 100%;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  text-align: left;
}
.ai-orb,
.ai-spinner {
  width: 66px;
  height: 66px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: radial-gradient(circle, rgba(139,92,246,.22), rgba(47,124,255,.14));
  border: 1px solid var(--line);
  color: #60a5fa;
  box-shadow: 0 0 38px rgba(47,124,255,.22);
}
.ai-spinner {
  animation: spin 1.4s linear infinite;
}
.strategy-loading .progress {
  width: min(480px, 100%);
  height: 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  overflow: hidden;
  background: var(--panel-2);
}
.strategy-loading .progress span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  border-radius: inherit;
  transition: width .28s ease;
}
.strategy-stages {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.strategy-stages span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.strategy-stages span.active,
.strategy-stages span.done {
  color: var(--brand-2);
  border-color: color-mix(in srgb, var(--brand-2) 45%, var(--line));
}
.strategy-result {
  display: grid;
  gap: 16px;
}
.strategy-result-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 16px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  background:
    linear-gradient(135deg, rgba(47,124,255,.14), rgba(139,92,246,.08)),
    color-mix(in srgb, var(--panel-2) 70%, transparent);
}
.strategy-result-head h2 {
  margin: 10px 0 8px;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1.08;
}
.strategy-score {
  min-height: 118px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  display: grid;
  place-items: center;
  align-content: center;
  background: rgba(255,255,255,.04);
}
.strategy-score strong {
  font-size: 34px;
  line-height: 1;
}
.strategy-score span {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .06em;
  text-align: center;
}
.strategy-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.strategy-result-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.clients-page {
  display: grid;
  gap: 18px;
}
.clients-hero {
  display: grid;
  grid-template-columns: minmax(260px, .92fr) minmax(0, 1.5fr);
  gap: 18px;
  align-items: stretch;
  background:
    radial-gradient(circle at 8% 0, color-mix(in srgb, var(--brand) 18%, transparent), transparent 34%),
    linear-gradient(135deg, color-mix(in srgb, var(--panel) 96%, transparent), color-mix(in srgb, var(--panel-2) 62%, transparent));
}
.clients-hero h2 {
  margin: 8px 0;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1.04;
  letter-spacing: -.03em;
}
.clients-hero-kpis {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-content: center;
}
.clients-hero-kpis .card.kpi {
  box-shadow: none;
  background: color-mix(in srgb, var(--panel) 78%, transparent);
}
.clients-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.client-card {
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 8px);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 96%, transparent), color-mix(in srgb, var(--panel-2) 34%, transparent)),
    var(--panel);
  box-shadow: var(--shadow);
  padding: 16px;
  display: grid;
  gap: 14px;
  min-width: 0;
}
.client-card-top,
.client-card-footer,
.client-card-actions,
.client-health > div:first-child,
.clients-error-panel,
.clients-loading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.client-card-top {
  align-items: flex-start;
}
.client-card-top > div:nth-child(2) {
  min-width: 0;
  flex: 1;
}
.client-card-top strong,
.client-table-name strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.client-card-top p,
.client-table-name small {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
}
.client-avatar {
  width: 46px;
  height: 46px;
  min-width: 46px;
  border-radius: 16px;
  display: inline-grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--brand) 42%, var(--line));
  background:
    radial-gradient(circle at 30% 16%, color-mix(in srgb, var(--brand-3) 42%, transparent), transparent 35%),
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 72%, #0b1220), color-mix(in srgb, var(--brand-2) 62%, #0b1220));
  color: #fff;
  font-weight: 950;
  letter-spacing: .04em;
}
.client-avatar.mini {
  width: 34px;
  height: 34px;
  min-width: 34px;
  border-radius: 12px;
  font-size: 11px;
}
.client-card-body {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 13px;
}
.client-card-body span,
.client-card-body a {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: inherit;
}
.client-health {
  display: grid;
  gap: 8px;
  padding: 11px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 62%, transparent);
}
.client-health small {
  color: var(--muted);
  font-weight: 850;
}
.client-health-bar {
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--line) 70%, transparent);
}
.client-health-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand), var(--brand-3));
}
.client-card-actions {
  justify-content: flex-end;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}
.client-table-name {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 240px;
}
.clients-table-wrap table {
  min-width: 900px;
}
.clients-empty-state {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 26px;
  align-items: center;
  min-height: 320px;
  padding: clamp(18px, 4vw, 34px);
  background:
    radial-gradient(circle at 16% 22%, color-mix(in srgb, var(--brand) 24%, transparent), transparent 30%),
    linear-gradient(135deg, color-mix(in srgb, var(--panel) 96%, transparent), color-mix(in srgb, var(--panel-2) 68%, transparent));
}
.clients-empty-state h2 {
  margin: 8px 0;
  font-size: clamp(24px, 3vw, 36px);
  letter-spacing: -.03em;
}
.clients-empty-visual {
  position: relative;
  min-height: 190px;
  border-radius: 28px;
  border: 1px solid color-mix(in srgb, var(--brand) 34%, var(--line));
  background:
    radial-gradient(circle at 28% 24%, rgba(255,255,255,.32), transparent 24%),
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 78%, #101827), color-mix(in srgb, var(--brand-2) 58%, #101827));
  display: grid;
  place-items: center;
  overflow: hidden;
  color: #fff;
  box-shadow: 0 26px 70px color-mix(in srgb, var(--brand) 24%, transparent);
}
.clients-empty-visual span {
  font-size: 42px;
  font-weight: 950;
  z-index: 1;
}
.clients-empty-visual i,
.clients-empty-visual b {
  position: absolute;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
}
.clients-empty-visual i {
  width: 160px;
  height: 160px;
}
.clients-empty-visual b {
  width: 230px;
  height: 230px;
  opacity: .48;
}
.clients-empty-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 16px 0;
}
.clients-empty-steps span,
.client-card-footer .badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.client-card-footer .badge.ok {
  color: var(--ok);
  border-color: color-mix(in srgb, var(--ok) 38%, var(--line));
}
.clients-error-panel {
  border-color: color-mix(in srgb, var(--danger) 45%, var(--line));
  background: color-mix(in srgb, var(--danger) 8%, var(--panel));
}
.clients-loading {
  justify-content: flex-start;
}
.client-skeleton {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  background: linear-gradient(90deg, var(--panel-2), color-mix(in srgb, var(--brand) 18%, var(--panel-2)), var(--panel-2));
  background-size: 220% 100%;
  animation: clientSkeleton 1.2s ease-in-out infinite;
}
@keyframes clientSkeleton {
  0% { background-position: 0% 50%; }
  100% { background-position: 220% 50%; }
}
.client-modal-head {
  align-items: flex-start;
}
.client-form {
  gap: 16px;
}
.client-form-section {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 54%, transparent);
}
.client-form-section > div:first-child {
  grid-column: 1 / -1;
}
.client-form-section strong {
  display: block;
}
.client-form-section small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
}
.client-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
.strategy-block {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
  padding: 16px;
  min-width: 0;
}
.strategy-block h3 {
  margin: 0 0 8px;
}
.strategy-block p,
.strategy-block li {
  color: var(--muted);
  line-height: 1.5;
}
.strategy-input {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px;
  background:
    linear-gradient(135deg, rgba(47,124,255,.10), rgba(139,92,246,.06)),
    color-mix(in srgb, var(--panel-2) 72%, transparent);
  position: sticky;
  bottom: 0;
}
.strategy-input input {
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--text);
  border-radius: var(--radius);
  min-height: 48px;
  padding: 0 14px;
}
.source-divider {
  border: 1px solid var(--line);
  border-left: 4px solid var(--brand-2);
  border-radius: var(--radius);
  padding: 14px 16px;
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.source-divider span {
  font-weight: 900;
}
.source-divider small {
  color: var(--muted);
  line-height: 1.35;
}
.modal-backdrop {
  position: fixed; inset: 0; z-index: 50;
  background: rgba(15,20,27,.58);
  display: grid; place-items: center; padding: 20px;
  animation: modalFadeIn .18s ease-out;
}
.modal {
  background: var(--panel);
  color: var(--text);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  width: min(980px, 100%);
  max-height: 88vh;
  overflow: auto;
  padding: 20px;
  box-shadow: var(--shadow);
  animation: modalScaleIn .2s ease-out;
}
@keyframes modalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes modalScaleIn {
  from { opacity: 0; transform: translateY(8px) scale(.97); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.modal-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-grid .field { margin-bottom: 0; }
.form-grid .field input,
.form-grid .field select,
.form-grid .field textarea {
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel-2) 72%, var(--panel));
}
.span-2 { grid-column: span 2; }
.cookie-consent {
  position: fixed;
  left: 20px;
  right: 20px;
  bottom: 20px;
  z-index: 80;
  max-width: 980px;
  margin: 0 auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow);
  padding: 14px;
  display: grid;
  gap: 12px;
}
.cookie-consent p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}
.cookie-consent-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.cookie-consent-actions .btn {
  min-height: 40px;
}
.cookie-consent-form {
  display: grid;
  gap: 12px;
}
.cookie-type-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-2) 64%, transparent);
}
.cookie-type-row p {
  margin: 4px 0 0;
}
.cookie-consent-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.switch {
  position: relative;
  display: inline-block;
  width: 46px;
  height: 28px;
}
.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.switch span {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 82%, transparent);
  transition: .2s ease;
}
.switch span::before {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  left: 3px;
  top: 3px;
  border-radius: 50%;
  background: var(--text);
  transition: .2s ease;
}
.switch input:checked + span {
  background: color-mix(in srgb, var(--brand) 30%, var(--panel));
  border-color: color-mix(in srgb, var(--brand) 65%, var(--line));
}
.switch input:checked + span::before {
  transform: translateX(18px);
  background: var(--brand);
}
.switch input:disabled + span {
  opacity: .65;
}
.ai-credit-notice,
.ai-notice {
  border: 1px solid color-mix(in srgb, var(--brand) 42%, var(--line));
  border-radius: 14px;
  background:
    radial-gradient(circle at 0 0, color-mix(in srgb, var(--brand) 18%, transparent), transparent 34%),
    linear-gradient(135deg, color-mix(in srgb, #0b1220 82%, var(--brand) 18%), color-mix(in srgb, #0b1220 78%, var(--brand-2) 22%));
  color: var(--text);
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04), 0 14px 42px rgba(30, 64, 175, .12);
}
.ai-credit-notice.compact {
  margin-top: 10px;
}
.ai-credit-notice.full {
  margin: 12px 0;
}
.ai-credit-notice-icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #c7d8ff;
  background: linear-gradient(135deg, color-mix(in srgb, var(--brand) 26%, transparent), color-mix(in srgb, var(--brand-2) 24%, transparent));
  border: 1px solid color-mix(in srgb, var(--brand) 45%, transparent);
}
.ai-credit-notice-icon svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2;
}
.ai-credit-notice-copy p {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
}
.ai-credit-notice-copy p + p {
  margin-top: 4px;
}
.ai-credit-notice-copy {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-width: 0;
}
.ai-credit-notice-text {
  min-width: 0;
}
.ai-credit-notice-text small {
  display: block;
  margin-top: 7px;
  color: var(--muted);
}
.ai-credit-notice-link {
  border: 0;
  background: transparent;
  color: #8fb4ff;
  font-weight: 700;
  font-size: 12px;
  padding: 0;
  cursor: pointer;
  flex: 0 0 auto;
  white-space: nowrap;
}
.ai-credit-notice-link:hover {
  color: #b5c9ff;
  text-decoration: underline;
}
.ai-credit-tip {
  border-bottom: 1px dashed color-mix(in srgb, var(--brand) 70%, transparent);
  cursor: help;
}
.report-workspace {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.report-sidebar,
.report-main {
  display: grid;
  gap: 14px;
  min-width: 0;
}
.report-template {
  border: 1px solid var(--line);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(47,124,255,.12), rgba(139,92,246,.06)),
    color-mix(in srgb, var(--panel) 90%, transparent);
  color: var(--text);
  padding: 16px;
  min-height: 82px;
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 4px 12px;
  align-items: center;
  text-align: left;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.report-template span {
  grid-row: span 2;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(47,124,255,.14);
  color: #60a5fa;
}
.report-template strong { font-size: 16px; }
.report-template small { color: var(--muted); line-height: 1.35; }
.report-template:hover,
.report-template.active {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--brand) 58%, var(--line));
  background:
    linear-gradient(135deg, rgba(47,124,255,.18), rgba(139,92,246,.10)),
    var(--panel);
}
.report-schedule-card,
.report-builder-cta,
.report-list-panel {
  display: grid;
  gap: 14px;
}
.report-schedule-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
  padding: 16px;
}
.report-row {
  position: relative;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel-2) 52%, transparent);
  padding: 16px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}
.report-row .actions {
  justify-content: flex-end;
}
.report-icon,
.plus-orb {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(47,124,255,.14);
  color: #60a5fa;
}
.report-hover-preview {
  grid-column: 2 / -1;
  display: none;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px;
  background: var(--panel);
  max-height: 240px;
  overflow: auto;
}
.report-row:hover .report-hover-preview {
  display: block;
}
.report-builder-cta {
  align-content: start;
  padding: 26px;
}
.builder { display: grid; grid-template-columns: 340px 1fr; gap: 18px; }
.report-builder-layout {
  grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
  align-items: start;
}
.report-builder-hero,
.export-hero {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
  background:
    linear-gradient(135deg, rgba(47,124,255,.14), rgba(139,92,246,.08)),
    color-mix(in srgb, var(--panel) 92%, transparent);
}
.report-builder-hero h2,
.export-hero h2 {
  margin: 10px 0 8px;
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.06;
}
.report-ai-summary {
  min-width: 260px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 78%, transparent);
  padding: 14px;
  display: grid;
  gap: 9px;
}
.report-ai-summary span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}
.report-control-panel {
  position: sticky;
  top: 92px;
  display: grid;
  gap: 16px;
}
.builder-templates {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.template-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
  color: var(--text);
  min-height: 68px;
  padding: 12px 14px;
  display: grid;
  gap: 4px;
  text-align: left;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.template-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--brand) 55%, var(--line));
  background: color-mix(in srgb, var(--brand) 10%, var(--panel-2));
}
.template-card small {
  color: var(--muted);
  line-height: 1.35;
}
.form-grid.compact {
  grid-template-columns: 1fr;
  gap: 0;
}
.metric-picker {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 58%, transparent);
  padding: 14px;
  display: grid;
  gap: 12px;
}
.drag-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.metric-chip {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--text);
  min-height: 44px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  font-weight: 850;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.metric-chip span {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--panel-2);
  color: var(--brand);
  font-size: 12px;
}
.metric-chip span svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.metric-chip:hover,
.metric-chip.selected {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--brand) 60%, var(--line));
  background: color-mix(in srgb, var(--brand) 12%, var(--panel));
}
.metric-chip.selected span {
  background: var(--brand);
  color: #fff;
}
.hidden-metrics { display: none; }
.unified-filters {
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel-2) 65%, transparent), transparent 38%),
    var(--panel);
  padding: 14px;
  gap: 12px;
}
.unified-filters-head {
  align-items: flex-start;
  gap: 10px;
}
.unified-filters-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px 12px;
}
.unified-filters .field.compact {
  margin: 0;
}
.unified-filters .field.compact label {
  font-size: 12px;
  margin-bottom: 6px;
}
.unified-filters .field.compact select,
.unified-filters .field.compact input {
  min-height: 40px;
  padding: 8px 11px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel-2) 84%, transparent);
}
.unified-filters.collapsed .unified-filters-grid {
  display: none;
}
.mini-bars {
  display: grid;
  gap: 10px;
}
.mini-bar {
  display: grid;
  gap: 6px;
}
.mini-bar > div {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: baseline;
}
.mini-bar b {
  display: block;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  min-width: 8px;
}
.report-preview-panel {
  display: grid;
  gap: 16px;
  min-height: 640px;
  transition: border-color .18s ease, box-shadow .18s ease;
}
.report-preview-panel.drag-over {
  border-color: var(--brand-2);
  box-shadow: var(--shadow), 0 0 0 3px rgba(139,92,246,.16);
}
.report-preview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
  gap: 16px;
}
.report-ai-card {
  background:
    linear-gradient(135deg, rgba(139,92,246,.10), rgba(47,124,255,.08)),
    color-mix(in srgb, var(--panel) 92%, transparent);
}
.report-ai-card p {
  color: var(--muted);
  line-height: 1.5;
}
.report-creator-page {
  display: grid;
  gap: 16px;
}
.report-creator-page .page-head {
  align-items: start;
}
.plus-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 6px;
  background: rgba(10, 15, 28, .55);
  color: #fff;
  font-size: 11px;
  font-weight: 950;
}
.report-filter-bar {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 10px;
  position: relative;
}
.report-filter-card {
  min-height: 58px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--panel-2) 72%, transparent), color-mix(in srgb, var(--panel) 96%, transparent));
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 4px 10px;
  align-items: center;
  padding: 10px 12px;
  overflow: hidden;
}
.report-filter-card > span {
  grid-row: span 2;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: #9fb7ff;
  background: rgba(59,130,246,.10);
}
.report-filter-card svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
}
.report-filter-card em,
.report-filter-card label {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}
.report-filter-card strong,
.report-filter-card select {
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--text);
  font-weight: 900;
  padding: 0;
  outline: 0;
}
.report-filter-card small {
  grid-column: 2;
  color: var(--muted);
  font-size: 11px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.report-metric-drawer {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 4px 0 2px;
}
.report-creator-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
  gap: 14px;
  align-items: start;
}
.report-creator-main {
  display: grid;
  gap: 14px;
  min-width: 0;
}
.report-kpi-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}
.report-kpi-card {
  min-height: 104px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--panel-2) 72%, transparent), color-mix(in srgb, var(--panel) 96%, transparent));
  padding: 16px;
  overflow: hidden;
}
.report-kpi-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}
.report-kpi-card strong {
  display: block;
  margin: 10px 0 6px;
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.report-kpi-card small {
  color: #22c55e;
  font-weight: 900;
}
.report-kpi-card small.bad {
  color: #fb7185;
}
.report-creator-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, .75fr);
  gap: 12px;
}
.report-chart-panel,
.report-quick-insights,
.report-table-panel,
.report-ai-drawer,
.report-mode-card {
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(15,27,48,.92), rgba(8,14,27,.84)),
    radial-gradient(circle at 92% 8%, rgba(59,130,246,.10), transparent 28%);
}
.legend-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 3px;
  margin: 0 6px 0 14px;
}
.legend-dot:first-child {
  margin-left: 0;
}
.legend-dot.purple { background: var(--brand-2); }
.legend-dot.blue { background: #3b82f6; }
.report-main-chart {
  width: 100%;
  height: 260px;
  display: block;
}
.report-quick-insights {
  display: grid;
  gap: 14px;
  align-content: start;
}
.report-quick-insights ul,
.report-mode-card ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}
.report-quick-insights li {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 10px;
  color: var(--muted);
  line-height: 1.45;
}
.report-quick-insights li svg {
  width: 18px;
  height: 18px;
  color: var(--brand-2);
}
.report-table-panel {
  display: grid;
  gap: 12px;
}
.report-table-panel .campaign-table-wrap {
  max-height: 270px;
  overflow: auto;
}
.report-table-footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.pager {
  display: flex;
  gap: 8px;
  align-items: center;
}
.report-ai-drawer {
  border-color: color-mix(in srgb, var(--brand-2) 72%, var(--line));
  box-shadow: 0 0 0 1px rgba(124,58,237,.20), 0 18px 50px rgba(124,58,237,.12);
  display: grid;
  gap: 16px;
  position: sticky;
  top: 88px;
}
.report-ai-message {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(15, 23, 42, .54);
  padding: 14px;
  color: var(--muted);
  line-height: 1.55;
}
.report-ai-drawer h4 {
  margin: 0;
}
.report-ai-suggestions {
  display: grid;
  gap: 10px;
}
.report-ai-suggestions article {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--panel-2) 68%, transparent);
  padding: 10px;
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 9px;
  color: var(--muted);
  line-height: 1.4;
}
.report-ai-suggestions svg {
  width: 17px;
  height: 17px;
  color: #a78bfa;
}
.report-creator-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.2fr;
  gap: 12px;
}
.report-mode-card {
  display: grid;
  gap: 10px;
}
.report-mode-card h3 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
}
.report-mode-card h3 svg {
  width: 19px;
  height: 19px;
  color: var(--brand-2);
}
.report-mode-card li {
  color: var(--muted);
  line-height: 1.5;
}
.report-mode-card li::before {
  content: "âœ“";
  color: #c4b5fd;
  margin-right: 8px;
}
.report-mode-card.plus {
  border-color: rgba(124,58,237,.42);
}
.export-shell {
  display: grid;
  gap: 18px;
  width: 100%;
  max-width: 100%;
}
.export-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  min-width: 0;
}
.export-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 18px;
  align-items: start;
  min-width: 0;
}
.export-main,
.export-side {
  display: grid;
  gap: 16px;
  min-width: 0;
}
.export-hero {
  min-width: 0;
}
.export-hero > div {
  min-width: 0;
}
.export-hero h2 {
  max-width: 100%;
  overflow-wrap: break-word;
}
.export-hero p {
  max-width: 100%;
  line-height: 1.45;
}
.pillbox { display: flex; flex-wrap: wrap; gap: 8px; }
.pillbox label {
  border: 1px solid var(--line);
  padding: 8px 10px;
  border-radius: 999px;
  display: inline-flex;
  gap: 6px;
  align-items: center;
  color: var(--muted);
  font-weight: 750;
}
.chat { display: grid; grid-template-rows: auto 1fr auto auto; height: min(720px, calc(100vh - 210px)); min-height: 560px; gap: 12px; }
.chat-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 12px;
}
.messages { overflow: auto; display: grid; align-content: start; gap: 14px; padding: 4px; }
.msg-row { display: flex; justify-content: flex-start; }
.msg-row.me { justify-content: flex-end; }
.msg { max-width: min(720px, 78%); padding: 13px 15px; border-radius: 16px 16px 16px 6px; background: var(--panel-2); line-height: 1.45; }
.msg.me { border-radius: 16px 16px 6px 16px; background: var(--brand); color: #fff; }
.chat .messages {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  background: color-mix(in srgb, var(--panel-2) 58%, transparent);
}
.msg {
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
}
.msg.me { background: linear-gradient(135deg, var(--brand), var(--brand-2)); }
.chat-input { display: grid; grid-template-columns: 1fr auto; gap: 10px; margin-top: 0; }
.chat-input input {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  color: var(--text);
  min-height: 48px;
  padding: 0 14px;
}
.chat-disclaimer {
  margin-top: 12px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}
.ai-report h3, .report-story h3 { margin: 14px 0 8px; }
.ai-report p, .report-story p { line-height: 1.5; }
.users-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(380px, .85fr);
  gap: 18px;
  align-items: start;
}
.admin-manager-layout {
  grid-template-columns: minmax(460px, .95fr) minmax(520px, 1.05fr);
  align-items: start;
}
.admin-manager-layout .panel,
.admin-table-wrap {
  min-width: 0;
  max-width: 100%;
}
.admin-table-wrap table {
  min-width: 720px;
}
.admin-table-wrap td:first-child,
.admin-table-wrap td:nth-child(2),
.admin-table-wrap td:nth-child(3) {
  white-space: normal;
  min-width: 130px;
}
.admin-table-wrap td,
.admin-table-wrap th {
  vertical-align: middle;
}
.master-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ad-history {
  max-height: min(720px, calc(100vh - 230px));
  overflow: auto;
  padding-right: 6px;
}
.ad-generation-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 64%, transparent);
  padding: 16px;
  margin-bottom: 14px;
  overflow-wrap: anywhere;
}
.ad-generation-card ol {
  margin: 8px 0 16px;
  padding-left: 22px;
  color: var(--muted);
  line-height: 1.45;
}
.ad-generation-card h4 {
  margin: 14px 0 4px;
}
.admin-table-wrap td:first-child {
  min-width: 210px;
}
.admin-table-wrap .master-actions {
  min-width: 180px;
}
.permission-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.check-card,
.permission-row {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  padding: 10px;
}
.check-card {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 54px;
}
.check-card input { width: 18px; height: 18px; accent-color: var(--brand); }
.check-card span { display: grid; gap: 2px; line-height: 1.2; }
.check-card small { color: var(--muted); font-size: 11px; }
.permission-groups {
  display: grid;
  gap: 12px;
}
.permission-group {
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-2) 74%, transparent);
  border-radius: var(--radius);
  padding: 12px;
}
.permission-group h4 { margin: 0 0 10px; font-size: 14px; }
.permission-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 170px;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  padding: 8px 10px;
}
.permission-row select {
  min-height: 36px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  border-radius: var(--radius);
  padding: 0 10px;
}
.ad-history {
  display: grid;
  gap: 14px;
  max-height: 680px;
  overflow: auto;
}
.ad-generation-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  padding: 14px;
}
.ad-generation-card h4 { margin: 14px 0 8px; }
.ad-generation-card ol { margin: 0; padding-left: 22px; color: var(--muted); line-height: 1.45; }
.ad-generation-card .pillbox span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  color: var(--text);
  background: var(--panel);
}
.blocked-panel {
  border-color: rgba(239, 68, 68, .46);
  background:
    linear-gradient(135deg, rgba(239, 68, 68, .14), transparent 44%),
    color-mix(in srgb, var(--panel) 92%, transparent);
}
.billing-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.plan-mini {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 84%, transparent);
  padding: 16px;
}
.plan-mini .label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.plan-mini .value {
  margin-top: 8px;
  color: var(--text);
  font-size: 22px;
  font-weight: 900;
}
.master-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 10px;
  color: var(--text);
  background: var(--panel-2);
  font-size: 12px;
  font-weight: 900;
}
.master-status::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--accent);
}
.master-status.warn::before { background: var(--warn); }
.master-status.danger::before { background: var(--danger); }
.master-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.toast {
  position: fixed;
  right: 20px;
  bottom: 20px;
  background: var(--ink);
  color: var(--panel);
  border-radius: var(--radius);
  padding: 12px 14px;
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: .2s ease;
  z-index: 100;
}
.toast.toast-ok { border: 1px solid rgba(34, 197, 94, .35); }
.toast.toast-warn { border: 1px solid rgba(245, 158, 11, .45); }
.toast.toast-bad {
  border: 1px solid rgba(239, 68, 68, .55);
  background: rgba(40, 10, 10, .95);
  color: #ffe4e4;
}
.toast.show { opacity: 1; transform: translateY(0); }
.mobile-menu { display: none; }

@media (max-width: 1080px) {
  .grid.kpis { grid-template-columns: repeat(3, minmax(220px, 1fr)); }
  .grid.two, .grid.three { grid-template-columns: 1fr 1fr; }
  .landing-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .insight-list, .decision-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .landing-hero, .request-layout { grid-template-columns: 1fr; }
  .builder { grid-template-columns: 320px 1fr; }
  .filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .users-layout { grid-template-columns: 1fr; }
  .app-shell { grid-template-columns: 240px 1fr; }
  .admin-shell { grid-template-columns: 220px 1fr; }
  .decision-kpi-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .overview-layout, .decision-brief { grid-template-columns: 1fr; }
  .overview-alerts-grid { grid-template-columns: 1fr; }
  .strategy-layout, .strategy-hero { grid-template-columns: 1fr; }
  .unified-filters-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .report-builder-layout,
  .report-workspace,
  .report-preview-grid,
  .export-grid,
  .admin-manager-layout {
    grid-template-columns: 1fr;
  }
  .report-control-panel {
    position: static;
  }
  .report-builder-hero,
  .export-hero {
    display: grid;
  }
  .strategy-tools {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .strategy-tool {
    grid-template-columns: 1fr;
  }
  .sidebar { padding: 18px 12px; }
  .nav button { font-size: 14px; }
  .nav-title { padding-left: 10px; }
  .topbar { padding: 0 18px; }
  .content { padding: 22px 18px; }
  .aurix-public-nav nav { display: none; }
  .aurix-public-hero,
  .split-section,
  .leak-grid,
  .ai-section,
  .final-cta {
    grid-template-columns: 1fr;
  }
  .aurix-public-hero {
    gap: 26px;
  }
  .landing-metric-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 920px) {
  .grid.two, .grid.three, .builder { grid-template-columns: 1fr; }
  .msg { max-width: 88%; }
  .strategy-tools,
  .strategy-empty .insight-list {
    grid-template-columns: 1fr;
  }
  .strategy-kpi-row,
  .strategy-result-grid,
  .strategy-result-head {
    grid-template-columns: 1fr;
  }
  .strategy-workspace-head {
    grid-template-columns: 1fr;
  }
  .mini-context {
    justify-content: flex-start;
    padding-bottom: 0;
  }
}

@media (max-width: 760px) {
  .landing-shell { padding: 14px; }
  .landing-nav { align-items: flex-start; }
  .landing-hero, .request-layout { padding: 28px 0; }
  .landing-grid, .landing-grid.three { grid-template-columns: 1fr; }
  .insight-list, .decision-grid, .onboarding-items { grid-template-columns: 1fr; }
  .onboarding-panel, .section-row { display: grid; }
  .dashboard-preview { min-height: 340px; padding: 16px; }
  .preview-kpis { grid-template-columns: 1fr; }
  .auth-shell { grid-template-columns: 1fr; }
  .auth-hero { min-height: 340px; padding: 32px 22px; }
  .auth-hero h1 { font-size: 34px; }
  .auth-panel { padding: 28px 18px; }
  .app-shell { grid-template-columns: 1fr; }
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar {
    position: fixed;
    z-index: 30;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(86vw, 320px);
    height: 100vh;
    transform: translateX(-105%);
    transition: .2s ease;
    border-right: 1px solid var(--line);
    border-bottom: 0;
    box-shadow: var(--shadow);
  }
  .admin-sidebar.open { transform: translateX(0); }
  .sidebar {
    position: fixed;
    z-index: 30;
    left: 0;
    top: 0;
    bottom: 0;
    height: 100vh;
    transform: translateX(-105%);
    transition: .2s ease;
    width: min(86vw, 320px);
    box-shadow: var(--shadow);
  }
  .sidebar.open { transform: translateX(0); }
  .mobile-sidebar-open { overflow: hidden; }
  .mobile-menu { display: inline-flex; }
  .mobile-top-brand {
    display: inline-flex;
    min-width: 0;
    flex: 1;
  }
  .mobile-top-brand .brand-copy small { display: none; }
  .mobile-top-brand .brand-logo-img {
    width: 34px;
    height: 34px;
  }
  .topbar-primary > strong {
    display: none;
  }
  .topbar {
    padding: 10px 14px;
    height: auto;
    min-height: 64px;
    align-items: flex-start;
    display: grid;
    grid-template-columns: 1fr;
  }
  .topbar > .actions {
    width: 100%;
    justify-content: space-between;
  }
  .admin-topbar-context {
    grid-template-columns: auto minmax(0, 1fr);
  }
  .admin-topbar-context > span:last-child {
    display: none;
  }
  .topbar select {
    flex: 1;
    min-width: 0;
    max-width: 100%;
  }
  .cookie-consent {
    left: 12px;
    right: 12px;
    bottom: 12px;
    padding: 12px;
  }
  .cookie-consent-actions .btn,
  .cookie-consent-modal-actions .btn {
    width: 100%;
    flex: 1 1 100%;
  }
  .cookie-type-row {
    align-items: flex-start;
  }
  .content { padding: 16px 12px; }
  .clients-hero,
  .clients-empty-state {
    grid-template-columns: 1fr;
  }
  .clients-hero-kpis {
    grid-template-columns: 1fr;
  }
  .clients-empty-visual {
    min-height: 150px;
  }
  .client-form-section {
    grid-template-columns: 1fr;
  }
  .client-card-footer,
  .client-card-actions,
  .clients-error-panel {
    align-items: stretch;
    flex-direction: column;
  }
  .client-card-actions .btn,
  .clients-error-panel .btn,
  .client-form-actions .btn {
    width: 100%;
  }
  .client-form-actions {
    flex-direction: column-reverse;
  }
  .grid.kpis, .grid.two, .grid.three, .filters, .form-grid, .builder, .admin-manager-layout { grid-template-columns: 1fr; }
  .report-row {
    grid-template-columns: 1fr;
  }
  .report-row .actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }
  .report-hover-preview {
    grid-column: auto;
  }
  .decision-kpi-grid { grid-template-columns: 1fr; }
  .unified-filters-grid { grid-template-columns: 1fr; }
  .source-divider { display: grid; }
  .permission-grid, .permission-groups { grid-template-columns: 1fr; }
  .permission-row { grid-template-columns: 1fr; }
  .billing-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .span-2 { grid-column: auto; }
  .page-head { display: grid; }
  .page-head h1 { font-size: 24px; }
  .page-head > .actions {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
  }
  .page-head .actions .btn { width: 100%; min-width: 0; }
  .channel-filter {
    align-items: stretch;
  }
  .channel-filter .segments {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .period-segments {
    justify-content: stretch;
  }
  .app-footer {
    display: grid;
    padding: 16px 14px calc(22px + 68px + env(safe-area-inset-bottom));
  }
  .overview-alert-card {
    grid-template-columns: 42px 1fr;
  }
  .overview-alert-card > span {
    grid-column: 2;
    width: max-content;
  }
  .strategy-orbit {
    min-height: 150px;
  }
  .strategy-workspace {
    min-height: auto;
  }
  .strategy-input {
    grid-template-columns: 1fr;
    position: static;
  }
  .seg-btn, .btn, .tab-btn, .icon-btn {
    min-height: 44px;
    padding: 0 12px;
  }
  .kpi .value { font-size: clamp(18px, 4.8vw, 24px); }
  .chart { height: 260px; }
  .mini-chart { height: 170px; }
  table { min-width: 880px; }
  th, td { padding: 10px; }
  .modal-backdrop {
    padding: 0;
    align-items: stretch;
  }
  .modal {
    width: 100%;
    min-height: 100vh;
    max-height: 100vh;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    padding: 18px 14px;
  }
  .modal-head {
    position: sticky;
    top: 0;
    z-index: 1;
    background: var(--panel);
    padding-bottom: 12px;
    align-items: flex-start;
    gap: 12px;
  }
  .chat {
    height: calc(100vh - 190px);
    min-height: 520px;
  }
  .chat-input {
    grid-template-columns: 1fr;
  }
  .msg { max-width: 94%; }
  .auth-tabs { grid-template-columns: 1fr; }
  .toast {
    left: 14px;
    right: 14px;
    bottom: 14px;
  }
  .aurix-public-landing {
    padding: 12px;
  }
  .aurix-public-nav {
    position: static;
    display: grid;
    gap: 12px;
  }
  .aurix-public-nav .actions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }
  .aurix-public-hero {
    padding-top: 18px;
  }
  .aurix-public-hero h1 {
    font-size: clamp(36px, 11vw, 52px);
  }
  .mock-grid,
  .mock-main,
  .comparison-grid,
  .landing-metric-row {
    grid-template-columns: 1fr;
  }
  .mock-score {
    grid-template-columns: 1fr;
  }
  .score-ring {
    width: 96px;
    height: 96px;
  }
  .landing-section {
    padding: 48px 0;
  }
  .landing-section-head {
    text-align: left;
  }
  .ai-section,
  .final-cta {
    padding: 20px;
  }
  .landing-footer {
    display: grid;
  }
  .drag-metrics {
    grid-template-columns: 1fr;
  }
  .export-actions {
    justify-content: stretch;
  }
  .export-actions .btn {
    width: 100%;
  }
  .floating-whatsapp-wrap {
    right: 14px;
    bottom: calc(14px + env(safe-area-inset-bottom));
    width: 52px;
    height: 52px;
  }
  .floating-whatsapp:not(.static) {
    width: 52px;
    height: 52px;
    min-height: 52px;
    padding: 0;
  }
  .user-chip {
    max-width: 100%;
  }
  .user-chip span:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}

@media (max-width: 430px) {
  .auth-hero { min-height: 300px; }
  .auth-hero h1 { font-size: 30px; }
  .brand { font-size: 17px; }
  .content { padding: 14px 10px; gap: 16px; }
  .panel, .card { padding: 14px; }
  .page-head h1 { font-size: 22px; }
  .page-head p { font-size: 14px; }
  .channel-filter .segments {
    grid-template-columns: 1fr;
  }
  .actions {
    width: 100%;
  }
  .actions .btn, .actions select {
    flex: 1 1 100%;
  }
  .page-head > .actions {
    grid-template-columns: 1fr;
  }
  .grid { gap: 12px; }
  .billing-summary { grid-template-columns: 1fr; }
  .kpi .value { font-size: clamp(18px, 6vw, 22px); white-space: nowrap; }
  .field input, .field select, .field textarea {
    font-size: 16px;
  }
  .chat { min-height: 500px; }
  .chat-head { align-items: flex-start; }
}

/* Incremental UI hardening: reports, integrations, scripts and responsive tables */
.filters {
  grid-template-columns: repeat(4, minmax(180px, 1fr)) minmax(180px, .9fr);
}
.filters .btn {
  height: 54px;
  align-self: end;
}

.report-row-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(47,124,255,.08), rgba(139,92,246,.05)),
    color-mix(in srgb, var(--panel-2) 58%, transparent);
  padding: 16px;
  display: grid;
  gap: 14px;
  min-width: 0;
}
.report-row-top {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}
.report-row-copy {
  min-width: 0;
}
.report-row-copy strong,
.campaign-name strong {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.report-row-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}
.report-row-actions .btn {
  min-width: 92px;
}
.report-preview-details {
  border-top: 1px solid var(--line);
  padding-top: 10px;
}
.report-preview-details summary {
  cursor: pointer;
  color: var(--muted);
  font-weight: 800;
}
.report-preview-details .report-hover-preview {
  display: block;
  margin-top: 10px;
  max-height: 260px;
}

.ad-generator-layout {
  grid-template-columns: minmax(360px, 1fr) minmax(360px, 1fr);
  align-items: start;
}
.ad-history-panel {
  position: sticky;
  top: 18px;
}
.ad-history-control {
  margin: 12px 0;
}
.ad-history-preview {
  max-height: min(690px, calc(100vh - 330px));
  overflow: auto;
  padding-right: 6px;
}
.ad-history-preview .ad-generation-card {
  margin-bottom: 0;
}
.badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.ai-credit-kpi-grid.is-loading .ai-kpi-card,
#ai-credit-kpis.is-loading .kpi {
  position: relative;
  overflow: hidden;
}
.ai-credit-kpi-grid.is-loading .kpi::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  animation: aiShimmer 1.1s linear infinite;
}
@keyframes aiShimmer {
  from { transform: translateX(-100%); }
  to { transform: translateX(100%); }
}
.ai-kpi-card {
  animation: aiEnter .18s ease both;
}
@keyframes aiEnter {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.ai-kpi-card:hover { transform: scale(1.02); transition: transform .16s ease; }
.ai-kpi-card:active { transform: scale(.98); }
.live-dot {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--muted);
}
.live-dot span {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #34d399;
  box-shadow: 0 0 0 0 rgba(52,211,153,.6);
  animation: aiPulse 1.6s infinite;
}
@keyframes aiPulse {
  70% { box-shadow: 0 0 0 8px rgba(52,211,153,0); }
  100% { box-shadow: 0 0 0 0 rgba(52,211,153,0); }
}
.ai-kpi-card.is-low {
  border-color: rgba(229,72,77,.5);
  box-shadow: 0 0 0 1px rgba(229,72,77,.2), 0 0 26px rgba(229,72,77,.16);
}
.ai-kpi-card.is-critical {
  animation: aiBreath 1.9s ease-in-out infinite;
}
@keyframes aiBreath {
  50% { box-shadow: 0 0 0 1px rgba(229,72,77,.36), 0 0 30px rgba(229,72,77,.2); }
}
.ai-mini-line {
  height: 20px;
  margin-top: 4px;
  overflow: hidden;
}
.ai-mini-line i {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 35%, rgba(47,124,255,.35) 35%, rgba(47,124,255,.18) 100%);
  clip-path: polygon(0% 80%, 14% 65%, 26% 72%, 38% 40%, 52% 58%, 66% 30%, 78% 46%, 100% 12%, 100% 100%, 0 100%);
}
.ai-package-card {
  display: grid;
  gap: 8px;
  align-content: start;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.ai-package-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--brand) 45%, var(--line));
}
.ai-package-card.is-featured {
  border-color: color-mix(in srgb, var(--brand-2) 60%, var(--line));
  box-shadow: 0 0 0 1px rgba(139,92,246,.24), 0 0 24px rgba(139,92,246,.18);
}
.ai-package-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.ai-credit-history-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.ai-credit-history-controls select,
.ai-credit-history-controls input {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  color: var(--text);
  padding: 0 12px;
}
.admin-ai-control-panel {
  margin-bottom: 16px;
}
.admin-ai-filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}
.admin-ai-filters label {
  display: grid;
  gap: 7px;
  min-width: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.admin-ai-filters select,
.admin-ai-filters input {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel-2) 88%, transparent);
  color: var(--text);
  padding: 0 12px;
}
.admin-ai-kpis {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}
.admin-ai-main-grid {
  align-items: start;
}
.admin-sync-control-panel {
  display: grid;
  gap: 14px;
  margin-bottom: 16px;
}
.admin-sync-actions {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: 12px;
  align-items: end;
}
.admin-sync-actions label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.admin-sync-actions select {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel-2) 88%, transparent);
  color: var(--text);
  padding: 0 12px;
}
.admin-sync-kpis {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}
.admin-sync-main-grid {
  align-items: start;
}
.admin-ai-control-shell {
  display: grid;
  gap: 16px;
}
.admin-ai-control-grid,
.admin-ai-rankings {
  align-items: stretch;
}
.nested-panel {
  background: color-mix(in srgb, var(--panel-2) 82%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 14px;
  padding: 16px;
}
.nested-panel h4 {
  margin: 0 0 12px;
  font-size: 14px;
}
.ai-bars {
  display: grid;
  gap: 10px;
}
.ai-bar-row {
  display: grid;
  grid-template-columns: minmax(78px, 1fr) minmax(120px, 2fr) auto;
  align-items: center;
  gap: 10px;
  min-width: 0;
  color: var(--muted);
  font-size: 12px;
}
.ai-bar-row div {
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(148, 163, 184, .14);
}
.ai-bar-row i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #3b82f6, #22c55e);
  box-shadow: 0 0 18px rgba(59, 130, 246, .32);
}
.ai-bar-row i.purple {
  background: linear-gradient(90deg, #7c3aed, #3b82f6);
}
.ai-bar-row strong {
  color: var(--text);
  font-size: 12px;
}
.mini-ranking {
  display: grid;
  gap: 9px;
}
.mini-ranking div {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 11px;
  background: rgba(15, 23, 42, .42);
}
.mini-ranking span {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: rgba(59, 130, 246, .16);
  color: #93c5fd;
  font-size: 11px;
  font-weight: 800;
}
.mini-ranking strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mini-ranking em {
  color: var(--muted);
  font-style: normal;
  font-size: 12px;
}
.ai-alert-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 10px;
}
.ai-alert-item {
  display: grid;
  gap: 5px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(59, 130, 246, .22);
  background: rgba(59, 130, 246, .08);
}
.ai-alert-item.medio,
.ai-alert-item.alto {
  border-color: rgba(245, 158, 11, .32);
  background: rgba(245, 158, 11, .08);
}
.ai-alert-item.critico {
  border-color: rgba(239, 68, 68, .38);
  background: rgba(239, 68, 68, .09);
}
.ai-alert-item span,
.ai-alert-item em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}
.btn.mini {
  min-height: 34px;
  padding: 7px 10px;
  border-radius: 9px;
  font-size: 12px;
}
#admin-ai-current-balance {
  color: var(--text);
}
#admin-ai-history table,
#admin-ai-payment-orders table,
#admin-ai-wallets table,
#admin-ai-packages table,
#admin-ai-costs table,
.ai-limits-table table {
  min-width: 920px;
}
.admin-intelligence-dashboard {
  display: grid;
  gap: 16px;
  margin-bottom: 16px;
}
.admin-intelligence-filter-panel {
  margin-bottom: 16px;
}
.admin-intelligence-main {
  align-items: start;
}
.admin-alert-cards,
.admin-recommendation-list {
  display: grid;
  gap: 10px;
}
.admin-alert-card,
.admin-rec-card {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, .18);
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(15, 23, 42, .88), rgba(30, 41, 59, .48));
}
.admin-alert-card > div:first-child,
.admin-rec-card > div:first-child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.admin-alert-card p,
.admin-rec-card p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}
.admin-alert-card small,
.admin-rec-card small {
  color: var(--muted);
}
.admin-alert-card.alto,
.admin-rec-card.alto {
  border-color: rgba(245, 158, 11, .36);
  box-shadow: inset 0 0 32px rgba(245, 158, 11, .06);
}
.admin-alert-card.critico,
.admin-rec-card.critico {
  border-color: rgba(239, 68, 68, .4);
  box-shadow: inset 0 0 34px rgba(239, 68, 68, .08);
}
.admin-alert-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.admin-alert-action span {
  color: var(--text);
  font-size: 12px;
  font-weight: 700;
}
.admin-score-table table {
  min-width: 860px;
}
.admin-ranking-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}
.admin-ranking-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(148, 163, 184, .14);
  border-radius: 12px;
  background: rgba(15, 23, 42, .42);
}
.admin-ranking-card h4 {
  margin: 0;
  font-size: 13px;
}
.admin-ranking-card div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 12px;
}
.admin-ranking-card strong {
  color: var(--text);
  white-space: nowrap;
}
.lead-test-kpis {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.lead-test-funnel-panel,
.lead-test-filter-panel {
  margin-bottom: 16px;
}
.lead-test-funnel {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 10px;
}
.lead-test-funnel div {
  display: grid;
  gap: 5px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, .18);
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(15, 23, 42, .82), rgba(30, 41, 59, .48));
}
.lead-test-funnel strong {
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1;
}
.lead-test-funnel span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: capitalize;
}
.lead-test-table table {
  min-width: 1180px;
}
.financial-kpis {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.financial-filter-panel {
  margin-bottom: 16px;
}
.financial-main-grid {
  align-items: start;
}
.financial-table table,
.financial-due-table table {
  min-width: 980px;
}
.financial-origin-grid {
  display: grid;
  gap: 12px;
}
.financial-origin-grid article {
  display: grid;
  gap: 6px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, .18);
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(15, 23, 42, .82), rgba(30, 41, 59, .48));
}
.financial-origin-grid article span {
  color: var(--text);
  font-size: clamp(22px, 2vw, 30px);
  font-weight: 900;
  line-height: 1;
}
.financial-origin-grid article small {
  color: var(--muted);
  font-weight: 700;
}
.audit-risk-summary {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}
.audit-table-wrap table {
  min-width: 1040px;
}
.risk-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  border: 1px solid var(--line);
}
.risk-badge.low {
  color: var(--ok);
  background: rgba(34,197,94,.1);
  border-color: rgba(34,197,94,.28);
}
.risk-badge.medium {
  color: #fbbf24;
  background: rgba(245,158,11,.12);
  border-color: rgba(245,158,11,.32);
}
.risk-badge.high {
  color: #fb7185;
  background: rgba(244,63,94,.12);
  border-color: rgba(244,63,94,.34);
}
.risk-badge.critical {
  color: #fecdd3;
  background: linear-gradient(135deg, rgba(244,63,94,.22), rgba(124,58,237,.16));
  border-color: rgba(244,63,94,.55);
  box-shadow: 0 0 18px rgba(244,63,94,.16);
}
.audit-table-wrap details {
  position: relative;
}
.audit-table-wrap summary {
  cursor: pointer;
  list-style: none;
}
.audit-table-wrap summary::-webkit-details-marker {
  display: none;
}
.audit-table-wrap pre {
  max-width: 420px;
  max-height: 260px;
  overflow: auto;
  margin: 10px 0 0;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #08111f;
  color: var(--muted);
  white-space: pre-wrap;
  font-size: 11px;
}
#ai-credit-history tbody tr {
  animation: aiRowIn .18s ease both;
}
@keyframes aiRowIn {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}
#ai-credit-history tbody tr:hover {
  background: color-mix(in srgb, var(--brand) 8%, var(--panel-2));
}
.ok-txt { color: var(--ok); font-weight: 800; }
.danger-txt { color: #fb7185; font-weight: 800; }
.ai-usage-wrap {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}
.ai-donut {
  width: 200px;
  height: 200px;
  border-radius: 999px;
  background: conic-gradient(var(--donut));
  display: grid;
  place-items: center;
  animation: aiRotateIn .3s ease;
}
@keyframes aiRotateIn {
  from { transform: scale(.96) rotate(-8deg); opacity: .8; }
  to { transform: scale(1) rotate(0); opacity: 1; }
}
.ai-donut > div {
  width: 122px;
  height: 122px;
  border-radius: 999px;
  background: var(--panel);
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  text-align: center;
}
.ai-donut strong {
  font-size: 34px;
  line-height: 1;
}
.ai-usage-wrap ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}
.ai-usage-wrap li {
  display: grid;
  grid-template-columns: 14px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}
.ai-usage-wrap li span {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}
.ai-no-credit strong {
  display: block;
  font-size: 30px;
  color: #fb7185;
  animation: aiShake .22s ease;
}
@keyframes aiShake {
  20% { transform: translateX(-3px); }
  40% { transform: translateX(3px); }
  60% { transform: translateX(-2px); }
  80% { transform: translateX(2px); }
}

.script-form {
  gap: 16px;
}
.script-block {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
  padding: 14px;
  display: grid;
  gap: 12px;
}
.script-block h3 {
  margin: 0 0 4px;
}
.script-block textarea {
  min-height: 150px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
}
.field.compact {
  min-width: 180px;
  margin: 0;
}

.meta-business-panel,
.active-integrations-panel {
  display: grid;
  gap: 16px;
}
.empty-state.compact {
  border: 1px dashed var(--line);
  border-radius: var(--radius);
  padding: 16px;
}
.meta-business-list,
.active-integrations-list {
  display: grid;
  gap: 12px;
}
.meta-business-card,
.active-integration-row {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--ok) 28%, var(--line));
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(22, 163, 74, .10), rgba(47,124,255,.05));
  padding: 16px;
}
.meta-business-card.error {
  border-color: color-mix(in srgb, var(--danger) 42%, var(--line));
  background: linear-gradient(135deg, rgba(239, 68, 68, .10), rgba(47,124,255,.05));
}
.meta-business-actions,
.integration-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}
.active-integration-row {
  grid-template-columns: 48px minmax(0, 1fr) minmax(110px, auto) auto auto;
  border-color: var(--line);
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
}
.integration-avatar {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-weight: 900;
  color: #fff;
  background: rgba(47,124,255,.22);
}
.integration-avatar.meta { background: linear-gradient(135deg, #2563eb, #db2777); }
.integration-avatar.ga { background: linear-gradient(135deg, #2563eb, #16a34a); }
.integration-avatar.google { background: linear-gradient(135deg, #2563eb, #f59e0b); }
.integration-avatar.shop { background: linear-gradient(135deg, #2f7cff, #8b5cf6); }
.integration-sync {
  display: grid;
  gap: 2px;
  justify-items: end;
}

.google-ads-oauth-panel {
  display: grid;
  gap: 14px;
  border-color: rgba(96, 165, 250, .34);
  background:
    linear-gradient(135deg, rgba(15, 27, 48, .94), rgba(8, 14, 27, .86)),
    radial-gradient(circle at 92% 0%, rgba(245, 158, 11, .12), transparent 30%),
    radial-gradient(circle at 8% 100%, rgba(59, 130, 246, .13), transparent 34%);
}
.integration-alert {
  border: 1px solid rgba(96, 165, 250, .28);
  border-radius: 10px;
  padding: 11px 13px;
  color: #cfe1ff;
  background: rgba(59, 130, 246, .10);
  font-weight: 800;
}
.integration-alert.error {
  border-color: rgba(248, 113, 113, .36);
  color: #fecdd3;
  background: rgba(127, 29, 29, .18);
}
.integration-alert.ok {
  border-color: rgba(34, 197, 94, .34);
  color: #bbf7d0;
  background: rgba(20, 83, 45, .18);
}
.google-ads-account-list {
  display: grid;
  gap: 10px;
}
.google-ads-account-list > strong {
  color: #f8fbff;
}
.google-ads-account-list article {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
  background: rgba(15, 23, 42, .55);
}
.google-ads-account-list b,
.google-ads-account-list small {
  display: block;
}
.google-ads-account-list small {
  margin-top: 3px;
  color: var(--muted);
  font-weight: 800;
}

.campaign-table-wrap table {
  min-width: 1040px;
}
.campaign-table th,
.campaign-table td {
  padding: 15px 14px;
  vertical-align: middle;
}
.campaign-table tbody tr {
  background: color-mix(in srgb, var(--panel-2) 52%, transparent);
}
.campaign-table tbody tr:hover {
  background: color-mix(in srgb, var(--brand) 9%, var(--panel-2));
}
.campaign-name {
  display: grid;
  gap: 4px;
  max-width: 460px;
}
.campaign-name small {
  color: var(--muted);
}
.objective-pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  background: rgba(148, 163, 184, .14);
  color: var(--muted);
}
.objective-pill.vendas { background: rgba(34,197,94,.14); color: #86efac; }
.objective-pill.trafego { background: rgba(37,99,235,.16); color: #93c5fd; }
.objective-pill.leads { background: rgba(34,211,238,.14); color: #67e8f9; }
.objective-pill.engajamento { background: rgba(168,85,247,.16); color: #d8b4fe; }

.sidebar {
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--muted) 55%, transparent) transparent;
}
.sidebar::-webkit-scrollbar,
.ad-history-preview::-webkit-scrollbar {
  width: 8px;
}
.sidebar::-webkit-scrollbar-track,
.ad-history-preview::-webkit-scrollbar-track {
  background: transparent;
}
.sidebar::-webkit-scrollbar-thumb,
.ad-history-preview::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--muted) 45%, transparent);
  border-radius: 999px;
}

.reports-premium-page {
  display: grid;
  gap: 22px;
}

.reports-premium-page .page-head {
  align-items: start;
}

.reports-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(180px, 1fr));
  gap: 16px;
}

.reports-kpi-card {
  position: relative;
  min-width: 0;
  min-height: 124px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 22px 20px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--panel-2) 72%, transparent), color-mix(in srgb, var(--panel) 92%, transparent)),
    radial-gradient(circle at 90% 12%, rgba(124, 58, 237, .18), transparent 34%);
  box-shadow: 0 16px 44px rgba(0, 0, 0, .16);
}

.reports-kpi-card span,
.reports-kpi-card small {
  display: block;
  color: var(--muted);
  font-weight: 800;
}

.reports-kpi-card strong {
  display: block;
  margin-top: 10px;
  color: var(--text);
  font-size: clamp(28px, 3vw, 42px);
  line-height: .98;
  letter-spacing: 0;
}

.reports-kpi-card > i {
  position: absolute;
  right: 18px;
  top: 20px;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel-2) 78%, transparent);
  color: var(--muted);
  opacity: .95;
}

.reports-kpi-card svg {
  width: 21px;
  height: 21px;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.reports-kpi-card em {
  position: absolute;
  left: 86px;
  bottom: 22px;
  color: #32d583;
  font-style: normal;
  font-weight: 900;
  font-size: 13px;
}

.reports-kpi-card em.neutral {
  color: var(--muted);
}

.reports-kpi-card.time {
  display: grid;
  align-content: center;
  background:
    radial-gradient(circle at 88% 18%, rgba(255,255,255,.18), transparent 28%),
    linear-gradient(135deg, #2563eb 0%, #7c3aed 74%);
  color: #fff;
  border-color: rgba(255, 255, 255, .18);
}

.reports-kpi-card.time span,
.reports-kpi-card.time small {
  color: rgba(255,255,255,.78);
}

.reports-kpi-card.time div {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 12px;
}

.reports-kpi-card.time i {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  color: #dbeafe;
}

.reports-recents-panel {
  padding: 22px;
  overflow: hidden;
}

.reports-panel-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 22px;
}

.reports-panel-head h3 {
  margin: 0 0 8px;
  font-size: 24px;
}

.reports-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.reports-toolbar .btn {
  min-height: 44px;
  border-radius: 10px;
}

.reports-toolbar .btn svg,
.reports-see-all svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2;
}

.reports-search {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: min(360px, 44vw);
  height: 44px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
  color: var(--muted);
}

.reports-search svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
}

.reports-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
}

.reports-list {
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}

.reports-row.report-row-card {
  position: relative;
  display: grid;
  grid-template-columns: 48px minmax(220px, 1.5fr) minmax(150px, .72fr) minmax(110px, .48fr) auto;
  align-items: center;
  gap: 18px;
  margin: 0;
  padding: 18px 18px;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  transition: background .18s ease, transform .18s ease;
}

.reports-row.report-row-card:last-child {
  border-bottom: 0;
}

.reports-row.report-row-card:hover {
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(59, 130, 246, .08), rgba(124, 58, 237, .08)),
    color-mix(in srgb, var(--panel-2) 32%, transparent);
}

.reports-row-copy {
  min-width: 0;
}

.reports-row-copy strong {
  display: block;
  overflow: hidden;
  color: var(--text);
  font-size: 15px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reports-row-copy p {
  margin: 6px 0 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 13px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reports-row .report-icon {
  width: 40px;
  height: 40px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  color: #fff;
}

.reports-row .report-icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 1.9;
}

.report-icon.purple { background: linear-gradient(135deg, #4f46e5, #7c3aed); }
.report-icon.green { background: linear-gradient(135deg, #047857, #22c55e); }
.report-icon.orange { background: linear-gradient(135deg, #b45309, #f59e0b); }
.report-icon.pink { background: linear-gradient(135deg, #be185d, #d946ef); }
.report-icon.blue { background: linear-gradient(135deg, #2563eb, #38bdf8); }

.report-client-cell {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  grid-template-rows: auto auto;
  column-gap: 10px;
  align-items: center;
  min-width: 0;
}

.report-client-cell span {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 9px;
  background: rgba(124, 58, 237, .24);
  color: #d8b4fe;
  font-weight: 900;
  font-size: 12px;
}

.report-client-cell strong,
.report-date-cell strong {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-size: 13px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.report-client-cell small,
.report-date-cell small {
  color: var(--muted);
  font-size: 12px;
}

.report-date-cell {
  display: grid;
  gap: 4px;
}

.report-row-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: max-content;
}

.report-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  min-width: 38px;
  height: 38px;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 9px;
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
  color: var(--muted);
  transition: transform .16s ease, color .16s ease, border-color .16s ease, background .16s ease;
}

.report-action-btn:hover {
  transform: translateY(-1px);
  color: var(--text);
  border-color: color-mix(in srgb, var(--brand) 55%, var(--line));
  background: color-mix(in srgb, var(--brand) 14%, var(--panel-2));
}

.report-action-btn.danger {
  color: #fb7185;
  background: rgba(225, 29, 72, .11);
}

.report-action-btn.danger:hover {
  border-color: rgba(251, 113, 133, .52);
  background: rgba(225, 29, 72, .18);
}

.report-action-btn svg {
  width: 17px;
  height: 17px;
  stroke: currentColor;
  stroke-width: 2;
}

.reports-row .report-hover-preview {
  position: absolute;
  right: 18px;
  bottom: calc(100% - 8px);
  pointer-events: none;
  opacity: 0;
  transform: translateY(8px) scale(.98);
  transition: opacity .18s ease, transform .18s ease;
}

.reports-row:hover .report-hover-preview {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.report-preview-mini {
  display: grid;
  grid-template-columns: repeat(3, minmax(92px, 1fr));
  gap: 8px;
  min-width: 330px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel) 96%, #070b16);
  box-shadow: var(--shadow);
}

.report-preview-mini span {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel-2) 74%, transparent);
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.report-preview-mini b {
  color: var(--text);
  font-size: 14px;
}

.reports-see-all {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  margin-top: 16px;
  border: 0;
  background: transparent;
  color: var(--brand);
  font-weight: 900;
}

.reports-empty-state {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 44px 20px;
  text-align: center;
}

.reports-builder-banner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, .82fr);
  min-height: 280px;
  overflow: hidden;
  padding: 30px;
  background:
    radial-gradient(circle at 72% 24%, rgba(124, 58, 237, .26), transparent 28%),
    radial-gradient(circle at 88% 78%, rgba(37, 99, 235, .18), transparent 28%),
    linear-gradient(135deg, color-mix(in srgb, var(--panel) 94%, transparent), color-mix(in srgb, var(--panel-2) 78%, transparent));
}

.reports-builder-copy {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 16px;
  max-width: 760px;
}

.reports-builder-copy h2 {
  margin: 0;
  font-size: clamp(24px, 2.6vw, 34px);
}

.reports-builder-copy p {
  max-width: 560px;
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.55;
}

.report-ai-spark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  color: #bfdbfe;
  background: rgba(37, 99, 235, .18);
}

.report-ai-spark svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
}

.report-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.report-chip-row span {
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.reports-builder-copy .btn {
  width: min(100%, 720px);
  min-height: 52px;
  margin-top: 10px;
}
.reports-builder-copy .ai-credit-notice {
  margin-top: 8px;
  max-width: 520px;
}

.reports-visual-lab {
  position: relative;
  min-height: 260px;
}

.reports-visual-lab > div {
  position: absolute;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-radius: 16px;
  background: rgba(15, 23, 42, .64);
  box-shadow: 0 20px 60px rgba(0, 0, 0, .24);
  backdrop-filter: blur(14px);
}

.report-line-visual {
  left: 0;
  bottom: 38px;
  width: 290px;
  height: 136px;
  padding: 22px;
}

.report-line-visual span {
  position: absolute;
  top: -28px;
  left: 88px;
  padding: 8px 14px;
  border-radius: 999px 999px 999px 4px;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
}

.report-line-visual svg {
  width: 100%;
  height: 100%;
}

.report-line-visual path {
  fill: none;
  stroke: #7567ff;
  stroke-width: 3;
  stroke-linecap: round;
}

.report-donut-visual {
  right: 222px;
  top: 32px;
  display: flex;
  align-items: center;
  gap: 16px;
  width: 210px;
  padding: 18px;
}

.report-donut-visual div {
  position: relative;
  display: grid;
  place-items: center;
  width: 86px;
  height: 86px;
  border-radius: 999px;
  background: conic-gradient(#7c3aed 0 68%, #2563eb 68% 86%, rgba(255,255,255,.12) 86% 100%);
}

.report-donut-visual div:before {
  content: "";
  position: absolute;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: #10182b;
}

.report-donut-visual strong {
  position: relative;
  z-index: 1;
  color: #fff;
}

.report-donut-visual span {
  color: #dbeafe;
  font-size: 12px;
  font-weight: 800;
}

.report-bar-visual {
  right: -26px;
  top: 0;
  display: grid;
  grid-template-columns: repeat(5, 18px);
  align-items: end;
  gap: 10px;
  width: 210px;
  height: 128px;
  padding: 48px 20px 18px;
}

.report-bar-visual strong,
.report-bar-visual small {
  position: absolute;
  left: 18px;
}

.report-bar-visual strong {
  top: 14px;
  color: #fff;
  font-size: 12px;
}

.report-bar-visual small {
  top: 32px;
  color: #22c55e;
  font-size: 11px;
  font-weight: 900;
}

.report-bar-visual i {
  display: block;
  border-radius: 6px 6px 2px 2px;
  background: linear-gradient(180deg, #7c3aed, #2563eb);
}

.report-reco-visual {
  right: 14px;
  bottom: -34px;
  width: 260px;
  padding: 18px;
}

.report-reco-visual strong {
  display: block;
  margin-bottom: 14px;
  color: #fff;
  font-size: 13px;
}

.report-reco-visual span {
  display: block;
  height: 8px;
  margin-top: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
}

.report-reco-visual span:nth-child(2) { width: 92%; }
.report-reco-visual span:nth-child(3) { width: 74%; }
.report-reco-visual span:nth-child(4) { width: 62%; }

.report-pdf-preview {
  max-height: 72vh;
  overflow: auto;
  padding-right: 4px;
}

.report-pdf-preview .cover,
.report-pdf-preview .section,
.report-pdf-preview .card {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel-2) 70%, transparent);
  padding: 18px;
}

.report-pdf-preview .grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 14px 0;
}

.report-pdf-preview .card strong {
  display: block;
  margin-top: 6px;
  font-size: clamp(20px, 2.6vw, 28px);
  overflow: hidden;
  text-overflow: ellipsis;
}

.report-pdf-preview .section {
  margin-top: 14px;
}

.report-pdf-preview .chart {
  height: 160px;
  border-radius: 14px;
  background:
    linear-gradient(180deg, transparent 24%, rgba(148,163,184,.16) 25%, transparent 26%, transparent 49%, rgba(148,163,184,.16) 50%, transparent 51%),
    color-mix(in srgb, var(--panel) 82%, transparent);
}

@media (max-width: 1180px) {
  .filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .filters .btn { grid-column: span 2; }
  .report-filter-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .report-filter-metrics,
  .report-metric-drawer {
    grid-column: 1 / -1;
  }
  .report-creator-grid,
  .report-creator-content-grid,
  .report-creator-info-grid {
    grid-template-columns: 1fr;
  }
  .report-ai-drawer {
    position: static;
  }
  .report-kpi-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .reports-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .reports-kpi-card.time {
    grid-column: span 2;
  }
  .reports-row.report-row-card {
    grid-template-columns: 44px minmax(190px, 1fr) minmax(140px, .72fr);
  }
  .reports-row .report-date-cell,
  .reports-row .report-hover-preview {
    display: none;
  }
  .reports-row-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
    min-width: 0;
  }
  .reports-builder-banner {
    grid-template-columns: 1fr;
  }
  .reports-visual-lab {
    min-height: 230px;
  }
  .report-workspace,
  .ad-generator-layout {
    grid-template-columns: 1fr;
  }
  .ad-history-panel {
    position: static;
  }
}

@media (max-width: 760px) {
  .filters { grid-template-columns: 1fr; }
  .filters .btn { grid-column: auto; }
  .report-filter-bar,
  .report-kpi-row {
    grid-template-columns: 1fr;
  }
  .report-metric-drawer {
    max-height: 210px;
    overflow: auto;
  }
  .report-table-footer {
    display: grid;
  }
  .pager {
    justify-content: center;
  }
  .report-main-chart {
    height: 220px;
  }
  .reports-kpi-grid {
    grid-template-columns: 1fr;
  }
  .reports-kpi-card.time {
    grid-column: auto;
  }
  .reports-panel-head,
  .reports-toolbar {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: stretch;
  }
  .reports-search {
    min-width: 0;
    width: 100%;
  }
  .reports-row.report-row-card {
    grid-template-columns: 42px minmax(0, 1fr);
    padding: 16px;
  }
  .report-client-cell {
    grid-column: 1 / -1;
  }
  .report-row-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    width: 100%;
  }
  .report-action-btn {
    width: 100%;
  }
  .reports-builder-banner {
    padding: 20px;
  }
  .reports-builder-copy .btn {
    width: 100%;
  }
  .reports-builder-copy .ai-credit-notice {
    width: 100%;
    max-width: none;
  }
  .reports-visual-lab {
    min-height: 340px;
  }
  .reports-visual-lab > div {
    position: relative;
    inset: auto;
    width: 100%;
    margin-top: 14px;
  }
  .report-line-visual {
    height: 130px;
  }
  .report-donut-visual,
  .report-bar-visual {
    right: auto;
    top: auto;
  }
  .report-pdf-preview .grid {
    grid-template-columns: 1fr;
  }
  .report-row-top,
  .meta-business-card,
  .active-integration-row {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .google-ads-account-list article {
    align-items: stretch;
    flex-direction: column;
  }
  .google-ads-account-list .btn {
    width: 100%;
  }
  .report-icon,
  .integration-avatar {
    width: 42px;
    height: 42px;
  }
  .report-row-actions,
  .meta-business-actions,
  .integration-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
  }
  .report-row-actions .btn,
  .meta-business-actions .btn,
  .integration-actions .icon-btn {
    width: 100%;
  }
  .integration-sync {
    justify-items: start;
  }
  .script-block .section-row {
    display: grid;
    gap: 10px;
  }
  .field.compact {
    min-width: 0;
  }
  .ai-credit-history-controls {
    grid-template-columns: 1fr;
  }
  .admin-ai-filters {
    grid-template-columns: 1fr;
  }
  .admin-sync-actions {
    grid-template-columns: 1fr;
  }
  .ai-usage-wrap {
    grid-template-columns: 1fr;
    justify-items: start;
  }
  .ai-donut {
    width: 170px;
    height: 170px;
  }
.ai-donut > div {
  width: 104px;
  height: 104px;
}
}

/* Retaguarda UX refinement (visual only) */
.admin-shell {
  display: grid;
  grid-template-columns: 268px minmax(0, 1fr);
  align-items: stretch;
  width: 100%;
}
/* Neutraliza herança do design-system para evitar colapso estrutural no Admin. */
.admin-shell.ds-layout {
  display: grid;
}
.admin-shell > .admin-sidebar.ds-sidebar {
  position: relative;
  left: auto;
  top: auto;
  width: auto;
  min-width: 0;
  max-width: none;
  height: 100%;
}
.admin-shell > .main.ds-main {
  margin-left: 0;
  padding: 0;
  min-width: 0;
  width: 100%;
}
.admin-shell > .main.ds-main > .content.ds-main-content {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}
.admin-sidebar {
  padding: 16px 14px 14px;
  gap: 14px;
  background: linear-gradient(180deg, rgba(6, 10, 20, .92), rgba(8, 12, 24, .84));
}
.admin-sidebar .brand {
  padding: 2px 4px 8px;
}
.admin-sidebar .nav {
  gap: 6px;
  padding-right: 2px;
}
.admin-sidebar .nav a {
  min-height: 42px;
  border: 1px solid transparent;
  border-radius: 12px;
  padding: 0 11px;
}
.admin-sidebar .nav a.active {
  background: linear-gradient(135deg, rgba(47,124,255,.18), rgba(139,92,246,.10));
  border-color: color-mix(in srgb, var(--brand) 48%, var(--line));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.admin-sidebar .nav a:hover {
  border-color: color-mix(in srgb, var(--brand) 28%, var(--line));
}
.admin-sidebar-bottom {
  margin-top: auto;
  display: grid;
  gap: 10px;
  padding: 10px 2px 2px;
}
.admin-sidebar-version {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 12px;
  background: rgba(15, 23, 42, .45);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.admin-sidebar-version small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}
.admin-sidebar-version strong {
  font-size: 12px;
  letter-spacing: .04em;
}
.admin-topbar-context {
  display: grid;
  gap: 2px;
}
.admin-topbar-context strong {
  font-size: 15px;
  font-weight: 900;
}
.admin-topbar-context small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.admin-shell .topbar {
  min-height: 72px;
  padding: 0 20px;
}
.admin-shell .content {
  padding: 20px;
  gap: 16px;
}
.admin-shell .panel,
.admin-shell .card {
  border-radius: 14px;
  border-color: color-mix(in srgb, var(--line) 84%, rgba(255,255,255,.08));
  box-shadow: 0 8px 22px rgba(2, 6, 23, .18);
}
.admin-shell .card.kpi {
  min-height: 116px;
  display: grid;
  align-content: start;
  gap: 6px;
}
.admin-shell .card .label {
  font-size: 12px;
  color: color-mix(in srgb, var(--muted) 88%, #fff 12%);
}
.admin-shell .card .value,
.admin-shell .card .card-value {
  font-size: clamp(26px, 2vw, 36px);
  line-height: 1.05;
}
.admin-shell .section-title {
  font-size: 18px;
}
.admin-shell .field {
  gap: 6px;
}
.admin-shell .field label {
  font-size: 12px;
  font-weight: 800;
}
.admin-shell .field input,
.admin-shell .field select,
.admin-shell .field textarea {
  min-height: 42px;
  border-radius: 12px;
  padding: 10px 12px;
  background: rgba(15, 23, 42, .5);
}
.admin-shell .field textarea {
  min-height: 108px;
}
.admin-shell .field small {
  color: color-mix(in srgb, var(--muted) 92%, #fff 8%);
}
.admin-shell .btn {
  min-height: 40px;
  border-radius: 12px;
  font-weight: 800;
}
.admin-shell .btn.mini {
  min-height: 34px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 12px;
}
.admin-shell .table-wrap,
.admin-shell .admin-table-wrap,
.admin-shell .financial-table,
.admin-shell .financial-due-table,
.admin-shell .lead-test-table,
.admin-shell .audit-table-wrap {
  border: 1px solid color-mix(in srgb, var(--line) 84%, rgba(255,255,255,.08));
  border-radius: 14px;
  overflow: auto;
  background: rgba(8, 12, 24, .45);
}
.admin-shell table {
  min-width: 860px;
  font-size: 13px;
}
.admin-shell th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: rgba(8, 13, 26, .94);
  font-size: 11px;
}
.admin-shell td,
.admin-shell th {
  padding: 10px 12px;
  vertical-align: middle;
}
.admin-shell tbody tr:hover {
  background: color-mix(in srgb, var(--panel-2) 84%, transparent);
}
.admin-shell .status,
.admin-shell .risk-badge,
.admin-shell .badge {
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
}
.admin-shell .empty-state,
.admin-shell .alerts-empty,
.admin-shell .reports-empty-state {
  border-radius: 12px;
  border: 1px dashed color-mix(in srgb, var(--line) 76%, rgba(255,255,255,.12));
  padding: 14px;
  background: rgba(15, 23, 42, .3);
}
.admin-shell .section-row {
  align-items: center;
  gap: 12px;
}
.admin-shell .ai-credit-history-controls,
.admin-shell .admin-ai-filters {
  align-items: end;
}
.admin-shell *:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--brand) 62%, transparent);
  outline-offset: 2px;
}
@media (max-width: 980px) {
  .admin-shell {
    grid-template-columns: 220px minmax(0, 1fr);
  }
  .admin-shell .topbar {
    padding: 0 14px;
  }
  .admin-shell .content {
    padding: 14px;
  }
  .admin-sidebar .nav a {
    min-height: 40px;
  }
}
@media (max-width: 760px) {
  .admin-sidebar {
    padding: 12px;
    gap: 10px;
  }
  .admin-sidebar-bottom {
    border-top: 1px solid var(--line);
    padding-top: 12px;
  }
  .admin-shell .topbar {
    min-height: 64px;
    gap: 10px;
  }
  .admin-shell .topbar > .actions:last-child {
    justify-content: flex-start;
  }
  .admin-shell .content {
    padding: 12px;
    gap: 12px;
  }
  .admin-shell table {
    min-width: 760px;
  }
}

/* Retaguarda - Central de Logs */
.audit-quick-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 16px;
}

.audit-tab {
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.72);
  color: var(--muted);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, color .16s ease, background .16s ease;
}

.audit-tab:hover,
.audit-tab.active {
  transform: translateY(-1px);
  border-color: rgba(96, 165, 250, 0.62);
  color: var(--text);
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.24), rgba(124, 58, 237, 0.24));
}

.audit-filters {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.audit-attention-panel {
  margin: 14px 0;
}

.audit-attention-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.audit-attention-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  border: 1px solid rgba(148, 163, 184, 0.15);
  border-radius: 14px;
  padding: 12px;
  background: rgba(15, 23, 42, 0.68);
}

.audit-attention-item.critico,
.audit-attention-item.alto {
  border-color: rgba(248, 113, 113, 0.42);
  background: linear-gradient(135deg, rgba(127, 29, 29, 0.24), rgba(15, 23, 42, 0.74));
}

.audit-list-panel {
  overflow: hidden;
}

.audit-list-toolbar,
.audit-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.audit-view-pill,
.audit-count {
  border: 1px solid rgba(96, 165, 250, 0.24);
  background: rgba(37, 99, 235, 0.12);
  color: #bfdbfe;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.audit-table-wrap {
  max-height: min(58vh, 620px);
  overflow: auto;
  border: 1px solid rgba(148, 163, 184, 0.12);
  border-radius: 14px;
}

.audit-table-wrap table {
  min-width: 980px;
}

.audit-table-wrap thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(9, 15, 28, 0.96);
  backdrop-filter: blur(10px);
}

.audit-table-loading {
  display: grid;
  gap: 10px;
  padding: 8px 0;
}

.skeleton-line {
  display: block;
  height: 42px;
  border-radius: 12px;
  background: linear-gradient(90deg, rgba(148, 163, 184, 0.08), rgba(148, 163, 184, 0.18), rgba(148, 163, 184, 0.08));
  background-size: 220% 100%;
  animation: shimmer 1.2s ease-in-out infinite;
}

.audit-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin: 14px 0;
}

.audit-detail-field {
  border: 1px solid rgba(148, 163, 184, 0.14);
  background: rgba(15, 23, 42, 0.72);
  border-radius: 12px;
  padding: 10px;
  min-width: 0;
}

.audit-detail-field span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 5px;
}

.audit-detail-field strong {
  display: block;
  overflow-wrap: anywhere;
}

.audit-review-field {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.audit-technical-details {
  margin-top: 14px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 14px;
  padding: 12px;
  background: rgba(2, 6, 23, 0.38);
}

.audit-technical-details pre {
  max-height: 320px;
  overflow: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  color: #cbd5e1;
}

@media (max-width: 720px) {
  .audit-list-toolbar,
  .audit-pagination {
    align-items: flex-start;
    flex-direction: column;
  }

  .audit-table-wrap {
    max-height: 520px;
  }
}

/* WBUY guided connection */
.wbuy-setup {
  display: grid;
  gap: 14px;
}

.wbuy-setup-block {
  margin: 0;
}

.wbuy-status-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin: 12px 0;
}

.wbuy-status-item {
  border: 1px solid rgba(148, 163, 184, 0.14);
  background: rgba(15, 23, 42, 0.72);
  border-radius: 12px;
  padding: 11px;
  min-width: 0;
}

.wbuy-status-item span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.wbuy-status-item strong {
  display: block;
  overflow-wrap: anywhere;
}

.wbuy-webhook-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.wbuy-webhook-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(160px, 220px) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid rgba(148, 163, 184, 0.14);
  background: rgba(15, 23, 42, 0.7);
  border-radius: 14px;
  padding: 12px;
}

.wbuy-webhook-row p {
  overflow-wrap: anywhere;
}

.wbuy-steps {
  margin: 12px 0 0 18px;
  color: var(--muted);
}

.wbuy-steps li {
  margin-bottom: 8px;
}

.wbuy-advanced {
  margin-top: 12px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 12px;
  padding: 10px;
  background: rgba(2, 6, 23, 0.28);
}

@media (max-width: 760px) {
  .wbuy-webhook-row {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }
}

/* Responsive layout hardening
   Breakpoints: sm 480px | md 768px | lg 1024px | xl 1200px */
.grid.kpis,
.overview-exec-kpis,
.analytics-kpi-grid,
.meta-summary-kpis,
.overview-comparison-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.card.kpi,
.overview-exec-kpi,
.analytics-kpi-card {
  min-height: 160px;
  align-content: start;
}

.kpi .label,
.overview-exec-kpi small,
.analytics-kpi-card small,
.meta-summary-kpis .label,
.metric-label-text {
  min-width: 0;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kpi .value,
.overview-exec-kpi strong,
.analytics-kpi-card strong.card-value,
.card-value {
  font-size: clamp(1.35rem, 1.7vw, 2rem);
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: 0;
}

.overview-exec-kpi .kpi-top > div,
.analytics-kpi-card > div,
.card.kpi,
.overview-reconciliation,
.reconciliation-source-grid,
.reconciliation-delta,
.reconciliation-weekly-chart,
.overview-score-card,
.overview-main-alert,
.main,
.content,
.topbar,
.overview-exec-page,
.analytics-command-page {
  min-width: 0;
}

.overview-top-grid {
  grid-template-columns: minmax(300px, .66fr) minmax(0, 1fr);
}

.reconciliation-source-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.app-shell {
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
}

@media (max-width: 1199px) and (min-width: 768px) {
  .grid.kpis,
  .overview-exec-kpis,
  .analytics-kpi-grid,
  .meta-summary-kpis,
  .overview-comparison-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .app-shell {
    grid-template-columns: 240px minmax(0, 1fr);
  }

  .overview-reconciliation .reconciliation-source-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .grid.kpis,
  .overview-exec-kpis,
  .analytics-kpi-grid,
  .meta-summary-kpis,
  .overview-comparison-grid,
  .reconciliation-source-grid,
  .overview-top-grid,
  .overview-main-grid,
  .overview-sync-grid {
    grid-template-columns: 1fr;
  }

  .app-shell,
  .admin-shell {
    grid-template-columns: 1fr;
  }

  .sidebar,
  .admin-sidebar {
    position: fixed;
    z-index: 30;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(86vw, 320px);
    height: 100vh;
    transform: translateX(-105%);
    transition: transform .2s ease;
  }

  .sidebar.open,
  .admin-sidebar.open {
    transform: translateX(0);
  }

  .sidebar-backdrop,
  .admin-sidebar-backdrop {
    z-index: 29;
  }

  .content {
    padding: 16px;
  }

  .topbar {
    padding: 0 12px;
  }
}

@media (max-width: 479px) {
  .kpi .value,
  .overview-exec-kpi strong,
  .analytics-kpi-card strong.card-value,
  .card-value {
    font-size: clamp(1.15rem, 7vw, 1.65rem);
  }

  .card.kpi,
  .overview-exec-kpi,
  .analytics-kpi-card {
    min-height: 148px;
    padding: 14px;
  }
}

/* KPI labels: never truncate on Overview/Dashboard cards */
.overview-exec-page .kpi .label,
.overview-exec-page .overview-exec-kpi small,
.overview-exec-page .metric-label-text,
.analytics-command-page .analytics-kpi-card small,
.analytics-command-page .metric-label-text,
.analytics-command-page [class*="kpi-label"],
.overview-exec-page [class*="kpi-label"],
.overview-exec-page [class*="card-label"],
.analytics-command-page [class*="card-label"] {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  word-break: break-word;
  min-width: 0;
  line-height: 1.3;
  font-size: 13px;
}

.overview-exec-page .overview-exec-kpi,
.overview-exec-page .card.kpi,
.analytics-command-page .analytics-kpi-card,
.analytics-command-page [class*="kpi-card"],
.analytics-command-page [class*="metric-card"] {
  min-width: 0;
  overflow: visible;
  word-break: break-word;
}

/* Dashboard insight cards: dynamic height, no text overlap */
.analytics-insights-panel .insight-card,
.analytics-insights-panel [class*="insight-card"] {
  height: auto !important;
  min-height: 180px;
  overflow: visible !important;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.analytics-insights-panel .insight-card *,
.analytics-insights-panel [class*="insight-card"] * {
  overflow: visible;
}

.analytics-insights-panel .insight-card p,
.analytics-insights-panel .insight-card .causa-text,
.analytics-insights-panel [class*="insight-card"] p {
  font-size: 13px;
  line-height: 1.6;
  color: #8892A4;
  white-space: normal;
  word-break: break-word;
  overflow: visible;
  display: block;
}

/* Dashboard KPI grid: responsive fill without orphan cards. */
.analytics-command-page .analytics-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  align-items: start;
}

@media (min-width: 1200px) {
  .analytics-command-page .analytics-kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 768px) and (max-width: 1199px) {
  .analytics-command-page .analytics-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .analytics-command-page .analytics-kpi-grid {
    grid-template-columns: 1fr;
  }
}

/* Dashboard WBUY cards: labels should wrap instead of truncating. */
.analytics-commerce-panel .analytics-commerce-grid article,
.analytics-commerce-panel .analytics-commerce-grid article label,
.analytics-commerce-panel .analytics-commerce-grid article span,
.analytics-commerce-panel .analytics-commerce-grid article small,
.analytics-commerce-panel .wbuy-card-label,
.analytics-commerce-panel .plataforma-card label,
.analytics-commerce-panel .plataforma-card span {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  font-size: 12px;
  line-height: 1.4;
  min-width: 0;
}

.analytics-commerce-panel .analytics-commerce-grid article,
.analytics-commerce-panel .wbuy-card,
.analytics-commerce-panel .plataforma-card {
  min-width: 140px;
  flex: 1 1 140px;
}

/* Overview Top/Bottom campaign ranking: stable two-column layout. */
.top-bottom-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: start;
}

@media (max-width: 768px) {
  .top-bottom-container {
    grid-template-columns: 1fr;
  }
}

.top-3-col,
.bottom-3-col {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}

.campaign-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  font-size: 13px;
  line-height: 1.5;
  word-break: break-word;
}

.campaign-row > span {
  min-width: 0;
}

/* Aurix Design System v1.0 compatibility layer */
:root {
  --leading-tight: 1.2;
  --leading-normal: 1.5;
  --leading-loose: 1.75;
  --tracking-tight: -0.02em;
  --tracking-normal: 0em;
  --tracking-wide: 0.05em;
  --tracking-wider: 0.1em;
}

body {
  background: var(--bg-base, var(--bg));
  color: var(--text-primary, var(--text));
  font-family: var(--font-sans, inherit);
}

.panel.ds-card,
.panel.ds-card-kpi,
.card.ds-card-kpi,
.overview-exec-kpi.ds-card-kpi,
.analytics-kpi-card.ds-card-kpi {
  background: var(--bg-surface);
  border-color: var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-1);
}

.panel.ds-card:hover,
.panel.ds-card-kpi:hover,
.card.ds-card-kpi:hover,
.overview-exec-kpi.ds-card-kpi:hover,
.analytics-kpi-card.ds-card-kpi:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-2);
}

.ds-card-kpi.ds-card-kpi--primary {
  border-color: rgba(34, 197, 94, 0.2);
}

.ds-label-card,
.ds-nav-item,
.ds-alert-critical__body {
  color: var(--text-secondary);
}

.ds-value-kpi {
  font-family: var(--font-mono);
  color: var(--text-primary);
}

.ds-nav-item.active,
.ds-nav-item--active {
  color: var(--text-primary);
  border-left-color: var(--primary-500);
  background: var(--primary-glow);
}

.ds-alert-critical {
  border-color: transparent;
  border-left-color: var(--danger-500);
  background: rgba(239, 68, 68, 0.06);
}

.ds-alert-critical__label {
  color: var(--danger-500);
}

/* ============================================
   KPI CARD — estrutura premium
   ============================================ */

.kpi-card {
  background: #0F1629;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
  transition: border-color 180ms ease, box-shadow 180ms ease;
  position: relative;
  overflow: hidden;
}

.kpi-card:hover {
  border-color: rgba(255,255,255,0.14);
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}

.kpi-card--empty {
  opacity: 0.5;
}

/* Linha topo: ícone + label + tooltip */
.kpi-card__top {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-width: 0;
}

/* Ícone colorido — tamanho fixo, nunca encolhe */
.kpi-card__icon-wrap {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid;
  display: flex;
  align-items: center;
  justify-content: center;
}

.kpi-card__icon-wrap svg,
.kpi-card__icon-wrap i {
  width: 16px;
  height: 16px;
}

/* Label — ocupa o espaço restante, quebra de linha normal */
.kpi-card__label {
  flex: 1;
  min-width: 0;
  font-size: 13px;
  font-weight: 500;
  color: #8892A4;
  line-height: 1.35;
  white-space: normal;
  word-break: break-word;
  overflow: visible;
  /* NUNCA position: absolute */
  position: static;
}

/* Tooltip ⓘ — alinhado na linha, não absoluto */
.kpi-card__info {
  flex-shrink: 0;
  font-size: 12px;
  color: #4B5563;
  cursor: help;
  position: static;
  /* NUNCA position: absolute */
}

/* Valor principal — monospace, fluido */
.kpi-card__value {
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 700;
  color: #F1F5FF;
  line-height: 1;
  letter-spacing: -0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-variant-numeric: tabular-nums;
  /* NUNCA position: absolute */
  position: static;
}

.kpi-card__value--empty {
  color: #4B5563;
  font-size: 24px;
}

/* Delta variação */
.kpi-delta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 999px;
  align-self: flex-start;
}

.kpi-delta--positive {
  color: #22C55E;
  background: rgba(34, 197, 94, 0.12);
}

.kpi-delta--negative {
  color: #EF4444;
  background: rgba(239, 68, 68, 0.12);
}

.kpi-delta--neutral {
  color: #8892A4;
  background: rgba(255,255,255,0.05);
}

/* Sparkline */
.kpi-card__sparkline {
  height: 32px;
  overflow: hidden;
}

.kpi-card__sparkline svg {
  width: 100%;
  height: 32px;
  color: #38BDF8;
}

.kpi-card__sparkline path {
  fill: none;
  stroke: currentColor;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Disclaimer */
.kpi-card__disclaimer {
  font-size: 11px;
  color: #4B5563;
  font-style: italic;
  line-height: 1.4;
  margin-top: auto;
}

/* ============================================
   GRID KPI — responsivo sem órfãos
   ============================================ */

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  align-items: start;
}

@media (max-width: 1400px) {
  .kpi-grid { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 1100px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .kpi-card__value { font-size: clamp(18px, 2.8vw, 26px); }
}

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

/* ============================================
   SIDEBAR — estrutura premium
   ============================================ */

.app-shell {
  display: block;
  min-height: 100vh;
  position: relative;
  grid-template-columns: none;
}

.sidebar {
  width: 220px;
  min-width: 220px;
  max-width: 220px;
  height: 100vh;
  position: fixed;
  left: 0;
  top: 0;
  background: #0B1120;
  border-right: 1px solid rgba(255,255,255,0.05);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0;
  gap: 0;
  box-shadow: none;
  z-index: 100;
}

/* Logo */
.sidebar__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px 16px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  flex-shrink: 0;
}

.sidebar__logo-img {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.sidebar__logo-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.sidebar__brand {
  font-size: 13px;
  font-weight: 700;
  color: #F1F5FF;
  letter-spacing: 0.08em;
}

.sidebar__tagline {
  font-size: 10px;
  color: #4B5563;
  line-height: 1.3;
  white-space: normal;
}

/* Navegação */
.sidebar__nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px 8px;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.sidebar__nav::-webkit-scrollbar {
  width: 3px;
}

.sidebar__nav::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.08);
  border-radius: 999px;
}

/* Label de grupo */
.nav-group-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #4B5563;
  padding: 16px 8px 6px;
}

.nav-group-label:first-child {
  padding-top: 4px;
}

/* Item de menu — horizontal, 36px altura */
.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 36px;
  padding: 0 10px;
  border-radius: 7px;
  border-left: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background 120ms ease, color 120ms ease;
  min-width: 0;
  position: relative;
}

.nav-item:hover {
  background: rgba(255,255,255,0.04);
}

/* Ícone */
.nav-item__icon {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #4B5563;
  transition: color 120ms ease;
}

.nav-item__icon svg {
  width: 15px;
  height: 15px;
}

/* Label */
.nav-item__label {
  flex: 1;
  min-width: 0;
  font-size: 13px;
  font-weight: 400;
  color: #8892A4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color 120ms ease;
}

/* Badge opcional */
.nav-item__badge {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 600;
  background: rgba(99,102,241,0.2);
  color: #818CF8;
  padding: 1px 6px;
  border-radius: 999px;
}

.google-ads-page {
  display: grid;
  gap: 16px;
}

.google-ads-tabs {
  justify-content: flex-start;
}

.google-ads-connection-panel,
.google-ads-account-row,
.google-ads-alert-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.google-ads-state.error {
  border-color: color-mix(in srgb, var(--danger) 36%, var(--line));
}

.google-ads-account-list,
.google-ads-alert-list {
  display: grid;
  gap: 10px;
}

.google-ads-account-row,
.google-ads-alert-row {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--panel-2) 68%, transparent);
}

.google-ads-alert-row {
  justify-content: flex-start;
}

.google-ads-alert-row > span {
  display: inline-flex;
  width: 28px;
  height: 28px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-weight: 900;
  background: rgba(59, 130, 246, .12);
  color: #60a5fa;
}

.google-ads-alert-row.critical > span,
.google-ads-alert-row.critico > span {
  background: rgba(239, 68, 68, .14);
  color: #fb7185;
}

.google-ads-alert-row.warning > span {
  background: rgba(245, 158, 11, .14);
  color: #f59e0b;
}

@media (max-width: 768px) {
  .google-ads-connection-panel,
  .google-ads-account-row {
    align-items: stretch;
    flex-direction: column;
  }
}

/* Estado ativo */
.nav-item--active {
  background: rgba(99,102,241,0.1);
  border-left-color: #6366F1;
}

.nav-item--active .nav-item__icon {
  color: #818CF8;
}

.nav-item--active .nav-item__label {
  color: #F1F5FF;
  font-weight: 600;
}

/* Rodapé */
.sidebar__footer {
  flex-shrink: 0;
  padding: 12px 16px;
  border-top: 1px solid rgba(255,255,255,0.05);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.sidebar__version {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #4B5563;
}

/* Sair — discreto, não é CTA principal */
.sidebar__signout {
  font-size: 12px;
  font-weight: 500;
  color: #8892A4;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: color 120ms ease, background 120ms ease;
}

.sidebar__signout:hover {
  color: #EF4444;
  background: rgba(239,68,68,0.08);
}

/* Mobile — drawer */
@media (max-width: 768px) {
  .sidebar {
    transform: translateX(-100%);
    transition: transform 220ms ease;
    z-index: 200;
    box-shadow: 4px 0 24px rgba(0,0,0,0.5);
  }

  .sidebar--open {
    transform: translateX(0);
  }
}

.main-content {
  margin-left: 220px;
  min-height: 100vh;
  background: #080D1A;
  min-width: 0;
}

@media (max-width: 768px) {
  .main-content {
    margin-left: 0;
  }
}

.alerta-principal {
  position: relative;
  overflow: hidden;
  background: rgba(239,68,68,0.06);
  border: 1px solid rgba(239,68,68,0.15);
  border-left: 4px solid #EF4444;
  border-radius: 12px;
  padding: 24px 140px 24px 28px;
}

/* Ícone decorativo do carrinho — decoração, não informação */
.alerta-principal__icon-deco {
  position: absolute;
  right: -10px;
  top: 50%;
  transform: translateY(-50%);
  width: 100px;
  height: 100px;
  opacity: 0.15;
  pointer-events: none;
}

.overview-top-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: stretch;
  margin-bottom: 20px;
}

.overview-top-grid > * {
  height: 100%;
}

@media (max-width: 768px) {
  .app-shell .main {
    margin-left: 0;
  }

  .overview-top-grid {
    grid-template-columns: 1fr;
  }

  .alerta-principal {
    padding-right: 28px;
  }

  .alerta-principal__icon-deco {
    display: none;
  }
}

.alerts-ai-strip .ai-credit-notice {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding: 0;
  border: 0;
  background: transparent;
  font-size: .75rem;
  opacity: .7;
}
.alerts-ai-strip .ai-credit-notice-icon {
  width: 20px;
  height: 20px;
}
.alerts-ai-strip .ai-credit-notice-copy,
.alerts-ai-strip .ai-credit-notice-copy p {
  margin: 0;
  font-size: .75rem;
}
.alerts-active-panel .icon-btn {
  min-width: 40px;
}

@media (max-width: 1180px) {
  .alerts-filter-bar {
    align-items: stretch;
    flex-direction: column;
    gap: 12px;
  }
}

@media (max-width: 760px) {
  .alerts-filter-bar .channel-filter {
    align-items: stretch;
    flex-direction: column;
    gap: 10px;
  }
  .alerts-filter-bar .channel-filter .segments {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .dashboard-sync-warning p {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .alerts-summary-panel,
  .alerts-top-impact-card,
  .alerts-critical-channel-card,
  .alerts-active-panel,
  .alerts-finance-panel,
  .alerts-channel-panel,
  .alerts-actions-panel,
  .alerts-ai-strip {
    padding: 20px;
  }
}

@media (max-width: 760px) {
  .analytics-kpi-grid,
  .analytics-score-grid,
  .analytics-insights-grid,
  .analytics-commerce-grid {
    grid-template-columns: 1fr;
  }
  .analytics-filters-panel,
  .analytics-executive-summary,
  .analytics-kpi-card,
  .analytics-commerce-panel,
  .analytics-commerce-grid article,
  .analytics-score-panel,
  .analytics-score-card,
  .analytics-funnel-panel,
  .analytics-performance-panel,
  .analytics-insights-panel,
  .analytics-insights-grid article,
  .analytics-alerts-panel article,
  .analytics-actions-panel,
  .analytics-actions-panel article,
  .analytics-manager-panel,
  .analytics-evolution-panel,
  .analytics-work-panel {
    padding: 24px;
  }
}

/* OPRIX visual system layer: tokens only, preserving layout and behavior. */
:root {
  --oprix-bg: #020B1C;
  --oprix-bg-soft: #071326;
  --oprix-card: rgba(255,255,255,0.055);
  --oprix-card-strong: rgba(255,255,255,0.085);
  --oprix-border: rgba(255,255,255,0.11);
  --oprix-cyan: #35D6D0;
  --oprix-cyan-dark: #1AAFA9;
  --oprix-text: #F5F7FA;
  --oprix-muted: #A8B3C7;
  --oprix-muted-2: #748197;
  --oprix-silver: #D9DEE7;
  --oprix-warning: #F2C94C;
  --oprix-danger: #FF6B6B;
  --oprix-radius: 28px;
  --oprix-radius-sm: 16px;
  --oprix-shadow: 0 30px 80px rgba(0,0,0,0.35);
  --oprix-shell-bg:
    radial-gradient(circle at 20% 0%, rgba(53,214,208,0.18), transparent 28%),
    radial-gradient(circle at 80% 10%, rgba(53,214,208,0.08), transparent 24%),
    linear-gradient(180deg, #020B1C 0%, #030713 52%, #020B1C 100%);
  --oprix-surface-bg: linear-gradient(180deg, var(--oprix-card-strong), rgba(255,255,255,0.035));
  --oprix-sidebar-bg: rgba(2,11,28,0.76);
  --oprix-cyan-soft: rgba(53,214,208,0.08);
  --oprix-cyan-hover: rgba(53,214,208,0.05);
  --oprix-cyan-ring: rgba(53,214,208,0.15);
  --oprix-ghost-border: rgba(53,214,208,0.28);
  --oprix-row-border: rgba(255,255,255,0.07);
  --oprix-row-hover: rgba(53,214,208,0.04);
  --oprix-scroll-thumb: rgba(53,214,208,0.3);
  --oprix-scroll-thumb-hover: rgba(53,214,208,0.6);
  --oprix-input-radius: 12px;
  --bg: var(--oprix-bg);
  --panel: var(--oprix-card);
  --panel-2: var(--oprix-card-strong);
  --text: var(--oprix-text);
  --muted: var(--oprix-muted);
  --line: var(--oprix-border);
  --brand: var(--oprix-cyan);
  --brand-2: var(--oprix-cyan-dark);
  --brand-3: var(--oprix-cyan);
  --ink: var(--oprix-text);
  --shadow: var(--oprix-shadow);
  --radius: var(--oprix-radius-sm);
  font-family: 'Inter', system-ui, sans-serif;
}

html,
body {
  background: var(--oprix-shell-bg);
  color: var(--oprix-text);
  font-family: 'Inter', system-ui, sans-serif;
}

h1,
h2,
h3,
.logo-text,
.page-title,
.brand-name,
.sidebar-title,
.brand-copy strong,
.sidebar__brand,
.page-head h1,
.topbar-primary > strong {
  font-family: 'Sora', sans-serif;
  font-weight: 800;
  letter-spacing: -0.04em;
}

.brand-mark,
.sidebar__logo .brand-mark {
  background: var(--oprix-cyan);
  border-radius: var(--oprix-radius-sm);
  box-shadow: none;
  color: var(--oprix-bg);
  font-family: 'Sora', sans-serif;
  font-weight: 800;
}

.brand-logo-img,
.sidebar__logo-img {
  filter: none;
}

.app-shell,
.admin-shell,
.landing-shell,
.auth-shell,
.main,
.main-content {
  background: transparent;
}

.sidebar,
.admin-sidebar,
.topbar {
  background: var(--oprix-sidebar-bg);
  border-color: var(--oprix-border);
  backdrop-filter: blur(20px);
}

.sidebar__tagline,
.nav-group-label,
.ds-nav-group-label,
.card p,
.panel p,
.muted,
.hint,
.field label,
.kpi .label {
  color: var(--oprix-muted);
}

.nav-item,
.ds-nav-item,
.admin-sidebar .nav a {
  color: var(--oprix-muted);
  border-left-color: transparent;
}

.nav-item:hover,
.ds-nav-item:hover,
.admin-sidebar .nav a:hover {
  color: var(--oprix-cyan);
  background: var(--oprix-cyan-hover);
}

.nav-item--active,
.ds-nav-item--active,
.admin-sidebar .nav a.active {
  color: var(--oprix-cyan);
  background: var(--oprix-cyan-soft);
  border-left-color: var(--oprix-cyan);
}

.panel,
.card,
.kpi,
.modal,
.auth-card,
.request-shell .panel,
.overview-exec-kpi,
.overview-score-card,
.overview-main-alert,
.overview-funnel-panel,
.overview-performance-panel,
.overview-ai-panel,
.overview-channel-panel,
.overview-action-plan,
.overview-integrations-panel,
.next-sync-panel,
.admin-sync-panel,
.admin-sync-control-panel,
.analytics-kpi-card,
.landing-card,
.ds-card,
.ds-card-kpi {
  background: var(--oprix-surface-bg);
  border-color: var(--oprix-border);
  border-radius: var(--oprix-radius);
  box-shadow: var(--oprix-shadow);
}

.btn,
.tab-btn,
.seg-btn,
.icon-btn {
  border-radius: 999px;
}

.btn.primary,
.btn.glow {
  background: var(--oprix-cyan);
  border-color: var(--oprix-cyan);
  color: var(--oprix-bg);
  font-weight: 700;
}

.btn.primary:hover,
.btn.glow:hover {
  background: var(--oprix-cyan-dark);
  border-color: var(--oprix-cyan-dark);
}

.btn.ghost,
.btn.secondary,
.tab-btn,
.seg-btn,
.icon-btn {
  background: var(--oprix-cyan-soft);
  border-color: var(--oprix-ghost-border);
  color: var(--oprix-cyan);
}

.btn:focus-visible,
.tab-btn:focus-visible,
.seg-btn:focus-visible,
.icon-btn:focus-visible,
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--oprix-cyan);
  outline-offset: 2px;
}

input,
select,
textarea,
.field input,
.field select,
.field textarea,
.topbar select {
  background: var(--oprix-card);
  border-color: var(--oprix-border);
  border-radius: var(--oprix-input-radius);
  color: var(--oprix-text);
}

input:focus,
select:focus,
textarea:focus,
.field input:focus,
.field select:focus,
.field textarea:focus,
.topbar select:focus {
  border-color: var(--oprix-cyan);
  box-shadow: 0 0 0 3px var(--oprix-cyan-ring);
}

th,
thead th {
  background: var(--oprix-card);
  color: var(--oprix-muted);
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

td,
tbody td {
  color: var(--oprix-text);
  border-bottom-color: var(--oprix-row-border);
}

tbody tr:hover {
  background: var(--oprix-row-hover);
}

::-webkit-scrollbar-track {
  background: var(--oprix-bg);
}

::-webkit-scrollbar-thumb {
  background: var(--oprix-scroll-thumb);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--oprix-scroll-thumb-hover);
}

/* Retaguarda dark-theme stabilization: visual only, preserving behavior. */
html,
body,
body[data-theme] {
  color-scheme: dark;
  background: var(--oprix-shell-bg);
  color: var(--oprix-text);
}

.admin-shell,
.admin-shell .main,
.admin-shell .content,
.app-shell,
.main-content {
  color: var(--oprix-text);
}

.admin-sidebar,
.sidebar,
.topbar {
  background: var(--oprix-sidebar-bg);
  border-color: var(--oprix-border);
}

.panel,
.card,
.modal,
.modal-card,
.modal-content,
.notification-popover,
.table-wrap,
.report-filter-card,
.admin-sync-panel,
.admin-sync-control-panel {
  background: var(--oprix-surface-bg);
  border-color: var(--oprix-border);
  color: var(--oprix-text);
}

input,
select,
textarea,
button.select-like,
.field input,
.field select,
.field textarea,
.topbar select,
#global-client,
.report-filter-card input,
.report-filter-card select,
.report-filter-card textarea,
.filters input,
.filters select,
.filters textarea,
.search-field,
.search-input {
  background: var(--oprix-card);
  border-color: var(--oprix-border);
  color: var(--oprix-text);
  caret-color: var(--oprix-cyan);
}

select option,
select optgroup,
#global-client option {
  background: var(--oprix-bg-soft);
  color: var(--oprix-text);
}

input::placeholder,
textarea::placeholder {
  color: var(--oprix-muted-2);
  opacity: 1;
}

input:hover,
select:hover,
textarea:hover,
.field input:hover,
.field select:hover,
.field textarea:hover,
.topbar select:hover,
#global-client:hover {
  border-color: var(--oprix-ghost-border);
}

input:focus,
select:focus,
textarea:focus,
.field input:focus,
.field select:focus,
.field textarea:focus,
.topbar select:focus,
#global-client:focus {
  outline: 2px solid var(--oprix-cyan);
  outline-offset: 2px;
  border-color: var(--oprix-cyan);
  box-shadow: 0 0 0 3px var(--oprix-cyan-ring);
}

.modal-backdrop,
.dialog-backdrop {
  background: rgba(2, 11, 28, .72);
  backdrop-filter: blur(8px);
}

table,
.table,
.data-table {
  color: var(--oprix-text);
}

thead,
.table thead,
.data-table thead {
  background: var(--oprix-card);
}




