:root{--bg:#0f172a;--panel:#111827;--text:#e5e7eb;--muted:#9ca3af;--primary:#2563eb;--danger:#ef4444;--ok:#16a34a;--border:#1f2937}
body.theme-light{--bg:#f6f7fb;--panel:#ffffff;--text:#111827;--muted:#6b7280;--primary:#2563eb;--danger:#dc2626;--ok:#16a34a;--border:#e5e7eb}
body.theme-ocean{--bg:#0d1b1e;--panel:#102a30;--text:#e5e7eb;--muted:#9ca3af;--primary:#0ea5a5;--danger:#ef4444;--ok:#16a34a;--border:#1f3a40}
body.theme-forest{--bg:#0f1f17;--panel:#132a1f;--text:#e5e7eb;--muted:#9ca3af;--primary:#22c55e;--danger:#ef4444;--ok:#16a34a;--border:#1b3327}
body.theme-rose{--bg:#1a0f15;--panel:#22121b;--text:#e5e7eb;--muted:#9ca3af;--primary:#e11d48;--danger:#ef4444;--ok:#16a34a;--border:#2a1a23}
body.theme-sunset{--bg:#1f1a0f;--panel:#2a2213;--text:#e5e7eb;--muted:#9ca3af;--primary:#f59e0b;--danger:#ef4444;--ok:#16a34a;--border:#3a2f19}
body.theme-lavanda{--bg:#171629;--panel:#1d1b35;--text:#e5e7eb;--muted:#9ca3af;--primary:#8b5cf6;--danger:#ef4444;--ok:#16a34a;--border:#2a2749}
body.theme-neon{--bg:#0a0f0a;--panel:#0f1a0f;--text:#e5e7eb;--muted:#9ca3af;--primary:#a3e635;--danger:#ef4444;--ok:#16a34a;--border:#193019}
body.theme-ocean-light{--bg:#e6fbfb;--panel:#ffffff;--text:#0f172a;--muted:#475569;--primary:#0ea5a5;--danger:#dc2626;--ok:#16a34a;--border:#dbeafe}
body.theme-forest-light{--bg:#ecfdf5;--panel:#ffffff;--text:#0f172a;--muted:#475569;--primary:#22c55e;--danger:#dc2626;--ok:#16a34a;--border:#d1fae5}
body.theme-rose-light{--bg:#fff1f2;--panel:#ffffff;--text:#0f172a;--muted:#475569;--primary:#e11d48;--danger:#dc2626;--ok:#16a34a;--border:#ffe4e6}
body.theme-sunset-light{--bg:#fff7ed;--panel:#ffffff;--text:#0f172a;--muted:#475569;--primary:#f59e0b;--danger:#dc2626;--ok:#16a34a;--border:#ffedd5}
body.theme-lavanda-light{--bg:#f5f3ff;--panel:#ffffff;--text:#0f172a;--muted:#475569;--primary:#8b5cf6;--danger:#dc2626;--ok:#16a34a;--border:#ede9fe}
body.theme-neon-light{--bg:#f7fee7;--panel:#ffffff;--text:#0f172a;--muted:#475569;--primary:#a3e635;--danger:#dc2626;--ok:#16a34a;--border:#d9f99d}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}
header{padding:16px 24px;border-bottom:1px solid var(--border)}
.header-top{display:flex;align-items:center;gap:12px;justify-content:space-between}
.header-top{position:relative}
h1+ .tabs{flex:1}
.header-top .tabs{margin-top:0;justify-content:center}
h1{margin:0;font-size:45px}
.header-top h1 .logo-inline{height:55px;width:auto;margin-right:4px;vertical-align:middle}
.header-top h1 .logo-caption{font-size:10px;line-height:12px;color:var(--muted)}
.title-lg{font-size:25px;margin:0 0 6px}
.subtitle{color:var(--muted);font-size:14px;margin-bottom:8px}
body.theme-light .subtitle,
body.theme-ocean-light .subtitle,
body.theme-forest-light .subtitle,
body.theme-rose-light .subtitle,
body.theme-sunset-light .subtitle,
body.theme-lavanda-light .subtitle,
body.theme-neon-light .subtitle{color:var(--primary);font-weight:600}
.list-section .consulta-banner{font-size:29px;font-weight:700;text-align:center;margin:4px 0 8px;color:var(--text)}
.list-section[data-content="citas"] .consulta-banner{margin:4px 0 16px}
.list-section[data-content="consulta"] .consulta-banner{margin:4px 0 24px}
.list-section[data-content="consulta"] .title-lg{margin-top:5px;font-size:18px}
.list-section[data-content="consulta"] .title-lg{text-align:center}
.list-section[data-content="consulta"]> .field label{text-align:center;display:block}
.list-section[data-content="consulta"]> .field input{width:200px;margin:0 auto;text-align:center}
.tabs{margin-top:8px;display:flex;gap:8px}
.subtabs{margin-top:8px;display:flex;gap:8px;justify-content:flex-start}
.tab{background:#1f2937;color:#e5e7eb;border:none;border-radius:4px;padding:6px 10px;cursor:pointer;font-size:14px;transition:background .15s ease,box-shadow .15s ease}
.subtab{background:#1f2937;color:#e5e7eb;border:none;border-radius:4px;padding:6px 10px;cursor:pointer;font-size:13px;transition:background .15s ease,box-shadow .15s ease}
.tab:hover{background:#243042}
.subtab:hover{background:#243042}
.tab.active{background:var(--primary);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.subtab.active{background:var(--primary);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
main{max-width:1000px;margin:24px auto;padding:0 16px;display:grid;gap:24px}
.form-section,.list-section{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px;box-shadow:0 6px 20px rgba(0,0,0,.25)}
.grid-2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;align-items:start}
.config-content[data-config-content="ajustes"] .grid-2{grid-template-columns:minmax(0,1fr) max-content}
.grid-2 > *{min-width:0;position:relative;overflow:hidden}
.grid-2 > *:first-child{z-index:2}
.grid-3{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:8px;align-items:center}
.grid-4{display:grid;grid-template-columns:minmax(0,1fr) repeat(3,minmax(0,1fr)) auto;gap:8px;align-items:center}
.calendar-assign{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:8px}
.row{display:flex;gap:8px}
.field{display:grid;gap:8px;margin-bottom:12px}
label{font-size:14px;color:var(--muted)}
input,textarea,select{width:100%;padding:8px 10px;background:#0b1220;color:var(--text);border:1px solid var(--border);border-radius:8px;transition:border-color .15s ease,box-shadow .15s ease}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(37,99,235,.25)}
.theme-swatch{width:24px;height:24px;border-radius:6px;border:1px solid var(--border);background-image:linear-gradient(135deg,var(--panel) 0%,var(--primary) 100%);display:inline-block;margin-left:8px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.chip{display:inline-flex;align-items:center;gap:6px;background:#1f2937;color:#e5e7eb;border-radius:999px;padding:5px 8px;font-size:13px}
.chip button{background:transparent;color:#e5e7eb;border:none;cursor:pointer}
.availability{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.availability .day{display:grid;grid-template-columns:120px minmax(120px,1fr) minmax(120px,1fr) minmax(100px,1fr);gap:8px;align-items:center}
.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.list-section[data-content="citas"] .actions.controls{display:grid;grid-template-columns:1fr;align-items:center}
.list-section[data-content="citas"] .actions.controls .center-controls{display:flex;justify-content:center;gap:10px}
/* Agendado: centrar bloque prev/rango/next */
.list-section[data-content="consulta"] .actions.controls{display:grid;grid-template-columns:1fr;align-items:center}
.list-section[data-content="consulta"] .actions.controls .center-controls{display:flex;flex-direction:column;align-items:center;gap:8px}
.list-section[data-content="consulta"] .actions.controls .center-controls .center-row{display:flex;justify-content:center;gap:10px}
.list-section[data-content="consulta"] .actions.controls .misc-controls{display:flex;justify-content:flex-end;gap:8px}
/* Forzar que "Ver mis reservas" quede bajo el rango y centrado */
.list-section[data-content="consulta"] #consulta-mis{flex-basis:100%;width:max-content;margin:6px auto 0}
/* Select de Zona en esquina superior izquierda del panel Citas */
.list-section[data-content="citas"]{position:relative}
.list-section[data-content="citas"] .zone-top-left{position:absolute;top:8px;left:16px;z-index:1;display:flex;align-items:center}
/* Selector compacto para filtro de zona en Citas */
#citas-zona-select{width:90px;min-width:90px;padding:4px 6px;font-size:11px;white-space:nowrap}
.actions .dow-item{display:flex;flex-direction:column-reverse;align-items:center;gap:2px}
.actions .dow-item input{appearance:none;-webkit-appearance:none;width:14px;height:14px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;margin:0}
.actions .dow-item input:checked{box-shadow: inset 0 0 0 6px #fff}
.actions .dow-item .dow-letter{font-weight:600;color:var(--muted);font-size:10px;line-height:1}
.actions .range{margin-left:0;font-weight:700;border:1px solid var(--border);background:#0b1220;padding:6px 10px;border-radius:6px}
.user-badge{margin-left:auto;border:1px solid var(--border);background:#0b1220;padding:6px 10px;border-radius:4px;color:var(--muted);font-weight:600;font-size:12px;text-align:center}
.user-badge .user-sep{text-align:center;display:block;margin:2px 0}
.overlay{position:fixed;inset:0;background:#000;display:flex;align-items:center;justify-content:center;z-index:9999}
.overlay[hidden]{display:none!important}
.overlay .panel{min-width:360px;max-width:420px;background:transparent;border:none;box-shadow:none;color:#fff}
.overlay .panel .brand{font-size:28px;font-weight:800;letter-spacing:.5px;text-align:center;margin-bottom:16px;color:#fff}
.overlay .panel .brand-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px;margin-top:-20px}
.overlay .panel .brand-logo{height:50px;width:auto}
.overlay .panel .brand-text{font-size:38px;font-weight:800;letter-spacing:.5px;color:#fff}
.overlay .panel .field label{color:#ddd}
.overlay .panel .field input{background:#111;border:1px solid #333;color:#fff}
button{appearance:none;border:none;border-radius:4px;padding:8px 12px;background:var(--primary);color:white;font-weight:600;cursor:pointer;font-size:14px;transition:background .15s ease,transform .05s ease}
button:hover{background:#1d4ed8}
button:active{transform:translateY(1px)}
.secondary{background:#374151}
.secondary:hover{background:#415062}
button.danger{background:var(--danger)}
button.danger:hover{background:#dc2626}
button.ok{background:var(--ok)}
button.ok:hover{background:#15803d}
/* Tamaños */
.btn-sm{padding:6px 10px;font-size:13px;border-radius:4px}
.btn-xs{padding:3px 6px;font-size:11px;border-radius:4px}
.btn-lg{padding:12px 16px;font-size:15px;border-radius:4px}
.tab.btn-sm{padding:8px 14px;font-size:18px}
.toolbar{display:flex;justify-content:flex-end;margin-bottom:12px}
.tabla{width:100%;border-collapse:collapse;table-layout:fixed}
.tabla th,.tabla td{border-top:1px solid var(--border);padding:8px;text-align:left;word-break:break-word;overflow-wrap:anywhere}
.tabla thead th{color:var(--muted);font-weight:600;border-top:none;background:#0b1220}
.tabla tbody tr:nth-child(odd){background:#0c1627}
.tabla tbody tr:hover{background:#0e1b31}
.tabla tr.selected{background:#0f2a1a;color:#a7f3d0}
.tabla td a{color:#f59e0b;font-weight:600;text-decoration:underline}
.tabla td a:hover{color:#fbbf24}
/* Config: acciones compactas y paralelas */
.config-content .tabla td:last-child{display:flex;gap:6px}
.config-content .tabla td:last-child button{flex:1}
.config-content button{border-radius:4px}
.config-content .actions button{padding:3px 6px;font-size:11px;border-radius:4px}
.config-content[data-config-content="ajustes"] .field label{display:flex;align-items:center;gap:1ch;justify-content:flex-start;white-space:nowrap}
.config-content[data-config-content="ajustes"] .field label input[type="checkbox"]{margin:0;width:auto;display:inline-block;flex:0 0 auto;box-shadow:none;border:none;outline:none}
.config-content[data-config-content="ajustes"] .field label input[type="checkbox"]:focus{box-shadow:none}
/* Light theme specifics */
body.theme-light .tabla thead th{background:#f9fafb}
body.theme-light .calendar-cell.tech{background:#f9fafb}
body.theme-light .calendar-cell.unavailable{background:#ffffff;color:#6b7280}
footer{padding:16px;text-align:center;color:var(--muted)}
.toasts{position:fixed;right:16px;bottom:16px;display:grid;gap:8px;z-index:9999}
.toast{background:#111827;color:#e5e7eb;border:1px solid var(--border);border-radius:8px;padding:10px 12px;min-width:240px;box-shadow:0 8px 24px rgba(0,0,0,.35);animation:toastIn .2s ease}
.toast.success{border-color:var(--ok)}
.toast.error{border-color:var(--danger)}
.toast.info{border-color:var(--primary)}
@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.invalid{border-color:#ef4444}
.calendar{margin-top:12px;border:1px solid var(--border);border-radius:10px;overflow:auto}
.calendar-grid{display:grid;grid-template-columns:200px repeat(var(--cols),minmax(110px,1fr));margin:0 auto}
.calendar-header{display:contents}
.calendar-row{display:contents}
.calendar-cell{border-top:1px solid var(--border);border-left:1px solid var(--border);padding:6px;position:relative;transition:background-color .25s ease,color .25s ease,opacity .2s ease}
.calendar-cell.tech{position:sticky;left:0;background:#0b1220;font-weight:600}
.calendar-cell.available{background:#0f1b33}
.list-section[data-content="citas"] .calendar-cell.available{color:var(--muted)}
.calendar-cell.pending{background:#facc15;color:#111}
.calendar-cell.unavailable{background:#0b1220;color:#6b7280}
.calendar-cell.available{cursor:pointer}
.calendar-cell.available:hover{outline:2px solid var(--primary)}
.calendar-cell.readonly{cursor:default}
.calendar-cell.readonly:hover{outline:none}
.list-section[data-content="citas"] .calendar-cell{background:#000}
.list-section[data-content="citas"] .calendar-cell.reserved{background:#2a0f14;color:#fca5a5}
.list-section[data-content="citas"] .calendar-cell.reserved.selected{background:var(--ok);color:#fff}
.list-section[data-content="consulta"] .calendar-cell{background:#000}
.list-section[data-content="consulta"] .calendar-cell.available{background:#000}
.list-section[data-content="consulta"] .calendar-cell.unavailable{background:#000;color:#6b7280}
.list-section[data-content="consulta"] .subtitle{text-align:center}
.list-section[data-content="consulta"] .actions #consulta-mis{margin-left:auto}
.list-section[data-content="config"] .field input,
.list-section[data-content="config"] .field select,
.list-section[data-content="config"] .field textarea{width:240px}
.config-content[data-config-content="usuarios"] .grid-2{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
.config-content[data-config-content="usuarios"] .grid-2{grid-template-columns:minmax(0,240px) minmax(0,1fr);gap:8px}
.config-content[data-config-content="usuarios"] .grid-2 > div:first-child{max-width:240px}
.config-content[data-config-content="usuarios"] .grid-2 > div:last-child{display:block;max-width:100%}
.config-content[data-config-content="usuarios"] .actions{justify-content:flex-start}
.config-content[data-config-content="usuarios"] .tabla{font-size:14px}
/* Usuarios: fila única en tabla */
.config-content[data-config-content="usuarios"] .tabla th,
.config-content[data-config-content="usuarios"] .tabla td{white-space:nowrap;word-break:normal;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis;padding:6px 8px}
.config-content[data-config-content="usuarios"] .tabla th:nth-child(4),
.config-content[data-config-content="usuarios"] .tabla td:nth-child(4){width:96px}
.config-content[data-config-content="usuarios"] .tabla th:nth-child(5),
.config-content[data-config-content="usuarios"] .tabla td:nth-child(5){width:220px}
.config-content[data-config-content="zonas"] .actions{justify-content:flex-start}
.config-content[data-config-content="zonas"] .grid-2{grid-template-columns:minmax(0,240px) minmax(0,1fr);gap:8px}
.config-content[data-config-content="zonas"] .grid-2 > div:first-child{max-width:240px}
.config-content[data-config-content="zonas"] .grid-2 > div:last-child{display:block;max-width:100%}
.config-content[data-config-content="zonas"] .tabla{font-size:14px}
.config-content[data-config-content="zonas"] .tabla th,
.config-content[data-config-content="zonas"] .tabla td{white-space:nowrap;word-break:normal;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis;padding:6px 8px}
.config-content[data-config-content="zonas"] .tabla th:nth-child(3),
.config-content[data-config-content="zonas"] .tabla td:nth-child(3){width:180px}
.config-content[data-config-content="tecnicos"] .actions{justify-content:flex-start}
.config-content[data-config-content="tecnicos"] .grid-2{grid-template-columns:minmax(0,240px) minmax(0,1fr);gap:8px}
.config-content[data-config-content="tecnicos"] .grid-2 > div:first-child{max-width:240px}
.config-content[data-config-content="tecnicos"] .grid-2 > div:last-child{display:block;max-width:100%}
.config-content[data-config-content="tecnicos"] .tabla{font-size:14px}
.config-content[data-config-content="tecnicos"] .tabla th,
.config-content[data-config-content="tecnicos"] .tabla td{white-space:nowrap;word-break:normal;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis;padding:6px 8px}
.config-content[data-config-content="tecnicos"] .tabla th:nth-child(5),
.config-content[data-config-content="tecnicos"] .tabla td:nth-child(5){width:180px}
.config-content[data-config-content="agentes"] .actions{justify-content:flex-start}
.config-content[data-config-content="agentes"] .grid-2{grid-template-columns:minmax(0,240px) minmax(0,1fr);gap:8px}
.config-content[data-config-content="agentes"] .grid-2 > div:first-child{max-width:240px}
.config-content[data-config-content="agentes"] .grid-2 > div:last-child{display:block;max-width:100%}
.config-content[data-config-content="agentes"] .tabla{font-size:14px}
.config-content[data-config-content="agentes"] .tabla th,
.config-content[data-config-content="agentes"] .tabla td{white-space:nowrap;word-break:normal;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis;padding:6px 8px}
.config-content[data-config-content="agentes"] .tabla th:nth-child(3),
.config-content[data-config-content="agentes"] .tabla td:nth-child(3){width:180px}
.config-content[data-config-content="ajustes"] .actions{justify-content:flex-start}
.config-content[data-config-content="ajustes"] #agendado-start-offset.ag-start-plus{padding-left:18px;background-repeat:no-repeat;background-position:6px center;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16'><text x='8' y='12' font-family='Arial' font-size='14' fill='%239ca3af' text-anchor='middle'>+</text></svg>");}
.legend{display:flex;gap:16px;align-items:center;margin-top:8px}
.legend-item{display:inline-flex;gap:6px;align-items:center;color:var(--muted)}
.swatch{width:14px;height:14px;border-radius:3px;border:1px solid #1f2937;display:inline-block}
.swatch.available{background:#0f1b33}
.swatch.reserved{background:#2a0f14;border-color:#7f1d1d}
.swatch.unavailable{background:#0b1220}
.calendar-cell.reserved{background:#2a0f14;color:#fca5a5}
.calendar-cell.cancelled{background:#5a1e1e;color:#93c5fd}
.list-section[data-content="citas"] .calendar-cell.cancelled{color:#93c5fd!important}
.calendar-cell.reserved a.dorus-link{color:#facc15;text-decoration:underline}
.calendar-cell.reserved.selected{background:var(--ok);color:#111}
.calendar-cell .cell-badge{position:absolute;right:4px;bottom:4px;font-size:10px;font-weight:700;color:#facc15}
/* Rango de semana en Consulta */
.range{margin-top:6px;color:var(--muted)}
/* Semana: agrega columna Hora y usa var(--cols) para días */
.week .calendar-grid{grid-template-columns:200px 120px repeat(var(--cols),minmax(120px,1fr));}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.config-content[data-config-content="logs"] #logs-download, .config-content[data-config-content="logs"] #logs-download:visited, .config-content[data-config-content="logs"] #logs-download:hover, .config-content[data-config-content="logs"] #logs-download:focus{color:#fff !important}
.manual-link{color:#ffeb3b !important;font-weight:600}
.manual-link:visited,.manual-link:hover,.manual-link:focus{color:#ffeb3b !important}
#cal-builder .calendar-cell{font-size:11px}
#cal-preview .calendar-cell{font-size:11px}
#cal-builder .calendar-grid{grid-template-columns:max-content repeat(var(--cols),max-content);}
#cal-preview .calendar-grid{grid-template-columns:max-content repeat(var(--cols),max-content);}
#cal-builder .calendar-cell{padding:4px}
