/* ==========================================================================
   Sistema de Cartera y Cobranzas — Teal Petrol Dark Financial UI
   Familia cromatica unica: teal/petrol desaturado.
   Contraste por luminosidad, no por blanco dominante.
   ========================================================================== */

/* ===================== TOKENS ===================== */

:root {
  /* ========== Base palette — Pizarra (default) ========== */
  --app-bg: #1a2327;
  --panel-bg: #263439;
  --panel-secondary: #33454b;
  --fill-primary: #8da7ae;
  --fill-secondary: #bacccf;
  --text-on-dark: #eef3f4;
  --text-on-light: #141c1f;
  --border-strong: #0f1619;

  /* Text hierarchy */
  --text-label: #cddbdd;
  --text-secondary: #9bb3b9;
  --text-muted: #6a848c;
  --hover-bg: #36494f;
  --navbar-bg: #151e22;
  --interactive-hover: #7a959c;
  --input-bg: #1b2629;
  --input-bg-focus: #212f33;

  /* Semantic */
  --success: #2e7d32;
  --warning: #b26a00;
  --error: #c62828;

  --radius-sm: 0.375rem;
  --radius: 0.5rem;
  --radius-lg: 0.75rem;
  --shadow: 0 2px 6px rgba(11, 27, 31, 0.3);

  --bs-primary: var(--fill-primary);
  --bs-primary-rgb: 141, 167, 174;
  --bs-success: var(--success);
  --bs-success-rgb: 46, 125, 50;
  --bs-warning: var(--warning);
  --bs-warning-rgb: 178, 106, 0;
  --bs-danger: var(--error);
  --bs-danger-rgb: 198, 40, 40;
  --bs-info: #7a9ea5;
  --bs-info-rgb: 122, 158, 165;
  --bs-body-bg: var(--app-bg);
  --bs-body-color: var(--text-on-dark);
  --bs-card-bg: var(--panel-bg);
  --bs-card-color: var(--text-on-dark);
  --bs-border-color: var(--border-strong);
  --bs-body-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
  --bs-body-font-size: 0.9rem;
}

/* ===================== THEME: Oscuro Profundo ===================== */
/* Fondo casi negro, paneles deep teal, acentos brillantes */

[data-theme="darker"] {
  --app-bg: #071417;
  --panel-bg: #0f2a30;
  --panel-secondary: #173b43;
  --fill-primary: #96d1db;
  --fill-secondary: #6fb2bf;
  --text-on-dark: #deeef0;
  --text-on-light: #0b1e22;
  --border-strong: #051b1f;
  --text-label: #aedbe3;
  --text-secondary: #7ebfcb;
  --text-muted: #4d95a3;
  --hover-bg: #1a3d46;
  --navbar-bg: #051518;
  --input-bg: #0a1e23;
  --input-bg-focus: #0c272e;
}

/* ===================== THEME: Amber ===================== */
/* Neutros oscuros, acentos cobrizos */

[data-theme="lighter"] {
  --app-bg: #1b1f21;
  --panel-bg: #262b2f;
  --panel-secondary: #30363b;
  --fill-primary: #c9975a;
  --fill-secondary: #d9b889;
  --text-on-dark: #eef0f0;
  --text-on-light: #111417;
  --border-strong: #121618;
  --text-label: #d4c0a8;
  --text-secondary: #a09888;
  --text-muted: #787068;
  --hover-bg: #30363b;
  --navbar-bg: #1b1f21;
  --bs-primary: #c9975a;
  --interactive-hover: #b8884a;
  --input-bg: #1e2326;
  --input-bg-focus: #23292d;
}

/* ===================== THEME: Claro (light mode from v1) ===================== */

