:root{--bg-primary: #f0f9ff;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #e0f2fe;--bg-glass: rgba(255, 255, 255, .92);--bg-input: #e0f2fe;--bg-sidebar: #0c4a6e;--bg-modal: rgba(12, 74, 110, .5);--accent-primary: #0ea5e9;--accent-primary-hover: #0284c7;--accent-secondary: #38bdf8;--accent-gradient: linear-gradient(135deg, #0ea5e9, #0284c7, #38bdf8);--accent-glow: 0 0 25px rgba(14, 165, 233, .2);--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #94a3b8;--text-accent: #0ea5e9;--border-color: rgba(12, 74, 110, .1);--border-active: rgba(14, 165, 233, .4);--success: #059669;--success-bg: rgba(5, 150, 105, .1);--warning: #d97706;--warning-bg: rgba(217, 119, 6, .1);--danger: #dc2626;--danger-bg: rgba(220, 38, 38, .08);--info: #2563eb;--info-bg: rgba(37, 99, 235, .08);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs: .75rem;--font-sm: .8125rem;--font-base: .875rem;--font-md: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 50%;--shadow-sm: 0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.06);--shadow-md: 0 4px 12px rgba(15,23,42,.1), 0 2px 6px rgba(15,23,42,.06);--shadow-lg: 0 8px 32px rgba(15,23,42,.12), 0 4px 12px rgba(15,23,42,.07);--shadow-glow: 0 0 40px rgba(14, 165, 233, .12);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--sidebar-width: 260px;--sidebar-collapsed: 72px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--text-primary);background:var(--bg-primary);line-height:1.6;overflow-x:hidden;min-height:100vh}a{color:var(--text-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-primary-hover)}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideToast{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideToastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.animate-fade{animation:fadeIn .4s ease forwards}.animate-slide-left{animation:slideInLeft .4s ease forwards}.animate-slide-right{animation:slideInRight .4s ease forwards}.animate-slide-up{animation:slideInUp .5s ease forwards}.animate-scale{animation:scaleIn .3s ease forwards}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(14,165,233,.12) 0%,transparent 70%);top:-200px;right:-200px;border-radius:50%}.login-page:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(56,189,248,.1) 0%,transparent 70%);bottom:-150px;left:-150px;border-radius:50%}.login-card{position:relative;z-index:1;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-12);width:100%;max-width:420px;box-shadow:var(--shadow-lg);animation:scaleIn .5s ease}.login-logo{text-align:center;margin-bottom:var(--space-8)}.login-logo h1{font-size:var(--font-3xl);font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.login-logo p{color:var(--text-secondary);font-size:var(--font-sm);margin-top:var(--space-1)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width var(--transition-base);overflow-y:auto;overflow-x:hidden}.sidebar-brand{padding:var(--space-6);border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:var(--space-3)}.sidebar-brand-icon{width:38px;height:38px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:var(--font-lg);flex-shrink:0}.sidebar-brand-text h2{font-size:var(--font-md);font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.sidebar-brand-text span{font-size:var(--font-xs);color:var(--text-muted)}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-3)}.sidebar-section-title{font-size:.6875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px;padding:var(--space-4) var(--space-3) var(--space-2)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);margin-bottom:2px;position:relative;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{color:var(--text-primary);background:#0ea5e914}.sidebar-link.active{color:var(--accent-primary-hover);background:#0ea5e924}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent-gradient);border-radius:0 3px 3px 0}.sidebar-link i,.sidebar-link svg{width:18px;height:18px;flex-shrink:0}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--border-color)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md)}.sidebar-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-sm);flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-info .name{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-info .role{font-size:var(--font-xs);color:var(--text-muted)}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.topbar{height:64px;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);position:sticky;top:0;z-index:50}.topbar-left{display:flex;align-items:center;gap:var(--space-4)}.topbar-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary)}.topbar-breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-muted)}.topbar-breadcrumb .separator{color:var(--text-muted)}.topbar-breadcrumb .current{color:var(--text-primary);font-weight:500}.topbar-right{display:flex;align-items:center;gap:var(--space-3)}.page-content{flex:1;padding:var(--space-8)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8);animation:fadeIn .4s ease}.page-header-left h1{font-size:var(--font-2xl);font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.page-header-left p{color:var(--text-secondary);font-size:var(--font-sm);margin-top:var(--space-1)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.card:hover{border-color:var(--border-active);box-shadow:var(--shadow-glow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.card-title{font-size:var(--font-md);font-weight:600;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--transition-base);animation:fadeIn .5s ease backwards}.stat-card:nth-child(1){animation-delay:.05s}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-card:nth-child(4){animation-delay:.2s}.stat-card:hover{transform:translateY(-2px);border-color:var(--border-active);box-shadow:var(--shadow-glow)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.purple{background:#0ea5e926;color:var(--accent-primary)}.stat-icon.green{background:var(--success-bg);color:var(--success)}.stat-icon.orange{background:var(--warning-bg);color:var(--warning)}.stat-icon.blue{background:var(--info-bg);color:var(--info)}.stat-icon.red{background:var(--danger-bg);color:var(--danger)}.stat-info h3{font-size:var(--font-3xl);font-weight:800;color:var(--text-primary);line-height:1}.stat-info p{font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-1)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;border:none;transition:all var(--transition-fast);white-space:nowrap;line-height:1.5}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 10px #0ea5e94d}.btn-primary:hover{box-shadow:0 4px 20px #0ea5e973;transform:translateY(-1px)}.btn-secondary{background:var(--bg-input);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--border-active);color:var(--text-primary)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444433}.btn-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(16,185,129,.2)}.btn-success:hover{background:#10b98133}.btn-ghost{background:transparent;color:var(--text-secondary);padding:var(--space-2)}.btn-ghost:hover{color:var(--text-primary);background:#94a3b814}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-md)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.btn:disabled,.btn.loading{opacity:.6;pointer-events:none}.btn .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-base);transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #0ea5e926}.form-input::placeholder{color:var(--text-muted)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-error{font-size:var(--font-xs);color:var(--danger);margin-top:var(--space-1)}.form-checkbox{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color);animation:fadeIn .5s ease}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-secondary)}.data-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#0ea5e90a}.data-table tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;align-items:center;gap:var(--space-2)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-3);border-radius:999px;font-size:var(--font-xs);font-weight:600;letter-spacing:.3px}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-purple{background:#6366f11f;color:var(--accent-primary-hover)}.badge-neutral{background:#94a3b81f;color:var(--text-secondary)}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.modal-overlay{position:fixed;inset:0;background:var(--bg-modal);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .2s ease}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:scaleIn .3s ease}.modal-lg{max-width:740px}.modal-xl{max-width:920px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:var(--font-lg);font-weight:700;color:var(--text-primary)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color)}#toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:300;display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.toast{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);display:flex;align-items:center;gap:var(--space-3);min-width:320px;max-width:440px;box-shadow:var(--shadow-lg);animation:slideToast .3s ease;pointer-events:auto}.toast.removing{animation:slideToastOut .3s ease forwards}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--danger)}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon{color:var(--info)}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-warning{border-left:3px solid var(--warning)}.toast-info{border-left:3px solid var(--info)}.toast-message{flex:1;font-size:var(--font-sm);color:var(--text-primary)}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px}.empty-state{text-align:center;padding:var(--space-12) var(--space-8);color:var(--text-muted)}.empty-state svg{width:48px;height:48px;margin-bottom:var(--space-4);opacity:.5}.empty-state h3{font-size:var(--font-md);color:var(--text-secondary);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--font-sm);max-width:360px;margin:0 auto var(--space-4)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--space-12)}.loading-spinner:after{content:"";width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .7s linear infinite}.toolbar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.toolbar-search{position:relative;flex:1;max-width:360px}.toolbar-search input{width:100%;padding:var(--space-2) var(--space-4) var(--space-2) 36px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-sm);outline:none;transition:all var(--transition-fast)}.toolbar-search input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #0ea5e926}.toolbar-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted)}.toolbar-filter{display:flex;align-items:center;gap:var(--space-2)}.toolbar-filter select{padding:var(--space-2) var(--space-8) var(--space-2) var(--space-3);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.detail-item label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.detail-item p{font-size:var(--font-base);color:var(--text-primary);margin-top:var(--space-1);font-weight:500}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color);margin-bottom:var(--space-6)}.tab{padding:var(--space-3) var(--space-5);font-size:var(--font-sm);font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent-primary-hover);border-bottom-color:var(--accent-primary)}.confirm-content{text-align:center;padding:var(--space-4) 0}.confirm-content .icon{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4)}.confirm-content .icon.danger{background:var(--danger-bg);color:var(--danger)}.confirm-content .icon.warning{background:var(--warning-bg);color:var(--warning)}.confirm-content h3{font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.confirm-content p{color:var(--text-secondary);font-size:var(--font-sm)}.avail-grid{display:grid;gap:2px;font-size:var(--font-xs)}.avail-header{display:flex;gap:2px;margin-bottom:var(--space-2)}.avail-room-row{display:flex;align-items:center;gap:2px;margin-bottom:2px}.avail-room-label{width:100px;font-weight:600;color:var(--text-secondary);font-size:var(--font-xs);flex-shrink:0;padding-right:var(--space-2)}.avail-cell{width:32px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0}.avail-cell.available{background:#10b98126;color:var(--success)}.avail-cell.occupied{background:#ef444426;color:var(--danger)}.avail-cell.maintenance{background:#f59e0b26;color:var(--warning)}.avail-cell.header{background:var(--bg-secondary);color:var(--text-muted);font-size:9px}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.page-content{padding:var(--space-4)}.stats-grid,.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}}.sidebar{color-scheme:dark}.sidebar .sidebar-brand-text h2{color:#fff}.sidebar .sidebar-brand-text span,.sidebar .sidebar-section-title{color:#7dd3fc}.sidebar .sidebar-link{color:#e2e8f0}.sidebar .sidebar-link:hover{color:#fff;background:#ffffff1f}.sidebar .sidebar-link.active{color:#fff;background:#0ea5e94d}.sidebar .sidebar-link.active i,.sidebar .sidebar-link.active svg{color:#7dd3fc}.sidebar .sidebar-user-info .name{color:#fff}.sidebar .sidebar-user-info .role{color:#7dd3fc}.sidebar .sidebar-footer{border-top-color:#ffffff26}.sidebar-group-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#475569;padding:var(--space-3) var(--space-6) var(--space-1);margin-top:var(--space-1)}.sidebar .sidebar-group-label{color:#93c5fd}.sidebar-link-sub{padding-left:calc(var(--space-6) + 12px);font-size:var(--font-sm)}.sidebar-link-sub i{width:16px;height:16px}.stats-grid-6{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}@media(max-width:1200px){.stats-grid-6{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.stats-grid-6{grid-template-columns:repeat(2,1fr)}}.stat-card-v2{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;align-items:center;gap:var(--space-3);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat-card-v2:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-v2-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-v2-icon i{width:22px;height:22px}.stat-v2-info h3{font-size:var(--font-2xl);font-weight:800;color:var(--text-primary);line-height:1.1}.stat-v2-info p{font-size:var(--font-xs);color:var(--text-muted);margin-top:2px}.stat-occupied .stat-v2-icon{background:#ef444426;color:#ef4444}.stat-vacant .stat-v2-icon{background:#10b98126;color:var(--success)}.stat-arrival .stat-v2-icon{background:#3b82f626;color:var(--info)}.stat-departure .stat-v2-icon{background:#f59e0b26;color:var(--warning)}.stat-checkedin .stat-v2-icon{background:#0ea5e926;color:var(--accent-primary)}.stat-checkedout .stat-v2-icon{background:#0ea5e926;color:var(--accent-secondary)}.filter-chips{display:flex;gap:var(--space-2);flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:5px 12px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:var(--font-xs);font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.filter-chip:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.filter-chip.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.chip-count{background:#fff3;border-radius:8px;padding:0 6px;font-size:10px}.filter-chip.active .chip-count{background:#ffffff4d}.room-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:var(--space-4)}.room-card{border-radius:var(--radius-lg);border:1px solid var(--border-color);position:relative;overflow:hidden;transition:transform var(--transition-fast),box-shadow var(--transition-fast);cursor:default}.room-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.room-card-inner{padding:var(--space-3) var(--space-4);position:relative;z-index:1;height:100%;display:flex;flex-direction:column;min-height:160px}.room-card-watermark{position:absolute;right:-10px;bottom:-10px;opacity:.06;z-index:0}.room-card-watermark i{width:90px;height:90px}.room-card-vacant{background:#10b98114;border-color:#10b98140}.room-card-occupied{background:#ef64441a;border-color:#ef64444d}.room-card-arrived{background:#3b82f61a;border-color:#3b82f64d}.room-card-dueout{background:#f59e0b1a;border-color:#f59e0b59}.room-card-maintenance{background:#64748b1f;border-color:#64748b4d}.room-card-blocked{background:#64748b14;border-color:#64748b33}.room-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.room-card-number{font-size:var(--font-xl);font-weight:800;color:var(--text-primary);line-height:1.1}.room-card-type{font-size:var(--font-xs);color:var(--text-muted);margin-top:2px}.room-card-guest{flex:1;margin-bottom:var(--space-2)}.room-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.room-card-actions{display:flex;gap:4px}.room-card-actions .btn{color:var(--text-muted)}.room-card-actions .btn:hover{color:var(--text-primary)}.room-status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.badge-dueout{background:#f59e0b33;color:var(--warning);border:1px solid rgba(245,158,11,.4)}.badge-arrived{background:#10b98133;color:var(--success);border:1px solid rgba(16,185,129,.4)}.badge-occupied{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.4)}.badge-vacant{background:#10b98126;color:var(--success);border:1px solid rgba(16,185,129,.3)}.badge-maintenance{background:#f59e0b26;color:var(--warning);border:1px solid rgba(245,158,11,.3)}.badge-blocked{background:#64748b26;color:var(--text-secondary);border:1px solid rgba(100,116,139,.3)}.form-section-box{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-4)}.form-section-title{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-primary);margin-bottom:var(--space-3)}.booking-item-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-4);animation:fadeIn .2s ease;box-shadow:var(--shadow-sm)}.booking-item-card:last-child{margin-bottom:0}.layout-block-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.layout-block-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent-primary)}.layout-block-header{padding:var(--space-4) var(--space-5);display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.layout-block-body{padding:var(--space-4) var(--space-5);min-height:80px}.layout-floor-preview{margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.layout-floor-preview:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.layout-room-cell{display:inline-flex;align-items:center;justify-content:center;width:40px;height:32px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);border:1px solid transparent;-webkit-user-select:none;user-select:none}.layout-room-cell:hover{transform:scale(1.1);box-shadow:var(--shadow-sm);z-index:1;position:relative}.layout-room-cell-lg{display:flex;flex-direction:column;align-items:center;justify-content:center;width:120px;height:100px;border-radius:var(--radius-md);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);border:1px solid transparent;padding:var(--space-2);gap:2px}.layout-room-cell-lg:hover{transform:scale(1.05);box-shadow:var(--shadow-md);z-index:1;position:relative}.layout-room-number{font-size:var(--font-md);font-weight:800}.layout-room-type{font-size:10px;text-align:center;opacity:.8}.layout-room-booking{font-size:9px;opacity:.7}.layout-room-dates{font-size:9px;opacity:.7;text-align:center}.layout-room-vacant{background:#10b98126;color:var(--success);border-color:#10b9814d}.layout-room-occupied{background:#ef644426;color:#f87171;border-color:#ef64444d}.layout-room-arrived{background:#3b82f626;color:#60a5fa;border-color:#3b82f64d}.layout-room-dueout{background:#f59e0b26;color:var(--warning);border-color:#f59e0b4d}.layout-room-maintenance{background:#f59e0b1a;color:var(--warning);border-color:#f59e0b40}.layout-room-blocked{background:#64748b1f;color:var(--text-muted);border-color:#64748b33}.layout-floor-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.layout-floor-header{padding:var(--space-3) var(--space-5);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.layout-floor-rooms{padding:var(--space-4) var(--space-5);display:flex;flex-wrap:wrap;gap:var(--space-2)}.layout-floor-rooms-lg{display:flex;flex-wrap:wrap;gap:var(--space-3)}@media(max-width:1200px){.room-cards-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr))}}@media(max-width:768px){.stats-grid-6{grid-template-columns:repeat(2,1fr)}.room-cards-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.layout-floor-rooms-lg .layout-room-cell-lg{width:90px;height:80px}}.checkin-page{min-height:100vh;background:linear-gradient(135deg,#f0f9ff,#e0f2fe,#f0f9ff);display:flex;flex-direction:column;align-items:center;padding:32px 16px 48px;font-family:inherit}.checkin-header{text-align:center;margin-bottom:32px;max-width:480px}.checkin-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:20px;font-size:20px;font-weight:700;color:#1e293b}.checkin-title{font-size:28px;font-weight:800;color:#0f172a;margin:0 0 8px}.checkin-subtitle{color:#64748b;margin:0;font-size:15px;line-height:1.6}.checkin-steps{display:flex;align-items:center;gap:0;margin-bottom:28px}.checkin-step{display:flex;flex-direction:column;align-items:center;gap:6px}.step-num{width:36px;height:36px;border-radius:50%;background:#e2e8f0;color:#94a3b8;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;transition:all .3s ease}.checkin-step.active .step-num{background:#0ea5e9;color:#fff}.checkin-step.done .step-num{background:#10b981;color:#fff}.step-label{font-size:12px;color:#94a3b8;font-weight:500}.checkin-step.active .step-label,.checkin-step.done .step-label{color:#0ea5e9}.checkin-step-line{width:64px;height:2px;background:#e2e8f0;margin-bottom:18px}.checkin-card{background:#fff;border-radius:20px;box-shadow:0 4px 32px #0f172a1a;padding:36px 32px;width:100%;max-width:520px}.checkin-step-title{font-size:20px;font-weight:700;color:#0f172a;margin:0 0 6px}.checkin-step-desc{color:#64748b;font-size:14px;margin:0 0 24px;line-height:1.6}.checkin-field{margin-bottom:16px}.checkin-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.checkin-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.checkin-input{width:100%;padding:11px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:15px;color:#0f172a;background:#f8fafc;outline:none;transition:border-color .2s ease;font-family:inherit;box-sizing:border-box}.checkin-input:focus{border-color:#0ea5e9;background:#fff;box-shadow:0 0 0 3px #0ea5e91a}select.checkin-input{cursor:pointer}textarea.checkin-input{resize:vertical;min-height:80px}.checkin-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 24px;margin-top:8px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s ease,transform .1s ease}.checkin-btn:hover{opacity:.92;transform:translateY(-1px)}.checkin-btn:active{transform:translateY(0)}.checkin-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.checkin-footer{margin-top:32px;font-size:13px;color:#94a3b8;text-align:center}.ci-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@media(max-width:540px){.checkin-card{padding:24px 18px;border-radius:16px}.checkin-field-row{grid-template-columns:1fr;gap:0}.checkin-title{font-size:22px}.checkin-step-line{width:40px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0c4a6e,#0369a1,#0ea5e9);padding:var(--space-6)}.login-card{background:#fff;border-radius:var(--radius-xl);padding:48px 40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0c4a6e59}.login-logo{text-align:center;margin-bottom:36px}.login-brand-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0ea5e9,#0c4a6e);color:#fff;font-size:28px;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 4px 16px #0ea5e966}.login-logo h1{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 4px}.login-logo p{font-size:var(--font-sm);color:var(--text-muted);margin:0}.login-input{background:#f8fafc!important;border:2px solid #e2e8f0!important;color:#0f172a!important;font-size:var(--font-base)!important;padding:12px 16px!important}.login-input:focus{border-color:#0ea5e9!important;background:#fff!important;box-shadow:0 0 0 3px #0ea5e926!important}.login-input::placeholder{color:#94a3b8}.login-btn{width:100%;justify-content:center;margin-top:8px;padding:13px 24px;font-size:var(--font-base);background:linear-gradient(135deg,#0ea5e9,#0284c7)!important;box-shadow:0 4px 14px #0ea5e94d}.login-btn:hover{box-shadow:0 6px 20px #0ea5e973;transform:translateY(-1px)}.login-footer-note{text-align:center;margin-top:16px;font-size:var(--font-xs);color:var(--text-muted)}.btn-logout{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background:#dc26261f;color:#fca5a5;border:1px solid rgba(220,38,38,.25);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-3);font-family:var(--font-family)}.btn-logout:hover{background:#dc262638;color:#f87171;border-color:#dc262673}.btn-logout i{width:16px;height:16px;flex-shrink:0}.sidebar-toggle-btn{display:none}@media(max-width:768px){.sidebar-toggle-btn{display:flex}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:100;transform:translate(-100%);transition:transform .3s ease}.sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 24px #0000004d}.main-content{margin-left:0!important}}.roles-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--space-6);align-items:start;overflow:hidden}.roles-layout>*{min-width:0;overflow:hidden}.roles-layout .table-wrapper{overflow-x:auto}@media(max-width:960px){.roles-layout{grid-template-columns:1fr}}.setup-flow-banner{background:linear-gradient(135deg,#0ea5e914,#0ea5e90a);border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);margin-bottom:var(--space-5);display:flex;align-items:center;gap:var(--space-5);flex-wrap:wrap}.setup-flow-title{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-primary);display:flex;align-items:center;white-space:nowrap}.setup-flow-steps{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.setup-flow-step{display:flex;align-items:center;gap:var(--space-2);padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border-color);color:var(--text-muted);font-size:var(--font-xs);font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.setup-flow-step:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.setup-flow-step.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.setup-flow-num{width:18px;height:18px;border-radius:50%;background:currentColor;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0}.setup-flow-step:not(.active) .setup-flow-num{background:var(--border-color);color:var(--text-muted)}.setup-flow-step.active .setup-flow-num{background:#ffffff4d;color:#fff}.setup-flow-arrow{color:var(--text-muted);font-size:var(--font-sm)}.avail-block-header{display:flex;align-items:center;gap:var(--space-2);font-weight:700;color:var(--text-primary);font-size:var(--font-sm);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:2px solid var(--border-color)}.avail-cell.checked-in{background:#0ea5e92e;color:var(--accent-primary);border:1px solid rgba(14,165,233,.3)}.avail-cell.weekend{background:#f59e0b0d}.avail-legend-item{display:flex;align-items:center;gap:6px;font-size:var(--font-xs);color:var(--text-secondary)}.avail-legend-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0}.payment-balance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-4)}@media(max-width:600px){.payment-balance-grid{grid-template-columns:1fr}}.payment-balance-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-4);text-align:center}.payment-balance-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.payment-balance-value{font-size:var(--font-xl);font-weight:800;color:var(--text-primary)}.stat-card-v2 .stat-value{font-size:var(--font-2xl);font-weight:800;color:var(--text-primary);line-height:1.1}.stat-card-v2 .stat-label{font-size:var(--font-xs);color:var(--text-muted);margin-top:4px}.topbar{border-bottom:1px solid var(--border-color)}@media(max-width:768px){.page-header{flex-wrap:wrap}.page-header>button{flex-shrink:0}}
