*{box-sizing:border-box;margin:0;padding:0}:root{--green-50:#f0fdf4;--green-100:#dcfce7;--green-200:#bbf7d0;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--green-800:#166534;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--white:#fff;--danger:#ef4444;--danger-light:#fef2f2;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--room-a:#3b82f6;--room-a-light:#eff6ff;--room-a-border:#93c5fd;--room-b:#8b5cf6;--room-b-light:#f5f3ff;--room-b-border:#c4b5fd}body{background:var(--gray-50);color:var(--gray-800);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--green-600);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--green-700)}.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover:not(:disabled){background:var(--gray-50)}.btn-sm{padding:5px 12px;font-size:12px}.btn-icon{border-radius:var(--radius);cursor:pointer;color:var(--gray-500);background:0 0;border:none;align-items:center;padding:8px;display:flex}.btn-icon:hover{background:var(--gray-100)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-light)!important}.btn-full{justify-content:center;width:100%}.form-group{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.form-group label{color:var(--gray-600);font-size:13px;font-weight:500}.form-group input,.form-group select{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--white);color:var(--gray-800);outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--green-500);box-shadow:0 0 0 3px #22c55e1a}.form-group input::placeholder{color:var(--gray-400)}.input-disabled{cursor:not-allowed;background:var(--gray-100)!important;color:var(--gray-500)!important}.form-hint{color:var(--gray-400);font-size:12px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.auth-container{background:var(--white);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{width:100%;max-width:400px}.auth-header{text-align:center;margin-bottom:32px}.auth-icon{background:var(--green-50);width:48px;height:48px;color:var(--green-600);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.auth-header h1{color:var(--gray-900);margin-bottom:4px;font-size:24px;font-weight:600}.auth-header p{color:var(--gray-500);font-size:14px}.auth-footer{text-align:center;color:var(--gray-500);margin-top:24px;font-size:14px}.auth-footer a{color:var(--green-600);font-weight:500;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.layout{flex-direction:column;min-height:100vh;display:flex}.navbar{background:var(--white);border-bottom:1px solid var(--gray-200);z-index:50;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.nav-brand{color:var(--green-700);align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.nav-links{gap:4px;display:flex}.nav-links a{border-radius:var(--radius);color:var(--gray-500);align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-links a:hover{background:var(--gray-100);color:var(--gray-700)}.nav-links a.active{background:var(--green-50);color:var(--green-700)}.nav-right{align-items:center;gap:8px;display:flex}.nav-user{color:var(--gray-500);font-size:13px}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dashboard-header h1{color:var(--gray-900);font-size:22px;font-weight:600}.filter-tabs{border-bottom:1px solid var(--gray-200);gap:4px;margin-bottom:20px;padding-bottom:0;display:flex}.tab{color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:13px;font-weight:500;transition:color .15s}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--green-600);border-bottom-color:var(--green-600)}.calendar-nav{align-items:center;gap:12px;margin-bottom:16px;display:flex}.calendar-nav-arrows{align-items:center;gap:4px;display:flex}.calendar-nav-label{color:var(--gray-800);text-transform:capitalize;font-size:15px;font-weight:600}.rooms-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.room-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:14px 16px}.room-card-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.room-card-header h3{color:var(--gray-800);font-size:15px;font-weight:600}.room-status{text-transform:uppercase;letter-spacing:.3px;border-radius:10px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:600}.room-status.free{background:var(--green-50);color:var(--green-700)}.room-status.occupied{background:var(--danger-light);color:var(--danger)}.room-card-details{justify-content:space-between;align-items:center;display:flex}.room-capacity{color:var(--gray-500);align-items:center;gap:4px;font-size:13px;display:flex}.room-bookings{font-size:12px;font-weight:600}.room-legend{align-items:center;gap:16px;display:flex}.legend-item{color:var(--gray-600);align-items:center;gap:6px;font-size:13px;display:flex}.legend-dot{border-radius:3px;width:10px;height:10px}.today-view{margin-top:8px}.today-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.today-header h2{color:var(--gray-800);text-transform:capitalize;font-size:16px;font-weight:600}.timeline{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden}.timeline-header{border-bottom:1px solid var(--gray-200);background:var(--gray-50);grid-template-columns:56px 1fr 1fr;display:grid}.timeline-hour-col{padding:8px}.timeline-room-col-header{color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;border-left:1px solid var(--gray-200);text-align:center;padding:8px 12px;font-size:12px;font-weight:600}.timeline-body{margin-left:56px;position:relative}.time-slot{align-items:center;height:0;display:flex;position:absolute;left:-56px;right:0}.time-label{text-align:right;width:56px;color:var(--gray-400);padding-right:10px;font-size:11px;font-weight:500;position:absolute;left:0;transform:translateY(-50%)}.time-line{background:var(--gray-100);height:1px;position:absolute;left:56px;right:0}.current-time-line{z-index:10;pointer-events:none;align-items:center;display:flex;position:absolute;left:-56px;right:0}.current-time-dot{background:var(--danger);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-left:50px}.current-time-rule{background:var(--danger);opacity:.6;flex:1;height:2px}.timeline-columns{grid-template-columns:1fr 1fr;gap:0;display:grid;position:absolute;inset:0}.timeline-room-col{border-left:1px solid var(--gray-200);padding:0 6px;position:relative}.timeline-block{cursor:pointer;z-index:5;border-left:3px solid;border-radius:6px;padding:6px 8px;transition:box-shadow .15s;position:absolute;left:6px;right:6px;overflow:hidden}.timeline-block:hover{box-shadow:var(--shadow)}.timeline-block-content{flex-direction:column;gap:1px;min-width:0;display:flex}.timeline-block-title{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.timeline-block-time{color:var(--gray-500);font-size:10px}.timeline-block-owner{color:var(--gray-400);font-size:10px}.timeline-block-lock{color:var(--danger);position:absolute;top:6px;right:6px}.timeline-block.in-use{border-left-color:var(--danger);box-shadow:0 0 0 1px #ef444426}.week-view{margin-top:8px}.week-grid{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);grid-template-columns:repeat(7,1fr);gap:0;display:grid;overflow:hidden}.week-day-column{border-right:1px solid var(--gray-200);min-height:180px}.week-day-column:last-child{border-right:none}.week-day-header{border-bottom:1px solid var(--gray-200);background:var(--gray-50);flex-direction:column;align-items:center;gap:2px;padding:10px 4px 8px;display:flex}.day-name{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.day-number{color:var(--gray-700);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;font-weight:600;display:flex}.today-number{background:var(--green-600);color:var(--white)}.week-day-column.is-today{background:#22c55e05}.week-day-body{flex-direction:column;gap:4px;padding:6px;display:flex}.week-empty{text-align:center;color:var(--gray-300);padding:8px 0;font-size:13px}.week-chip{cursor:pointer;border-left:3px solid;border-radius:6px;padding:6px 8px;transition:box-shadow .15s}.week-chip:hover{box-shadow:var(--shadow-sm)}.week-chip-header{justify-content:space-between;align-items:center;gap:4px;display:flex}.week-chip-title{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:600;overflow:hidden}.week-chip-time{color:var(--gray-500);font-size:10px;display:block}.week-chip-room{margin-top:1px;font-size:10px;font-weight:600;display:block}.week-chip-owner{color:var(--gray-400);font-size:10px;display:block}.week-chip.in-use{border-left-color:var(--danger);box-shadow:0 0 0 1px #ef444426}.chip-lock{color:var(--danger);flex-shrink:0}.month-view{margin-top:8px}.month-grid{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden}.month-header-row{background:var(--gray-50);border-bottom:1px solid var(--gray-200);grid-template-columns:repeat(7,1fr);display:grid}.month-header-cell{text-align:center;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;padding:8px;font-size:11px;font-weight:600}.month-week-row{border-bottom:1px solid var(--gray-100);grid-template-columns:repeat(7,1fr);display:grid}.month-week-row:last-child{border-bottom:none}.month-day-cell{border-right:1px solid var(--gray-100);cursor:pointer;min-height:90px;padding:6px;transition:background .1s}.month-day-cell:last-child{border-right:none}.month-day-cell:hover{background:var(--gray-50)}.month-day-cell.other-month{opacity:.35}.month-day-cell.is-today{background:#22c55e0a}.month-day-number{color:var(--gray-600);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin-bottom:4px;font-size:13px;font-weight:500;display:inline-flex}.month-day-number.today-number{background:var(--green-600);color:var(--white);font-weight:600}.month-day-reservations{flex-direction:column;gap:2px;display:flex}.month-bar{border-radius:3px;align-items:center;height:18px;padding:0 4px;display:flex;overflow:hidden}.month-bar-text{color:var(--white);white-space:nowrap;text-overflow:ellipsis;font-size:10px;font-weight:500;overflow:hidden}.month-more{color:var(--gray-400);padding-left:2px;font-size:10px;font-weight:500}.reservation-chip{border-left:3px solid;border-radius:6px;padding:8px 10px}.chip-content{flex-direction:column;gap:2px;display:flex}.chip-header{justify-content:space-between;align-items:center;gap:4px;display:flex}.chip-title{color:var(--gray-800);font-size:13px;font-weight:600}.chip-time{color:var(--gray-500);font-size:12px}.chip-room{font-size:11px;font-weight:600}.chip-owner{color:var(--gray-400);font-size:11px}.reservation-chip.in-use{border-left-color:var(--danger)}.star-icon{color:#f59e0b;fill:#f59e0b;vertical-align:middle;flex-shrink:0;margin-right:3px}.star-icon-white{color:#fbbf24;fill:#fbbf24}.special-toggle{border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;color:var(--gray-700);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-bottom:16px;padding:10px 12px;font-size:14px;transition:border-color .15s,background .15s;display:flex}.special-toggle:hover{background:var(--gray-50)}.special-toggle input[type=checkbox]{display:none}.special-star{color:var(--gray-300);transition:color .15s}.special-star.active{color:#f59e0b;fill:#f59e0b}.modal-sm{max-width:380px}.detail-body{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.detail-row{justify-content:space-between;align-items:center;display:flex}.detail-label{color:var(--gray-500);font-size:13px}.detail-value{color:var(--gray-800);font-size:13px;font-weight:500}.detail-actions{border-top:1px solid var(--gray-200);gap:8px;padding-top:16px;display:flex}.btn-danger-outline{border:1px solid var(--danger);border-radius:var(--radius);background:var(--white);color:var(--danger);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.btn-danger-outline:hover{background:var(--danger-light)}.modal-overlay{z-index:100;background:#0000004d;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow-md);padding:24px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{color:var(--gray-900);font-size:18px;font-weight:600}.modal-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.profile-page{justify-content:center;padding-top:24px;display:flex}.profile-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:32px}.profile-header{text-align:center;margin-bottom:28px}.profile-avatar{background:var(--green-50);width:56px;height:56px;color:var(--green-600);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 12px;display:flex}.profile-header h1{color:var(--gray-900);font-size:20px;font-weight:600}.loading-container{justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--green-600);border-radius:50%;width:32px;height:32px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.dashboard-header{flex-direction:column;gap:12px}.navbar{padding:0 16px}.main-content{padding:16px}.form-row{grid-template-columns:1fr}.today-header{flex-direction:column;align-items:flex-start;gap:8px}.week-grid{grid-template-columns:repeat(7,minmax(120px,1fr));overflow-x:auto}.month-day-cell{min-height:60px;padding:4px}.month-bar{height:14px}.month-bar-text{font-size:9px}}