[data-theme="claro"] {
  --app-bg: #f1f3f5;
  --panel-bg: #ffffff;
  --panel-secondary: #f8f9fa;
  --fill-primary: #376d78;
  --fill-secondary: #5b8a93;
  --text-on-dark: #ffffff;
  --text-on-light: #1a1d20;
  --border-strong: #d0e0e3;
  --text-label: #376d78;
  --text-secondary: #6b7280;
  --text-muted: #9ca3af;
  --hover-bg: #b8c9cb;
  --navbar-bg: #376d78;
  --bs-primary: #376d78;
  --interactive-hover: #2c5a63;
  --input-bg: #ffffff;
  --input-bg-focus: #ffffff;
  --bs-primary-rgb: 55, 109, 120;
  --bs-success: #198754;
  --bs-success-rgb: 25, 135, 84;
  --bs-warning: #d97706;
  --bs-body-bg: var(--app-bg);
  --bs-body-color: var(--text-on-light);
  --bs-card-bg: var(--panel-bg);
  --bs-card-color: var(--text-on-light);
  --bs-border-color: var(--border-strong);
}

/* ===================== THEME: Petroleo ===================== */

[data-theme="petroleo"] {
  --app-bg: #072a33;
  --panel-bg: #124e5c;
  --panel-secondary: #1d6572;
  --fill-primary: #6fa5ae;
  --fill-secondary: #8fbbc2;
  --text-on-dark: #eef6f7;
  --text-on-light: #0b2830;
  --border-strong: #031f26;
  --text-label: #bfd4d8;
  --text-secondary: #8fbbc2;
  --text-muted: #5b8a93;
  --hover-bg: #1d6b79;
  --navbar-bg: #052027;
  --input-bg: #0c3842;
  --input-bg-focus: #104652;
}

/* ===================== THEME: Grafito ===================== */
/* Gris frio industrial, acentos plateados */

[data-theme="bosque"] {
  --app-bg: #1e2226;
  --panel-bg: #2c3136;
  --panel-secondary: #373d42;
  --fill-primary: #9aafb5;
  --fill-secondary: #bcc9cd;
  --text-on-dark: #eef0f1;
  --text-on-light: #131719;
  --border-strong: #161b1e;
  --text-label: #c4d1d4;
  --text-secondary: #8d9ea3;
  --text-muted: #65787d;
  --hover-bg: #343a3e;
  --navbar-bg: #1e2226;
  --bs-primary: #9aafb5;
  --interactive-hover: #8a9fa5;
  --input-bg: #252a2e;
  --input-bg-focus: #2b3135;
}

/* ===================== THEME: Alto Contraste ===================== */

[data-theme="alto-contraste"] {
  --app-bg: #000000;
  --panel-bg: #161a1c;
  --panel-secondary: #262b2e;
  --fill-primary: #a0c4c8;
  --fill-secondary: #c8dadd;
  --text-on-dark: #ffffff;
  --text-on-light: #0a0d0f;
  --border-strong: #2a2f32;
  --text-label: #d6e3e6;
  --text-secondary: #a0c4c8;
  --text-muted: #607c82;
  --hover-bg: #282f32;
  --navbar-bg: #000000;
  --interactive-hover: #7fa7ae;
  --input-bg: #141b1d;
  --input-bg-focus: #1a2325;
}

/* ===================== THEME: Ceniza ===================== */
/* Tono claro calido, beige suave */

[data-theme="ceniza"] {
  --app-bg: #e8e6e2;
  --panel-bg: #f7f5f1;
  --panel-secondary: #ece9e4;
  --fill-primary: #7a6b5c;
  --fill-secondary: #9a8e82;
  --text-on-dark: #ffffff;
  --text-on-light: #1f1c18;
  --border-strong: #d6d2cc;
  --text-label: #7a6b5c;
  --text-secondary: #7a726a;
  --text-muted: #a69e96;
  --hover-bg: #efede8;
  --navbar-bg: #7a6b5c;
  --bs-primary: #7a6b5c;
  --interactive-hover: #65594c;
  --input-bg: #f2efe9;
  --input-bg-focus: #f2efe9;
  --bs-primary-rgb: 122, 107, 92;
  --bs-body-bg: var(--app-bg);
  --bs-body-color: var(--text-on-light);
  --bs-card-bg: var(--panel-bg);
  --bs-card-color: var(--text-on-light);
  --bs-border-color: var(--border-strong);
}

/* ===================== GLOBAL ===================== */

