@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

/* ── Reset y Variables ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --verde: #2d6a4f;
  --verde-oscuro: #1b4332;
  --verde-claro: #40916c;
  --verde-muy-claro: #d8f3dc;
  --amarillo: #f9c74f;
  --rojo: #e63946;
  --rojo-claro: #ffd6d8;
  --azul: #457b9d;
  --azul-claro: #a8dadc;
  --naranja: #f4a261;
  --morado: #7b2d8b;
  --gris: #6c757d;
  --gris-claro: #f8f9fa;
  --blanco: #ffffff;
  --negro: #212529;
  --borde: #dee2e6;
  --shadow: 0 2px 8px rgba(0,0,0,.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,.12);
  --radius: 8px;
  --radius-lg: 12px;
  --font: 'DM Sans', 'Segoe UI', system-ui, -apple-system, sans-serif;
  --font-mono: 'DM Mono', 'Courier New', monospace;
  --sidebar-w: 240px;
  --sidebar-collapsed-w: 52px;
}

/* ══════════════════════════════════════════════════════════════════════════
   TEMA OSCURO
   La clase 'dark' se aplica a <html> vía JS (auth.js → applyTheme).
   Las variables de layout se replican en data-theme="dark" y @media para
   que funcionen incluso antes de que JS cargue.
   ══════════════════════════════════════════════════════════════════════════ */

/* Variables de layout: explícito + auto-detección del sistema */
[data-theme="dark"],
html.dark {
  --gris-claro: #1e2430;
  --blanco:     #151b27;
  --negro:      #e8eaf0;
  --borde:      #2a3347;
  --gris:       #8892a4;
  --shadow:     0 2px 8px rgba(0,0,0,.4);
  --shadow-md:  0 4px 16px rgba(0,0,0,.5);
}
@media (prefers-color-scheme: dark) {
  html:not([data-theme="light"]) {
    --gris-claro: #1e2430;
    --blanco:     #151b27;
    --negro:      #e8eaf0;
    --borde:      #2a3347;
    --gris:       #8892a4;
    --shadow:     0 2px 8px rgba(0,0,0,.4);
    --shadow-md:  0 4px 16px rgba(0,0,0,.5);
  }
}

