.login-bg{background:linear-gradient(145deg, var(--color-primary-dark) 0%, var(--color-primary) 50%, var(--color-accent) 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:36px 28px}.login-header{text-align:center;margin-bottom:28px}.login-logo{background:var(--color-primary);color:#fff;width:64px;height:64px;box-shadow:var(--shadow-md);letter-spacing:1px;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 14px;font-size:1.5rem;font-weight:800;display:flex}.login-title{color:var(--color-text);margin-bottom:4px;font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--color-text-muted);font-size:.9rem}.login-extra{animation:.25s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.login-new-badge{color:#7c5c00;border-radius:var(--radius-sm);background:#fff8e1;border:1px solid #ffe082;margin-bottom:14px;padding:10px 14px;font-size:.88rem;line-height:1.5}.login-submit{letter-spacing:.3px;margin-top:8px;padding:13px;font-size:1rem}@media (width<=440px){.login-card{padding:28px 18px}}.selector-mes{justify-content:center;align-items:center;gap:16px;margin:20px 0;display:flex}.selector-mes-btn{background:var(--color-primary);color:#fff;cursor:pointer;width:36px;height:36px;transition:background var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.3rem;line-height:1;display:flex}.selector-mes-btn:hover:not(:disabled){background:var(--color-primary-dark)}.selector-mes-label{color:var(--color-text);text-align:center;min-width:160px;font-size:1.05rem;font-weight:700}.tabla-wrapper{margin-top:8px}.tabla-scroll{border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto}.tabla-horas{border-collapse:collapse;width:100%;min-width:560px;font-size:.88rem}.tabla-horas th{background:var(--color-primary);color:#fff;text-align:left;letter-spacing:.3px;white-space:nowrap;padding:10px 12px;font-size:.82rem;font-weight:600}.tabla-horas td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:8px 10px}.tabla-horas tbody tr:last-child td{border-bottom:none}.tabla-horas tbody tr:hover{background:var(--color-primary-light)}.fila-readonly td{color:var(--color-text-muted);background:#fafbfc}.celda-input{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);width:100%;min-width:80px;font-size:.85rem;font-family:var(--font-main);background:var(--color-surface);transition:border-color var(--transition);outline:none;padding:5px 8px}.celda-input:focus{border-color:var(--color-primary)}.celda-hora{max-width:100px}.input-error{border-color:var(--color-danger)!important}.celda-error{color:var(--color-danger);font-size:.75rem;display:block}.celda-horas{color:var(--color-primary);white-space:nowrap;font-weight:700}.fecha-wrapper{position:relative}.fecha-btn{background:var(--color-primary-light);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;color:var(--color-primary);white-space:nowrap;padding:5px 10px;font-size:.85rem;font-weight:600}.calendario-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:1000;width:300px;padding:16px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.calendario-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.cal-dia{border-radius:var(--radius-sm);cursor:pointer;text-align:center;transition:background var(--transition);background:0 0;border:1px solid #0000;padding:5px 2px;font-size:.8rem}.cal-dia:hover{background:var(--color-primary-light)}.cal-dia-activo{color:#fff;border-color:var(--color-primary);background:var(--color-primary)!important}.tabla-footer{flex-direction:column;gap:6px;margin-top:10px;display:flex}.btn-agregar-fila{border:2px dashed var(--color-primary);color:var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);background:0 0;width:100%;margin-top:4px;padding:8px 16px;font-size:.9rem;font-weight:600}.btn-agregar-fila:hover{background:var(--color-primary-light)}.tabla-totales{border-top:2px solid var(--color-border);flex-direction:column;gap:8px;margin-top:16px;padding-top:12px;display:flex}.total-row{color:var(--color-text);justify-content:space-between;align-items:center;font-size:.95rem;font-weight:600;display:flex}.total-valor{color:var(--color-primary);font-size:1.05rem}.total-monto{color:var(--color-success);font-size:1.1rem}.tabla-guardar{justify-content:flex-end;margin-top:16px;display:flex}.tabla-loading{text-align:center;color:var(--color-text-muted);padding:30px}.staff-page{background:var(--color-bg);min-height:100vh}.staff-saludo{margin-bottom:4px}.staff-saludo h1{color:var(--color-text);font-size:1.3rem;font-weight:700}.staff-saludo p{color:var(--color-text-muted);margin-top:2px;font-size:.88rem}.aviso-readonly{color:#7c5c00;border-radius:var(--radius-sm);background:#fff8e1;border:1px solid #ffe082;margin-bottom:12px;padding:10px 14px;font-size:.88rem}.auto-guardado-msg{color:var(--color-success);align-self:center;font-size:.85rem;font-weight:600}.calendario-overlay{z-index:999;background:#00000059;position:fixed;inset:0}.admin-page{background:var(--color-bg);min-height:100vh}.admin-panels{grid-template-columns:1fr 1fr;gap:20px;margin-top:20px;display:grid}.admin-panel-card{flex-direction:column;gap:12px;display:flex}.admin-panel-header{align-items:center;gap:10px;display:flex}.admin-panel-header h2{color:var(--color-text);font-size:1.1rem;font-weight:700}.admin-panel-icon{font-size:1.4rem}.admin-panel-desc{color:var(--color-text-muted);flex:1;font-size:.87rem;line-height:1.5}.admin-menu-lista{flex-direction:column;gap:10px;margin-top:4px;display:flex}.admin-menu-item{background:var(--color-primary-light);border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:background var(--transition), border-color var(--transition);text-align:left;justify-content:space-between;align-items:center;width:100%;padding:14px 16px;font-size:.95rem;font-weight:600;display:flex}.admin-menu-item:hover{border-color:var(--color-primary);background:#d6e8f5}.admin-menu-arrow{color:var(--color-primary);font-size:1.3rem}.admin-nombre-actual{background:var(--color-primary-light);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-direction:column;gap:4px;margin-bottom:20px;padding:12px 16px;display:flex}.label-muted{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:.78rem;font-weight:600}.nombre-display{color:var(--color-text);font-size:1.05rem;font-weight:700}.admin-acciones-lista{flex-direction:column;gap:10px;margin-top:8px;display:flex}.lista-staff{flex-direction:column;gap:10px;margin-top:16px;list-style:none;display:flex}.lista-staff-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.staff-item-info{align-items:center;gap:8px;display:flex}.staff-item-nombre{color:var(--color-text);font-size:.95rem;font-weight:600}.staff-item-acciones{flex-shrink:0;gap:8px;display:flex}.badge-nuevo{color:#7c5c00;text-transform:uppercase;letter-spacing:.3px;background:#fff8e1;border:1px solid #ffe082;border-radius:20px;padding:2px 8px;font-size:.72rem;font-weight:700}.btn-icono{border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;transition:opacity var(--transition);border:none;justify-content:center;align-items:center;font-size:1rem;display:flex}.btn-icono:hover{opacity:.8}.btn-icono-edit{background:var(--color-primary-light);color:var(--color-primary)}.btn-icono-delete{color:var(--color-danger);background:#fdecea}.btn-agregar-miembro{width:100%;margin-bottom:16px}.sin-miembros{text-align:center;color:var(--color-text-muted);padding:24px 0;font-size:.92rem}.input-prefix-wrapper{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--transition), box-shadow var(--transition);align-items:center;display:flex;overflow:hidden}.input-prefix-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #2c5f8a1f}.input-prefix{background:var(--color-primary-light);color:var(--color-primary);border-right:1.5px solid var(--color-border);padding:10px 12px;font-size:.95rem;font-weight:700}.input-con-prefix{flex:1;box-shadow:none!important;border:none!important;border-radius:0!important}.aviso-delicado{color:#7c5c00;border-radius:var(--radius-sm);background:#fff8e1;border:1px solid #ffe082;margin-bottom:16px;padding:10px 14px;font-size:.88rem;line-height:1.5}.char-count{color:var(--color-text-muted);text-align:right;margin-top:4px;font-size:.78rem;display:block}@media (width<=600px){.admin-panels{grid-template-columns:1fr}}:root{--color-primary:#2c5f8a;--color-primary-dark:#1e4266;--color-primary-light:#e8f0f7;--color-accent:#4a90c4;--color-danger:#e53935;--color-danger-dark:#b71c1c;--color-success:#2e7d32;--color-warning:#f57c00;--color-bg:#f4f7fb;--color-surface:#fff;--color-border:#d0dce8;--color-text:#1a2a3a;--color-text-muted:#5a7a99;--color-text-light:#fff;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 4px #2c5f8a14;--shadow-md:0 4px 16px #2c5f8a21;--shadow-lg:0 8px 32px #2c5f8a2e;--font-main:"Segoe UI", system-ui, -apple-system, sans-serif;--transition:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-main);background-color:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.5}.loading-screen{min-height:100vh;color:var(--color-primary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.loading-spinner{border:4px solid var(--color-primary-light);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition), transform var(--transition), opacity var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-light)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-danger{background:var(--color-danger);color:var(--color-text-light)}.btn-danger:hover:not(:disabled){background:var(--color-danger-dark)}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:#b0c4d8}.btn-ghost{color:var(--color-primary);border:1.5px solid var(--color-primary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-primary-light)}.btn-sm{padding:6px 14px;font-size:.85rem}.btn-full{width:100%}.input{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);width:100%;font-size:.95rem;font-family:var(--font-main);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 14px}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2c5f8a1f}.input::placeholder{color:var(--color-text-muted)}.input:disabled{cursor:not-allowed;background:#f0f4f8}.msg-error{color:var(--color-danger);align-items:center;gap:4px;margin-top:6px;font-size:.85rem;display:flex}.msg-success{color:var(--color-success);margin-top:6px;font-size:.85rem}.navbar{background:var(--color-primary);color:var(--color-text-light);box-shadow:var(--shadow-md);z-index:100;justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex;position:sticky;top:0}.navbar-left h2{letter-spacing:.3px;font-size:1rem;font-weight:700}.navbar-left p{opacity:.85;font-size:.8rem}.navbar-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.navbar-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);background:#ffffff26;border:1px solid #ffffff4d;padding:6px 12px;font-size:.82rem;font-weight:600}.navbar-btn:hover{background:#ffffff40}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);padding:24px}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-box{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:28px 24px}.modal-box h3{color:var(--color-text);margin-bottom:10px;font-size:1.1rem}.modal-box p{color:var(--color-text-muted);margin-bottom:20px;font-size:.92rem;line-height:1.6}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.form-group{margin-bottom:16px}.form-group label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px;font-size:.88rem;font-weight:600;display:block}.page-container{max-width:900px;margin:0 auto;padding:24px 16px}@media (width<=600px){.card{padding:16px}.modal-box{padding:20px 16px}.page-container{padding:16px 10px}.navbar{padding:10px 14px}}.btn-volver{color:var(--color-primary);cursor:pointer;transition:opacity var(--transition);background:0 0;border:none;align-items:center;gap:6px;margin-bottom:16px;padding:6px 0;font-size:.92rem;font-weight:600;display:inline-flex}.btn-volver:hover{opacity:.7}.section-title{color:var(--color-text);border-bottom:2px solid var(--color-primary-light);margin-bottom:20px;padding-bottom:10px;font-size:1.15rem;font-weight:700}.form-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-top:20px;display:flex}@media (width<=400px){.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}}
