/* style.css — Identidad visual Arblu */
/* Paleta: azul marino #003366, semáforo verde/amarillo/rojo, tipografía DM Sans */

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

:root {
  --azul:       #003366;
  --azul-medio: #005599;
  --azul-claro: #0077bb;
  --verde:      #0a7c42;
  --verde-bg:   #e8f5e9;
  --amarillo:   #b5720a;
  --amarillo-bg:#fff3e0;
  --rojo:       #c62828;
  --rojo-bg:    #fce4ec;
  --gris:       #5a5a5a;
  --gris-claro: #8a8a8a;
  --borde:      #e0ddd8;
  --fondo:      #f7f6f3;
  --card:       #ffffff;
  --sombra:     0 1px 4px rgba(0,0,0,.08);
  --radio:      10px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--fondo);
  color: #1a1a1a;
  line-height: 1.6;
  min-height: 100vh;
}

/* ── Layout ─────────────────────────────────────────────────────────────── */

.contenedor {
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px 20px 60px;
}

.contenedor-angosto {
  max-width: 520px;
  margin: 0 auto;
  padding: 40px 20px;
}

/* ── Header / Navbar ─────────────────────────────────────────────────────── */

.navbar {
  background: linear-gradient(135deg, var(--azul) 0%, var(--azul-medio) 60%, var(--azul-claro) 100%);
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}

.navbar-logo {
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.5px;
}

.navbar-logo span {
  opacity: 0.7;
  font-weight: 400;
  font-size: 13px;
  margin-left: 8px;
}

.navbar-user {
  display: flex;
  align-items: center;
  gap: 16px;
  color: rgba(255,255,255,.85);
  font-size: 13px;
}

.btn-logout {
  background: rgba(255,255,255,.15);
  color: #fff;
  border: 1px solid rgba(255,255,255,.3);
  padding: 6px 14px;
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  transition: background .15s;
}
.btn-logout:hover { background: rgba(255,255,255,.25); }

/* ── Hero header (formularios) ──────────────────────────────────────────── */

.header-form {
  text-align: center;
  padding: 28px 20px;
  background: linear-gradient(135deg, var(--azul) 0%, var(--azul-medio) 50%, var(--azul-claro) 100%);
  border-radius: 16px;
  color: #fff;
  margin-bottom: 24px;
}
.header-form h1 { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.header-form p  { font-size: 13px; opacity: .8; }

/* ── Cards ───────────────────────────────────────────────────────────────── */

.card {
  background: var(--card);
  border-radius: var(--radio);
  border: 1px solid var(--borde);
  box-shadow: var(--sombra);
  padding: 24px;
  margin-bottom: 20px;
}

.card-titulo {
  font-size: 15px;
  font-weight: 600;
  color: var(--gris);
  text-transform: uppercase;
  letter-spacing: .6px;
  font-size: 11px;
  margin-bottom: 16px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--azul-claro);
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ── Semáforo / badges de riesgo ─────────────────────────────────────────── */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
}