body {
  background: var(--app-bg);
  color: var(--bs-body-color);
  font-size: 0.9rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ===================== NAVIGATION ===================== */

.navbar {
  padding: 0.45rem 0;
  background: var(--navbar-bg) !important;
  box-shadow: 0 1px 0 var(--border-strong);
}

.navbar-brand {
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-on-dark);
}

.navbar .nav-link {
  font-size: 0.85rem;
  padding: 0.35rem 0.65rem;
  border-radius: var(--radius-sm);
  color: rgba(255, 255, 255, 0.78);
  transition: background 0.15s ease;
}

.navbar .nav-link:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
}

.navbar .nav-link.active {
  color: #fff;
  background: rgba(255, 255, 255, 0.2);
  font-weight: 600;
}

.navbar .dropdown-menu {
  background: var(--panel-bg);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  margin-top: 0.25rem;
}

[data-theme="claro"] .navbar .dropdown-menu {
  border: 1px solid var(--border-strong);
}

.navbar .dropdown-item {
  color: var(--bs-body-color);
  font-size: 0.85rem;
}

.navbar .dropdown-item:hover {
  background: var(--hover-bg);
  color: var(--bs-body-color);
}

/* ===================== PAGE HEADER ===================== */

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  padding-top: 0.75rem;
}

.page-header h4 {
  margin: 0;
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--bs-body-color);
}

.page-header h4 i {
  color: var(--fill-primary);
  margin-right: 0.35rem;
}

/* ===================== BUTTONS ===================== */

.btn {
  font-weight: 500;
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  transition: all 0.15s ease;
}

.btn-primary {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
  color: #fff;
}

.btn-primary:hover {
  background-color: var(--interactive-hover);
  border-color: var(--interactive-hover);
  color: #fff;
}

.btn-primary:focus {
  box-shadow: 0 0 0 0.2rem rgba(55, 109, 120, 0.25);
}

.btn-outline-primary {
  color: var(--fill-primary);
  border-color: var(--fill-primary);
}

.btn-outline-primary:hover {
  background-color: var(--fill-primary);
  color: var(--text-on-light);
}

.btn-outline-secondary {
  color: var(--text-secondary);
  border-color: var(--border-strong);
}

.btn-outline-secondary:hover {
  background: var(--hover-bg);
  border-color: var(--fill-primary);
  color: var(--bs-body-color);
}

.btn-success {
  background-color: var(--success);
  border-color: var(--success);
  color: #fff;
}

.btn-success:hover {
  background-color: #256f29;
  border-color: #256f29;
}

.btn-outline-success {
  color: #66bb6a;
  border-color: #66bb6a;
}

.btn-outline-success:hover {
  background-color: var(--success);
  color: #fff;
  border-color: var(--success);
}

.btn-outline-warning {
  color: #fbbf24;
  border-color: #fbbf24;
}

.btn-outline-warning:hover {
  background-color: var(--warning);
  color: #fff;
  border-color: var(--warning);
}

.btn-sm {
  padding: 0.25rem 0.6rem;
  font-size: 0.78rem;
}

/* ===================== CARDS / PANELS ===================== */

.card {
  background: var(--panel-bg);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  margin-bottom: 1rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 24px rgba(55, 109, 120, 0.2);
  border-color: var(--fill-primary);
  z-index: 10;
  position: relative;
}

.card:active {
  transform: translateY(-1px);
  transition: transform 0.08s ease;
}

/* Dashboard cards — filas de 3 con altura consistente */
#kpi-cards .card {
  min-height: 140px;
}

#panel-cards .card {
  min-height: 300px;
}

#panel-cards .card-body {
  overflow-y: auto;
}

/* Vencidas card — subtle red top border */
#panel-cards .col-md-4:first-child .card {
  border-top: 2px solid rgba(198, 40, 40, 0.25);
}

/* Alquileres card — teal top border */
#panel-cards .col-md-4:last-child .card {
  border-top: 2px solid rgba(55, 109, 120, 0.2);
}

.card-header {
  background: var(--panel-secondary);
  border-bottom: 1px solid var(--border-strong);
  font-weight: 600;
  font-size: 0.73rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--text-label);
  padding: 0.65rem 1rem;
  border-radius: var(--radius) var(--radius) 0 0 !important;
}

