﻿/* ============================================================
   iACCESS.app — Inspinia/Bootstrap 5 Theme
   Bootstrap 5 + Tabler Icons + iACCESS brand by iTIME.pt
   ============================================================ */

/* ── IBM Plex fonts ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

/* ── CSS Variables ──────────────────────────────────────────── */
:root {
  /* iACCESS Blue scale */
  --b-50:  #eff6ff;
  --b-100: #dbeafe;
  --b-200: #bfdbfe;
  --b-300: #93c5fd;
  --b-400: #60a5fa;
  --b-500: #3b82f6;
  --b-600: #2153a1;
  --b-700: #1d4ed8;
  --b-800: #1e40af;
  --b-900: #1e3a8a;
  --b-950: #172554;
  /* Orange accent */
  --o-300: #fdba74;
  --o-400: #fb923c;
  --o-500: #f97316;
  --o-600: #ea580c;
  /* Neutral scale */
  --n-50:  #f9fafb;
  --n-100: #f3f4f6;
  --n-200: #e5e7eb;
  --n-300: #d1d5db;
  --n-400: #9ca3af;
  --n-500: #6b7280;
  --n-600: #4b5563;
  --n-700: #374151;
  --n-800: #1f2937;
  --n-900: #111827;
  /* Status */
  --clr-success: #22c55e;
  --clr-danger:  #ef4444;
  --clr-warning: #f59e0b;
  --clr-info:    #3b82f6;
  /* Typography */
  --font-sans: 'IBM Plex Sans', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'IBM Plex Mono', 'Fira Code', 'Courier New', monospace;
  /* Input */
  --input-h: 36px;
  --input-border: var(--n-300);
  --input-radius: var(--theme-border-radius);
  --input-focus: var(--b-500);
  --input-bg: #fff;
  /* Text sizes */
  --text-sm: 13px;
  --text-base: 14px;
  /* Layout */
  --sidenav-width: 260px;
  --sidenav-width-compact: 220px;
  --sidenav-width-condensed: 70px;
  --topbar-height: 64px;
  /* Radius tokens (Inspinia/Bootstrap template scale) */
  --theme-border-radius: 0.3rem;
  --theme-border-radius-sm: 0.25rem;
  --theme-border-radius-lg: 0.4rem;
  --theme-border-radius-xl: 1rem;
  --theme-border-radius-xxl: 2rem;
  --theme-border-radius-pill: 50rem;
  --radius-sm: var(--theme-border-radius-sm);
  --radius-md: var(--theme-border-radius);
  --radius-lg: var(--theme-border-radius-lg);
  --radius-xl: var(--theme-border-radius-xl);
  /* Shadow tokens */
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:  0 4px 12px rgba(0,0,0,.10), 0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:  0 10px 30px rgba(0,0,0,.14), 0 4px 8px rgba(0,0,0,.08);
  /* Extended text-size tokens */
  --text-xs:    11px;
  --text-md:    15px;
  --text-lg:    16px;
  --text-xl:    18px;
  --text-2xl:   22px;
  --text-3xl:   28px;
  /* Neutral zero */
  --n-0:        #ffffff;
  /* Semantic color backgrounds/borders */
  --clr-success-bg:     #f0fdf4;
  --clr-success-border: #bbf7d0;
  --clr-warning-bg:     #fffbeb;
  --clr-warning-border: #fde68a;
  --clr-danger-bg:      #fef2f2;
  --clr-danger-border:  #fecaca;
  --clr-info-bg:        var(--b-50);
  --clr-info-border:    var(--b-200);
  /* Bootstrap CSS var overrides */
  --bs-primary: #2153a1;
  --bs-primary-rgb: 33, 83, 161;
  --bs-font-sans-serif: 'IBM Plex Sans', system-ui, sans-serif;
  --bs-border-radius: var(--theme-border-radius);
  --bs-border-radius-sm: var(--theme-border-radius-sm);
  --bs-border-radius-lg: var(--theme-border-radius-lg);
  --bs-border-radius-xl: var(--theme-border-radius-xl);
  --bs-border-radius-xxl: var(--theme-border-radius-xxl);
  --bs-border-radius-pill: var(--theme-border-radius-pill);
  --bs-border-color: var(--n-200);
  --bs-card-border-color: var(--n-200);
  --bs-body-font-family: 'IBM Plex Sans', system-ui, sans-serif;
  --bs-body-font-size: 14px;
  --bs-body-color: #1f2937;
  --bs-body-bg: #f9fafb;
}

html[data-border-radius="off"] {
  --theme-border-radius: 0;
  --theme-border-radius-sm: 0;
  --theme-border-radius-lg: 0;
  --theme-border-radius-xl: 0;
  --theme-border-radius-xxl: 0;
  --theme-border-radius-pill: 0;
  --input-radius: 0;
  --radius-sm: 0;
  --radius-md: 0;
  --radius-lg: 0;
  --radius-xl: 0;
  --bs-border-radius: 0;
  --bs-border-radius-sm: 0;
  --bs-border-radius-lg: 0;
  --bs-border-radius-xl: 0;
  --bs-border-radius-xxl: 0;
  --bs-border-radius-pill: 0;
}

html[data-border-radius="off"] *:not(.logo-icon-wrap):not(.logo-icon-wrap *):not(.login-brand-icon):not(.login-brand-icon *):not(.ls-mobile-icon):not(.ls-mobile-icon *):not(.ls-logo-icon):not(.ls-logo-icon *):not(.ls-shield):not(.ls-shield *):not(.sidenav-user-avatar):not(.topbar-avatar):not(.gs-avatar):not(.gs-user-modal-avatar):not(.avatar):not(.avatar *):not(.avatar-xs):not(.avatar-sm):not(.avatar-md):not(.avatar-lg):not(.avatar-initials):not(.ag-avatar):not(.cred-avatar):not(.tbl-avatar-wrap):not(.tbl-avatar-wrap *):not(.dp-avatar):not(.dp-avatar *):not(.em-avatar):not(.em-avatar *):not(.ev-av):not(.ev-av *):not(.fep-avatar):not(.fep-avatar *):not(.z-avatar):not(.fp-marker):not(.fp-marker *):not(.fp-marker-dot):not(.fp-remove):not(.fp-label):not(.fp-zone-chip):not(.fp-leg i):not(.toggle):not(.toggle *):not(.toggle-track):not(.form-switch):not(.form-switch *):not(.form-check-input):not(.form-check-input-light):not(.spinner):not(.spinner *):not(.skeleton):not(.skeleton *):not(.loading):not(.loading *):not(.fp-loading):not(.gs-loading) {
  border-radius: 0 !important;
}

html[data-border-radius="off"] .ls-logo-icon { border-radius: 22px !important; }
html[data-border-radius="off"] .ls-shield { border-radius: 16px !important; }

html[data-border-radius="off"] .sidenav-user-avatar,
html[data-border-radius="off"] .topbar-avatar,
html[data-border-radius="off"] .gs-avatar,
html[data-border-radius="off"] .gs-user-modal-avatar,
html[data-border-radius="off"] .avatar,
html[data-border-radius="off"] .avatar-xs,
html[data-border-radius="off"] .avatar-sm,
html[data-border-radius="off"] .avatar-md,
html[data-border-radius="off"] .avatar-lg,
html[data-border-radius="off"] .avatar-initials,
html[data-border-radius="off"] .ag-avatar,
html[data-border-radius="off"] .cred-avatar,
html[data-border-radius="off"] .dp-avatar,
html[data-border-radius="off"] .em-avatar,
html[data-border-radius="off"] .ev-av,
html[data-border-radius="off"] .fep-avatar {
  border-radius: 50% !important;
}

html[data-border-radius="off"] .z-avatar { border-radius: 7px !important; }

html[data-border-radius="off"] .fp-marker { border-radius: 7px !important; }
html[data-border-radius="off"] .fp-marker-dot,
html[data-border-radius="off"] .fp-remove { border-radius: 50% !important; }
html[data-border-radius="off"] .fp-label { border-radius: 4px !important; }
html[data-border-radius="off"] .fp-zone-chip,
html[data-border-radius="off"] .fp-leg i { border-radius: 6px !important; }
html[data-border-radius="off"] .fp-marker.fp-active::before { border-radius: 11px !important; }
html[data-border-radius="off"] .fp-marker.fp-active::after { border-radius: 14px !important; }