/* ── Badges ── */
html.dark .badge-success   { background: rgba(45,106,79,.28);  color: #74c69d; }
html.dark .badge-warning   { background: rgba(249,199,79,.15); color: #f5c518; }
html.dark .badge-danger    { background: rgba(230,57,70,.22);  color: #ff8080; }
html.dark .badge-info      { background: rgba(69,123,157,.25); color: #74b3ce; }
html.dark .badge-gray,
html.dark .badge-secondary { background: rgba(255,255,255,.08); color: #8892a4; }
html.dark .badge-purple    { background: rgba(123,45,139,.25); color: #c77dff; }

/* ── Badges de etapa ── */
html.dark .badge-etapa-germinacion    { background: rgba(249,199,79,.15);  color: #f5c518; }
html.dark .badge-etapa-propagacion    { background: rgba(13,202,240,.12);  color: #7fc8e7; }
html.dark .badge-etapa-endurecimiento { background: rgba(13,202,240,.08);  color: #5bb8d4; }
html.dark .badge-etapa-veg            { background: rgba(45,106,79,.28);   color: #74c69d; }
html.dark .badge-etapa-flora_inicial  { background: rgba(244,162,97,.18);  color: #f4a261; }
html.dark .badge-etapa-flora_tardia   { background: rgba(123,45,139,.25);  color: #c77dff; }
html.dark .badge-etapa-flush          { background: rgba(69,123,157,.2);   color: #74b3ce; }
html.dark .badge-etapa-cosechado      { background: rgba(45,106,79,.2);    color: #74c69d; }

/* ── Alertas de app (.alert-*) ── */
html.dark .alert-success { background: rgba(45,106,79,.2);    color: #74c69d; border-color: rgba(45,106,79,.35); }
html.dark .alert-warning { background: rgba(249,199,79,.12);  color: #f5c518; border-color: rgba(249,199,79,.3); }
html.dark .alert-danger  { background: rgba(230,57,70,.16);   color: #ff8080; border-color: rgba(230,57,70,.3); }
html.dark .alert-info    { background: rgba(69,123,157,.18);  color: #74b3ce; border-color: rgba(69,123,157,.3); }

/* ── Panel de alertas (alerta-item) ── */
html.dark .alerta-item               { background: rgba(255,255,255,.04); border-color: var(--borde); }
html.dark .alerta-item.critico       { background: rgba(230,57,70,.12);   border-left-color: var(--rojo); color: var(--negro); }
html.dark .alerta-item.warning       { background: rgba(249,199,79,.1);   border-left-color: var(--amarillo); color: var(--negro); }
html.dark .alerta-item.info          { background: rgba(69,123,157,.1);   border-left-color: var(--azul); }

/* ── Formularios ── */
html.dark .form-control {
  background: rgba(255,255,255,.06);
  border-color: var(--borde);
  color: var(--negro);
}
html.dark .form-control:focus {
  background: rgba(255,255,255,.09);
  border-color: var(--verde-claro);
}
html.dark select option {
  background: #1e2430;
  color: #e8eaf0;
}

/* ── Botones ── */
html.dark .btn-secondary {
  background: rgba(255,255,255,.08);
  color: var(--negro);
  border-color: var(--borde);
}
html.dark .btn-secondary:hover {
  background: rgba(255,255,255,.15);
  border-color: rgba(255,255,255,.2);
}
html.dark .btn-warning { color: #1a1a1a; } /* texto oscuro sobre amarillo */

/* ── Tab buttons (Configuración) ── */
html.dark .tab-btn { color: var(--gris); }
html.dark .tab-btn.active { color: var(--verde-claro); border-bottom-color: var(--verde-claro); }
html.dark .tab-btn:hover { color: var(--negro); background: rgba(255,255,255,.05); }

/* ── Topbar ── */
html.dark .topbar { background: var(--blanco); border-color: var(--borde); }

/* ── Código inline ── */
html.dark code { background: rgba(255,255,255,.1); color: #a8d8aa; padding: 1px 5px; border-radius: 4px; }

/* ── Chip/tag ── */
html.dark .chip { background: rgba(255,255,255,.06); border-color: var(--borde); color: var(--negro); }

/* ── Stat card coloreadas (dashboard) ── */
/* Las stat-card usan var(--blanco) como fondo — adapta sola */
/* El borde izquierdo de color se mantiene igual en dark (es intencional) */

/* ── Progress bars en dashboard ── */
html.dark .lote-stat,
html.dark .reg-param { background: rgba(255,255,255,.08); color: var(--negro); }

/* ── Tabla ── */
html.dark thead th { background: rgba(255,255,255,.05); color: var(--negro); }
html.dark tbody tr:hover { background: rgba(255,255,255,.04); }

/* ── Paginación ── */
html.dark .paginacion .btn-secondary { background: rgba(255,255,255,.08); }

/* ── Timeline ── */
html.dark .timeline-dot { border-color: var(--blanco); }

/* ── Ciclo stages ── */
html.dark .ciclo-header { background: rgba(255,255,255,.04); }

/* ── Input placeholders ── */
html.dark .form-control::placeholder { color: rgba(232,234,240,.4); }

/* ── Modal backdrop más oscuro en dark ── */
html.dark .modal-overlay { background: rgba(0,0,0,.65); }

/* ── Mapa: swatches de leyenda ── */
/* Los colores oscuros (genéticas, etapas) se funden con el fondo dark sin borde */
html.dark .leyenda-color {
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 0 0 1px rgba(0,0,0,.4);
}

body {
  font-family: var(--font);
  background: var(--gris-claro);
  color: var(--negro);
  line-height: 1.5;
  font-size: 14px;
}

/* ── Layout ───────────────────────────────────────────────────────────── */
.layout {
  display: flex;
  min-height: 100vh;
}

.sidebar {
  width: var(--sidebar-w);
  background: var(--verde);
  color: #fff;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 100;
  transition: transform .3s;
}

.sidebar-logo {
  padding: 20px 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.sidebar-logo h1 { font-size: 18px; font-weight: 700; }
.sidebar-logo span { font-size: 11px; opacity: .7; }

.sidebar-nav { flex: 1; padding: 12px 0; overflow-y: auto; }

.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  border-radius: 0;
  transition: background .15s, color .15s;
  font-size: 13.5px;
  cursor: pointer;
}
.nav-item:hover, .nav-item.active {
  background: rgba(255,255,255,.15);
  color: #fff;
}
.nav-item .icon { font-size: 16px; min-width: 20px; text-align: center; }

.nav-separator { height: 1px; background: rgba(255,255,255,.1); margin: 8px 16px; }
.nav-label { padding: 6px 16px 2px; font-size: 10px; text-transform: uppercase; letter-spacing: .8px; opacity: .5; font-family: var(--font-mono); }

.sidebar-footer {
  padding: 12px 16px;
  border-top: 1px solid rgba(255,255,255,.1);
  font-size: 12px;
  opacity: .7;
}

.main-content {
  margin-left: var(--sidebar-w);
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  transition: margin-left .3s;
}

/* ── Sidebar toggle button (desktop only) ──────────────────────────────── */
.sidebar-toggle-btn {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 5px 7px;
  border-radius: 6px;
  color: var(--gris);
  font-size: 13px;
  line-height: 1;
  transition: background .15s, color .15s;
  flex-shrink: 0;
}
.sidebar-toggle-btn:hover { background: var(--borde); color: var(--negro); }
html.dark .sidebar-toggle-btn:hover { background: rgba(255,255,255,.1); }
@media (min-width: 769px) { .sidebar-toggle-btn { display: inline-flex; align-items: center; } }

/* ── Sidebar colapsado (solo desktop) ─────────────────────────────────── */
@media (min-width: 769px) {
  .layout.sidebar-collapsed .sidebar { width: var(--sidebar-collapsed-w); overflow: hidden; }
  .layout.sidebar-collapsed .main-content { margin-left: var(--sidebar-collapsed-w); }

  /* Logo: solo icono */
  .layout.sidebar-collapsed .sidebar-logo { padding: 14px 0; text-align: center; }
  .layout.sidebar-collapsed .sidebar-logo .label-text { display: none; }
  .layout.sidebar-collapsed .sidebar-logo h1 { font-size: 20px; justify-content: center; }

  /* Nav items: solo icono centrado */
  .layout.sidebar-collapsed .nav-item { justify-content: center; padding: 10px 0; }
  .layout.sidebar-collapsed .nav-item .label-text { display: none; }
  .layout.sidebar-collapsed .nav-label { display: none; }
  .layout.sidebar-collapsed .nav-separator { margin: 4px 10px; }

  /* Footer: solo botones icono */
  .layout.sidebar-collapsed .sidebar-footer { padding: 8px 4px; }
  .layout.sidebar-collapsed .sidebar-footer .footer-user-info { display: none; }
  .layout.sidebar-collapsed .sidebar-footer .footer-btns {
    flex-direction: column; gap: 4px; margin-top: 0; align-items: center;
  }
  .layout.sidebar-collapsed .sidebar-footer .footer-btns .btn {
    flex: unset; width: 36px; padding: 6px; justify-content: center;
  }
  .layout.sidebar-collapsed .sidebar-footer .footer-btns .btn .label-text { display: none; }
}

.topbar {
  background: var(--blanco);
  border-bottom: 1px solid var(--borde);
  padding: 12px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky; top: 0; z-index: 50;
  box-shadow: var(--shadow);
}

.topbar-title { font-size: 16px; font-weight: 600; }

.topbar-right { display: flex; align-items: center; gap: 12px; }

.page-body { padding: 24px; flex: 1; }

/* ── Componentes base ─────────────────────────────────────────────────── */
.card {
  background: var(--blanco);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding: 20px;
  margin-bottom: 16px;
}

.card-title { font-size: 15px; font-weight: 600; margin-bottom: 12px; }

.stat-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; margin-bottom: 20px; }

.stat-card {
  background: var(--blanco);
  border-radius: var(--radius-lg);
  padding: 16px 20px;
  box-shadow: var(--shadow);
  border-left: 4px solid var(--verde);
}
.stat-card.warning { border-left-color: var(--amarillo); }
.stat-card.danger  { border-left-color: var(--rojo); }
.stat-card.info    { border-left-color: var(--azul); }
.stat-card.purple  { border-left-color: var(--morado); }

.stat-value { font-size: 28px; font-weight: 700; line-height: 1; }
.stat-label { font-size: 12px; color: var(--gris); margin-top: 4px; font-family: var(--font-mono); }

/* Botones */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: var(--radius);
  font-size: 13px; font-weight: 500; cursor: pointer;
  border: none; transition: all .15s; text-decoration: none;
  white-space: nowrap;
}
.btn-primary { background: var(--verde); color: #fff; }
.btn-primary:hover { background: var(--verde-claro); }
.btn-secondary { background: var(--gris-claro); color: var(--negro); border: 1px solid var(--borde); }
.btn-secondary:hover { background: var(--borde); }
.btn-danger { background: var(--rojo); color: #fff; }
.btn-danger:hover { opacity: .85; }
.btn-warning { background: var(--amarillo); color: var(--negro); }
.btn-sm { padding: 5px 10px; font-size: 12px; }
.btn-icon { padding: 6px; border-radius: 6px; }

/* Badges */
.badge {
  display: inline-block; padding: 2px 8px; border-radius: 12px;
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .3px;
}
.badge-success   { background: var(--verde-muy-claro); color: var(--verde); }
.badge-warning   { background: #fff3cd; color: #664d03; }
.badge-danger    { background: var(--rojo-claro); color: var(--rojo); }
.badge-info      { background: #cfe2ff; color: #084298; }
.badge-gray      { background: #e9ecef; color: var(--gris); }
.badge-secondary { background: #e9ecef; color: var(--gris); }
.badge-purple    { background: #e8d5ff; color: var(--morado); }

/* Etapas */
.badge-etapa-germinacion    { background: #fff3cd; color: #856404; }
.badge-etapa-propagacion    { background: #d1ecf1; color: #0c5460; }
.badge-etapa-endurecimiento { background: #e0f4f8; color: #2a7a8a; }
.badge-etapa-veg            { background: var(--verde-muy-claro); color: var(--verde); }
.badge-etapa-flora_inicial  { background: #ffe8cc; color: #8a4000; }
.badge-etapa-flora_tardia   { background: #e8d5ff; color: var(--morado); }
.badge-etapa-flush          { background: #cfe2ff; color: #084298; }
.badge-etapa-cosechado      { background: #d1e7dd; color: #0a3622; }

/* Tablas */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
thead th { background: var(--gris-claro); padding: 10px 12px; text-align: left; font-weight: 600; border-bottom: 2px solid var(--borde); white-space: nowrap; }
tbody td { padding: 10px 12px; border-bottom: 1px solid var(--borde); vertical-align: middle; }
tbody tr:hover { background: var(--gris-claro); }
tbody tr:last-child td { border-bottom: none; }

/* Formularios */
.form-group { margin-bottom: 14px; }
.form-label { display: block; font-size: 12px; font-weight: 600; margin-bottom: 4px; color: var(--gris); text-transform: uppercase; letter-spacing: .3px; font-family: var(--font-mono); }
.form-control {
  width: 100%; padding: 8px 12px; border: 1px solid var(--borde);
  border-radius: var(--radius); font-size: 13px; background: var(--blanco);
  color: var(--negro); transition: border-color .15s, box-shadow .15s;
}
.form-control:focus { outline: none; border-color: var(--verde-claro); box-shadow: 0 0 0 3px rgba(64,145,108,.15); }
select.form-control { cursor: pointer; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }

/* Alertas en app */
.alert {
  padding: 12px 16px; border-radius: var(--radius); margin-bottom: 12px;
  display: flex; align-items: flex-start; gap: 10px;
}
.alert-success { background: var(--verde-muy-claro); color: var(--verde); border: 1px solid #b7e4c7; }
.alert-warning { background: #fff3cd; color: #664d03; border: 1px solid #ffc107; }
.alert-danger  { background: var(--rojo-claro); color: var(--rojo); border: 1px solid #f5c6cb; }
.alert-info    { background: #d1ecf1; color: #0c5460; border: 1px solid #bee5eb; }

/* Modal */
.modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.5);
  z-index: 1000; display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.modal {
  background: var(--blanco); border-radius: var(--radius-lg);
  width: 100%; max-width: 560px; max-height: 90vh; overflow-y: auto;
  box-shadow: var(--shadow-md); animation: modalIn .2s ease;
}
@keyframes modalIn { from { transform: scale(.95); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.modal-header {
  padding: 16px 20px; border-bottom: 1px solid var(--borde);
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; background: var(--blanco); z-index: 1;
}
.modal-title { font-size: 15px; font-weight: 600; }
.modal-body { padding: 20px; }
.modal-footer { padding: 12px 20px; border-top: 1px solid var(--borde); display: flex; gap: 8px; justify-content: flex-end; }

/* Semáforo salas */
.semaforo { display: inline-block; width: 10px; height: 10px; border-radius: 50%; }
.semaforo-verde   { background: #2d6a4f; }
.semaforo-amarillo { background: #f9c74f; }
.semaforo-rojo    { background: #e63946; }
.semaforo-desconocido { background: var(--gris); }

/* Timeline bitácora */
.timeline { position: relative; padding-left: 24px; }
.timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: var(--borde); }
.timeline-item { position: relative; margin-bottom: 16px; }
.timeline-dot {
  position: absolute; left: -20px; top: 3px;
  width: 10px; height: 10px; border-radius: 50%; background: var(--verde);
  border: 2px solid var(--blanco);
}
.timeline-content { background: var(--blanco); border: 1px solid var(--borde); border-radius: var(--radius); padding: 10px 14px; }
.timeline-meta { font-size: 11px; color: var(--gris); margin-bottom: 4px; }

/* Chips / Tags */
.chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 20px; font-size: 12px;
  background: var(--gris-claro); border: 1px solid var(--borde);
}

/* Alertas panel */
.alerta-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px; border-radius: var(--radius);
  background: var(--blanco); border: 1px solid var(--borde); margin-bottom: 8px;
}
.alerta-item.critico { border-left: 3px solid var(--rojo); background: var(--rojo-claro); }
.alerta-item.warning { border-left: 3px solid var(--amarillo); background: #fff3cd; }
.alerta-item.info    { border-left: 3px solid var(--azul); }

/* Filtros */
.filtros { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; align-items: center; }
.filtros .form-control { width: auto; min-width: 140px; }

/* Spinner */
.spinner {
  display: inline-block; width: 20px; height: 20px;
  border: 2px solid var(--borde); border-top-color: var(--verde);
  border-radius: 50%; animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Empty state */
.empty-state { text-align: center; padding: 48px 24px; color: var(--gris); }
.empty-state .icon { font-size: 48px; margin-bottom: 12px; }
.empty-state p { font-size: 15px; }

/* Responsive */
#hamb-btn { display: none; }

/* Backdrop mobile sidebar */
#sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 99;
}
#sidebar-backdrop.visible { display: block; }

@media (max-width: 768px) {
  :root { --sidebar-w: 0px; }
  body { overflow-x: hidden; }
  .sidebar { transform: translateX(-240px); }
  .sidebar.open { transform: translateX(0); width: 240px; }
  .main-content { margin-left: 0; min-width: 0; overflow-x: hidden; }
  .form-row, .form-row-3 { grid-template-columns: 1fr; }
  .stat-cards { grid-template-columns: 1fr 1fr; }
  .page-body { padding: 12px; }
  /* Grilla de métricas del lote: 2 columnas en mobile */
  .lote-metrics-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Widgets: una columna en mobile */
  #widgets-grid { grid-template-columns: 1fr !important; }
  #hamb-btn { display: inline-flex !important; }
  .sidebar-toggle-btn { display: none !important; }
}

/* Utilidades */
.text-muted { color: var(--gris); }
.text-small { font-size: 12px; }
.text-center { text-align: center; }
.fw-bold { font-weight: 600; }
.d-flex { display: flex; }
.align-center { align-items: center; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.ml-auto { margin-left: auto; }
.w-100 { width: 100%; }
.hidden { display: none !important; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Mini stat cards con color (usados en detalle de ciclos, alertas, etc.) ── */
.mini-stat { border-radius: var(--radius); padding: 10px 14px; display: flex; align-items: center; gap: 10px; border: 1px solid transparent; }
.mini-stat-danger  { background: #fef2f2; border-color: #fecaca; }
.mini-stat-warning { background: #fffbeb; border-color: #fde68a; }
.mini-stat-info    { background: #eff6ff; border-color: #bfdbfe; }
.mini-stat-success { background: #f0fdf4; border-color: #bbf7d0; }
.mini-stat-orange  { background: #fff7ed; border-color: #fed7aa; }
.mini-stat-purple  { background: #faf5ff; border-color: #e9d5ff; }
.mini-stat-cosecha { background: #dcfce7; border-color: #bbf7d0; }

html.dark .mini-stat-danger  { background: rgba(230,57,70,.15);  border-color: rgba(230,57,70,.3);  }
html.dark .mini-stat-warning { background: rgba(249,199,79,.12); border-color: rgba(249,199,79,.28); }
html.dark .mini-stat-info    { background: rgba(69,123,157,.18); border-color: rgba(69,123,157,.35); }
html.dark .mini-stat-success { background: rgba(45,106,79,.18);  border-color: rgba(45,106,79,.35);  }
html.dark .mini-stat-orange  { background: rgba(244,162,97,.15); border-color: rgba(244,162,97,.3);  }
html.dark .mini-stat-purple  { background: rgba(123,45,139,.18); border-color: rgba(123,45,139,.32); }
html.dark .mini-stat-cosecha { background: rgba(45,106,79,.18);  border-color: rgba(45,106,79,.35);  }

.mini-stat-val-danger  { font-size: 20px; font-weight: 700; color: #dc2626; }
.mini-stat-val-warning { font-size: 20px; font-weight: 700; color: #d97706; }
.mini-stat-val-info    { font-size: 20px; font-weight: 700; color: #2563eb; }
.mini-stat-val-success { font-size: 20px; font-weight: 700; color: #16a34a; }
html.dark .mini-stat-val-danger  { color: #ff8080; }
html.dark .mini-stat-val-warning { color: #f5c518; }
html.dark .mini-stat-val-info    { color: #74b3ce; }
html.dark .mini-stat-val-success { color: #74c69d; }

.mini-stat-label { font-size: 11px; color: var(--gris); }

/* ── Día de hoy en calendario ── */
.dia-hoy { background: rgba(45,106,79,.08); border-radius: 6px; }
html.dark .dia-hoy { background: rgba(45,106,79,.2); }

/* ── Cosecha preview en ciclos ── */
.preview-cosecha { background: #dcfce7; border-radius: var(--radius); padding: 8px 12px; }
html.dark .preview-cosecha { background: rgba(45,106,79,.2); }

/* ── Login card ── */
.login-card { background: var(--blanco) !important; color: var(--negro); }
html.dark .login-card { box-shadow: 0 8px 40px rgba(0,0,0,.5); }

/* ── Mapa canvas ── */
html.dark #mapa-canvas { background: var(--blanco) !important; }
html.dark .celda.vacia:hover { background: rgba(255,255,255,.08) !important; }

/* ── Error msg (login) ── */
html.dark .error-msg { background: rgba(230,57,70,.2); color: #ff8080; }

/* Colores tipo evento en calendario */
.ev-riego        { border-left: 3px solid var(--azul); }
.ev-nutrientes   { border-left: 3px solid var(--verde-claro); }
.ev-fitosanitario{ border-left: 3px solid var(--rojo); }
.ev-poda         { border-left: 3px solid var(--naranja); }
.ev-cosecha      { border-left: 3px solid var(--morado); }
.ev-limpieza     { border-left: 3px solid var(--gris); }
.ev-monitoreo    { border-left: 3px solid var(--azul-claro); }
.ev-otro         { border-left: 3px solid var(--borde); }
