/* ============================================================
   NexoGente · estilos propios de la app
   (se apoyan en los tokens del design system Bodypal)
   ============================================================ */

/* Evita la barra de scroll horizontal por desbordes del layout.
   Las tablas anchas (grilla, exportación) tienen su propio scroll interno. */
body { overflow-x: hidden; }
/* La sidebar solo necesita scroll vertical (su contenido se desbordaba ~12px
   por el botón de colapsar y disparaba una barra horizontal). */
.sidebar { overflow-x: hidden; }

/* Login -------------------------------------------------------- */
.login-wrap {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--space-6);
  background:
    radial-gradient(900px 500px at 110% -10%, rgba(111, 174, 234, 0.25), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(31, 63, 140, 0.25), transparent 60%),
    var(--surface-sunk);
}
.login-card {
  width: 100%;
  max-width: 380px;
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: var(--space-8);
}
.login-brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.login-brand .mark {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  background: var(--brand-600);
  border-radius: var(--radius-md);
  color: white; font-weight: 800; font-size: 20px;
}
.login-brand .name { font-weight: 700; font-size: 20px; letter-spacing: -0.01em; }
.login-brand .sub { font-size: 12px; color: var(--text-muted); }

/* Topbar (app) ------------------------------------------------- */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-6);
  border-bottom: 1px solid var(--border);
  background: var(--surface-raised);
  position: sticky; top: 0; z-index: 5;
}
.topbar .who { font-size: 13px; color: var(--text-muted); }
.topbar .who strong { color: var(--text); }

.sidebar-logo .mark img { width: 22px; height: 22px; object-fit: contain; }

/* Vistas ------------------------------------------------------- */
.view-head { margin-bottom: var(--space-6); }
.view-head h1 { font-size: 28px; font-weight: 600; letter-spacing: -0.015em; margin: 0 0 4px; }
.view-head p { margin: 0; color: var(--text-muted); font-size: 14px; }

.panel {
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-6);
}
.panel h3 { margin: 0 0 var(--space-4); font-size: 16px; font-weight: 600; }

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}
.form-grid .full { grid-column: 1 / -1; }
.form-grid .field { min-width: 0; }

/* Variante compacta para la carga de incidencias (más práctica de rellenar). */
.form-grid.compacto {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3) var(--space-4);
}
.form-grid.compacto .field { gap: 4px; min-width: 0; }
.form-grid.compacto label { font-size: 12.5px; }
.form-grid.compacto .input,
.form-grid.compacto select.input { height: 34px; font-size: 13.5px; }
.form-grid.compacto textarea.input { min-height: 32px; height: 34px; padding: 6px 10px; font-size: 13.5px; resize: none; }
.form-grid.compacto .field.span-2 { grid-column: span 2; }
@media (max-width: 900px) { .form-grid.compacto { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

/* Formulario de carga de incidencia: grilla de 6 columnas, campos cómodos.
   Filas: (Empleado | Tipo) · (Fecha | Hora desde | Hora hasta) · (Detalle). */
.form-inc { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-4); }
.form-inc .field { min-width: 0; gap: 5px; }
.form-inc .field label { font-size: 13px; }
.form-inc .input { height: 38px; font-size: 14px; width: 100%; }
.form-inc .c2 { grid-column: span 2; }
.form-inc .c3 { grid-column: span 3; }
.form-inc .c6 { grid-column: span 6; }
@media (max-width: 640px) { .form-inc .c2, .form-inc .c3 { grid-column: span 6; } }
select.input { appearance: none; background-image:
  linear-gradient(45deg, transparent 50%, var(--text-muted) 50%),
  linear-gradient(135deg, var(--text-muted) 50%, transparent 50%);
  background-position: calc(100% - 18px) 16px, calc(100% - 13px) 16px;
  background-size: 5px 5px, 5px 5px; background-repeat: no-repeat;
}
textarea.input { height: auto; padding: 10px 12px; resize: vertical; min-height: 64px; }

/* Grilla de horarios ------------------------------------------- */
.grilla-horarios { overflow-x: auto; }
.grilla-horarios table { font-size: 12.5px; }
.grilla-horarios th, .grilla-horarios td { white-space: nowrap; text-align: center; }
.grilla-horarios th:first-child, .grilla-horarios td:first-child { text-align: left; }
.grilla-horarios th:nth-child(2), .grilla-horarios td:nth-child(2) { text-align: left; }
.grilla-horarios .descanso-cell { color: var(--text-soft); font-size: 11px; }
.grilla-horarios .sabado-tag { font-size: 10px; padding: 1px 5px; border-radius: var(--radius-full); }
.grilla-horarios .sabado-tag.alterno { background: var(--warning-50); color: var(--warning-700); }
.grilla-horarios .sabado-tag.semanal { background: var(--success-50); color: var(--success-700); }
.cell-hor { font-size: 12px; font-variant-numeric: tabular-nums; letter-spacing: -0.2px; }

/* Empleado inactivo -------------------------------------------- */
tr.empleado-inactivo { opacity: 0.55; }
.badge-baja { font-size: 11px; padding: 2px 8px; border-radius: var(--radius-full); background: var(--danger-50); color: var(--danger-700); }

/* Input pequeño ------------------------------------------------- */
.input-sm { height: 30px !important; font-size: 12.5px !important; padding: 4px 8px !important; }

/* Modal más ancho para grilla ----------------------------------- */
.modal-wide { max-width: 900px !important; width: 100% !important; }

/* Conceptos calculados (chips) --------------------------------- */
.concept-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.concept-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; padding: 3px 9px; border-radius: var(--radius-full);
  background: var(--accent-50); color: var(--accent-700);
  font-feature-settings: 'tnum';
}