.badge-verde   { background: var(--verde-bg);    color: var(--verde); }
.badge-amarillo{ background: var(--amarillo-bg); color: var(--amarillo); }
.badge-rojo    { background: var(--rojo-bg);     color: var(--rojo); }
.badge-gris    { background: #f0f0f0;            color: var(--gris-claro); }
.badge-naranja { background: #fff3e0;            color: #e65100; }  /* REQ-026: en_intervencion */

/* ── Stats del dashboard ─────────────────────────────────────────────────── */

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.stat-card {
  background: var(--card);
  border-radius: var(--radio);
  border: 1px solid var(--borde);
  box-shadow: var(--sombra);
  padding: 20px;
  text-align: center;
}

.stat-numero {
  font-size: 36px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 4px;
}

.stat-label {
  font-size: 12px;
  color: var(--gris-claro);
  text-transform: uppercase;
  letter-spacing: .5px;
}

.stat-verde    .stat-numero { color: var(--verde); }
.stat-amarillo .stat-numero { color: var(--amarillo); }
.stat-rojo     .stat-numero { color: var(--rojo); }
.stat-total    .stat-numero { color: var(--azul); }

/* ── Tabs de navegación ─────────────────────────────────────────────────── */

.tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 24px;
  border-bottom: 2px solid var(--borde);
  padding-bottom: -2px;
}

.tab-btn {
  padding: 10px 20px;
  border: none;
  background: none;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  color: var(--gris);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all .15s;
}
.tab-btn:hover { color: var(--azul-medio); }
.tab-btn.activo {
  color: var(--azul);
  border-bottom-color: var(--azul);
  font-weight: 600;
}

/* ── Tabla de empleados ─────────────────────────────────────────────────── */

.tabla-wrap { overflow-x: auto; }

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

thead th {
  text-align: left;
  padding: 10px 14px;
  background: #f4f3f0;
  color: var(--gris);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  border-bottom: 1px solid var(--borde);
}

tbody tr {
  border-bottom: 1px solid var(--borde);
  transition: background .1s;
  cursor: pointer;
}
tbody tr:hover { background: #f9f8f6; }
tbody tr:last-child { border-bottom: none; }

td { padding: 12px 14px; vertical-align: middle; }

.td-nombre { font-weight: 500; }
.td-patologia {
  font-size: 12px;
  color: var(--gris-claro);
  text-transform: capitalize;
}

/* ── Panel de alertas ───────────────────────────────────────────────────── */

.alerta-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 16px;
  border-radius: 8px;
  margin-bottom: 12px;
  border: 1px solid var(--borde);
  cursor: pointer;
  transition: box-shadow .15s;
}
.alerta-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.alerta-item.rojo   { border-left: 4px solid var(--rojo);    background: #fffbfb; }
.alerta-item.amarillo { border-left: 4px solid var(--amarillo); background: #fffdf7; }

.alerta-icono { font-size: 24px; flex-shrink: 0; }
.alerta-info { flex: 1; }
.alerta-nombre { font-weight: 600; font-size: 15px; margin-bottom: 2px; }
.alerta-detalle { font-size: 13px; color: var(--gris); }
.alerta-meta { font-size: 12px; color: var(--gris-claro); margin-top: 4px; }

.alerta-llamada {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--rojo-bg);
  color: var(--rojo);
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  margin-left: 8px;
}

/* ── Vista detalle de empleado ──────────────────────────────────────────── */

.detalle-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
}

.btn-volver {
  background: none;
  border: 1px solid var(--borde);
  padding: 8px 14px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  color: var(--gris);
  transition: all .15s;
}
.btn-volver:hover { border-color: var(--azul-medio); color: var(--azul-medio); }

.detalle-nombre { font-size: 22px; font-weight: 700; }
.detalle-meta   { font-size: 13px; color: var(--gris); }

.historial-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--borde);
}
.historial-item:last-child { border-bottom: none; }
.historial-fecha { font-size: 13px; color: var(--gris); }
.historial-notas { font-size: 13px; color: var(--gris); font-style: italic; margin-top: 4px; }

/* ── Formulario de login ─────────────────────────────────────────────────── */

.login-box {
  background: var(--card);
  border-radius: 16px;
  border: 1px solid var(--borde);
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  padding: 40px;
}

.login-logo {
  text-align: center;
  margin-bottom: 32px;
}

.login-logo h1 {
  font-size: 28px;
  font-weight: 700;
  color: var(--azul);
  letter-spacing: -0.5px;
}

.login-logo p {
  font-size: 13px;
  color: var(--gris-claro);
  margin-top: 4px;
}

/* ── Formularios generales ──────────────────────────────────────────────── */

.campo {
  margin-bottom: 18px;
}

.campo label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 6px;
  color: #333;
}

.campo input,
.campo select,
.campo textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--borde);
  border-radius: 7px;
  font-size: 15px;
  font-family: inherit;
  background: #fff;
  transition: border-color .15s;
}

.campo input:focus,
.campo select:focus,
.campo textarea:focus {
  outline: none;
  border-color: var(--azul-claro);
}

.campo textarea { resize: vertical; min-height: 80px; }

/* ── Botones ─────────────────────────────────────────────────────────────── */

