/* ── Design System — solicitudTurnos ── */
:root {
  --primary:    #1a3a5c;
  --primary-lt: #2563eb;
  --accent:     #f59e0b;
  --success:    #16a34a;
  --danger:     #dc2626;
  --warning:    #d97706;
  --bg:         #f1f5f9;
  --surface:    #ffffff;
  --border:     #e2e8f0;
  --text:       #1e293b;
  --text-muted: #64748b;
}

* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Open Sans',sans-serif; background:var(--bg); color:var(--text); }

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

/* ── Sidebar ── */
.sidebar {
  width:220px; min-height:100vh; background:var(--primary);
  display:flex; flex-direction:column; padding:0;
  position:fixed; top:0; left:0; z-index:200;
  transition:transform .25s;
}
.sidebar-brand {
  padding:22px 18px 16px;
  font-size:1rem; font-weight:700; color:#fff;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
.logo-accent { color:var(--accent); }
.sidebar-nav { flex:1; padding:10px 0; }
.nav-link {
  display:flex; align-items:center; gap:10px;
  padding:10px 18px; color:rgba(255,255,255,0.75);
  font-size:14px; text-decoration:none; cursor:pointer;
  transition:background .15s, color .15s;
}
.nav-link:hover, .nav-link.active {
  background:rgba(255,255,255,0.1); color:#fff;
}
.nav-link svg { flex-shrink:0; }
.sidebar-user {
  padding:14px 18px; border-top:1px solid rgba(255,255,255,0.1);
  font-size:0.78rem; color:rgba(255,255,255,0.6);
}
.sidebar-user strong { display:block; color:#fff; font-size:0.85rem; margin-bottom:2px; }
.sidebar-user .rol-badge {
  display:inline-block; font-size:0.65rem; font-weight:700; letter-spacing:.05em;
  text-transform:uppercase; background:var(--accent); color:#fff;
  padding:2px 7px; border-radius:10px; margin-top:4px;
}

/* ── Main Content ── */
.main { margin-left:220px; flex:1; display:flex; flex-direction:column; min-height:100vh; }
.topbar {
  background:var(--surface); border-bottom:1px solid var(--border);
  padding:14px 28px; display:flex; align-items:center; justify-content:space-between;
}
.topbar h2 { font-size:1rem; font-weight:700; color:var(--primary); }
.page-content { padding:24px 28px; }

/* ── Cards ── */
.cards-row { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:24px; }
.card-stat {
  background:var(--surface); border:1px solid var(--border); border-radius:10px;
  padding:18px 22px; flex:1; min-width:160px;
  display:flex; flex-direction:column; gap:4px;
}
.card-stat .num { font-size:2rem; font-weight:800; color:var(--primary); }
.card-stat .lbl { font-size:0.78rem; color:var(--text-muted); }

/* ── Panel de módulo en dashboard ── */
.modulo-cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:16px; }
.modulo-card {
  background:var(--surface); border:1px solid var(--border); border-radius:10px;
  overflow:hidden; box-shadow:0 2px 6px rgba(0,0,0,.04);
}
.modulo-card-header {
  padding:12px 16px; color:#fff; font-weight:700; font-size:0.9rem;
  display:flex; align-items:center; justify-content:space-between;
}
.modulo-card-body { padding:14px 16px; }
.turno-actual {
  font-size:2.5rem; font-weight:900; color:var(--primary);
  letter-spacing:.05em; text-align:center; margin:8px 0;
}
.turno-actual.vacio { font-size:1.1rem; color:var(--text-muted); font-weight:400; }
.cola-preview { font-size:0.75rem; color:var(--text-muted); text-align:center; }
.badge-espera {
  display:inline-flex; align-items:center; gap:4px;
  background:#eff6ff; color:var(--primary-lt); border-radius:12px;
  font-size:0.72rem; font-weight:700; padding:3px 8px;
}

/* ── Tabla ── */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:0.85rem; }
th { background:var(--primary); color:#fff; font-weight:600; padding:10px 12px; text-align:left; white-space:nowrap; }
td { padding:9px 12px; border-bottom:1px solid var(--border); vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:#f8fafc; }

.badge {
  display:inline-block; font-size:0.7rem; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; padding:3px 8px; border-radius:10px;
}
.badge-espera-st  { background:#eff6ff; color:#1d4ed8; }
.badge-llamado    { background:#fef9c3; color:#a16207; }
.badge-atencion   { background:#dcfce7; color:#15803d; }
.badge-completado { background:#f0fdf4; color:#166534; }
.badge-cancelado  { background:#fef2f2; color:#b91c1c; }
.badge-saltado    { background:#f5f3ff; color:#6d28d9; }

/* ── Botones ── */
.btn { display:inline-flex; align-items:center; gap:6px; padding:8px 16px; border-radius:6px; border:none; font-size:0.85rem; font-weight:600; cursor:pointer; transition:background .15s; }
.btn-primary   { background:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--primary-lt); }
.btn-success   { background:var(--success); color:#fff; }
.btn-success:hover { background:#15803d; }
.btn-danger    { background:var(--danger); color:#fff; }
.btn-danger:hover  { background:#b91c1c; }
.btn-warning   { background:var(--warning); color:#fff; }
.btn-warning:hover { background:#b45309; }
.btn-secondary { background:#f1f5f9; color:var(--text); border:1px solid var(--border); }
.btn-secondary:hover { background:#e2e8f0; }
.btn-sm { padding:5px 10px; font-size:0.78rem; }
.btn-lg { padding:14px 28px; font-size:1rem; }

/* ── Formularios ── */
.form-group { margin-bottom:16px; }
.form-label { display:block; font-size:0.82rem; font-weight:600; margin-bottom:5px; color:var(--text); }
.form-control {
  width:100%; padding:9px 12px; border:1px solid var(--border); border-radius:6px;
  font-size:0.88rem; color:var(--text); background:var(--surface);
  transition:border-color .15s;
}
.form-control:focus { outline:none; border-color:var(--primary-lt); }
select.form-control { cursor:pointer; }

/* ── Modal ── */
.modal-overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:500; align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--surface); border-radius:12px; padding:28px;
  width:90%; max-width:480px; box-shadow:0 20px 60px rgba(0,0,0,.2);
  max-height:90vh; overflow-y:auto;
}
.modal-title { font-size:1.05rem; font-weight:700; color:var(--primary); margin-bottom:18px; }
.modal-footer { display:flex; gap:10px; justify-content:flex-end; margin-top:20px; }

/* ── Sección solicitar turno ── */
.ticket-card {
  background:var(--surface); border-radius:14px; padding:32px;
  max-width:480px; margin:0 auto; text-align:center;
  box-shadow:0 4px 20px rgba(0,0,0,.08); border:1px solid var(--border);
}
.ticket-numero {
  font-size:4rem; font-weight:900; color:var(--primary); letter-spacing:.05em;
  margin:12px 0;
}
.ticket-posicion { font-size:1rem; color:var(--text-muted); margin-bottom:8px; }
.ticket-modulo {
  display:inline-block; font-size:0.9rem; font-weight:700; color:#fff;
  padding:6px 16px; border-radius:20px; margin-top:8px;
}

/* ── Operador: panel cola ── */
.cola-panel {
  background:var(--surface); border-radius:10px; border:1px solid var(--border);
  overflow:hidden;
}
.cola-header {
  background:var(--primary); color:#fff; padding:14px 20px;
  display:flex; align-items:center; justify-content:space-between;
}
.cola-header h3 { font-size:0.95rem; font-weight:700; }
.btn-llamar {
  background:var(--accent); color:#fff; border:none; border-radius:6px;
  padding:8px 18px; font-weight:700; font-size:0.88rem; cursor:pointer;
  transition:background .15s;
}
.btn-llamar:hover { background:#d97706; }
.turno-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 20px; border-bottom:1px solid var(--border);
}
.turno-row:last-child { border-bottom:none; }
.turno-num-big { font-size:1.4rem; font-weight:800; color:var(--primary); }
.turno-info { font-size:0.8rem; color:var(--text-muted); }

/* ── Timer ── */
.timer-display {
  background:#eff6ff; border:1px solid #bfdbfe; border-radius:8px;
  padding:10px 18px; text-align:center; margin-bottom:16px;
}
.timer-display .timer-val { font-size:1.6rem; font-weight:800; color:var(--primary-lt); }
.timer-display .timer-lbl { font-size:0.72rem; color:var(--text-muted); }

/* ── Secciones ── */
.section { display:none; }
.section.active { display:block; }

/* ── Hamburguesa ── */
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:4px; }
.sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:150; }

/* ── Login ── */
.login-body {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--primary) 0%, #0f2540 100%);
}
.login-card {
  background:#fff; border-radius:12px; padding:36px; width:360px;
  box-shadow:0 8px 32px rgba(0,0,0,.2);
}
.login-logo { text-align:center; margin-bottom:24px; }
.login-logo h1 { font-size:1.3rem; font-weight:800; color:var(--primary); }
.login-logo p  { font-size:0.8rem; color:var(--text-muted); margin-top:4px; }
.btn-login { width:100%; background:var(--primary); color:#fff; border:none; border-radius:6px; padding:11px; font-size:0.95rem; font-weight:700; cursor:pointer; transition:background .15s; }
.btn-login:hover { background:var(--primary-lt); }

/* ── Responsive ── */
@media (max-width:768px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); }
  .sidebar-overlay { display:block; opacity:0; pointer-events:none; transition:opacity .25s; }
  .sidebar-overlay.open { opacity:1; pointer-events:all; }
  .main { margin-left:0; }
  .hamburger { display:flex; }
  .topbar { padding:10px 16px; }
  .page-content { padding:16px; }
  .modulo-cards { grid-template-columns:1fr; }
  .cards-row { flex-direction:column; }
}
