:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;background:#2c3e50;color:#fff;display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{font-size:18px;font-weight:600;margin-bottom:4px}.sidebar-header p{font-size:12px;opacity:.7}.sidebar-nav{flex:1;padding:10px;overflow-y:auto}.nav-item{display:flex;align-items:center;padding:12px 16px;margin-bottom:4px;border-radius:6px;cursor:pointer;transition:background .2s;color:#fffc;text-decoration:none;font-size:14px}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#3498db;color:#fff}.sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;margin-bottom:10px}.user-avatar{width:32px;height:32px;border-radius:50%;background:#3498db;display:flex;align-items:center;justify-content:center;font-weight:600;margin-right:10px}.user-details h4{font-size:14px;font-weight:500}.user-details p{font-size:12px;opacity:.7}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:60px;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:16px}.topbar-right{display:flex;align-items:center;gap:12px}.content-area{flex:1;overflow-y:auto;padding:24px;background:#f5f5f5}button{font-family:inherit;font-size:14px;padding:8px 16px;border-radius:6px;border:none;cursor:pointer;transition:all .2s;font-weight:500}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9}.btn-primary:disabled{background:#bdc3c7;cursor:not-allowed}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-success{background:#27ae60;color:#fff}.btn-success:hover{background:#229954}.form-group{margin-bottom:16px}label{display:block;margin-bottom:6px;font-weight:500;font-size:14px;color:#2c3e50}input,select,textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;transition:border .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:#3498db}textarea{resize:vertical;min-height:80px}.card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e0e0e0}.card-header h2{font-size:18px;font-weight:600;color:#2c3e50}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:8px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.quick-book-modal,.booking-form-modal,.room-form-modal{max-width:900px}.booking-form-header{position:relative;justify-content:center}.booking-form-title{width:100%;text-align:center}.booking-form-header button{position:absolute;right:20px}.quick-book-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:16px}.quick-book-full-width{grid-column:1 / -1}.booking-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:16px}.booking-form-full-width{grid-column:1 / -1}.room-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:16px}.room-form-full-width{grid-column:1 / -1}.booking-audit-box{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:10px 12px}.booking-audit-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:13px;color:#2c3e50}.booking-color-picker{display:flex;flex-wrap:wrap;gap:10px}.booking-color-swatch{width:34px;height:34px;border-radius:6px;border:2px solid transparent;cursor:pointer;padding:0}.booking-color-swatch.selected{border-color:#2c3e50;box-shadow:0 0 0 2px #dfe6e9}.booking-color-swatch:hover{transform:scale(1.05)}.modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:18px;font-weight:600;color:#2c3e50}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end}@media (max-width: 768px){.quick-book-grid{grid-template-columns:1fr}.quick-book-full-width{grid-column:auto}.booking-form-grid{grid-template-columns:1fr}.booking-form-full-width{grid-column:auto}.room-form-grid{grid-template-columns:1fr}.room-form-full-width{grid-column:auto}}.calendar-view{background:#fff;border-radius:8px;padding:20px;min-height:500px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.calendar-grid{display:grid;grid-template-columns:80px repeat(7,1fr);gap:1px;background:#e0e0e0;border:1px solid #e0e0e0}.time-slot,.room-slot{background:#fff;padding:8px;min-height:60px}.time-slot{display:flex;align-items:center;justify-content:center;font-size:12px;color:#7f8c8d;font-weight:500}.booking-block{background:#3498db;color:#fff;padding:8px;border-radius:4px;font-size:12px;cursor:pointer;transition:background .2s}.booking-block:hover{background:#2980b9}.booking-block.cancelled{background:#95a5a6;opacity:.6}table{width:100%;border-collapse:collapse}thead{background:#f8f9fa}th,td{padding:12px;text-align:left;border-bottom:1px solid #e0e0e0;font-size:14px}th{font-weight:600;color:#2c3e50}tbody tr:hover{background:#f8f9fa}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;border-radius:12px;padding:40px;width:400px;box-shadow:0 10px 40px #0003}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:24px;margin-bottom:8px;color:#2c3e50}.login-header p{color:#7f8c8d;font-size:14px}.alert{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:14px}.alert-error{background:#fee;color:#c0392b;border:1px solid #e74c3c}.alert-success{background:#efe;color:#27ae60;border:1px solid #27ae60}.alert-warning{background:#ffeaa7;color:#d35400;border:1px solid #e67e22}.alert-info{background:#d6eaf8;color:#2874a6;border:1px solid #3498db}.filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.filter-item{display:flex;flex-direction:column;min-width:200px}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.badge-primary{background:#d6eaf8;color:#2874a6}.badge-success{background:#d5f4e6;color:#27ae60}.badge-danger{background:#fadbd8;color:#c0392b}.badge-warning{background:#fdebd0;color:#d68910}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.flex{display:flex}.flex-col{flex-direction:column}.gap-1{gap:8px}.gap-2{gap:16px}.items-center{align-items:center}.justify-between{justify-content:space-between}
