/* xdinamic — design system del prototipo (Outfit + IBM Plex Mono + dark/light/auto)
   Generado a partir de rrhh_v2.html. Tema oscuro por defecto.
   Variables: --bg, --surface, --text, --accent, --danger, --success, etc. */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{--font:'Outfit',-apple-system,sans-serif;--mono:'IBM Plex Mono',monospace;--radius:8px;--radius-lg:12px;--transition:150ms cubic-bezier(.4,0,.2,1)}
[data-theme="dark"]{--bg:#09090b;--surface:#121215;--surface-2:#1a1a1e;--surface-3:#232328;--surface-hover:#28282e;--border:#27272a;--border-light:#333338;--text:#fafafa;--text-secondary:#a1a1aa;--text-muted:#63636e;--accent:#3b82f6;--accent-hover:#2563eb;--accent-bg:rgba(59,130,246,.08);--accent-bg-hover:rgba(59,130,246,.14);--accent-border:rgba(59,130,246,.25);--accent-text:#60a5fa;--danger:#ef4444;--danger-bg:rgba(239,68,68,.08);--danger-border:rgba(239,68,68,.2);--warning:#f59e0b;--success:#10b981;--success-bg:rgba(16,185,129,.08);--success-border:rgba(16,185,129,.25);--info:#8b5cf6;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow:0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 12px 48px rgba(0,0,0,.55);--modal-backdrop:rgba(0,0,0,.65);--input-bg:var(--surface-2);--scrollbar-thumb:#333;--scrollbar-hover:#555}
[data-theme="light"]{--bg:#f8f9fa;--surface:#fff;--surface-2:#f1f3f5;--surface-3:#e9ecef;--surface-hover:#dee2e6;--border:#dee2e6;--border-light:#ced4da;--text:#212529;--text-secondary:#495057;--text-muted:#868e96;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-bg:rgba(37,99,235,.06);--accent-bg-hover:rgba(37,99,235,.12);--accent-border:rgba(37,99,235,.2);--accent-text:#2563eb;--danger:#e03131;--danger-bg:rgba(224,49,49,.06);--danger-border:rgba(224,49,49,.15);--warning:#e67700;--success:#0d9668;--success-bg:rgba(13,150,104,.06);--success-border:rgba(13,150,104,.2);--info:#7048e8;--shadow-sm:0 1px 2px rgba(0,0,0,.06);--shadow:0 2px 8px rgba(0,0,0,.08);--shadow-lg:0 12px 48px rgba(0,0,0,.12);--modal-backdrop:rgba(0,0,0,.35);--input-bg:#fff;--scrollbar-thumb:#ced4da;--scrollbar-hover:#adb5bd}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.55;min-height:100vh;-webkit-font-smoothing:antialiased;transition:background 250ms ease,color 250ms ease}
::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}
a{color:var(--accent-text);text-decoration:none}a:hover{text-decoration:underline}

/* Layout */
.app{display:flex;min-height:100vh}
.sidebar{width:250px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:background 250ms ease}
.sidebar-header{padding:20px;border-bottom:1px solid var(--border)}
.logo{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;letter-spacing:-.3px}
.dia-tipo{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s}.dia-tipo:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}
.logo-mark{width:34px;height:34px;background:var(--accent);border-radius:var(--radius);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px}.logo-text{font-size:1.5rem;font-weight:800;letter-spacing:-1.5px;color:var(--text);line-height:1}.logo-text .x{color:var(--accent)}.logo-text .com{font-weight:300;color:var(--text-muted);font-size:1rem;letter-spacing:-.5px}
.sidebar-nav{padding:12px 10px;flex:1;overflow-y:auto}
.nav-group-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:10px 12px 5px}
.nav-btn{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;background:none;border-radius:7px;cursor:pointer;font-family:var(--font);font-size:13px;color:var(--text-secondary);transition:all var(--transition);text-align:left}
.nav-btn:hover{background:var(--surface-2);color:var(--text)}
.nav-btn.active{background:var(--accent-bg);color:var(--accent-text)}
.nav-btn svg{width:18px;height:18px;flex-shrink:0;opacity:.65}
.nav-btn.active svg{opacity:1}
.nav-badge{margin-left:auto;background:var(--surface-3);color:var(--text-muted);font-size:11px;font-weight:500;padding:1px 8px;border-radius:10px;font-family:var(--mono)}
.nav-btn.active .nav-badge{background:var(--accent-border);color:var(--accent-text)}

