@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";
:root{--font-family:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--bg-deep:#09201b;--bg-card:#0e2d26;--bg-input:#12362e;--bg-hover:#164238;--primary:#00c07f;--primary-hover:#05e297;--primary-glow:#00c07f26;--text-primary:#fff;--text-secondary:#9cb1ad;--text-muted:#6b8681;--border-color:#ffffff14;--glass-bg:#0e2d26bf;--glass-blur:blur(20px);--accent-blue:#3b82f6;--accent-blue-glow:#3b82f626;--accent-red:#ef4444;--accent-yellow:#eab308}*{box-sizing:border-box;font-family:var(--font-family);-webkit-font-smoothing:antialiased;margin:0;padding:0}body{background-color:var(--bg-deep);color:var(--text-primary);min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-deep)}::-webkit-scrollbar-thumb{background:var(--bg-card);border-radius:4px}.app-container{width:100%;min-height:100vh;display:flex}.sidebar{background-color:var(--bg-card);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;justify-content:space-between;width:280px;height:100vh;padding:2rem 1.5rem;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed}.logo-section{color:var(--text-primary);align-items:center;gap:.75rem;margin-bottom:2.5rem;font-size:1.2rem;font-weight:700;display:flex}.nav-links{flex-direction:column;gap:.5rem;list-style:none;display:flex}.nav-link{color:var(--text-secondary);cursor:pointer;border-radius:12px;align-items:center;gap:1rem;padding:.85rem 1rem;font-weight:500;text-decoration:none;transition:all .3s;display:flex}.nav-link:hover,.nav-link.active{background-color:var(--bg-hover);color:var(--text-primary)}.nav-link.active{border-left:3px solid var(--primary);background:linear-gradient(90deg, var(--primary-glow) 0%, transparent 100%);border-radius:0 12px 12px 0}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:#0009;animation:.2s forwards fadeIn;display:none;position:fixed;inset:0}.main-content{flex-grow:1;width:calc(100% - 280px);min-height:100vh;margin-left:280px;padding:2.5rem}.topbar-wrapper{justify-content:space-between;align-items:center;gap:1.5rem;width:100%;margin-bottom:2.5rem;display:flex}.topbar-left{align-items:center;gap:1rem;display:flex}.topbar-title{color:var(--text-primary);font-size:1.8rem;font-weight:700}.topbar-subtitle{color:var(--text-secondary);margin-top:.2rem;font-size:.85rem}.topbar-right{align-items:center;display:flex}.user-profile{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);border-radius:50px;align-items:center;gap:1rem;padding:.5rem 1.25rem .5rem .5rem;display:flex}.user-avatar{object-fit:cover;border:2px solid var(--primary);border-radius:50%;width:40px;height:40px}.user-info{flex-direction:column;display:flex}.user-name{font-size:.9rem;font-weight:600}.ms-badge{color:#00a4ef;align-items:center;gap:4px;font-size:.7rem;font-weight:600;display:flex}.card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);border-radius:20px;margin-bottom:2rem;padding:1.75rem;box-shadow:0 8px 32px #0000004d}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.kpi-card{justify-content:space-between;align-items:center;transition:transform .3s;display:flex}.kpi-card:hover{border-color:var(--primary);transform:translateY(-5px)}.kpi-info h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;font-size:.85rem}.kpi-info p{font-size:2rem;font-weight:700}.kpi-trend{margin-top:.25rem;font-size:.8rem}.kpi-trend.up{color:var(--primary)}.kpi-trend.down{color:var(--accent-red)}.kpi-icon-wrapper{background-color:var(--bg-hover);border-radius:16px;justify-content:center;align-items:center;width:54px;height:54px;display:flex}.dashboard-grid{grid-template-columns:3fr 2fr;gap:2rem;width:100%;display:grid}.slots-container{grid-template-columns:repeat(auto-fill,minmax(65px,1fr));gap:.75rem;margin-top:1.5rem;display:grid}.slot-item{aspect-ratio:1;border:1px solid var(--border-color);cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;transition:all .3s;display:flex}.slot-item.libre{border-color:var(--primary);background:var(--primary-glow);color:var(--primary)}.slot-item.ocupado{border-color:var(--accent-blue);background:var(--accent-blue-glow);color:var(--accent-blue)}.slot-item.reservado{border-color:var(--accent-yellow);color:var(--accent-yellow);background:#eab3081a}.slot-item:hover{transform:scale(1.05)}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;display:block}.form-control{background-color:var(--bg-input);border:1px solid var(--border-color);width:100%;color:var(--text-primary);border-radius:12px;padding:.85rem 1rem;font-size:.95rem;transition:all .3s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 10px var(--primary-glow);outline:none}.btn{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:.5rem;padding:.85rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .3s;display:inline-flex}.btn-primary{background-color:var(--primary);color:var(--bg-deep)}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:0 4px 15px var(--primary-glow);transform:translateY(-2px)}.btn-secondary{background-color:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--bg-input)}.btn-danger{background-color:var(--accent-red);color:#fff}.btn-danger:hover{opacity:.9}.table-container{border:1px solid var(--border-color);background:#00000026;border-radius:12px;width:100%;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;white-space:nowrap;width:100%}.custom-table th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-transform:uppercase;padding:1rem;font-size:.85rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:1rem;font-size:.95rem}.custom-table tr:hover{background-color:#ffffff05}.menu-toggle{color:#fff;cursor:pointer;z-index:110;background:0 0;border:none;display:none}@media (max-width:1024px){.dashboard-grid{grid-template-columns:1fr;gap:1.5rem}}@media (max-width:768px){.menu-toggle{display:block!important}.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay.active{display:block}.main-content{width:100%;margin-left:0;padding:1.5rem}.topbar-wrapper{flex-direction:column;align-items:stretch;gap:1rem}.topbar-left{justify-content:flex-start;width:100%}.topbar-title{font-size:1.5rem}.topbar-subtitle{display:none}.topbar-right{justify-content:stretch;width:100%}.user-profile{justify-content:space-between;width:100%;padding:.5rem 1rem}.kpi-grid{grid-template-columns:1fr}.card{padding:1.25rem!important}.dashboard-grid>div{min-width:0}}@media (max-width:480px){.slots-container{grid-template-columns:repeat(auto-fill,minmax(52px,1fr))!important;gap:.5rem!important}.slot-item{font-size:.75rem!important}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s forwards fadeIn}.mobile-reservations-list{flex-direction:column;gap:1rem;width:100%;margin-top:1rem;display:none}.reservation-mobile-card{border:1px solid var(--border-color);background:#ffffff05;border-radius:16px;flex-direction:column;gap:.85rem;padding:1.25rem;display:flex}.res-card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}.res-date{color:var(--text-primary);font-size:1.1rem;font-weight:700}.res-slot-badge{border:1px solid var(--primary);color:var(--primary);background:var(--primary-glow);border-radius:8px;padding:.25rem .65rem;font-size:.8rem;font-weight:600}.res-card-body{flex-direction:column;gap:.5rem;display:flex}.res-info-row{justify-content:space-between;font-size:.85rem;display:flex}.res-label{color:var(--text-secondary)}.res-value{color:var(--text-primary);text-align:right;font-weight:500}.btn-danger-outline{border:1px solid var(--accent-red);color:var(--accent-red);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;width:100%;padding:.7rem;font-size:.85rem;font-weight:600;transition:all .3s;display:flex}.btn-danger-outline:hover{background:#ef444414}@media (max-width:768px){.desktop-table-wrapper{display:none!important}.mobile-reservations-list{display:flex!important}}.card-header-flex{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.legend-container{flex-wrap:wrap;gap:15px;font-size:.8rem;display:flex}@media (max-width:768px){.card-header-flex{flex-direction:column;align-items:flex-start;gap:.75rem}}