.card-header .badge {
  text-transform: none;
  letter-spacing: 0;
}

.card-body {
  padding: 1rem;
}

.card-footer {
  background: rgba(11, 27, 31, 0.2);
  border-top: 1px solid var(--border-strong);
  border-radius: 0 0 var(--radius) var(--radius) !important;
}

/* ===================== KPI / METRIC CARDS ===================== */

.card-kpi {
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  border-left: 3px solid var(--fill-primary);
  background: var(--panel-bg);
  box-shadow: var(--shadow);
}

.card-kpi:hover {
  border-left-width: 5px;
  border-left-color: var(--fill-secondary);
}

/* KPI label — reusable, works inside card-kpi and regular cards */
.kpi-label {
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  color: var(--text-label);
}

.card-kpi .kpi-label {
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  color: var(--text-label);
  margin-bottom: 0.15rem;
}

.kpi-value {
  font-weight: 700;
  color: var(--bs-card-color);
}

.card-kpi .kpi-value {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--bs-card-color);
}

.card-kpi .kpi-sub {
  font-size: 0.76rem;
  color: var(--text-secondary);
}

/* ===================== TABLES ===================== */

.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--bs-card-color);
  margin-bottom: 0;
  border-collapse: separate;
  border-spacing: 0;
}

.table > thead > tr > th {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-label);
  font-weight: 700;
  padding: 0.55rem 0.7rem;
  border-bottom: 2px solid var(--border-strong);
  white-space: nowrap;
  background: transparent;
}

.table > tbody > tr > td {
  vertical-align: middle;
  padding: 0.45rem 0.7rem;
  font-size: 0.85rem;
  border-bottom: 1px solid var(--border-strong);
  transition: background 0.15s ease, color 0.15s ease, border-radius 0.15s ease;
}

.table > tbody > tr:last-child > td {
  border-bottom: none;
}

.table > tbody > tr:hover {
  background: var(--hover-bg);
  box-shadow: inset 2px 0 0 var(--fill-primary);
  border-radius: 6px;
}

.table > tbody > tr:hover td:first-child {
  border-radius: 6px 0 0 6px;
  color: var(--fill-primary);
  font-weight: 600;
}

.table > tbody > tr:hover td:last-child {
  border-radius: 0 6px 6px 0;
}

/* Alternating rows using fill tones */
.table-striped > tbody > tr:nth-of-type(odd) {
  background: rgba(143, 177, 184, 0.06);
}

.table-sm th,
.table-sm td {
  padding: 0.42rem 0.6rem;
}

.table-danger {
  --bs-table-bg: rgba(198, 40, 40, 0.08);
}

.table-danger:hover {
  --bs-table-bg: rgba(198, 40, 40, 0.16) !important;
}

.table-success {
  --bs-table-bg: rgba(46, 125, 50, 0.06);
}

.table-success:hover {
  --bs-table-bg: rgba(46, 125, 50, 0.14) !important;
}

/* ===================== BADGES ===================== */

.badge {
  font-weight: 500;
  padding: 0.25em 0.55em;
  border-radius: var(--radius-sm);
  font-size: 0.72rem;
}

.badge.bg-success {
  background-color: rgba(46, 125, 50, 0.15) !important;
  color: #2e7d32;
}

.badge.bg-danger {
  background-color: rgba(198, 40, 40, 0.15) !important;
  color: #c62828;
}

.badge.bg-warning {
  background-color: rgba(178, 106, 0, 0.15) !important;
  color: #b26a00;
}

.badge.bg-info {
  background-color: rgba(55, 109, 120, 0.12) !important;
  color: #376d78;
}

.badge.bg-primary {
  background-color: rgba(55, 109, 120, 0.12) !important;
  color: #376d78;
}

.badge.bg-secondary {
  background-color: rgba(95, 107, 112, 0.12) !important;
  color: #5f6b70;
}