html[data-border-radius="off"] .toggle-track { border-radius: 20px !important; }
html[data-border-radius="off"] .toggle-track::after,
html[data-border-radius="off"] .form-check-input,
html[data-border-radius="off"] .form-check-input-light,
html[data-border-radius="off"] .spinner { border-radius: 50% !important; }
html[data-border-radius="off"] .skeleton { border-radius: 6px !important; }

html[data-border-radius="off"] .avatar img,
html[data-border-radius="off"] .dp-avatar img,
html[data-border-radius="off"] .em-avatar img,
html[data-border-radius="off"] .ev-av img,
html[data-border-radius="off"] .fep-avatar img {
  border-radius: inherit !important;
}

/* ── Base reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { font-size: 14px; }

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  background: var(--n-50);
  color: var(--n-800);
  margin: 0;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── Wrapper (Inspinia layout root) ─────────────────────────── */
/* Não usar flex aqui: sidenav e topbar são position:fixed (fora do fluxo).
   Como bloco, o content-page calcula a largura correctamente como
   100vw − margin-left sem overflow. */
.wrapper {
  display: block;
  min-height: 100vh;
}

/* ── Sidenav (sidebar) ──────────────────────────────────────── */
.sidenav-menu {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidenav-width);
  background: #1e2434;
  display: flex;
  flex-direction: column;
  z-index: 1000;
  transition: width 0.2s ease, transform 0.25s ease;
  overflow: hidden;
  flex-shrink: 0;
}

[data-menu-color="gradient"] .sidenav-menu {
  background:
    radial-gradient(circle at 18% 0%, rgba(33,83,161,.32), transparent 30%),
    linear-gradient(180deg, #172033 0%, #111827 48%, #07111f 100%);
}
[data-menu-color="gradient"] .sidenav-menu .logo {
  border-bottom-color: rgba(255,255,255,.08);
}
[data-menu-color="gradient"] .side-nav-item > .side-nav-link.active {
  background: #2153a1;
  color: #fff;
  box-shadow: none;
}
[data-menu-color="gradient"] .side-nav-item > .side-nav-link:hover {
  background: rgba(255,255,255,.09);
}
[data-menu-color="gradient"] .side-nav-item.side-nav-section-item,
[data-menu-color="gradient"] .sidenav-user-footer {
  border-color: rgba(255,255,255,.08);
}

/* Logo area */
.sidenav-menu .logo {
  height: var(--topbar-height);
  display: flex;
  align-items: center;
  padding: 0 20px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  text-decoration: none;
  flex-shrink: 0;
  gap: 12px;
}
.logo-icon-wrap {
  width: 36px; height: 36px;
  background: var(--b-600);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  flex-shrink: 0;
  font-size: 18px;
}
.logo-text-block { display: flex; flex-direction: column; overflow: hidden; }
.logo-title {
  font-size: 16px; font-weight: 700; color: #fff;
  letter-spacing: -0.3px; white-space: nowrap;
}
.logo-sub {
  font-size: 10px; color: rgba(255,255,255,0.4);
  letter-spacing: 0.5px; white-space: nowrap;
}

/* Scrollable menu area */
.sidenav-menu .scrollbar {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px 0 24px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.12) transparent;
}
.sidenav-menu .scrollbar::-webkit-scrollbar { width: 4px; }
.sidenav-menu .scrollbar::-webkit-scrollbar-track { background: transparent; }
.sidenav-menu .scrollbar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border-radius: 4px; }
.sidenav-menu .scrollbar::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.25); }
.sidenav-menu:hover .scrollbar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.18); }

/* Nav structure */
.side-nav { list-style: none; padding: 0; margin: 0; }

.side-nav-title {
  padding: 16px 20px 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.3);
}

.side-nav-item { margin: 1px 8px; }

.side-nav-item > .side-nav-link {
  display: flex;
  align-items: center;
  padding: 9px 12px;
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  border-radius: 6px;
  transition: background 0.12s, color 0.12s;
  gap: 10px;
}
.side-nav-item > .side-nav-link:hover {
  background: rgba(255,255,255,0.07);
  color: #fff;
}
.side-nav-item > .side-nav-link.active {
  background: #2153a1;
  color: #fff;
}
.menu-icon {
  width: 20px;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
}
.menu-arrow {
  margin-left: auto;
  font-size: 11px;
  opacity: 0.5;
  transition: transform 0.2s, opacity 0.2s;
  flex-shrink: 0;
}
/* Arrow rotates when parent li has .open */
.side-nav-item.open > .side-nav-link .menu-arrow { transform: rotate(90deg); opacity: 1; }

/* Section-level collapsible items (Relatórios, Infra, etc.)
   — styled identically to other nav items but with a top separator */
.side-nav-item.side-nav-section-item {
  margin-top: 6px;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 4px;
}

/* Sub-nav — hidden by default, shown when parent has .open */
.sub-nav {
  list-style: none; padding: 2px 0 4px; margin: 0;
  display: none;
  overflow: hidden;
}
.sub-nav.open { display: block; }

