:root{--color-primary:#0f766e;--color-accent:#2dd4bf;--font-display:"Outfit", sans-serif;--font-body:"IBM Plex Sans", sans-serif;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001f;--transition:.2s ease;--sidebar-width:260px;--header-height:64px}[data-theme=light]{--color-bg:#f8f7f4;--color-surface:#fff;--color-border:#e2dfd8;--color-text:#1a1a18;--color-text-secondary:#6b6860;--color-text-muted:#9c9889;--color-hover:#f0ede6;--color-danger:#dc2626;--color-danger-bg:#fef2f2;--color-success:#16a34a;--color-success-bg:#f0fdf4}[data-theme=dark]{--color-bg:#111110;--color-surface:#1c1c1a;--color-border:#2e2e2a;--color-text:#e8e6e0;--color-text-secondary:#a3a093;--color-text-muted:#6b6860;--color-hover:#252522;--color-danger:#ef4444;--color-danger-bg:#2d1515;--color-success:#22c55e;--color-success-bg:#152d1a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.3}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}a{color:var(--color-primary);transition:color var(--transition);text-decoration:none}a:hover{color:var(--color-accent)}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}input,select,textarea{font-family:var(--font-body);font-size:.875rem}.btn{border-radius:var(--radius-md);transition:all var(--transition);border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-secondary{color:var(--color-text);border-color:var(--color-border);background:0 0}.btn-secondary:hover{background:var(--color-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-ghost{color:var(--color-text-secondary);background:0 0;padding:8px 12px}.btn-ghost:hover{background:var(--color-hover);color:var(--color-text)}.btn-sm{padding:6px 12px;font-size:.8125rem}.input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-text);transition:border-color var(--transition);padding:10px 14px;font-size:.875rem}.input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #0f766e1a}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:box-shadow var(--transition);padding:24px}.card:hover{box-shadow:var(--shadow-sm)}.badge{border-radius:100px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:500;display:inline-flex}.badge-primary{color:var(--color-primary);background:#0f766e1a}.badge-accent{color:var(--color-accent);background:#2dd4bf1a}.badge-room{color:var(--color-primary);background:#0f766e1a}.badge-desk{color:#0d9488;background:#2dd4bf26}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-lg);width:90%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);padding:32px;animation:.2s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:.3s fadeIn}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-container{justify-content:center;align-items:center;padding:48px;display:flex}.toast{border-radius:var(--radius-md);z-index:2000;box-shadow:var(--shadow-lg);padding:14px 20px;font-size:.875rem;font-weight:500;animation:.2s slideUp;position:fixed;bottom:24px;right:24px}.toast-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.toast-error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger)}.avatar{background:var(--color-primary);color:#fff;width:36px;height:36px;font-size:.875rem;font-weight:600;font-family:var(--font-display);border-radius:50%;justify-content:center;align-items:center;display:flex}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;transition:transform var(--transition);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:20px 24px;display:flex}.sidebar-logo{width:auto;height:32px}.sidebar-brand{font-family:var(--font-display);color:var(--color-text);font-size:1.125rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.sidebar-link{border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition);align-items:center;gap:12px;padding:10px 16px;font-size:.875rem;font-weight:500;display:flex}.sidebar-link:hover{background:var(--color-hover);color:var(--color-text)}.sidebar-link.active{color:var(--color-primary);background:#0f766e14}.sidebar-footer{border-top:1px solid var(--color-border);padding:16px 24px}.main-wrapper{margin-left:var(--sidebar-width);flex:1}.header{height:var(--header-height);border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:50;justify-content:flex-end;align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.main-content{max-width:1280px;padding:32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-wrapper{margin-left:0}.main-content{padding:16px}}.login-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{width:100%;max-width:420px;padding:40px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{margin-bottom:8px}.login-header p{color:var(--color-text-secondary);font-size:.875rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-footer{text-align:center;color:var(--color-text-secondary);margin-top:24px;font-size:.875rem}.login-footer a{font-weight:500}.login-logo{height:48px;margin-bottom:16px}.stat-card{padding:20px}.stat-card .stat-value{font-family:var(--font-display);color:var(--color-text);font-size:2rem;font-weight:700;line-height:1}.stat-card .stat-label{color:var(--color-text-secondary);margin-top:4px;font-size:.8125rem}.stat-card .stat-icon{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-primary);background:#0f766e14;justify-content:center;align-items:center;margin-bottom:12px;display:flex}.chart-card{padding:24px}.chart-card h3{margin-bottom:16px;font-size:.9375rem}.table{border-collapse:collapse;width:100%}.table th,.table td{text-align:left;border-bottom:1px solid var(--color-border);padding:10px 16px;font-size:.875rem}.table th{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.timeline{border-radius:var(--radius-sm);background:var(--color-hover);gap:2px;height:48px;display:flex;overflow:hidden}.timeline-slot{transition:background var(--transition);flex:1;position:relative}.timeline-slot.occupied{background:var(--color-primary);opacity:.7}.timeline-slot.available:hover{cursor:pointer;background:#0f766e26}.booking-card{align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.booking-card .booking-main{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.booking-card .booking-time{font-family:var(--font-display);color:var(--color-text);flex-wrap:wrap;align-items:center;gap:5px;font-size:.875rem;font-weight:600;display:flex}.booking-card .booking-resource{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.booking-card .booking-user{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:4px;font-size:.8125rem;display:flex;overflow:hidden}.booking-card .booking-purpose{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.resource-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.resource-card{cursor:pointer;transition:all var(--transition);padding:20px}.resource-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.resource-card.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px #0f766e33}.resource-card h4{margin-bottom:8px}.resource-card .resource-meta{color:var(--color-text-secondary);gap:12px;font-size:.8125rem;display:flex}.branding-preview{border-radius:var(--radius-lg);border:1px solid var(--color-border);margin-top:16px;padding:24px}.color-picker-group{align-items:center;gap:12px;display:flex}.color-picker-group input[type=color]{border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:0 0;width:48px;height:48px;padding:2px}.tabs{border-bottom:1px solid var(--color-border);gap:4px;margin-bottom:24px;display:flex}.tab{color:var(--color-text-secondary);transition:all var(--transition);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;font-size:.875rem;font-weight:500}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.calendar-nav{align-items:center;gap:16px;margin-bottom:20px;display:flex}.calendar-nav h3{text-align:center;min-width:200px}.day-header{text-align:center;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:8px;font-size:.75rem}.day-header .day-date{font-family:var(--font-display);color:var(--color-text);margin-top:2px;font-size:1.25rem;font-weight:600;display:block}.day-header.today .day-date{color:var(--color-primary)}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.select-wrapper{position:relative}.select-wrapper select{appearance:none;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:8px 32px 8px 14px;font-size:.875rem}.empty-state{text-align:center;color:var(--color-text-secondary);padding:48px 24px}.empty-state h3{color:var(--color-text-muted);margin-bottom:8px}.timeline-grid{flex-direction:column;gap:4px;display:flex}.timeline-row{gap:2px;display:flex}.timeline-hour-block{flex-direction:column;flex:1;gap:2px;display:flex}.timeline-hour-label{color:var(--color-text-muted);text-align:center;padding-bottom:1px;font-size:.625rem;line-height:1}.timeline-quarters{gap:1px;display:flex}.timeline-quarter{height:14px;transition:background var(--transition);border-radius:2px;flex:1}.timeline-quarter.occupied{background:var(--color-primary);opacity:.75;cursor:default}.timeline-quarter.available{background:var(--color-hover);cursor:pointer}.timeline-quarter.available:hover{background:#0f766e40}.timeline-quarter.occupied{cursor:pointer}.timeline-quarter.occupied:hover{opacity:1}.booking-slot-popover{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;flex-direction:column;gap:6px;min-width:180px;max-width:260px;padding:10px 12px;font-size:.875rem;display:flex;box-shadow:0 4px 16px #00000026}.booking-slot-popover-row{color:var(--color-text);align-items:center;gap:6px;line-height:1.3;display:flex}.week-day-btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:all var(--transition);cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;font-size:.75rem;display:flex;position:relative}.week-day-btn:hover{background:var(--color-hover);color:var(--color-text)}.week-day-btn.selected{color:var(--color-primary);background:#0f766e1a;border-color:#0f766e4d}.week-day-btn.today .week-day-num{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.week-day-btn.has-holiday{color:#b45309}[data-theme=dark] .week-day-btn.has-holiday{color:#fcd34d}.week-day-name{text-transform:uppercase;letter-spacing:.3px;color:inherit;font-size:.6875rem}.week-day-num{font-family:var(--font-display);font-size:1rem;font-weight:600;line-height:1}.week-holiday-dot{background:#b45309;border-radius:50%;width:4px;height:4px;position:absolute;bottom:3px}[data-theme=dark] .week-holiday-dot{background:#fcd34d}.holiday-banner{border-radius:var(--radius-sm);color:#92400e;background:#b453091f;align-items:center;gap:6px;margin-top:8px;padding:6px 10px;font-size:.75rem;font-weight:500;display:flex}[data-theme=dark] .holiday-banner{color:#fbbf24;background:#fcd34d1f}.month-cal-popover{z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:260px;padding:12px;position:absolute;top:calc(100% + 4px);left:0}.month-calendar{-webkit-user-select:none;user-select:none}.month-calendar-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.month-calendar-title{font-family:var(--font-display);font-size:.9375rem;font-weight:600}.month-calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.month-cal-header{text-align:center;color:var(--color-text-muted);text-transform:uppercase;padding:4px 0;font-size:.6875rem;font-weight:600}.month-cal-day{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);flex-direction:column;justify-content:center;align-items:center;gap:2px;font-size:.75rem;display:flex;position:relative}.month-cal-day:not(.empty):hover{background:var(--color-hover)}.month-cal-day.empty{cursor:default}.month-cal-day.in-week{background:#0f766e14}.month-cal-day.today .month-cal-day-num{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.month-cal-day.past{color:var(--color-text-muted)}.month-cal-day.holiday{color:#b45309}[data-theme=dark] .month-cal-day.holiday{color:#fcd34d}.month-cal-day-num{font-weight:500;line-height:1}.holiday-dot{background:#b45309;border-radius:50%;width:4px;height:4px}[data-theme=dark] .holiday-dot{background:#fcd34d}.region-picker-dropdown{z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:260px;max-height:320px;padding:8px;position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto}.region-picker-item{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);align-items:center;gap:8px;padding:6px 8px;font-size:.8125rem;display:flex}.region-picker-item:hover{background:var(--color-hover)}.region-picker-item input[type=checkbox]{accent-color:var(--color-primary);flex-shrink:0;width:14px;height:14px}.region-type-badge{letter-spacing:.3px;border-radius:4px;flex-shrink:0;padding:2px 5px;font-size:.625rem;font-weight:700}.region-national{color:var(--color-primary);background:#0f766e26}.region-community{color:#4f46e5;background:#6366f126}.region-local{color:#c2410c;background:#f9731626}.time-picker{justify-content:center;align-items:center;gap:6px;padding:10px 0 6px;display:flex}.time-picker-col{flex-direction:column;align-items:center;gap:2px;display:flex}.time-picker-val{font-family:var(--font-display);text-align:center;min-width:2ch;color:var(--color-text);letter-spacing:.02em;font-size:1.75rem;font-weight:700;line-height:1.1}.time-picker-sep{font-family:var(--font-display);color:var(--color-text-muted);align-self:center;margin-bottom:4px;font-size:1.75rem;font-weight:700;line-height:1.1}.time-picker-arrow{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:2px 10px;transition:background .15s,color .15s;display:flex}.time-picker-arrow:hover{background:var(--color-hover);color:var(--color-primary)}