/* DB Bar */
.db-bar{padding:10px 12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}
.db-info{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted)}
.db-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0}
.db-dot.warn{background:var(--warning)}.db-dot.off{background:var(--danger)}
.db-name{font-family:var(--mono);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}
.db-actions{display:flex;gap:4px;flex-wrap:wrap}
.db-btn{padding:4px 8px;border-radius:5px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-family:var(--font);font-size:11px;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:4px;white-space:nowrap}
.db-btn:hover{background:var(--surface-3);color:var(--text)}
.db-btn svg{width:12px;height:12px}

/* Theme */
.theme-switcher{display:flex;border-radius:6px;border:1px solid var(--border);overflow:hidden;margin:6px 0}
.theme-btn{flex:1;padding:6px 0;background:var(--surface-2);border:none;cursor:pointer;display:grid;place-items:center;color:var(--text-muted);transition:all var(--transition);font-size:0}
.theme-btn:not(:last-child){border-right:1px solid var(--border)}
.theme-btn:hover{background:var(--surface-3);color:var(--text)}
.theme-btn.active{background:var(--accent-bg);color:var(--accent-text)}
.theme-btn svg{width:16px;height:16px}

/* Main */
.main{flex:1;margin-left:250px;min-height:100vh}
.topbar{height:56px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;background:var(--surface);position:sticky;top:0;z-index:50}
.search-wrap{display:flex;align-items:center;gap:8px;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius);padding:0 12px;flex:1;max-width:420px}
.search-wrap:focus-within{border-color:var(--accent)}
.search-wrap svg{width:16px;height:16px;color:var(--text-muted);flex-shrink:0}
.search-wrap input{background:none;border:none;outline:none;color:var(--text);font-family:var(--font);font-size:13px;padding:8px 0;width:100%}
.search-wrap input::placeholder{color:var(--text-muted)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:7px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap;user-select:none}
.btn:hover{background:var(--surface-3);border-color:var(--border-light)}
.btn svg{width:15px;height:15px}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}
.btn-danger:hover{background:rgba(239,68,68,.14)}
.btn-success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-icon{padding:7px;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.btn-icon:hover{background:var(--surface-2);color:var(--text)}
.btn-icon svg{width:18px;height:18px}

/* Content */
.content{padding:24px}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.page-title{font-size:22px;font-weight:600;letter-spacing:-.5px}
.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:2px}

/* Stats */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}
.stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px}
.stat-value{font-size:28px;font-weight:700;letter-spacing:-1.5px;font-family:var(--mono)}

/* Card / Table */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.card-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;white-space:nowrap}
thead th:hover{color:var(--text-secondary)}
thead th.sorted{color:var(--accent-text)}
tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition);cursor:pointer}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--surface-hover)}
tbody td{padding:10px 16px;font-size:13px;vertical-align:top}

/* Dual-line employee row */
.emp-row-main{display:flex;align-items:center;gap:8px}
.emp-name{font-weight:500}
.emp-code{font-family:var(--mono);font-size:11px;color:var(--accent-text);background:var(--accent-bg);padding:1px 6px;border-radius:4px}
.emp-row-sub{font-size:11px;color:var(--text-muted);margin-top:3px;display:flex;gap:12px;flex-wrap:wrap}
.emp-row-sub span{display:inline-flex;align-items:center;gap:3px}
.emp-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500;font-family:var(--mono)}
.badge-activo{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}
.badge-baja{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}
.badge-inactivo{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border)}

/* Filter buttons */
.filter-bar{display:flex;gap:4px;margin-bottom:16px}
.filter-btn{padding:5px 14px;border-radius:20px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition)}
.filter-btn:hover{background:var(--surface-3)}
.filter-btn.active{background:var(--accent-bg);color:var(--accent-text);border-color:var(--accent-border)}

/* Tabs */
.tab-bar{display:flex;gap:2px;border-bottom:1px solid var(--border);padding:0 16px;overflow-x:auto}
.tab-btn{padding:10px 16px;border:none;background:none;font-family:var(--font);font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition);white-space:nowrap}
.tab-btn:hover{color:var(--text-secondary)}
.tab-btn.active{color:var(--accent-text);border-bottom-color:var(--accent)}
.tab-content{display:none;padding:20px}
.tab-content.active{display:block}

/* Info bar (per tab) */
.info-bar{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:8px 12px;margin-bottom:16px;font-size:12px;color:var(--text-muted)}
.info-bar .tbl-name{color:var(--accent-text);font-family:var(--mono);font-weight:500}

