:root{--primary: #FF6B35;--primary-light: #FF8F65;--primary-dark: #E55A25;--secondary: #6C63FF;--secondary-light: #8B85FF;--accent-green: #2DD4A8;--accent-yellow: #FFD166;--accent-pink: #FF6B9D;--accent-blue: #4ECDC4;--bg: #F8F7FF;--bg-card: #FFFFFF;--bg-sidebar: #2D2B55;--text: #2D2B55;--text-light: #6B6996;--text-white: #FFFFFF;--border: #E8E6F0;--success: #2DD4A8;--warning: #FFD166;--danger: #FF6B6B;--info: #4ECDC4;--shadow-sm: 0 1px 3px rgba(45, 43, 85, .08);--shadow-md: 0 4px 12px rgba(45, 43, 85, .1);--shadow-lg: 0 8px 24px rgba(45, 43, 85, .12);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Nunito,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);padding:20px}.login-card{background:#fff;border-radius:var(--radius-xl);padding:48px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-logo{font-size:2.2rem;font-weight:800;text-align:center;margin-bottom:8px;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-subtitle{text-align:center;color:var(--text-light);margin-bottom:32px;font-size:.95rem}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px;color:var(--text)}.form-input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:Nunito,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s;background:var(--bg)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b3526}select.form-input{cursor:pointer}textarea.form-input{resize:vertical;min-height:80px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-sm);font-family:Nunito,sans-serif;font-weight:700;font-size:.9rem;border:none;cursor:pointer;transition:all .2s;text-decoration:none}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:#5b52ee}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#25bb95}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#e55a5a}.btn-ghost{background:transparent;color:var(--text);border:2px solid var(--border)}.btn-ghost:hover{border-color:var(--text-light)}.btn-sm{padding:8px 16px;font-size:.8rem}.btn-block{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--bg-sidebar);color:var(--text-white);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s}.sidebar-header{padding:24px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo{font-size:1.6rem;font-weight:800;color:var(--accent-yellow)}.sidebar-label{font-size:.75rem;color:#fff6;margin-top:4px}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);color:#fff9;text-decoration:none;font-weight:600;font-size:.9rem;transition:all .2s}.sidebar-link:hover{background:#ffffff14;color:#fff}.sidebar-link.active{background:var(--primary);color:#fff}.sidebar-link .icon{font-size:1.2rem;width:24px;text-align:center}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:#ffffff80}.btn-logout{background:#ffffff14;border:none;color:#fff9;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;font-family:Nunito,sans-serif;font-weight:600;font-size:.8rem;transition:all .2s}.btn-logout:hover{background:var(--danger);color:#fff}.main-content{flex:1;margin-left:260px;padding:32px;max-width:1200px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:16px}.page-title{font-size:1.6rem;font-weight:800;color:var(--text)}.page-subtitle{font-size:.9rem;color:var(--text-light);margin-top:4px}.card{background:var(--bg-card);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border);display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.stat-icon.orange{background:#ff6b351f}.stat-icon.green{background:#2dd4a81f}.stat-icon.blue{background:#4ecdc41f}.stat-icon.purple{background:#6c63ff1f}.stat-icon.yellow{background:#ffd1661f}.stat-icon.pink{background:#ff6b9d1f}.stat-info h3{font-size:1.5rem;font-weight:800;line-height:1.2}.stat-info p{font-size:.8rem;color:var(--text-light);font-weight:500}.table-container{overflow-x:auto;border-radius:var(--radius-md)}table{width:100%;border-collapse:collapse}th{text-align:left;padding:12px 16px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);border-bottom:2px solid var(--border);white-space:nowrap}td{padding:14px 16px;font-size:.88rem;border-bottom:1px solid var(--border);vertical-align:middle}tr:hover td{background:#6c63ff08}tr.clickable{cursor:pointer}.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:capitalize}.badge-pendiente{background:#fff3cd;color:#856404}.badge-confirmada{background:#d4edda;color:#155724}.badge-completada{background:#d1ecf1;color:#0c5460}.badge-cancelada{background:#f8d7da;color:#721c24}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-header-cell{text-align:center;font-size:.75rem;font-weight:700;color:var(--text-light);padding:8px;text-transform:uppercase}.calendar-day{aspect-ratio:1;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;border:2px solid transparent;position:relative;min-height:64px}.calendar-day:hover{border-color:var(--primary-light)}.calendar-day.today{border-color:var(--primary)}.calendar-day.other-month{color:var(--border);cursor:default}.calendar-day.other-month:hover{border-color:transparent}.calendar-day.has-booking{background:#2dd4a81f}.calendar-day.blocked{background:#ff6b6b14;color:var(--text-light);text-decoration:line-through}.calendar-dot{width:6px;height:6px;border-radius:50%;background:var(--success);margin-top:4px}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.calendar-nav h2{font-size:1.2rem;font-weight:700;text-transform:capitalize}.calendar-nav-btn{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-sm);padding:8px 16px;cursor:pointer;font-weight:700;font-family:Nunito,sans-serif;transition:all .2s}.calendar-nav-btn:hover{border-color:var(--primary);color:var(--primary)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-row{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:.75rem;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:1rem;font-weight:600}.detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d2b5580;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fadeIn .2s}.modal{background:#fff;border-radius:var(--radius-lg);padding:32px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s}.modal h2{font-size:1.3rem;font-weight:800;margin-bottom:24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.filters-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.filters-bar .form-input{width:auto;min-width:180px}.search-input{flex:1;min-width:200px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-light)}.empty-state .icon{font-size:3rem;margin-bottom:12px}.empty-state p{font-size:.95rem}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;margin-bottom:16px}.alert-error{background:#fde8e8;color:#9b1c1c}.alert-success{background:#def7ec;color:#03543e}.hamburger{display:none;position:fixed;top:16px;left:16px;z-index:150;background:var(--bg-sidebar);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 12px;font-size:1.4rem;cursor:pointer}.sidebar-overlay{display:none}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:768px){.hamburger{display:block}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.main-content{margin-left:0;padding:72px 16px 24px}.stats-grid,.detail-grid,.settings-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.filters-bar{flex-direction:column}.filters-bar .form-input{width:100%}.modal{padding:24px 20px}}