.sub-nav .side-nav-item { margin: 0 8px; }
.sub-nav .side-nav-link {
  padding: 7px 12px 7px 42px;
  font-size: 13px;
  font-weight: 400;
  color: rgba(255,255,255,0.5);
  border-radius: 6px;
  display: flex; align-items: center; gap: 8px;
  text-decoration: none;
  transition: background 0.12s, color 0.12s;
}
.sub-nav .side-nav-link:hover { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.85); }
.sub-nav .side-nav-link.active { color: #fff; font-weight: 600; }
.sub-nav .side-nav-item.side-nav-nested { margin-top: 2px; }
.sub-nav .side-nav-item.side-nav-nested > .side-nav-link {
  padding-left: 42px;
  color: rgba(255,255,255,0.6);
}
.sub-nav.sub-nav-nested { padding-top: 0; padding-bottom: 2px; }
.sub-nav.sub-nav-nested .side-nav-link { padding-left: 62px; font-size: 12.5px; }
.sub-nav.sub-nav-nested .menu-icon { font-size: 15px; }

/* Sidenav user footer */
.sidenav-user-footer {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 12px 16px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  overflow: hidden;
}
.sidenav-user-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--b-600);
  color: #fff;
  font-size: 12px; font-weight: 600;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.sidenav-user-name {
  font-size: 13px; font-weight: 600;
  color: rgba(255,255,255,0.85);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sidenav-user-role {
  font-size: 11px;
  color: rgba(255,255,255,0.4);
  white-space: nowrap;
}

/* ── Compact sidebar (220 px — labels visible, espaçamento mais apertado) ── */
[data-sidenav-size="compact"] .sidenav-menu  { width: var(--sidenav-width-compact); }
[data-sidenav-size="compact"] .app-topbar    { left: var(--sidenav-width-compact); }
[data-sidenav-size="compact"] .content-page  { margin-left: var(--sidenav-width-compact); }
[data-sidenav-size="compact"] .side-nav-item > .side-nav-link {
  padding: 7px 12px;
  font-size: 12.5px;
}
[data-sidenav-size="compact"] .menu-icon { font-size: 15px; width: 18px; }
[data-sidenav-size="compact"] .side-nav-title {
  font-size: 9px;
  padding: 10px 16px 4px;
}
[data-sidenav-size="compact"] .sub-nav .side-nav-link {
  padding: 5px 12px 5px 36px;
  font-size: 12px;
}
[data-sidenav-size="compact"] .sidenav-user-footer { padding: 8px 12px; }
[data-sidenav-size="compact"] .sidenav-user-name   { font-size: 12px; }
[data-sidenav-size="compact"] .sidenav-user-role   { font-size: 10px; }

/* ── Condensed sidebar ──────────────────────────────────────── */
[data-sidenav-size="condensed"] .sidenav-menu { width: var(--sidenav-width-condensed); }
[data-sidenav-size="condensed"] .logo-text-block,
[data-sidenav-size="condensed"] .side-nav-title,
[data-sidenav-size="condensed"] .menu-arrow,
[data-sidenav-size="condensed"] .nav-label,
[data-sidenav-size="condensed"] .sidenav-badge,
[data-sidenav-size="condensed"] .sidenav-user-name,
[data-sidenav-size="condensed"] .sidenav-user-role { display: none !important; }
[data-sidenav-size="condensed"] .side-nav-item > .side-nav-link {
  justify-content: center; padding: 9px;
  overflow: hidden; white-space: nowrap;
}
[data-sidenav-size="condensed"] .menu-icon { font-size: 20px; width: auto; }
[data-sidenav-size="condensed"] .side-nav-title { padding: 12px 0; }
[data-sidenav-size="condensed"] .logo { justify-content: center; padding: 0; }
[data-sidenav-size="condensed"] .logo-icon-wrap { margin: 0; }
/* Condensed: hide sub-navs and section-item separators regardless of .open */
[data-sidenav-size="condensed"] .sub-nav { display: none !important; }
[data-sidenav-size="condensed"] .side-nav-section-item { border-top: none; padding-top: 0; margin-top: 1px; }

/* ── App Topbar ─────────────────────────────────────────────── */
.app-topbar {
  position: fixed;
  top: 0;
  left: var(--sidenav-width);
  right: 0;
  height: var(--topbar-height);
  background: #fff;
  border-bottom: 1px solid var(--n-200);
  display: flex;
  align-items: center;
  padding: 0 20px;
  z-index: 999;
  transition: left 0.2s ease;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}
[data-sidenav-size="condensed"] .app-topbar { left: var(--sidenav-width-condensed); }

.topbar-menu {
  display: flex; align-items: center; gap: 10px; width: 100%;
}

.topbar-title {
  font-size: 16px; font-weight: 600; color: var(--n-800);
  margin: 0; flex: 1;
}

.sidenav-toggle-button {
  width: 36px; height: 36px;
  border: none; background: none;
  color: var(--n-600); border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; line-height: 1;
}
.sidenav-toggle-button i { font-size: 22px; line-height: 1; display: block; }
.sidenav-toggle-button:hover { background: var(--n-100); color: var(--n-800); }

.topbar-mobile-brand {
  display: none;
  align-items: center;
  gap: 8px;
  color: var(--n-800);
  text-decoration: none;
  flex-shrink: 0;
}
.topbar-mobile-logo {
  width: 32px; height: 32px;
  background: var(--b-600);
  color: #fff;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px;
  box-shadow: 0 4px 14px rgba(33,83,161,.24);
}
.topbar-mobile-title {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0;
}

/* Topbar right actions */
.topbar-right { display: flex; align-items: center; gap: 4px; margin-left: auto; }

.topbar-icon-btn {
  position: relative;
  width: 36px; height: 36px;
  border: none; background: none;
  color: var(--n-500); border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.topbar-icon-btn:hover { background: var(--n-100); color: var(--n-800); }
.topbar-badge {
  position: absolute; top: 4px; right: 4px;
  min-width: 16px; height: 16px;
  background: var(--clr-danger); color: #fff;
  border-radius: 8px; font-size: 9px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; padding: 0 3px;
}
.topbar-sep { width: 1px; height: 24px; background: var(--n-200); margin: 0 4px; }

/* Fullscreen toggler */
.topbar-link {
  position: relative;
  width: 36px; height: 36px;
  border: none; background: none;
  color: var(--n-500); border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; padding: 0;
}
.topbar-link:hover { background: var(--n-100); color: var(--n-800); }
.topbar-link-icon { font-size: 18px; line-height: 1; }
body.fullscreen-enable .ti-maximize { display: none !important; }
body:not(.fullscreen-enable) .ti-minimize { display: none !important; }

.topbar-lang-wrap { position: relative; }
.topbar-lang-btn {
  width: auto;
  min-width: 54px;
  gap: 5px;
  padding: 0 9px;
  font-size: 12px;
  font-weight: 800;
  color: var(--n-700);
}
.topbar-lang-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 176px;
  background: #fff;
  border: 1px solid var(--n-200);
  border-radius: 8px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.1);
  display: none;
  overflow: hidden;
  z-index: 1200;
}
.topbar-lang-dropdown.open { display: block; }
.topbar-lang-option {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 12px;
  border: 0;
  background: #fff;
  color: var(--n-700);
  font-size: 13px;
  text-align: left;
  cursor: pointer;
}
.topbar-lang-option:hover,
.topbar-lang-option.active {
  background: var(--b-50);
  color: var(--b-700);
}
.topbar-lang-code {
  width: 30px;
  height: 20px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--n-100);
  color: var(--n-700);
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
}
.topbar-lang-option.active .topbar-lang-code {
  background: var(--b-600);
  color: #fff;
}

/* User dropdown trigger */
.topbar-user-wrap { position: relative; }
.topbar-avatar-btn {
  display: flex; align-items: center; gap: 8px;
  border: none; background: none; cursor: pointer;
  padding: 5px 8px; border-radius: 6px; color: var(--n-700);
}
.topbar-avatar-btn:hover { background: var(--n-100); }
.topbar-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--b-600); color: #fff;
  font-size: 12px; font-weight: 600;
  display: flex; align-items: center; justify-content: center;
}
.topbar-user-label { font-size: 13px; font-weight: 600; color: var(--n-700); }
.topbar-chevron { color: var(--n-400); transition: transform 0.2s; }
.topbar-avatar-btn[aria-expanded="true"] .topbar-chevron { transform: rotate(180deg); }

/* User dropdown panel */
.topbar-dropdown {
  position: absolute; top: calc(100% + 8px); right: 0;
  width: 220px; background: #fff;
  border: 1px solid var(--n-200); border-radius: 8px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.1);
  display: none; z-index: 1200;
  overflow: hidden;
}
.topbar-dropdown.open { display: block; }
.topbar-dropdown-header {
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--n-100);
}
.topbar-dropdown-name { font-size: 14px; font-weight: 600; color: var(--n-800); }
.topbar-dropdown-role { font-size: 11px; color: var(--n-400); margin-top: 2px; }
.topbar-dropdown-divider { height: 1px; background: var(--n-100); margin: 4px 0; }
.topbar-dropdown-item {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 9px 16px;
  border: none; background: none;
  font-size: 13px; color: var(--n-700);
  cursor: pointer; text-decoration: none;
}
.topbar-dropdown-item:hover { background: var(--n-50); color: var(--n-800); }
.topbar-dropdown-danger { color: var(--clr-danger); }
.topbar-dropdown-danger:hover { background: #fef2f2; color: var(--clr-danger); }

/* ── Content Page ───────────────────────────────────────────── */
.content-page {
  margin-left: var(--sidenav-width);
  padding-top: var(--topbar-height);
  min-height: 100vh;
  transition: margin-left 0.2s ease;
}
[data-sidenav-size="condensed"] .content-page { margin-left: var(--sidenav-width-condensed); }

.content-page > .container-fluid {
  padding: 24px;
}

/* Keep backwards-compat with old .content class */
.content-page .content { /* no-op */ }

/* ── Anti-FOUC ───────────────────────────────────────────────────
   Antes de injectLayout() mover #page-content para dentro do wrapper,
   ele é filho directo do body e ficaria visível sem layout.
   Este selector esconde-o nesse estado inicial; quando é movido para
   .content-page > .container-fluid o selector deixa de corresponder
   e o conteúdo aparece automaticamente — sem JS adicional.        */
body > #page-content {
  display: none !important;
}

/* ── Sidebar mobile overlay ─────────────────────────────────── */
.sidebar-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 999;
}
.sidebar-overlay.open { display: block; }

/* ── Page header ─────────────────────────────────────────────── */
.page-header {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
  flex-wrap: wrap; gap: 12px;
}
.page-header-left h1 {
  font-size: 20px; font-weight: 700;
  color: var(--n-800); margin: 0 0 2px;
  display: flex; align-items: center; gap: 10px;
}
.page-header-icon {
  width: 28px; height: 28px; border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--b-600); background: var(--b-50);
  font-size: 18px; flex-shrink: 0;
}
.page-header-left p { font-size: 13px; color: var(--n-500); margin: 0; }