/* Form */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.fg-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}
.fi{display:flex;flex-direction:column;gap:4px}
.fi.full{grid-column:1/-1}
.fi label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.fi input,.fi textarea,.fi select{background:var(--input-bg);border:1px solid var(--border);border-radius:6px;padding:8px 12px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color var(--transition)}
.fi input:focus,.fi textarea:focus,.fi select:focus{border-color:var(--accent)}
.fi input[readonly],.fi input:disabled,.fi select:disabled,.fi textarea:disabled{background:var(--surface-3);color:var(--text-muted);cursor:not-allowed;border-color:var(--border);opacity:.8}
.fi textarea{min-height:80px;resize:vertical}

/* Checkboxes group */
.checkbox-group{display:flex;gap:20px;align-items:center;flex-wrap:wrap;padding-top:8px}
.checkbox-group label{font-size:12px;text-transform:none;letter-spacing:0;display:flex;align-items:center;gap:6px;cursor:pointer;color:var(--text-secondary)}
.checkbox-group input[type="checkbox"]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}

/* Separator before save */
.form-sep{border:none;border-top:1px solid var(--border);margin:16px 0 12px}

/* Modal */
.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--modal-backdrop);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:50px 20px;z-index:1000;opacity:0;visibility:hidden;transition:all 200ms ease;overflow-y:auto}
.overlay.open{opacity:1;visibility:visible}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:640px;box-shadow:var(--shadow-lg);transform:translateY(-8px) scale(.98);transition:transform 200ms ease}
.overlay.open .modal{transform:translateY(0) scale(1)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}
.modal-head h3{font-size:16px;font-weight:600}
.modal-body{padding:24px;max-height:62vh;overflow-y:auto}
.modal-foot{padding:14px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* Toast */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:11px 16px;font-size:13px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;animation:tIn 250ms ease forwards;min-width:240px}
.toast.ok{border-left:3px solid var(--success)}.toast.err{border-left:3px solid var(--danger)}.toast.out{animation:tOut 180ms ease forwards}
@keyframes tIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes tOut{to{transform:translateX(100%);opacity:0}}

/* Confirm */
.confirm-wrap{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--modal-backdrop);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all 200ms ease}
.confirm-wrap.open{opacity:1;visibility:visible}
.confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;max-width:400px;width:92%;box-shadow:var(--shadow-lg)}
.confirm-box h4{font-size:16px;margin-bottom:8px}
.confirm-box p{font-size:13px;color:var(--text-secondary);margin-bottom:20px;line-height:1.6}
.confirm-box .actions{display:flex;justify-content:flex-end;gap:8px}

/* Pagination */
.pager{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted)}
.pager-btns{display:flex;gap:3px}
.pg-btn{padding:4px 9px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);border-radius:4px;cursor:pointer;font-size:12px;font-family:var(--font);transition:all var(--transition)}
.pg-btn:hover{background:var(--surface-3)}.pg-btn.act{background:var(--accent-bg);color:var(--accent-text);border-color:var(--accent-border)}.pg-btn:disabled{opacity:.35;cursor:default}

/* Empty */
.empty{display:flex;flex-direction:column;align-items:center;padding:50px 20px;color:var(--text-muted)}
.empty svg{width:44px;height:44px;margin-bottom:14px;opacity:.25}
.empty p{font-size:14px;margin-bottom:14px}

