/* ============================================================
   Horario del Equipo — estilos (paleta navy/azul/rojo, claro+oscuro)
   ============================================================ */
:root {
  --bg:#eef1f5; --surface:#ffffff; --surface-2:#f8fafc;
  --header-bg:#0f1e36; --header-text:#e9eef6; --header-muted:#9fb0c9;
  --text:#1b2a44; --text-muted:#64748b; --border:#e3e8ef;
  --primary:#2563eb; --primary-hover:#1d4ed8;
  --danger:#e11d48; --danger-hover:#be123c;
  --ring:rgba(37,99,235,.35);
  --shadow:0 1px 2px rgba(16,24,40,.06), 0 1px 3px rgba(16,24,40,.10);
  --c-blue:#2563eb; --c-green:#10b981; --c-gray:#64748b;
  --c-purple:#8b5cf6; --c-amber:#f59e0b; --c-red:#e11d48;
}
body.dark {
  --bg:#0b1220; --surface:#121c30; --surface-2:#0f1828;
  --header-bg:#0a1322; --header-text:#e6edf7; --header-muted:#8aa0c0;
  --text:#e6edf7; --text-muted:#93a4bd; --border:#233148;
  --primary:#3b82f6; --primary-hover:#60a5fa;
  --danger:#f43f5e; --danger-hover:#fb7185;
  --ring:rgba(59,130,246,.4);
  --shadow:0 1px 2px rgba(0,0,0,.45);
  --c-blue:#3b82f6; --c-green:#34d399; --c-gray:#94a3b8;
  --c-purple:#a78bfa; --c-amber:#fbbf24; --c-red:#fb7185;
}

* { box-sizing:border-box; }
html,body { margin:0; padding:0; }
body {
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--text); transition:background .2s,color .2s;
}
a { color:var(--primary); }

/* Header */
.topbar { background:var(--header-bg); color:var(--header-text); display:flex; align-items:center;
  gap:24px; padding:0 24px; height:60px; position:sticky; top:0; z-index:40; }
.brand { font-weight:700; font-size:18px; white-space:nowrap; }
.nav { display:flex; gap:6px; flex:1; }
.nav a { color:var(--header-muted); text-decoration:none; font-size:14px; padding:8px 12px;
  border-radius:8px; transition:all .15s; }
.nav a:hover { color:var(--header-text); background:rgba(255,255,255,.06); }
.nav a.active { color:#fff; background:var(--primary); }
.topbar .right { display:flex; align-items:center; gap:16px; white-space:nowrap; }
.user { font-size:14px; }
.user .muted { color:var(--header-muted); }
.link-muted { color:var(--header-muted); font-size:14px; text-decoration:none; cursor:pointer; }
.link-muted:hover { color:#fff; }
.toggle { display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  color:var(--header-text); border-radius:999px; padding:6px 12px; font-size:13px; }
.toggle .dot { width:9px; height:9px; border-radius:50%; background:var(--c-green); }

/* Layout */
.wrap { max-width:1320px; margin:0 auto; padding:24px; }
.page-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px;
  flex-wrap:wrap; margin-bottom:20px; }
h1 { font-size:28px; margin:0 0 2px; }
h2 { font-size:18px; margin:0; }
.sub { color:var(--text-muted); font-size:13px; }
.actions { display:flex; gap:8px; flex-wrap:wrap; }

/* Buttons */
.btn { font-size:14px; font-weight:600; border-radius:8px; padding:9px 14px; border:1px solid var(--border);
  background:var(--surface); color:var(--text); cursor:pointer; transition:all .15s; box-shadow:var(--shadow);
  text-decoration:none; display:inline-block; }
.btn:hover { border-color:var(--primary); }
.btn-primary { background:var(--primary); border-color:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--primary-hover); border-color:var(--primary-hover); }
.btn-danger { background:var(--danger); border-color:var(--danger); color:#fff; }
.btn-danger:hover { background:var(--danger-hover); }
.btn-sm { padding:6px 10px; font-size:13px; }

/* Stat cards */
.stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; margin-bottom:20px; }
.stat { background:var(--surface); border:1px solid var(--border); border-left:5px solid var(--c-blue);
  border-radius:12px; padding:16px 18px; box-shadow:var(--shadow); }
.stat .lbl { font-size:11px; letter-spacing:.6px; text-transform:uppercase; color:var(--text-muted); }
.stat .val { font-size:30px; font-weight:700; margin-top:4px; }
.stat.blue{border-left-color:var(--c-blue);} .stat.green{border-left-color:var(--c-green);}
.stat.gray{border-left-color:var(--c-gray);} .stat.purple{border-left-color:var(--c-purple);}
.stat.amber{border-left-color:var(--c-amber);} .stat.red{border-left-color:var(--c-red);}

/* Card */
.card { background:var(--surface); border:1px solid var(--border); border-radius:12px;
  box-shadow:var(--shadow); margin-bottom:20px; }
.card-pad { padding:20px; }
.card-head { display:flex; align-items:center; justify-content:space-between; padding:16px 20px;
  border-bottom:1px solid var(--border); }

/* Forms */
label { font-size:13px; font-weight:600; color:var(--text); }
.field label { display:block; margin-bottom:6px; }
select, input[type="text"], input[type="email"], input[type="password"], input[type="time"], input[type="date"], input[type="file"] {
  width:100%; height:40px; padding:0 12px; font-size:14px; border-radius:8px;
  border:1px solid var(--border); background:var(--surface-2); color:var(--text); }