/* ── Cards ───────────────────────────────────────────────────── */
.card {
  background: #fff;
  border: 1px solid var(--n-200);
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  margin-bottom: 20px;
}
.card-header {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--n-100);
  gap: 12px; flex-wrap: wrap;
}
.card-title { font-size: 14px; font-weight: 600; color: var(--n-800); margin: 0; }
.card-subtitle { font-size: 12px; color: var(--n-500); margin-top: 2px; }
.card-body { padding: 20px; }
.card-footer {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  border-top: 1px solid var(--n-100);
  background: var(--n-50);
  border-radius: 0 0 8px 8px;
  gap: 12px; flex-wrap: wrap;
}

/* Utility margin/padding helpers */
.mb-4 { margin-bottom: 16px !important; }
.mb-3 { margin-bottom: 12px !important; }
.mt-4 { margin-top: 16px !important; }
.p-0  { padding: 0 !important; }

/* ── Tables ──────────────────────────────────────────────────── */
.table-wrapper { overflow-x: auto; }

table { width: 100%; border-collapse: collapse; font-size: 13px; }

th {
  padding: 10px 16px;
  text-align: left; font-size: 11px;
  font-weight: 600; letter-spacing: 0.5px;
  text-transform: uppercase; color: var(--n-500);
  background: var(--n-50); border-bottom: 1px solid var(--n-200);
  white-space: nowrap;
}
td {
  padding: 12px 16px; color: var(--n-700);
  border-bottom: 1px solid var(--n-100); vertical-align: middle;
}
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--n-50); }
.td-actions { text-align: right; white-space: nowrap; }

/* Sortable headers */
th[data-col] { cursor: pointer; user-select: none; }
th[data-col]:hover { background: var(--n-100); color: var(--n-700); }
.sort-ic::before { content: '↕'; margin-left: 4px; opacity: 0.3; font-size: 10px; }
th[data-col].asc  .sort-ic::before { content: '↑'; opacity: 1; }
th[data-col].desc .sort-ic::before { content: '↓'; opacity: 1; }

/* ── Toolbar ─────────────────────────────────────────────────── */
.toolbar {
  display: flex; align-items: center;
  flex-wrap: nowrap; gap: 8px;
  margin-bottom: 16px;
  overflow-x: auto; padding-bottom: 2px;
}
.search-input-wrap {
  position: relative; display: flex; align-items: center;
}
.search-input-wrap svg {
  position: absolute; left: 10px;
  color: var(--n-400); pointer-events: none;
}
.search-input-wrap input { padding-left: 32px !important; }
.toolbar select,
.toolbar input[type="date"],
.toolbar input[type="text"]:not(.search-input-wrap input),
.toolbar input[type="search"] {
  height: var(--input-h);
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  padding: 0 8px; font-size: var(--text-sm);
  font-family: var(--font-sans);
  background: var(--input-bg); color: var(--n-800); outline: none; flex-shrink: 0;
}
.toolbar select:focus,
.toolbar input[type="date"]:focus { border-color: var(--input-focus); }

/* ── Forms ───────────────────────────────────────────────────── */
.form-group {
  display: flex; flex-direction: column;
  gap: 6px; margin-bottom: 16px;
}
.form-row { display: flex; gap: 16px; }
.form-row .form-group { flex: 1; min-width: 0; }

label {
  font-size: 13px; font-weight: 500; color: var(--n-700); display: block;
}
label.required::after { content: ' *'; color: var(--clr-danger); }

.form-control {
  height: var(--input-h);
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  padding: 0 12px; font-size: 13px;
  font-family: var(--font-sans);
  background: var(--input-bg); color: var(--n-800);
  outline: none; width: 100%;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.form-control:focus {
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px rgba(59,130,246,0.12);
}
.form-control::placeholder { color: var(--n-400); }
select.form-control { cursor: pointer; }
textarea.form-control { height: auto; min-height: 80px; padding: 10px 12px; resize: vertical; }

/* ── Buttons ─────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 16px; border-radius: 6px;
  font-size: 13px; font-weight: 500;
  border: 1px solid transparent;
  cursor: pointer; text-decoration: none;
  white-space: nowrap;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
  line-height: 1.4;
}
.btn:focus-visible { outline: 2px solid var(--b-400); outline-offset: 2px; }
.btn-primary   { background: var(--b-600); color: #fff; border-color: var(--b-600); }
.btn-primary:hover { background: var(--b-700); border-color: var(--b-700); color: #fff; }
.btn-secondary { background: #fff; color: var(--n-700); border-color: var(--n-300); }
.btn-secondary:hover { background: var(--n-50); color: var(--n-800); }
.btn-danger    { background: var(--clr-danger); color: #fff; border-color: var(--clr-danger); }
.btn-danger:hover { background: #dc2626; }
.btn-sm { padding: 4px 12px; font-size: 12px; }
.btn-icon {
  width: 30px; height: 30px; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
  border: none; background: none; color: var(--n-500);
  border-radius: 6px; cursor: pointer;
}
.btn-icon:hover { background: var(--n-100); color: var(--n-700); }

/* ── Badges ──────────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center;
  padding: 2px 8px; border-radius: 12px;
  font-size: 11px; font-weight: 600; white-space: nowrap;
}
.badge-success { background: #dcfce7; color: #166534; }
.badge-danger  { background: #fee2e2; color: #991b1b; }
.badge-warning { background: #fef9c3; color: #854d0e; }
.badge-info    { background: var(--b-50); color: var(--b-700); }
.badge-neutral { background: var(--n-100); color: var(--n-600); }
.status-online  { background: #dcfce7; color: #166534; }
.status-offline { background: var(--n-100); color: var(--n-500); }
.status-warning { background: #fef9c3; color: #854d0e; }

/* ── Pagination ──────────────────────────────────────────────── */
.pagination { display: flex; align-items: center; gap: 4px; }
.pagination-btn {
  min-width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--n-200);
  background: #fff; color: var(--n-600);
  border-radius: 6px; font-size: 13px;
  cursor: pointer; padding: 0 8px;
  transition: background 0.1s, border-color 0.1s;
}
.pagination-btn:hover:not(:disabled) { background: var(--n-50); border-color: var(--n-300); }
.pagination-btn.active { background: var(--b-600); color: #fff; border-color: var(--b-600); }
.pagination-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Modals (custom system — keep independent of Bootstrap modal) ── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.45);
  display: none; align-items: center; justify-content: center;
  z-index: 2000; padding: 20px;
}
.modal-overlay.open { display: flex; }

/* Override Bootstrap's .modal so it doesn't break our custom system */
.modal-overlay .modal {
  position: relative !important;
  display: flex !important;
  flex-direction: column;
  top: auto !important; left: auto !important;
  width: 100% !important; max-width: 560px;
  max-height: calc(100vh - 40px);
  overflow: hidden;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.18);
  border: none !important;
  z-index: auto !important;
  height: auto !important;
}
.modal-header {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--n-100);
  border-radius: 0 !important;
  flex-shrink: 0;
}
.modal-title { font-size: 16px; font-weight: 700; color: var(--n-800); margin: 0; }
.modal-close {
  width: 28px; height: 28px;
  border: none; background: none; color: var(--n-400);
  cursor: pointer; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
}
.modal-close:hover { background: var(--n-100); color: var(--n-700); }
.modal-body {
  padding: 20px 24px;
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
}
.modal-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 16px 24px; border-top: 1px solid var(--n-100);
  border-radius: 0 0 10px 10px !important;
  background: transparent !important;
  flex-shrink: 0;
}