/* Loader */
.loader-screen{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;z-index:5000;transition:opacity 300ms ease}
.loader-screen.gone{opacity:0;pointer-events:none}
.spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Sections */
.sec{display:none}.sec.on{display:block;animation:fadeUp 200ms ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* Detail panel */
.detail{display:none}.detail.on{display:block}
.d-name{font-size:22px;font-weight:700;letter-spacing:-.5px}
.d-sub{font-size:13px;color:var(--text-secondary);margin-top:2px}

/* Empresa inline editor */
.emp-editor{border-top:1px solid var(--border);background:var(--surface-2);display:none;overflow:hidden}
.emp-editor.open{display:block}
.emp-editor .tab-bar{padding:0 12px;background:var(--surface)}
.emp-editor .tab-content{padding:16px}
.inline-table{width:100%;border-collapse:collapse;font-size:13px}
.inline-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);padding:8px 10px;border-bottom:1px solid var(--border)}
.inline-table td{padding:6px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.inline-table input,.inline-table select{background:var(--input-bg);border:1px solid var(--border);border-radius:4px;padding:5px 8px;color:var(--text);font-family:var(--font);font-size:12px;outline:none;width:100%}
.inline-table input:focus,.inline-table select:focus{border-color:var(--accent)}

/* Responsive */
@media(max-width:800px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.fg{grid-template-columns:1fr}.fg-3{grid-template-columns:1fr}}
/* Handsontable overrides */
.htDias{font-family:var(--font);font-size:12px}
.htDias th{background:var(--surface-2)!important;color:var(--text-muted)!important;font-size:11px!important;font-weight:600!important;text-transform:uppercase!important;letter-spacing:.3px!important;border-color:var(--border)!important}
.htDias td{border-color:var(--border)!important;color:var(--text)!important;background:var(--surface)!important;vertical-align:middle!important}
.htDias .handsontable{color:var(--text)}
.htDias .wtHolder{background:var(--surface)}






/* ===== LOGIN PAGE (index.html) ===== */
body.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:var(--bg)}
.login-card{background:var(--surface);padding:2.5rem 2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:380px;border:1px solid var(--border)}
.login-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:1.75rem}
.dia-tipo{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s}.dia-tipo:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}
/* .login-logo .logo-mark eliminado — H1 */
.login-logo .logo-text{font-size:2rem;font-weight:800;letter-spacing:-1.5px;color:var(--text);line-height:1}.login-logo .logo-text .x{color:var(--accent)}.login-logo .logo-text .com{font-weight:300;color:var(--text-muted);font-size:1.2rem;letter-spacing:-.5px}
.login-step{display:none;flex-direction:column;gap:14px}
.login-step.active{display:flex}
.login-field{display:flex;flex-direction:column;gap:6px}
.login-field label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px}
.login-field input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:14px;color:var(--text);background:var(--input-bg);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}
.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.login-btn{width:100%;padding:11px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);margin-top:4px}
.login-btn:hover:not(:disabled){background:var(--accent-hover)}
.login-btn:disabled{opacity:.5;cursor:not-allowed}
.login-error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border);border-radius:var(--radius);padding:10px 12px;font-size:13px;display:none}
.login-error.show{display:block}
.login-link{text-align:center;font-size:12px;color:var(--text-muted);margin-top:8px}
.login-link button{background:none;border:none;color:var(--accent-text);cursor:pointer;text-decoration:underline;font-family:var(--font);font-size:12px;padding:0}
.login-theme{position:fixed;top:18px;right:18px}

/* ===== APP MAIN AREA (placeholder hasta que F2.1+ lo rellenen) ===== */
.section{display:none;padding:24px}
.section.active{display:block}
.section-title{font-size:22px;font-weight:600;margin-bottom:6px;letter-spacing:-.5px}
.section-sub{color:var(--text-muted);font-size:13px;margin-bottom:24px}
.placeholder-card{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-lg);padding:48px 24px;text-align:center;color:var(--text-muted)}
.placeholder-card h3{color:var(--text);margin-bottom:8px;font-weight:500}
.placeholder-card .icon{font-size:32px;margin-bottom:12px;opacity:.5}

/* User badge en topbar */
.user-badge{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border);font-size:13px}
.user-badge .user-rol{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.logout-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:6px 10px;border-radius:var(--radius);font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all var(--transition)}
.logout-btn:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}
/* ── Dashboard F2.1 additions ── */

/* Skeleton loading cards */
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
.stat-card.skeleton .stat-label,
.stat-card.skeleton .stat-value {
  background: linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);
  background-size: 400px 100%;
  animation: shimmer 1.4s infinite;
  border-radius: 4px;
  color: transparent;
  min-height: 14px;
}
.stat-card.skeleton .stat-value { min-height: 32px; margin-top: 6px; }

/* Tabla vacía */
.tbl-empty {
  text-align: center;
  padding: 30px !important;
  color: var(--text-muted);
  font-size: 13px;
}

/* table-wrap scroll horizontal en móvil */
.table-wrap { overflow-x: auto; }

/* Topbar icon buttons */
.topbar-icon-btn{background:none;border:1px solid transparent;color:var(--text-muted);width:34px;height:34px;border-radius:var(--radius);cursor:pointer;display:grid;place-items:center;transition:all var(--transition)}
.topbar-icon-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--border)}
.topbar-icon-btn svg{width:16px;height:16px}