/* Licencias: calendario y clases -------------------------------- */
.lic-cal-cell {
  display: inline-block;
  font-size: 10px; padding: 1px 5px;
  border-radius: var(--radius-sm);
  cursor: pointer; white-space: nowrap;
}
.lic-cal-cell.anual { background: var(--brand-50); color: var(--brand-700); }
.lic-cal-cell.matrimonio { background: var(--success-50); color: var(--success-700); }
.lic-cal-cell.estudio { background: var(--accent-50); color: var(--accent-700); }
.lic-cal-cell.duelo { background: var(--danger-50); color: var(--danger-700); }
.lic-cal-cell.paternidad { background: var(--warning-50); color: var(--warning-700); }
.lic-cal-cell.maternidad { background: var(--warning-50); color: var(--warning-700); }
.lic-cal-cell.enfermedad { background: var(--danger-50); color: var(--danger-700); }
.lic-cal-cell.generacion { background: var(--success-50); color: var(--success-700); }
.lic-cal-cell.cobro { background: var(--accent-50); color: var(--accent-700); }
.lic-cal-cell.ajuste { background: var(--ink-100); color: var(--ink-700); }

.text-danger { color: var(--danger-600) !important; font-weight: 600; }
.text-warning { color: var(--warning-600) !important; font-weight: 600; }

.badge.badge-info { background: var(--accent-50); color: var(--accent-700); }
.badge.badge-success { background: var(--success-50); color: var(--success-700); }
.badge.badge-neutral { background: var(--ink-100); color: var(--ink-700); }
[data-theme="dark"] .concept-chip { background: rgba(42,120,208,.16); color: var(--accent-200); }
.concept-chip .cant { font-family: var(--font-mono); font-weight: 500; }
.concept-chip.warn { background: var(--warning-50); color: var(--warning-700); }

/* Editor de perfiles — tabla: labels izq + una col por perfil */
.perfiles-tabla-wrap { padding: 0; overflow: hidden; margin-bottom: 0; }
.perfiles-tabla { display: grid; }
.perfiles-th {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-2);
  border-left: 1px solid var(--border);
  background: var(--surface-sunk);
  text-align: center;
}
.perfiles-group-hdr {
  padding: 6px var(--space-4);
  background: var(--surface-sunk);
  border-top: 1px solid var(--border);
}
.perfiles-row-label {
  display: flex; align-items: center;
  padding: 7px var(--space-4);
  font-size: 13px;
  border-top: 1px solid var(--border-subtle);
}
.perfiles-row-check {
  display: flex; align-items: center; justify-content: center;
  padding: 7px;
  border-top: 1px solid var(--border-subtle);
  border-left: 1px solid var(--border);
}

/* Menú contextual (click derecho / ⋯ en incidencias).
   position:fixed va en clase para que el binding :style (left/top) no lo pise. */
.ctx-menu { position: fixed; z-index: 60; min-width: 170px; }

/* Toast -------------------------------------------------------- */
.toast {
  position: fixed; right: var(--space-6); bottom: var(--space-6);
  z-index: 50; min-width: 260px; max-width: 380px;
  padding: var(--space-4); border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg); font-size: 14px;
  display: flex; gap: var(--space-3); align-items: flex-start;
}
.toast.ok { background: var(--success-600); color: white; }
.toast.err { background: var(--danger-600); color: white; }

/* Misc --------------------------------------------------------- */
.empty {
  text-align: center; padding: var(--space-12);
  color: var(--text-muted); font-size: 14px;
}
.spinner {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--border-strong); border-top-color: var(--brand-600);
  animation: spin 0.7s linear infinite; display: inline-block;
}
@keyframes spin { to { transform: rotate(360deg); } }
.toolbar { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; margin-bottom: var(--space-4); }
.toolbar .grow { flex: 1; }
[x-cloak] { display: none !important; }