/* ── Alerts ──────────────────────────────────────────────────── */
.alert {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 16px; border-radius: 6px;
  font-size: 13px; margin-bottom: 16px;
}
.alert-warning { background: #fffbeb; color: #92400e; border: 1px solid #fde68a; }
.alert-danger  { background: #fef2f2; color: #7f1d1d; border: 1px solid #fca5a5; }
.alert-info    { background: var(--b-50); color: var(--b-800); border: 1px solid var(--b-200); }
.alert-success { background: #f0fdf4; color: #14532d; border: 1px solid #86efac; }

/* ── Toasts ──────────────────────────────────────────────────── */
#toast-container {
  position: fixed; bottom: 24px; right: 24px;
  z-index: 3000; display: flex;
  flex-direction: column; gap: 8px;
  pointer-events: none;
}
.iax-toast {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; border-radius: 8px;
  font-size: 13px; font-weight: 500;
  box-shadow: 0 4px 20px rgba(0,0,0,0.14);
  pointer-events: auto;
  animation: toastIn 0.2s ease;
  min-width: 240px; max-width: 360px;
  opacity: 1;
}
.iax-toast-success { background: #166534; color: #fff; }
.iax-toast-danger  { background: #7f1d1d; color: #fff; }
.iax-toast-warning { background: #78350f; color: #fff; }
.iax-toast-info    { background: var(--b-700); color: #fff; }
@keyframes toastIn {
  from { transform: translateX(16px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

/* ── Toggle switch ───────────────────────────────────────────── */
.toggle {
  position: relative; display: inline-block;
  width: 36px; height: 20px; flex-shrink: 0;
}
.toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-track {
  position: absolute; inset: 0;
  background: var(--n-200); border-radius: 20px;
  cursor: pointer; transition: background 0.2s;
}
.toggle-track::after {
  content: ''; position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px; border-radius: 50%;
  background: #fff; transition: transform 0.2s;
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}
.toggle input:checked ~ .toggle-track { background: var(--b-500); }
.toggle input:checked ~ .toggle-track::after { transform: translateX(16px); }

/* ── Empty state ─────────────────────────────────────────────── */
.empty-state {
  text-align: center; padding: 48px 24px; color: var(--n-400);
}
.empty-state p { font-size: 14px; color: var(--n-500); margin-bottom: 16px; }

/* ── Spinner ─────────────────────────────────────────────────── */
.spinner {
  width: 24px; height: 24px;
  border: 2px solid var(--n-200);
  border-top-color: var(--b-500);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  display: inline-block;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Live dot ─────────────────────────────────────────────────── */
.live-dot {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.5px;
  color: #fff; background: var(--clr-danger);
  padding: 4px 10px; border-radius: 12px;
}
.live-dot::before {
  content: ''; width: 6px; height: 6px;
  background: #fff; border-radius: 50%;
  animation: pulseDot 1.2s ease infinite;
}
@keyframes pulseDot { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }

/* ── Password field wrapper ──────────────────────────────────── */
.login-pw-wrap { position: relative; }
.login-pw-wrap .form-control { padding-right: 36px; }
.login-pw-toggle {
  position: absolute; right: 8px; top: 50%;
  transform: translateY(-50%);
  border: none; background: none; cursor: pointer;
  color: var(--n-400); display: flex; align-items: center;
  padding: 0;
}
.login-pw-toggle:hover { color: var(--n-600); }

/* ── Tabs ─────────────────────────────────────────────────────── */
.tabs { display: flex; border-bottom: 1px solid var(--n-200); gap: 0; margin-bottom: 20px; }
.tab-btn,
.tab {
  padding: 10px 18px; border: none; background: none;
  font-size: 13px; font-weight: 500; color: var(--n-500);
  cursor: pointer; border-bottom: 2px solid transparent;
  margin-bottom: -1px; white-space: nowrap;
  text-decoration: none; display: inline-flex; align-items: center;
}
.tab-btn.active,
.tab.active { color: var(--b-600); border-bottom-color: var(--b-600); }
.tab-btn:hover:not(.active),
.tab:hover:not(.active) { color: var(--n-700); }
.tab-content { display: none; }
.tab-content.active { display: block; }

/* ── Text helpers ─────────────────────────────────────────────── */
.text-muted  { color: var(--n-400) !important; }
.text-danger { color: var(--clr-danger) !important; }

/* ── Login page (simple centered, fallback) ──────────────────── */
.login-page {
  min-height: 100vh; display: flex;
  align-items: center; justify-content: center;
  background: var(--n-50);
}

/* ── Login split-screen layout ───────────────────────────────── */
.login-split-page { min-height: 100vh; display: flex; background: #fff; }

.login-panel-left {
  flex: 0 0 55%;
  background: linear-gradient(160deg, var(--b-950) 0%, var(--b-900) 60%, var(--b-800) 100%);
  display: flex; align-items: center; justify-content: center;
  padding: 48px 56px; position: relative; overflow: hidden;
}
.login-panel-inner { position: relative; z-index: 1; max-width: 420px; width: 100%; }
.login-brand { display: flex; align-items: center; gap: 14px; margin-bottom: 56px; }
.login-brand-icon {
  width: 48px; height: 48px; background: var(--o-500);
  border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.login-brand-icon svg { color: #fff; }
.login-brand-name { font-size: 22px; font-weight: 800; color: #fff; letter-spacing: -.4px; }
.login-brand-name span { color: var(--o-400); }
.login-brand-sub { font-size: 11px; color: rgba(255,255,255,.45); margin-top: 2px; }
.login-tagline { margin-bottom: 40px; }
.login-tagline h2 { font-size: 28px; font-weight: 700; color: #fff; line-height: 1.3; margin-bottom: 16px; letter-spacing: -.3px; }
.login-tagline p { font-size: 14px; color: rgba(255,255,255,.6); line-height: 1.6; }
.login-features { list-style: none; display: flex; flex-direction: column; gap: 14px; margin: 0; padding: 0; }
.login-features li { display: flex; align-items: center; gap: 12px; font-size: 13px; color: rgba(255,255,255,.75); }
.login-feature-icon {
  width: 28px; height: 28px; background: rgba(255,255,255,.1); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--o-300);
}
.login-dots {
  position: absolute; bottom: -40px; right: -40px; width: 240px; height: 240px;
  background-image: radial-gradient(circle, rgba(255,255,255,.12) 1.5px, transparent 1.5px);
  background-size: 18px 18px; border-radius: 50%; z-index: 0;
}
.login-panel-right {
  flex: 0 0 45%; display: flex; align-items: center;
  justify-content: center; padding: 48px 40px; background: #fff;
}
.login-form-wrap { width: 100%; max-width: 360px; }
.login-mobile-logo { display: none; align-items: center; gap: 12px; margin-bottom: 32px; }
.login-form-title { font-size: 24px; font-weight: 700; color: var(--n-900); margin-bottom: 6px; letter-spacing: -.3px; }
.login-form-sub { font-size: 13px; color: var(--n-500); margin-bottom: 28px; }
.login-label { font-size: 13px; font-weight: 500; color: var(--n-700); }
.login-footer-note { margin-top: 24px; text-align: center; font-size: 12px; color: var(--n-400); }
.login-footer-note a { color: var(--n-400); }
.login-footer-note a:hover { color: var(--b-600); }
.login-panel-right .btn-primary { font-size: 14px; font-weight: 600; padding: 12px 20px; }
.w-full { width: 100% !important; }
.btn-lg { padding: 11px 22px !important; font-size: 14px !important; }

@media (max-width: 768px) {
  .login-split-page { flex-direction: column; }
  .login-panel-left { display: none; }
  .login-panel-right { flex: 1; padding: 40px 24px; justify-content: flex-start; }
  .login-form-wrap { max-width: 100%; }
  .login-mobile-logo { display: flex; }
}

/* ── KPI cards ────────────────────────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}
.kpi-card {
  background: #fff;
  border: 1px solid var(--n-200);
  border-radius: 10px;
  padding: 20px;
  display: flex; flex-direction: column; gap: 8px;
  box-shadow: var(--shadow-sm);
  position: relative; overflow: hidden;
}
.kpi-label {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .6px; color: var(--n-500);
}
.kpi-value {
  font-size: 28px; font-weight: 700; color: var(--n-800); line-height: 1;
}
.kpi-sub { font-size: 13px; color: var(--n-500); }
.kpi-icon {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--kpi-bg, var(--b-50));
  display: flex; align-items: center; justify-content: center;
  color: var(--kpi-color, var(--b-500));
}

/* ── Infrastructure pages ───────────────────────────────────── */
.infra-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.infra-kpis .kpi-card {
  min-height: 76px;
  padding: 10px 14px 9px;
  gap: 2px;
  box-shadow: none;
  transition: box-shadow .15s;
}
.infra-kpis .kpi-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.07); }
.infra-kpis .kpi-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.infra-kpis .kpi-label {
  font-size: .68rem;
  letter-spacing: .04em;
}
.infra-kpis .kpi-value {
  font-size: 1.5rem;
  line-height: 1.1;
}
.infra-kpis .kpi-sub {
  font-size: .68rem;
  margin-top: 2px;
}
.infra-kpis .kpi-icon {
  position: static;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  font-size: 16px;
  flex-shrink: 0;
}
.infra-tools {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  width: 100%;
}
.infra-tools-left,
.infra-tools-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.infra-tools .app-search { min-width: 260px; }
.infra-tools .form-control,
.infra-tools .form-select {
  height: 36px;
  border-radius: 6px;
  font-size: 13px;
}
.infra-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}
.infra-rel {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
}
.infra-rel .form-group { margin-bottom: 0; }
@media (max-width: 760px) {
  .infra-tools .app-search,
  .infra-tools .form-control,
  .infra-tools .form-select {
    width: 100% !important;
    min-width: 100%;
  }
  .infra-tools-left,
  .infra-tools-right { width: 100%; }
}

/* ── Skeleton loading ─────────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, var(--n-100) 25%, var(--n-200) 50%, var(--n-100) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 6px;
  color: transparent !important;
}
.skeleton * { visibility: hidden; }
@keyframes shimmer {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}

/* ── Button variants (extended) ───────────────────────────────── */
.btn-success { background: var(--clr-success); color: #fff; border-color: var(--clr-success); }
.btn-success:hover { background: #16a34a; border-color: #16a34a; color: #fff; }
.btn-warning { background: var(--clr-warning); color: #fff; border-color: var(--clr-warning); }
.btn-warning:hover { background: #d97706; border-color: #d97706; color: #fff; }

/* ── Modal size variants ──────────────────────────────────────── */
.modal-overlay .modal.modal-lg  { max-width: 760px; }
.modal-overlay .modal.modal-xl  { max-width: 960px; }

/* ── Badge extras ─────────────────────────────────────────────── */
.status-syncing { background: var(--clr-info-bg); color: var(--b-700); border: 1px solid var(--clr-info-border); }
.badge-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; display: inline-block; }

/* ── Form helpers ─────────────────────────────────────────────── */
.form-hint  { font-size: 12px; color: var(--n-400); margin-top: 2px; }
.form-error { font-size: 12px; color: var(--clr-danger); margin-top: 2px; }

/* ── Utility classes ──────────────────────────────────────────── */
.text-right   { text-align: right; }
.text-center  { text-align: center; }
.text-success { color: var(--clr-success) !important; }
.text-warning { color: var(--clr-warning) !important; }
.text-sm      { font-size: 13px !important; }
.text-xs      { font-size: 11px !important; }
.font-medium  { font-weight: 500 !important; }
.font-bold    { font-weight: 700 !important; }
.truncate     { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hidden       { display: none !important; }
.sr-only      { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

/* ── Misc ─────────────────────────────────────────────────────── */
a { color: var(--b-600); }
code { font-family: var(--font-mono); }

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 991px) {
  .sidenav-menu {
    transform: translateX(-100%);
    width: var(--sidenav-width) !important;
  }
  .sidenav-menu.mobile-open { transform: translateX(0); }
  .app-topbar { left: 0 !important; }
  .content-page { margin-left: 0 !important; }
  [data-sidenav-size="condensed"] .logo-text-block,
  [data-sidenav-size="condensed"] .side-nav-title,
  [data-sidenav-size="condensed"] .menu-arrow { display: flex; }
  [data-sidenav-size="condensed"] .logo-text-block { display: flex; }
  [data-sidenav-size="condensed"] .side-nav-item > .side-nav-link { justify-content: flex-start; padding: 9px 12px; overflow: visible; }
  [data-sidenav-size="condensed"] .menu-icon { font-size: 17px; width: 20px; }
  [data-sidenav-size="condensed"] .nav-label { display: inline !important; }
  [data-sidenav-size="condensed"] .sidenav-badge { display: inline !important; }
  [data-sidenav-size="condensed"] .sub-nav { display: block; }
  [data-sidenav-size="condensed"] .logo { justify-content: flex-start; padding: 0 20px; }
  [data-sidenav-size="condensed"] .sidenav-user-name,
  [data-sidenav-size="condensed"] .sidenav-user-role { display: block !important; }
}

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

@media (max-width: 640px) {
  .form-row { flex-direction: column; gap: 0; }
  .toolbar { flex-wrap: wrap; }
  .page-header { flex-direction: column; align-items: flex-start; }
  .kpi-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
}

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

/* ── Fire-alarm topbar ─────────────────────────── */
.app-topbar.topbar-fire-alarm {
  background: #dc2626 !important;
  animation: topbar-fire 1.4s ease-in-out infinite alternate;
}
@keyframes topbar-fire {
  from { background: #dc2626 !important; }
  to   { background: #b91c1c !important; }
}
.app-topbar.topbar-fire-alarm .topbar-icon-btn,
.app-topbar.topbar-fire-alarm .topbar-link { color: rgba(255,255,255,.85) !important; }
.app-topbar.topbar-fire-alarm .topbar-icon-btn:hover { background: rgba(255,255,255,.15) !important; }
.app-topbar.topbar-fire-alarm .topbar-user-label,
.app-topbar.topbar-fire-alarm .topbar-avatar { color: #fff !important; }
.side-nav-item > .side-nav-link.emergency-nav-alert,
[data-menu-color="gradient"] .side-nav-item > .side-nav-link.emergency-nav-alert {
  background: linear-gradient(135deg, #dc2626, #b91c1c) !important;
  color: #fff !important;
  box-shadow: 0 6px 18px rgba(220,38,38,.34);
}
.side-nav-item > .side-nav-link.emergency-nav-alert:hover,
[data-menu-color="gradient"] .side-nav-item > .side-nav-link.emergency-nav-alert:hover {
  background: linear-gradient(135deg, #ef4444, #dc2626) !important;
  color: #fff !important;
}
.side-nav-item > .side-nav-link.emergency-nav-alert .menu-icon,
.side-nav-item > .side-nav-link.emergency-nav-alert .nav-label {
  color: #fff !important;
}

/* ── Global search ─────────────────────────────── */
.topbar-search-wrap {
  flex: 1; max-width: 380px; min-width: 160px;
  position: relative; display: flex; align-items: center;
}
.topbar-search-icon {
  position: absolute; left: 10px; top: 50%;
  transform: translateY(-50%);
  color: var(--n-400); pointer-events: none; flex-shrink: 0;
}
.topbar-search-input {
  width: 100%; height: 34px;
  padding: 0 12px 0 32px;
  border: 1px solid var(--n-200); border-radius: 8px;
  font-size: .84rem; background: var(--n-50); color: var(--n-800);
  outline: none; transition: border-color .15s, background .15s;
}
.topbar-search-input:focus { border-color: var(--b-400); background: var(--n-0); }
.topbar-search-dd {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  background: var(--n-0); border: 1px solid var(--n-200);
  border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,.12);
  z-index: 999; max-height: 400px; overflow-y: auto; display: none;
}
.topbar-search-dd.gs-open { display: block; }
.gs-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; cursor: pointer;
  border-bottom: 1px solid var(--n-50); transition: background .1s;
}
.gs-item:last-child { border-bottom: none; }
.gs-item:hover { background: var(--b-50); }
.gs-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--b-100); color: var(--b-700);
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; font-weight: 700; flex-shrink: 0;
}
.gs-info { flex: 1; min-width: 0; }
.gs-name { font-size: .85rem; font-weight: 600; color: var(--n-900); }
.gs-meta { font-size: .73rem; color: var(--n-400); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; }
.gs-badge { font-size: .68rem; font-weight: 700; padding: 2px 7px; border-radius: 4px; white-space: nowrap; }
.gs-badge-ok      { background: #dcfce7; color: #15803d; }
.gs-badge-danger  { background: #fee2e2; color: #dc2626; }
.gs-badge-neutral { background: var(--n-100); color: var(--n-600); }
.gs-empty, .gs-loading { padding: 16px; text-align: center; font-size: .82rem; color: var(--n-400); }

@media (max-width: 767.98px) {
  .app-topbar { padding: 0 12px; }
  .topbar-menu { gap: 8px; }
  .topbar-search-wrap { display: none; }
  .topbar-mobile-brand { display: flex; }
  .topbar-mobile-title { display: none; }
  .topbar-user-label,
  .topbar-chevron { display: none; }
  .topbar-avatar-btn { padding: 4px; }
}

/* ── Global search user modal ──────────────────── */
.gs-user-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.45);
  z-index: 1050; display: flex; align-items: flex-start; justify-content: flex-end;
  padding: 64px 16px 16px;
}
.gs-user-modal {
  background: var(--n-0); border-radius: 12px;
  box-shadow: 0 16px 48px rgba(0,0,0,.2);
  width: 480px; max-width: 100%; max-height: calc(100vh - 80px);
  overflow-y: auto; display: flex; flex-direction: column;
}
.gs-user-modal-header {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px 14px; border-bottom: 1px solid var(--n-100);
}
.gs-user-modal-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--b-100); color: var(--b-700);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 700; flex-shrink: 0;
}
.gs-user-modal-info { flex: 1; min-width: 0; }
.gs-user-modal-name { font-size: 1rem; font-weight: 700; color: var(--n-900); }
.gs-user-modal-sub  { font-size: .8rem; color: var(--n-500); margin-top: 2px; }
.gs-user-modal-close {
  background: none; border: none; cursor: pointer;
  color: var(--n-400); font-size: 1.3rem; padding: 4px; line-height: 1;
}
.gs-user-modal-close:hover { color: var(--n-700); }
.gs-user-modal-body { padding: 16px 20px 20px; }
.gs-history-table { width: 100%; border-collapse: collapse; font-size: .8rem; }
.gs-history-table th { color: var(--n-500); font-weight: 600; padding: 6px 8px; text-align: left; border-bottom: 1px solid var(--n-100); }
.gs-history-table td { padding: 7px 8px; border-bottom: 1px solid var(--n-50); color: var(--n-700); }
.gs-history-table tr:last-child td { border-bottom: none; }

/* ═══════════════════════════════════════════════════════════════
   Complete Custom Table — classes compatíveis com custom-table.js
   ═══════════════════════════════════════════════════════════════ */

/* ── Utilitários de tamanho de texto ────────────────────────── */
.fs-xxs  { font-size: 10px !important; }
.fs-xs   { font-size: 11px !important; }
.fs-base { font-size: var(--text-base) !important; }
.fs-lg   { font-size: 16px !important; }

/* ── badge-soft-* — variantes suaves de badge ───────────────── */
.badge-soft-success  { background: rgba(34,197,94,.12);  color: #15803d; border-radius: 4px; padding: 2px 8px; font-weight: 600; }
.badge-soft-warning  { background: rgba(245,158,11,.12); color: #b45309; border-radius: 4px; padding: 2px 8px; font-weight: 600; }
.badge-soft-danger   { background: rgba(239,68,68,.12);  color: #b91c1c; border-radius: 4px; padding: 2px 8px; font-weight: 600; }
.badge-soft-info     { background: rgba(59,130,246,.12); color: #1d4ed8; border-radius: 4px; padding: 2px 8px; font-weight: 600; }
.badge-soft-primary  { background: rgba(33,83,161,.12);  color: #1d4ed8; border-radius: 4px; padding: 2px 8px; font-weight: 600; }
.badge-soft-secondary{ background: rgba(107,114,128,.12);color: #374151; border-radius: 4px; padding: 2px 8px; font-weight: 600; }
.badge-soft-dark     { background: rgba(17,24,39,.12);   color: #111827; border-radius: 4px; padding: 2px 8px; font-weight: 600; }

/* ── app-search — wrapper com ícone embutido ────────────────── */
.app-search {
  position: relative;
  display: flex;
  align-items: center;
}
.app-search .form-control {
  padding-left: 36px;
  height: var(--input-h);
  border-radius: var(--input-radius);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  font-size: var(--text-sm);
}
.app-search .app-search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--n-400);
  pointer-events: none;
  font-size: 15px;
  display: flex;
  align-items: center;
}

/* ── link-reset — herda cor, hover azul ────────────────────── */
.link-reset { color: inherit; text-decoration: none; transition: color .15s; }
.link-reset:hover { color: var(--b-600); }

/* ── avatar sizes ───────────────────────────────────────────── */
.avatar-xs { width: 24px;  height: 24px;  border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.avatar-sm { width: 32px;  height: 32px;  border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.avatar-md { width: 40px;  height: 40px;  border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.avatar-lg { width: 56px;  height: 56px;  border-radius: 50%; object-fit: cover; flex-shrink: 0; }

/* Avatar como iniciais */
.avatar-initials {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; font-weight: 700; color: #fff; flex-shrink: 0;
  background: var(--b-600);
}
.avatar-initials.avatar-sm  { width: 32px;  height: 32px;  font-size: 12px; }
.avatar-initials.avatar-md  { width: 40px;  height: 40px;  font-size: 14px; }
.avatar-initials.avatar-lg  { width: 56px;  height: 56px;  font-size: 20px; }

/* ── form-check-input-light ─────────────────────────────────── */
.form-check-input-light {
  background-color: #fff;
  border-color: var(--n-300);
  cursor: pointer;
}
.form-check-input-light:checked {
  background-color: var(--b-600);
  border-color: var(--b-600);
}

/* ── btn-icon — botão quadrado centrado (Bootstrap-compatible) ─ */
.btn.btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-shrink: 0;
}
.btn.btn-icon.btn-sm  { width: 28px; height: 28px; }
.btn.btn-icon.btn-md  { width: 34px; height: 34px; }
.btn.btn-icon:not(.btn-sm):not(.btn-md) { width: 36px; height: 36px; }

.td-actions,
.table-actions,
.row-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: nowrap;
}
.td-actions .btn.btn-icon,
.table-actions .btn.btn-icon,
.row-actions .btn.btn-icon {
  font-size: 14px;
}

/* ── table-custom — padding e layout da tabela ──────────────── */
.table-custom { border-collapse: separate; border-spacing: 0; }
.table-custom th { white-space: nowrap; }
.table-custom thead > tr > th:first-child,
.table-custom tbody > tr > td:first-child { padding-inline-start: 1rem !important; }
.table-custom thead > tr > th:last-child,
.table-custom tbody > tr > td:last-child  { padding-inline-end: 1rem !important; }

/* ── table-centered — alinha verticalmente ─────────────────── */
.table-centered td,
.table-centered th { vertical-align: middle; }

/* ── table-select — highlight de linhas seleccionadas ──────── */
.table-select tbody tr:has(input[type="checkbox"]:checked) {
  background-color: rgba(33,83,161,.05);
}

/* ── thead-sm — cabeçalho compacto ──────────────────────────── */
.thead-sm > * > * { padding: 0.4rem 0.55rem !important; }

/* ── pagination-boxed ────────────────────────────────────────── */
.pagination-boxed .page-item + .page-item { margin-left: 3px; }
.pagination-boxed .page-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px !important;
  min-width: 30px;
  height: 30px;
  padding: 0 6px;
  font-size: 13px;
}
.pagination-boxed.pagination-sm .page-link {
  min-width: 26px;
  height: 26px;
  font-size: 12px;
}

/* ── Toolbar do card (card-header com search + filtros) ─────── */
.card-header.justify-content-between {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 10px 16px;
}
.card-header .d-flex.gap-2 { gap: 8px !important; }

/* ── Dark mode overrides para as novas classes ──────────────── */
[data-theme="dark"] .badge-soft-success   { background: rgba(34,197,94,.18);  color: #4ade80; }
[data-theme="dark"] .badge-soft-warning   { background: rgba(245,158,11,.18); color: #fbbf24; }
[data-theme="dark"] .badge-soft-danger    { background: rgba(239,68,68,.18);  color: #f87171; }
[data-theme="dark"] .badge-soft-info      { background: rgba(59,130,246,.18); color: #93c5fd; }
[data-theme="dark"] .badge-soft-primary   { background: rgba(33,83,161,.18);  color: #93c5fd; }
[data-theme="dark"] .badge-soft-secondary { background: rgba(107,114,128,.18);color: #d1d5db; }
[data-theme="dark"] .badge-soft-dark      { background: rgba(255,255,255,.08);color: #e5e7eb; }
[data-theme="dark"] .form-check-input-light { background-color: var(--n-700); border-color: var(--n-600); }
[data-theme="dark"] .table-select tbody tr:has(input[type="checkbox"]:checked) { background-color: rgba(59,130,246,.1); }

/* ── Theme toggle icons ─────────────────────────────────────── */
/* Light mode → mostra lua (click para ir a dark) */
.mode-light-moon { display: inline-block; }
.mode-light-sun  { display: none; }
/* Dark mode → mostra sol (click para ir a light) */
[data-theme="dark"] .mode-light-moon { display: none; }
[data-theme="dark"] .mode-light-sun  { display: inline-block; }

/* ── Dark mode ──────────────────────────────────────────────── */
[data-theme="dark"] {
  /* Neutral scale invertida — os tokens de texto ficam claros,
     os tokens de fundo ficam escuros */
  --n-50:  #111827;
  --n-100: #1f2937;
  --n-200: #374151;
  --n-300: #4b5563;
  --n-400: #6b7280;
  --n-500: #9ca3af;
  --n-600: #d1d5db;
  --n-700: #e5e7eb;
  --n-800: #f3f4f6;
  --n-900: #f9fafb;
  --n-0:   #0f172a;
  /* Input */
  --input-bg:     #1f2937;
  --input-border: #374151;
  /* Bootstrap overrides */
  --bs-body-bg:    #111827;
  --bs-body-color: #f3f4f6;
  --bs-border-color: #374151;
  color-scheme: dark;
}

/* Body */
[data-theme="dark"] body { background: #111827; color: var(--n-800); }

/* ── Topbar ── */
[data-theme="dark"] .app-topbar {
  background: #1f2937 !important;
  border-color: #374151;
  box-shadow: 0 1px 4px rgba(0,0,0,.25);
}
[data-theme="dark"] .app-topbar.topbar-fire-alarm { background: #dc2626 !important; }
[data-theme="dark"] .topbar-sep { background: #374151; }
[data-theme="dark"] .sidenav-toggle-button { color: var(--n-500); }
[data-theme="dark"] .sidenav-toggle-button:hover { background: #374151; color: var(--n-800); }
[data-theme="dark"] .topbar-user-label { color: var(--n-700); }
[data-theme="dark"] .topbar-chevron { color: var(--n-400); }
[data-theme="dark"] .topbar-avatar-btn:hover { background: #374151; }

/* ── Topbar search ── */
[data-theme="dark"] .topbar-search-input {
  background: #111827; border-color: #374151; color: var(--n-800);
}
[data-theme="dark"] .topbar-search-input:focus { background: #1f2937; border-color: var(--b-400); }
[data-theme="dark"] .topbar-search-dd {
  background: #1f2937; border-color: #374151;
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
}
[data-theme="dark"] .gs-item { border-color: #111827; }
[data-theme="dark"] .gs-item:hover { background: #374151; }
[data-theme="dark"] .gs-name { color: var(--n-900); }

/* ── User dropdown ── */
[data-theme="dark"] .topbar-dropdown {
  background: #1f2937; border-color: #374151;
  box-shadow: 0 8px 30px rgba(0,0,0,.4);
}
[data-theme="dark"] .topbar-dropdown-header { border-color: #374151; }
[data-theme="dark"] .topbar-dropdown-name { color: var(--n-800); }
[data-theme="dark"] .topbar-dropdown-role { color: var(--n-500); }
[data-theme="dark"] .topbar-dropdown-divider { background: #374151; }
[data-theme="dark"] .topbar-dropdown-item { color: var(--n-700); }
[data-theme="dark"] .topbar-dropdown-item:hover { background: #374151; color: var(--n-800); }
[data-theme="dark"] .topbar-dropdown-danger { color: #f87171; }
[data-theme="dark"] .topbar-dropdown-danger:hover { background: rgba(239,68,68,.12); color: #f87171; }

/* ── Cards ── */
[data-theme="dark"] .card { background: #1f2937; border-color: #374151; }
[data-theme="dark"] .card-header { border-color: #374151; }
[data-theme="dark"] .card-footer { background: #111827; border-color: #374151; }
[data-theme="dark"] .card-title { color: var(--n-800); }

/* ── Tables ── */
[data-theme="dark"] th { background: #111827; border-color: #374151; color: var(--n-500); }
[data-theme="dark"] td { border-color: #374151; color: var(--n-700); }
[data-theme="dark"] tr:hover td { background: #374151; }

/* ── Forms ── */
[data-theme="dark"] .form-control { color: var(--n-800); }
[data-theme="dark"] .form-control:focus { box-shadow: 0 0 0 3px rgba(59,130,246,.2); }
[data-theme="dark"] .form-control::placeholder { color: var(--n-400); }
[data-theme="dark"] select.form-control option { background: #1f2937; color: var(--n-800); }

/* ── Buttons ── */
[data-theme="dark"] .btn-secondary {
  background: #1f2937; color: var(--n-700); border-color: #374151;
}
[data-theme="dark"] .btn-secondary:hover { background: #374151; color: var(--n-800); }
[data-theme="dark"] .btn-icon { color: var(--n-500); }
[data-theme="dark"] .btn-icon:hover { background: #374151; color: var(--n-700); }

/* ── Modals ── */
[data-theme="dark"] .modal-overlay { background: rgba(0,0,0,.6); }
[data-theme="dark"] .modal-overlay .modal { background: #1f2937; }
[data-theme="dark"] .modal-header { border-color: #374151; }
[data-theme="dark"] .modal-footer { border-color: #374151; }
[data-theme="dark"] .modal-title { color: var(--n-800); }
[data-theme="dark"] .modal-close { color: var(--n-500); }
[data-theme="dark"] .modal-close:hover { background: #374151; color: var(--n-700); }

/* ── Pagination ── */
[data-theme="dark"] .pagination-btn {
  background: #1f2937; border-color: #374151; color: var(--n-600);
}
[data-theme="dark"] .pagination-btn:hover:not(:disabled) { background: #374151; border-color: #4b5563; }
[data-theme="dark"] .pagination-btn.active { background: var(--b-600); color: #fff; border-color: var(--b-600); }

/* ── KPI cards ── */
[data-theme="dark"] .kpi-card { background: #1f2937; border-color: #374151; }
[data-theme="dark"] .kpi-label { color: var(--n-500); }
[data-theme="dark"] .kpi-value { color: var(--n-800); }

/* ── Alerts ── */
[data-theme="dark"] .alert-danger  { background: rgba(127,29,29,.35); border-color: #7f1d1d; color: #fca5a5; }
[data-theme="dark"] .alert-warning { background: rgba(120,53,15,.35);  border-color: #78350f; color: #fcd34d; }
[data-theme="dark"] .alert-info    { background: rgba(29,78,216,.15);  border-color: var(--b-800); color: var(--b-300); }
[data-theme="dark"] .alert-success { background: rgba(20,83,45,.35);   border-color: #14532d; color: #86efac; }

/* ── Badges (manter cores, só ajustar contraste no dark) ── */
[data-theme="dark"] .badge-neutral { background: #374151; color: var(--n-600); }

/* ── Misc ── */
[data-theme="dark"] .topbar-search-wrap .topbar-search-icon { color: var(--n-400); }
[data-theme="dark"] label { color: var(--n-700); }
[data-theme="dark"] .page-header-left h1 { color: var(--n-800); }
[data-theme="dark"] .page-header-left p  { color: var(--n-500); }
[data-theme="dark"] .empty-state p { color: var(--n-500); }
[data-theme="dark"] .grp-ms-wrap  { border-color: #374151; }
[data-theme="dark"] .grp-ms-pills { background: #1f2937; border-color: #374151; }
[data-theme="dark"] .grp-ms-item  { border-color: #374151; }
[data-theme="dark"] .grp-ms-item:hover { background: #374151; }
[data-theme="dark"] .grp-ms-item.selected { background: rgba(59,130,246,.12); }
[data-theme="dark"] .ip-entry { background: #111827; }
[data-theme="dark"] .umodal-photo { background: #111827; border-color: #374151; }
[data-theme="dark"] .umodal-tabs { border-color: #374151; }
[data-theme="dark"] .umodal-tab { color: var(--n-500); }
[data-theme="dark"] .umodal-tab:hover { color: var(--n-800); }
[data-theme="dark"] .umodal-tab.active { color: var(--b-400); border-bottom-color: var(--b-400); }
[data-theme="dark"] a { color: var(--b-400); }