/* User avatar */
.user-menu-wrap{position:relative}
.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.5px;cursor:pointer;display:grid;place-items:center;transition:all var(--transition)}
.user-avatar:hover{opacity:.85;box-shadow:0 0 0 2px var(--accent-border)}

/* User dropdown */
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-4px);transition:all 150ms ease;z-index:200}
.user-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}
.user-dropdown-header{padding:12px 14px}
.user-dropdown-name{font-weight:600;font-size:13px}
.user-dropdown-role{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.user-dropdown-sep{height:1px;background:var(--border);margin:0 8px}
.user-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;border:none;background:none;color:var(--text-secondary);font-family:var(--font);font-size:13px;cursor:pointer;transition:all var(--transition);text-align:left}
.user-dropdown-item:hover{background:var(--surface-2);color:var(--text)}
.user-dropdown-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.user-dropdown-item:first-of-type{border-radius:0}
.user-dropdown-item svg{width:15px;height:15px;opacity:.6}
.user-dropdown-item.logout:hover{background:var(--danger-bg);color:var(--danger)}
.user-dropdown-item.logout:hover svg{opacity:1}

/* F2.4c: fila nueva resaltada en Repositorio Festivos */
.inline-table tr.fest-row-new {
  background: rgba(59, 130, 246, 0.08);
}
.inline-table tr.fest-row-new input,
.inline-table tr.fest-row-new select {
  color: var(--accent, #3b82f6);
  font-weight: 600;
}
.inline-table tr.fest-row-new td {
  border-top: 2px solid var(--accent, #3b82f6);
  border-bottom: 2px solid var(--accent, #3b82f6);
}

/* Command palette (Ctrl+K) */
.cmd-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9000;display:none;align-items:flex-start;justify-content:center;padding-top:min(20vh,160px)}
.cmd-overlay.open{display:flex}
.cmd-box{width:min(540px,92vw);background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5);overflow:hidden;animation:cmdIn .15s ease}
@keyframes cmdIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.cmd-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}
.cmd-input-wrap svg{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}
.cmd-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:var(--font);font-size:15px}
.cmd-input::placeholder{color:var(--text-muted)}
.cmd-kbd{font-family:var(--mono);font-size:11px;color:var(--text-muted);background:var(--input-bg);padding:2px 6px;border-radius:4px;border:1px solid var(--border)}
.cmd-results{max-height:min(50vh,380px);overflow-y:auto;padding:6px 0}
.cmd-group-title{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:8px 16px 4px;font-weight:500}
.cmd-item{display:flex;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;transition:background .1s}
.cmd-item:hover,.cmd-item.active{background:var(--accent);color:#fff;border-radius:0}
.cmd-item:hover .cmd-item-sub,.cmd-item.active .cmd-item-sub{color:rgba(255,255,255,.7)}
.cmd-item-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px;font-weight:600}
.cmd-item-icon.emp{background:rgba(59,130,246,.15);color:var(--accent)}
.cmd-item:hover .cmd-item-icon,.cmd-item.active .cmd-item-icon{background:rgba(255,255,255,.2);color:#fff}
.cmd-item-text{flex:1;min-width:0}
.cmd-item-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmd-item-sub{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmd-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:13px}
.cmd-footer{display:flex;gap:12px;padding:8px 16px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted)}
.cmd-footer span{display:flex;align-items:center;gap:4px}
.cmd-footer kbd{font-family:var(--mono);font-size:10px;background:var(--input-bg);padding:1px 5px;border-radius:3px;border:1px solid var(--border)}
/* ═══════════════════════════════════════════════════════════════════════
   F2.5d — CSS para botón "Guardar N cambios" del topbar
   ═══════════════════════════════════════════════════════════════════════
   Añadir al final de public/css/app.css

   El botón se inserta dinámicamente por dirty.js. Esta CSS le da el toque
   final coherente con la paleta de la app. */

.topbar-dirty-btn {
  font-family: var(--font, inherit);
  letter-spacing: 0.2px;
}

.topbar-dirty-btn:hover {
  background: rgba(245, 158, 11, 0.25) !important;
  border-color: rgba(245, 158, 11, 0.6) !important;
}

.topbar-dirty-btn:active {
  transform: translateY(1px);
}

.topbar-dirty-btn .dirty-count {
  font-weight: 700;
  font-family: var(--font-mono, monospace);
}

