:root {
  --brand-blue: #1c72a8;
  --brand-blue-alt: #1273ca;
  --brand-cyan: #7cd3ed;
  --brand-rose: #3e4296;
  --brand-bg: #f7f5ff;
  --brand-bg-alt: #ffffff;
  --brand-text: #1a1a1a;
  --brand-muted: #6b5c7a;
  --brand-border: #e2def5;
  --brand-shadow: 0 8px 24px rgba(91, 57, 205, 0.12);
}
html:not([data-theme="dark"]) {
  --bg: var(--brand-bg);
  --bg-alt: var(--brand-bg-alt);
  --text: var(--brand-text);
  --muted: var(--brand-muted);
  --accent: var(--brand-blue);
  --accent-light: color-mix(in oklab, var(--brand-blue) 18%, white);
  --border: var(--brand-border);
  --shadow: var(--brand-shadow);
}
html[data-theme="dark"] {
  --bg: #06183f;
  --bg-alt: #0f1f41;
  --text: #ffffff;
  --muted: #c7c3e6;
  --accent: var(--brand-blue);
  --accent-light: #254791;
  --border: #0e3385;
  --shadow: 0 8px 24px rgba(6, 10, 36, 0.45);
}
body {
  font-family: "Canva Sans", Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.page-title,
.section-title,
.ttl,
.brand,
.login-title {
  font-family: "League Spartan", Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: 0.2px;
}
.brand-logo {
  display: inline-block;
  width: 100%;
  padding: 5px;
}
.brand-logo-dark { display: none; }
html[data-theme="dark"] .brand-logo-light { display: none; }
html[data-theme="dark"] .brand-logo-dark { display: inline-block; }
.sidebar {
  padding: 24px 16px 80px;
}
.app { grid-template-columns: 240px 1fr; }
.nav-group.open .nav-group-title {
  border-left: 4px solid var(--accent);
}
.content { padding: 24px; }
.card { border-radius: 12px; padding: 16px; margin-bottom: 24px; box-shadow: var(--shadow); }
.toolbar { gap: 12px; margin-bottom: 12px; }
.toolbar .left { gap: 12px; }
.toolbar .right { gap: 8px; }
.form-row { gap: 12px; margin-bottom: 12px; }
.btn {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.btn:hover {
  background: color-mix(in oklab, var(--accent) 85%, black);
  border-color: color-mix(in oklab, var(--accent) 85%, black);
}
.btn.btn-danger {
  background: var(--brand-rose);
  color: #fff;
  border-color: var(--brand-rose);
}
.btn.btn-danger:hover {
  background: color-mix(in oklab, var(--brand-rose) 85%, black);
  border-color: color-mix(in oklab, var(--brand-rose) 85%, black);
}
.input:hover,
.input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent) 16%, white) inset;
}
.table th {
  color: var(--text);
}
.kpi {
  border-color: var(--border);
}
.chart-bar {
  background: var(--accent);
}
.legend-color:nth-child(1) { background: var(--brand-blue); }
.legend-color:nth-child(2) { background: var(--brand-cyan); }
.legend-color:nth-child(3) { background: var(--brand-rose); }
.login-card {
  border-top: 6px solid var(--accent);
}
.login-actions .btn.btn-primary {
  background: var(--accent);
  border-color: var(--accent);
}
.nav-logout {
  border-color: var(--accent);
  color: var(--accent);
}
.nav-logout:hover {
  background: var(--accent-light);
}
@media (max-width: 900px) {
 
  .content { padding: 16px; }
  .card { padding: 14px; margin-bottom: 16px; }
  .kpis-compact { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}