input[type="file"] { padding:8px; height:auto; }
select:focus, input:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px var(--ring); }
.filters { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:16px; }
.week-nav { display:flex; align-items:center; gap:10px; }
.week-nav .lbl { font-weight:600; min-width:150px; text-align:center; }
.week-nav .btn { width:40px; height:40px; padding:0; font-size:18px; line-height:1; }
.filter-foot { display:flex; gap:8px; align-items:center; margin-top:16px; flex-wrap:wrap; }
.filter-foot input[type="text"] { max-width:220px; }

/* Table */
.table-scroll { overflow-x:auto; }
table.sched, table.data { width:100%; border-collapse:collapse; font-size:13px; }
table.sched th, table.sched td, table.data th, table.data td { padding:10px 12px; text-align:left;
  border-bottom:1px solid var(--border); }
table.sched thead th, table.data thead th { font-size:11px; letter-spacing:.5px; text-transform:uppercase;
  color:var(--text-muted); background:var(--surface-2); }
table.sched th.day, table.sched td.day { text-align:center; min-width:108px; }
td.day.editable { cursor:pointer; }
td.day.editable:hover { background:var(--surface-2); outline:2px solid var(--ring); outline-offset:-2px; }
table.sched th.today, table.sched td.today { background:rgba(37,99,235,.07); }
body.dark table.sched th.today, body.dark table.sched td.today { background:rgba(59,130,246,.12); }
td.total { text-align:center; font-weight:700; }
tbody tr:hover { background:var(--surface-2); }

.agent { display:flex; align-items:center; gap:10px; }
.avatar { width:34px; height:34px; border-radius:50%; background:rgba(37,99,235,.14); color:var(--primary);
  display:flex; align-items:center; justify-content:center; font-weight:700; font-size:12px; flex-shrink:0; }
.agent .nm { font-weight:600; }
.role { display:inline-block; font-size:12px; padding:3px 9px; border-radius:999px;
  background:var(--surface-2); border:1px solid var(--border); color:var(--text-muted); }
.shift { font-weight:600; }
.shift .tag { display:block; font-size:10px; font-weight:500; color:var(--text-muted);
  letter-spacing:.4px; text-transform:uppercase; }

/* Status badges */
.badge { display:inline-block; padding:5px 10px; border-radius:8px; font-size:12px; font-weight:600; }
.st-WORK { color:var(--text); }
.st-DESCANSO { background:#eef1f5; color:#475569; }
.st-VACACIONES { background:#ece9fd; color:#5b21b6; }
.st-SICK { background:#fef0d9; color:#b45309; }
.st-HOLIDAY { background:#dcfce7; color:#15803d; }
.st-NO_SHOW { background:#fde2e7; color:#be123c; }
body.dark .st-DESCANSO { background:#1c2840; color:#aab9d4; }
body.dark .st-VACACIONES { background:#2a2350; color:#c4b5fd; }
body.dark .st-SICK { background:#3a2a0c; color:#fbbf24; }
body.dark .st-HOLIDAY { background:#0e3a22; color:#86efac; }
body.dark .st-NO_SHOW { background:#3c1620; color:#fb7185; }

/* Legend */
.legend { display:flex; flex-wrap:wrap; gap:18px; }
.legend .item { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-muted); }
.legend .sw { width:16px; height:16px; border-radius:5px; }

/* Pill / chips */
.pill { display:inline-block; font-size:12px; font-weight:600; padding:3px 10px; border-radius:999px; }
.pill.ok { background:#dcfce7; color:#15803d; }
.pill.off { background:#fde2e7; color:#be123c; }
body.dark .pill.ok { background:#0e3a22; color:#86efac; }
body.dark .pill.off { background:#3c1620; color:#fb7185; }

/* Popover (editor de celda) */
.pop { position:absolute; z-index:60; width:250px; background:var(--surface); border:1px solid var(--border);
  border-radius:12px; box-shadow:0 8px 28px rgba(0,0,0,.18); padding:14px; }
.pop h4 { margin:0 0 10px; font-size:14px; }
.pop .row { margin-bottom:10px; }
.pop .grid2 { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.pop .pop-foot { display:flex; gap:8px; justify-content:flex-end; margin-top:6px; }

/* Toast */
#toast { position:fixed; right:24px; bottom:24px; z-index:80; display:flex; flex-direction:column; gap:10px; }
.toast { background:var(--surface); border:1px solid var(--border); border-left:4px solid var(--primary);
  border-radius:10px; box-shadow:0 8px 28px rgba(0,0,0,.18); padding:12px 16px; max-width:380px;
  font-size:13px; animation:slidein .2s ease; }
.toast.err { border-left-color:var(--danger); }
@keyframes slidein { from { transform:translateY(8px); opacity:0; } to { transform:none; opacity:1; } }

/* Flash messages */
.flash { padding:12px 16px; border-radius:10px; margin-bottom:14px; font-size:14px; border:1px solid var(--border); }
.flash.ok { background:#dcfce7; color:#15803d; border-color:#bbf7d0; }
.flash.error { background:#fde2e7; color:#be123c; border-color:#fbcfe0; }
body.dark .flash.ok { background:#0e3a22; color:#86efac; border-color:#14532d; }
body.dark .flash.error { background:#3c1620; color:#fb7185; border-color:#7f1d1d; }

/* Auth */
.auth-wrap { min-height:calc(100vh - 60px); display:flex; align-items:center; justify-content:center; padding:24px; }
.auth-card { width:100%; max-width:420px; }
.auth-card .card-pad { padding:28px; }
.muted { color:var(--text-muted); }
.foot-note { text-align:center; color:var(--text-muted); font-size:12px; padding:8px 0 24px; }
.mt { margin-top:16px; } .mb { margin-bottom:16px; }
.dev-user { display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 0; border-bottom:1px solid var(--border); }