/* Tema claro: ajustar contraste */
[data-theme="light"] .topbar-dirty-btn {
  background: rgba(245, 158, 11, 0.18) !important;
  color: #b45309 !important;
}
[data-theme="light"] .topbar-dirty-btn:hover {
  background: rgba(245, 158, 11, 0.3) !important;
}

/* Pulso suave para llamar la atención cuando aparece */
@keyframes dirtyAppear {
  from { transform: scale(0.85); opacity: 0; }
  to   { transform: scale(1);    opacity: 1; }
}
.topbar-dirty-btn {
  animation: dirtyAppear 200ms cubic-bezier(.4, 0, .2, 1);
}

/* Indicador de campo modificado (utilidad opcional para módulos) */
.field-dirty {
  border-color: rgba(245, 158, 11, 0.6) !important;
  box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.2);
}

/* cfm3 — modal de 3 botones (reutiliza estilos de confirm-wrap) */
#cfm3Wrap .actions {
  margin-top: 16px;
}
#cfm3Wrap .actions .btn {
  min-width: 100px;
}
/* ═══════════════════════════════════════════════════════════════════════
   F2.4d-B8 — Estilos: banner simulación + theme switcher topbar + cards
   ═══════════════════════════════════════════════════════════════════════
   Añadir al final de public/css/app.css (después de F2.5d) */

/* ─── Banner de simulación ─────────────────────────────────────────── */

.sim-banner {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: linear-gradient(90deg, #f59e0b, #d97706);
  color: #1a1a1a;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.2px;
  padding: 8px 16px;
  border-bottom: 2px solid #b45309;
  animation: simBannerSlide 250ms cubic-bezier(.4, 0, .2, 1);
}

.sim-banner-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: 1600px;
  margin: 0 auto;
}

.sim-banner .sim-icon {
  display: inline-flex;
  align-items: center;
  background: rgba(0, 0, 0, 0.15);
  padding: 4px;
  border-radius: 50%;
}

.sim-banner b {
  font-weight: 700;
}

.sim-banner .sim-end {
  margin-left: auto;
  background: rgba(0, 0, 0, 0.15);
  border: 1px solid rgba(0, 0, 0, 0.25);
  color: #1a1a1a;
  padding: 4px 12px;
  border-radius: 5px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: background 150ms;
}
.sim-banner .sim-end:hover {
  background: rgba(0, 0, 0, 0.25);
}

@keyframes simBannerSlide {
  from { transform: translateY(-100%); }
  to   { transform: translateY(0); }
}

/* Cuando está simulando, ajustamos un padding top arriba del .app
   para que el contenido no quede oculto bajo el banner */
body.simulating .app {
  padding-top: 0;
}
body.simulating .topbar {
  /* opcional: el avatar lleva un anillo amarillo */
}
body.simulating .user-avatar {
  box-shadow: 0 0 0 2px #f59e0b;
}

/* ─── Theme switcher en topbar ─────────────────────────────────────── */

.topbar-theme-switcher {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: var(--surface-3);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: 6px;
  padding: 2px;
  margin-right: 8px;
}

.topbar-theme-switcher .theme-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  width: 26px;
  height: 26px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 150ms, color 150ms;
}

.topbar-theme-switcher .theme-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
}

.topbar-theme-switcher .theme-btn.active {
  background: var(--accent, #3b82f6);
  color: #fff;
}

[data-theme="light"] .topbar-theme-switcher {
  background: #f1f5f9;
  border-color: #e2e8f0;
}
[data-theme="light"] .topbar-theme-switcher .theme-btn:hover {
  background: rgba(0, 0, 0, 0.05);
}

}

/* ─── Submenu simulador de rol ─────────────────────────────────────── */
.sim-submenu-wrap{position:relative}
.sim-submenu{position:absolute;top:-8px;right:calc(100% + 6px);width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateX(4px);transition:all 150ms ease;z-index:201;max-height:320px;overflow-y:auto;padding:6px 0}
.sim-submenu.open{opacity:1;visibility:visible;transform:translateX(0)}
.sim-submenu-title{padding:8px 14px 4px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.sim-submenu-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 14px;border:none;background:none;color:var(--text-secondary);font-family:var(--font);font-size:13px;cursor:pointer;transition:all var(--transition);text-align:left}
.sim-submenu-item:hover{background:var(--surface-2);color:var(--text)}
.sim-submenu-item .sim-nivel{font-family:var(--font-mono,monospace);font-size:10px;background:var(--surface-3);color:var(--text-muted);padding:1px 5px;border-radius:3px}