/* Dark mode badges — lighter text for dark backgrounds */
[data-theme="dark"] .badge.bg-success { color: #66bb6a; }
[data-theme="dark"] .badge.bg-danger  { color: #ef9a9a; }
[data-theme="dark"] .badge.bg-warning { color: #fbbf24; }
[data-theme="dark"] .badge.bg-info    { color: #a2c4c9; }
[data-theme="dark"] .badge.bg-primary { color: var(--fill-primary); }

/* ===================== FORMS ===================== */

.form-control {
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  padding: 0.4rem 0.7rem;
  background: var(--input-bg);
  color: var(--text-on-dark);
  transition: border-color 0.15s ease, background 0.15s ease;
}

.form-control:focus {
  border-color: var(--text-label);
  background: var(--input-bg-focus, var(--input-bg));
  box-shadow: 0 0 0 0.2rem rgba(200, 218, 221, 0.12);
  color: var(--text-on-dark);
}

.form-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-label);
  margin-bottom: 0.3rem;
}

.form-control::placeholder {
  color: var(--text-muted);
  opacity: 0.8;
}

[data-theme="claro"] .form-control {
  background: #fff;
  color: #1a1d20;
  border-color: #d1d5db;
}

[data-theme="claro"] .form-control:focus {
  background: #fff;
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 0.2rem rgba(55, 109, 120, 0.12);
}

[data-theme="claro"] .form-control::placeholder {
  color: #9ca3af;
}

[data-theme="alto-contraste"] .form-control {
  background: #141b1d;
  border-color: #2a2f32;
  color: #eef3f4;
}

[data-theme="alto-contraste"] .form-control:focus {
  background: #1a2325;
  border-color: #96d1db;
  box-shadow: 0 0 0 0.2rem rgba(150, 209, 219, 0.15);
}

/* ===================== INPUT GROUP ===================== */

.input-group-text {
  background: rgba(15, 76, 90, 0.5);
  border-color: var(--border-strong);
  color: var(--fill-primary);
  font-size: 0.8rem;
}

/* ===================== MODALS ===================== */

.modal-header,
.modal-footer {
  border-color: var(--border-strong);
}

.modal-content {
  background: var(--panel-bg);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  color: var(--bs-card-color);
}

.modal-header .btn-close {
  filter: invert(0.9);
}

/* ===================== LIST GROUP ===================== */

.list-group-item {
  border: none;
  border-bottom: 1px solid var(--border-strong);
  background: transparent;
  color: var(--bs-card-color);
  font-size: 0.85rem;
  transition: background 0.12s ease;
}

.list-group-item:hover {
  background: var(--hover-bg);
}

.list-group-item:last-child {
  border-bottom: none;
}

/* ===================== PROGRESS ===================== */

.progress {
  background: rgba(11, 27, 31, 0.5);
  border-radius: 10px;
  height: 5px;
}

.progress-bar {
  border-radius: 10px;
  background-color: var(--fill-primary);
}

/* Progress inside KPI cards — monochromatic teal */
.card-kpi .progress-bar {
  background-color: var(--fill-primary) !important;
}

/* ===================== DASHBOARD BOTTOM PANELS ===================== */

/* ===================== DASHBOARD BALANCE ===================== */

.balance-list {
  display: table;
  width: 100%;
}

.balance-row {
  display: table-row;
}

.balance-row span,
.balance-row strong {
  display: table-cell;
  padding: 0.4rem 0.7rem;
  border-bottom: 1px solid var(--border-strong);
  vertical-align: middle;
  font-size: 0.83rem;
}

.balance-row span {
  color: var(--text-secondary);
}

.balance-row strong {
  text-align: right;
  white-space: nowrap;
  color: var(--bs-card-color);
}

.balance-row:last-child span,
.balance-row:last-child strong {
  border-bottom: none;
}

/* ===================== ALERTS ===================== */

.alert {
  border: none;
  border-radius: var(--radius);
  font-size: 0.85rem;
}

.alert-danger {
  background: rgba(198, 40, 40, 0.12);
  color: #c62828;
}

[data-theme="dark"] .alert-danger {
  color: #ef9a9a;
}

.alert-warning {
  background: rgba(178, 106, 0, 0.12);
  color: #b26a00;
}

[data-theme="dark"] .alert-warning {
  color: #fbbf24;
}

/* ===================== LOGIN ===================== */

.login-page {
  background: var(--app-bg);
  display: flex;
  align-items: center;
  min-height: 100vh;
}

.login-card {
  max-width: 400px;
  width: 100%;
}

.login-brand {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--fill-primary);
}

.login-card .card {
  border: 1px solid var(--border-strong);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  border-radius: var(--radius-lg);
}

.login-card .card-body {
  padding: 2rem;
}

.login-card .card-title {
  color: var(--bs-card-color);
  font-weight: 600;
}

/* ===================== TEXT & LINKS ===================== */

a {
  color: var(--fill-primary);
}

a:hover {
  color: var(--fill-secondary);
}

.text-decoration-none {
  color: inherit;
}

.text-decoration-none:hover {
  color: var(--text-label);
}

.text-primary { color: var(--fill-primary) !important; }
.text-success { color: #2e7d32 !important; }
.text-danger  { color: #c62828 !important; }
.text-warning { color: var(--warning) !important; }
.text-muted   { color: var(--text-muted) !important; }
.text-white   { color: var(--text-on-dark) !important; }

[data-theme="dark"] .text-success { color: #81c784 !important; }
[data-theme="dark"] .text-danger  { color: #ef9a9a !important; }
[data-theme="dark"] .text-warning { color: #fbbf24 !important; }

/* ===================== NAV TABS ===================== */

.nav-tabs {
  border-bottom: 1px solid var(--border-strong);
}

.nav-tabs .nav-link {
  color: var(--text-secondary);
  border: none;
  border-bottom: 2px solid transparent;
  font-weight: 500;
  font-size: 0.83rem;
  padding: 0.4rem 0.7rem;
  background: transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}

.nav-tabs .nav-link:hover {
  color: var(--bs-body-color);
  border-bottom-color: var(--fill-primary);
}

.nav-tabs .nav-link.active {
  color: var(--bs-body-color);
  border-bottom-color: var(--fill-secondary);
  background: transparent;
  font-weight: 600;
}

/* ===================== SECTION COMPONENTS ===================== */

.section-divider {
  height: 1px;
  background: var(--border-strong);
  margin: 1rem 0;
}

/* Block heading for Activos/Pasivos */
.panel-heading {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--text-label);
  margin-bottom: 0.75rem;
  padding-bottom: 0.35rem;
  border-bottom: 2px solid var(--border-strong);
}

/* Sub-group heading (liquidos, no liquidos, etc) */
.subgroup-heading {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-secondary);
  padding: 0.4rem 0.7rem;
  background: rgba(11, 27, 31, 0.25);
  border-radius: var(--radius-sm);
  margin-bottom: 0.25rem;
}

/* Total row with top border accent */
.total-row td {
  border-top: 2px solid var(--border-strong);
  font-weight: 700;
  color: var(--bs-card-color);
}

.total-row-accent {
  background: rgba(143, 177, 184, 0.1);
}

.total-row-accent td {
  font-weight: 700;
  border-top: 2px solid var(--fill-primary);
  color: var(--bs-card-color);
}

/* ===================== RESPONSIVE ===================== */

.border-primary {
  border-color: var(--fill-primary) !important;
}

.border-info {
  border-color: var(--bs-info) !important;
}

.border-warning {
  border-color: var(--warning) !important;
}

/* Comparativa table - total row should not be white-bright on dark themes */
.table-light {
  --bs-table-bg: var(--panel-secondary);
  --bs-table-color: var(--bs-card-color);
}

/* Comparativa tables — unificar bordes de celdas */
.table-bordered > :not(caption) > * > * {
  border-color: var(--border-strong) !important;
}

.table-bordered > tbody > tr:last-child > td {
  border-bottom: 1px solid var(--border-strong);
}

@media (max-width: 768px) {
  .navbar-brand { font-size: 0.9rem; }
  .card-header { font-size: 0.7rem; }
  .table > thead > tr > th { font-size: 0.6rem; }
  .table > tbody > tr > td { font-size: 0.78rem; }
  .page-header h4 { font-size: 1rem; }
  .card-kpi .kpi-value { font-size: 1.1rem; }
}