.btn-primary {
  width: 100%;
  padding: 13px;
  background: var(--azul);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: background .15s, transform .1s;
}
.btn-primary:hover { background: var(--azul-medio); transform: translateY(-1px); }
.btn-primary:active { transform: none; }

.btn-secondary {
  padding: 8px 14px;
  background: #f4f3f0;
  color: #1a1a1a;
  border: 1px solid var(--borde);
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: background .15s;
}
.btn-secondary:hover { background: #eae8e4; }

/* ── Roster: sortable headers ───────────────────────────────────────────── */
th.sortable {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
th.sortable:hover { background: #f0ede8; }
th.sortable.sort-asc  .sort-icon::after { content: ' ↑'; }
th.sortable.sort-desc .sort-icon::after { content: ' ↓'; }
th.sortable .sort-icon { color: #8a8a8a; font-size: 11px; }
th.sortable.sort-asc  .sort-icon,
th.sortable.sort-desc .sort-icon { color: var(--azul); }

/* ── Check-in: opciones ──────────────────────────────────────────────────── */

.q-bloque {
  margin-bottom: 20px;
  padding: 16px;
  background: #fafaf8;
  border-radius: 8px;
  border: 1px solid transparent;
}

.q-num {
  font-size: 11px;
  font-weight: 600;
  color: var(--azul-claro);
  margin-bottom: 2px;
}

.q-normalizador {
  font-size: 13px;
  color: var(--gris);
  font-style: italic;
  padding: 6px 10px;
  background: #fffdf0;
  border-left: 3px solid #e6c84a;
  border-radius: 0 4px 4px 0;
  margin-bottom: 8px;
}

.q-texto { font-size: 15px; font-weight: 500; margin-bottom: 10px; }

.q-opciones { display: flex; flex-wrap: wrap; gap: 8px; }

.opt {
  padding: 8px 16px;
  border-radius: 6px;
  border: 1px solid var(--borde);
  font-size: 13px;
  cursor: pointer;
  transition: all .15s;
  background: #fff;
  font-family: inherit;
  user-select: none;
}
.opt:hover { border-color: var(--azul-claro); }
.opt.sel   { background: var(--azul); color: #fff; border-color: var(--azul); }
.opt.sel-verde    { background: var(--verde);    border-color: var(--verde);    color: #fff; }
.opt.sel-amarillo { background: var(--amarillo); border-color: var(--amarillo); color: #fff; }
.opt.sel-rojo     { background: var(--rojo);     border-color: var(--rojo);     color: #fff; }

.conf-box {
  background: #f0f7ff;
  border: 1px solid #cce0f5;
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 13px;
  color: #1a5276;
  margin-bottom: 20px;
}

/* ── Estados vacíos y mensajes ──────────────────────────────────────────── */

.vacio {
  text-align: center;
  padding: 40px;
  color: var(--gris-claro);
  font-size: 14px;
}
.vacio span { display: block; font-size: 32px; margin-bottom: 8px; }

.error-msg {
  background: var(--rojo-bg);
  color: var(--rojo);
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 13px;
  margin-bottom: 16px;
  display: none;
}

.exito-box {
  text-align: center;
  padding: 48px 24px;
}
.exito-box .icono { font-size: 56px; margin-bottom: 16px; }
.exito-box h2 { font-size: 22px; font-weight: 700; color: var(--verde); margin-bottom: 8px; }
.exito-box p  { font-size: 14px; color: var(--gris); }

/* ── Sección cabecera ────────────────────────────────────────────────────── */

.seccion-head {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--azul-claro);
  margin-bottom: 12px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--azul-claro);
}

/* ── Disclaimer ─────────────────────────────────────────────────────────── */

.disclaimer {
  text-align: center;
  font-size: 11px;
  color: var(--gris-claro);
  margin-top: 32px;
  padding-top: 16px;
  border-top: 1px solid var(--borde);
}

/* ── Responsive ─────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .navbar { padding: 0 16px; }
  .contenedor { padding: 16px 12px 40px; }
}

@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .login-box { padding: 24px; }
  .tabs { overflow-x: auto; }
  .tab-btn { white-space: nowrap; }
}
