@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-base:#0d1117;--bg-surface:#161b22;--bg-card:#161b22bf;--bg-glass:#ffffff0a;--bg-glass-hover:#ffffff14;--border:#ffffff14;--border-strong:#ffffff24;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#484f58;--text-inverse:#0d1117;--accent:#58a6ff;--accent-dark:#1f6feb;--accent-glow:#58a6ff40;--status-abonada:#d29922;--status-abonada-bg:#d2992224;--status-liquidada:#3fb950;--status-liquidada-bg:#3fb95024;--status-anulada:#f85149;--status-anulada-bg:#f8514924;--block-manana:#58a6ff;--block-tarde:#f0883e;--block-noche:#d2a8ff;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:22px;--shadow-glass:0 8px 32px #0006;--shadow-card:0 2px 12px #0000004d;--transition:.2s ease}[data-theme=light]{--bg-base:#f0f4f8;--bg-surface:#fff;--bg-card:#ffffffd9;--bg-glass:#00000008;--bg-glass-hover:#0000000f;--border:#00000017;--border-strong:#00000026;--text-primary:#1a2332;--text-secondary:#5a6a7e;--text-muted:#9aa5b4;--text-inverse:#fff;--accent:#1a7fd4;--accent-dark:#155da0;--accent-glow:#1a7fd433;--status-abonada:#b7791f;--status-abonada-bg:#b7791f1f;--status-liquidada:#276749;--status-liquidada-bg:#2767491a;--status-anulada:#c0392b;--status-anulada-bg:#c0392b1a;--block-manana:#1a7fd4;--block-tarde:#c2410c;--block-noche:#7c3aed;--shadow-glass:0 8px 32px #0000001a;--shadow-card:0 2px 12px #00000014}html{transition:background-color .25s,color .25s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}.layout{min-height:100vh;display:flex}.bottom-nav{display:none}@media (width<=768px){.sidebar{display:none}.layout{flex-direction:column;height:100vh}.main-content{flex:1;min-height:0;padding:1rem;overflow-y:auto}.bottom-nav{background:var(--bg-surface);border-top:1px solid var(--border);flex-shrink:0;justify-content:space-around;align-items:stretch;height:60px;padding:0;display:flex}.bottom-nav__item{color:var(--text-secondary);transition:color var(--transition), background var(--transition);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:0;font-family:inherit;font-size:.65rem;font-weight:600;text-decoration:none;display:flex}.bottom-nav__item.active,.bottom-nav__item:hover{color:var(--accent)}}@media (width>=769px){.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;height:100vh;padding:1rem .75rem;transition:width .22s;display:flex;position:sticky;top:0;overflow:hidden}.sidebar--open{width:220px}.sidebar--collapsed{width:60px}.sidebar--collapsed .sidebar__logo{text-align:center;padding:0}.sidebar--collapsed .nav-link{justify-content:center;padding:.65rem 0}}.sidebar__logo{color:var(--accent);letter-spacing:-.02em;white-space:nowrap;margin-bottom:1.5rem;padding:0 .5rem;font-size:1.25rem;font-weight:700;overflow:hidden}.sidebar__logo span{color:var(--text-secondary);font-weight:400}.sidebar__nav{flex-direction:column;gap:.25rem;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--transition), color var(--transition);text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:.65rem;width:100%;padding:.65rem .75rem;font-size:.875rem;font-weight:500;display:flex;overflow:hidden}.nav-link svg{flex-shrink:0}.nav-link:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.nav-link.active{background:var(--accent-glow);color:var(--accent)}.main-content{flex:1;min-width:0;padding:2rem;overflow-y:auto}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.75rem;display:flex}.page-title{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:.2rem;font-size:.875rem}.btn{border-radius:var(--radius-md);transition:background var(--transition), opacity var(--transition), transform var(--transition), box-shadow var(--transition);border:none;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.875rem;font-weight:600;line-height:1.4;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--accent);color:var(--text-inverse)}.btn--primary:hover:not(:disabled){box-shadow:0 0 0 3px var(--accent-glow);background:#79b8ff}.btn--ghost{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border)}.btn--ghost:hover:not(:disabled){background:var(--bg-glass-hover)}.btn--danger{background:var(--status-anulada-bg);color:var(--status-anulada);border:1px solid #f8514940}.btn--danger:hover:not(:disabled){background:#f8514940}.btn--success{background:var(--status-liquidada-bg);color:var(--status-liquidada);border:1px solid #3fb95040}.btn--success:hover:not(:disabled){background:#3fb95040}.btn--sm{padding:.35rem .75rem;font-size:.8rem}.btn--lg{padding:.75rem 1.5rem;font-size:1rem}.btn--full{justify-content:center;width:100%}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px)}.card--pad{padding:1.5rem}.badge{letter-spacing:.03em;text-transform:uppercase;border-radius:20px;align-items:center;gap:.3rem;padding:.2rem .7rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge--ABONADA{background:var(--status-abonada-bg);color:var(--status-abonada)}.badge--LIQUIDADA{background:var(--status-liquidada-bg);color:var(--status-liquidada)}.badge--ANULADA{background:var(--status-anulada-bg);color:var(--status-anulada)}.bloque-badge{align-items:center;gap:.3rem;font-size:.8rem;font-weight:500;display:inline-flex}.bloque-badge--MANANA{color:var(--block-manana)}.bloque-badge--TARDE{color:var(--block-tarde)}.bloque-badge--NOCHE{color:var(--block-noche)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap;padding:.65rem 1rem;font-size:.75rem;font-weight:600}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition)}th.sortable:hover{color:var(--text-primary)}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.85rem 1rem;font-size:.875rem}tr:last-child td{border-bottom:none}tr.clickable{cursor:pointer;transition:background var(--transition)}tr.clickable:hover td{background:var(--bg-glass)}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.form-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.form-control{background:var(--bg-glass);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition);width:100%;padding:.6rem .85rem;font-size:.875rem}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-control:disabled{opacity:.5;cursor:not-allowed}.form-control option{background:var(--bg-surface);color:var(--text-primary)}.form-grid{grid-template-columns:1fr 1fr;gap:0 1rem;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr}.blocks-grid{grid-template-columns:1fr!important}.filter-bar{gap:.5rem}.filter-bar .form-control{flex:150px;max-width:100%}.page-header{flex-direction:column;align-items:flex-start}.page-header .btn{justify-content:center;width:100%}}.filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.filter-bar .form-control{max-width:260px}.filter-chips{flex-wrap:wrap;gap:.4rem;display:flex}.chip{border:1px solid var(--border-strong);background:var(--bg-glass);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border-radius:20px;padding:.3rem .75rem;font-size:.78rem;font-weight:600}.chip.active{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}.chip:hover:not(.active){background:var(--bg-glass-hover);color:var(--text-primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-glass);padding:1.75rem;animation:.2s slideUp;overflow-y:auto}@media (width<=640px){.modal{border-radius:var(--radius-lg);max-height:95vh;padding:1.25rem}.modal-overlay{padding:.5rem}.modal--wide{max-width:100%}.detail-grid{grid-template-columns:1fr}.action-row{flex-direction:column}.action-row .btn{justify-content:center;width:100%}.action-row .btn[style*=marginLeft]{margin-left:0!important}}.modal--wide{max-width:680px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-title{font-size:1.15rem;font-weight:700}.modal-close{color:var(--text-secondary);border-radius:var(--radius-sm);transition:color var(--transition), background var(--transition);background:0 0;border:none;padding:.2rem .4rem;font-size:1.3rem;line-height:1}.modal-close:hover{color:var(--text-primary);background:var(--bg-glass-hover)}.modal-footer{flex-wrap:wrap;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.calendar-month-label{text-transform:capitalize;font-size:1rem;font-weight:600}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-dow{text-align:center;color:var(--text-muted);text-transform:uppercase;padding:.4rem 0;font-size:.7rem;font-weight:600}.calendar-day{aspect-ratio:1;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition), color var(--transition), transform var(--transition);-webkit-user-select:none;user-select:none;border:1px solid #0000;justify-content:center;align-items:center;font-size:.85rem;display:flex;position:relative}.calendar-day:hover:not(.empty):not(.selected){background:var(--bg-glass-hover);color:var(--text-primary);transform:scale(1.05)}.calendar-day.today{border-color:var(--accent);color:var(--accent);font-weight:700}.calendar-day.selected{box-shadow:inset 0 0 0 3px var(--accent);font-weight:700;transform:scale(1.05)}.calendar-day.selected:hover{box-shadow:inset 0 0 0 4px var(--accent);transform:scale(1.05)}.calendar-day.past{color:var(--text-muted)}.calendar-day.empty{cursor:default}.calendar-fast-nav-input{pointer-events:none;cursor:pointer!important}.blocks-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:1rem;display:grid}@media (width<=640px){.blocks-grid{grid-template-columns:1fr}}.block-card{border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition);padding:1rem;position:relative;overflow:hidden}button.block-card{flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}button.block-card:disabled{cursor:not-allowed;opacity:.4}button.block-card.occupied:disabled,button.block-card.occupied:disabled:hover{opacity:.6;background:#f851491f;border-color:#f851494d}button.block-card.available:disabled:hover{opacity:.4;background:#3fb9500f;border-color:#3fb9504d}.block-card:hover.available:not(:disabled){border-color:var(--accent);background:var(--accent-glow)}.block-card.available{background:#3fb9500f;border-color:#3fb9504d}.block-card.occupied{cursor:pointer;opacity:.85;background:#f851490f;border-color:#f8514933}.block-card.occupied:hover:not(:disabled){opacity:1;border-color:#f8514966}.block-card__icon{margin-bottom:.4rem;font-size:1.5rem}.block-card__name{margin-bottom:.15rem;font-size:.85rem;font-weight:700}.block-card__hours{color:var(--text-secondary);font-size:.75rem}.block-card__status{text-transform:uppercase;letter-spacing:.04em;margin-top:.4rem;font-size:.72rem;font-weight:600}.block-card.available .block-card__status{color:var(--status-liquidada)}.block-card.occupied .block-card__status{color:var(--status-anulada)}.reminder-dot{color:#e3b341;background:#e3b3411f;border-radius:20px;align-items:center;gap:.3rem;margin-left:.5rem;padding:.15rem .5rem;font-size:.72rem;font-weight:600;display:inline-flex}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem}.empty-state__icon{margin-bottom:.75rem;font-size:2.5rem}.empty-state__title{color:var(--text-primary);margin-bottom:.35rem;font-size:1rem;font-weight:600}.empty-state__desc{font-size:.875rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;margin:0 auto;animation:.7s linear infinite spin}.warning-banner{border-radius:var(--radius-md);color:#e3b341;background:#e3b3411a;border:1px solid #e3b3414d;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.65rem 1rem;font-size:.8rem;display:flex}.agenda-grid{grid-template-columns:1fr 1fr;align-items:start;gap:1.5rem;display:grid}@media (width<=768px){.agenda-grid{grid-template-columns:1fr}}.detail-grid{grid-template-columns:1fr 1fr;gap:.75rem 1.5rem;margin-bottom:1.25rem;display:grid}.detail-item__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.detail-item__value{margin-top:.15rem;font-size:.9rem;font-weight:500}.action-row{border-top:1px solid var(--border);flex-wrap:wrap;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;display:flex}.confirm-dialog{text-align:center;max-width:380px}.confirm-dialog__icon{margin-bottom:1rem;font-size:2.5rem}.confirm-dialog__msg{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.login-wrap{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex;position:relative;overflow:hidden}.login-card{z-index:10;width:100%;max-width:400px;animation:.3s slideUp;position:relative}.login-icon-box{border-radius:var(--radius-lg);background:var(--accent-glow);width:64px;height:64px;color:var(--accent);justify-content:center;align-items:center;margin:0 auto 1.5rem;display:flex}.login-title{text-align:center;color:var(--text-primary);margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:.875rem}.login-bg-shape{background:var(--accent);filter:blur(80px);opacity:.15;z-index:1;border-radius:50%;width:400px;height:400px;position:absolute}.login-bg-shape.top{top:-200px;right:-100px}.login-bg-shape.bottom{background:var(--block-noche);bottom:-200px;left:-100px}
