:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#dbeafe;--secondary:#64748b;--success:#22c55e;--success-light:#dcfce7;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--info:#3b82f6;--info-light:#dbeafe;--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;--sidebar-width:280px;--sidebar-collapsed:70px;--header-height:70px;--border-radius:12px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a, 0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:var(--gray-100);color:var(--gray-900);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}.app-container{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--gray-200);z-index:100;background:#fff;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0}.sidebar-header{border-bottom:1px solid var(--gray-200);align-items:center;gap:12px;padding:20px;display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:700;display:flex}.sidebar-title{color:var(--gray-900);font-size:20px;font-weight:700}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-item{color:var(--gray-600);border-radius:10px;align-items:center;gap:12px;margin-bottom:4px;padding:12px 16px;font-size:15px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{background:var(--gray-100);color:var(--gray-900)}.nav-item.active{background:var(--primary-light);color:var(--primary)}.nav-item svg{flex-shrink:0;width:22px;height:22px}.sidebar-footer{border-top:1px solid var(--gray-200);padding:16px}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.header{height:var(--header-height);border-bottom:1px solid var(--gray-200);z-index:50;background:#fff;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:16px;display:flex}.menu-btn{cursor:pointer;color:var(--gray-600);background:0 0;border:none;border-radius:8px;padding:8px;display:none}.menu-btn:hover{background:var(--gray-100)}.page-title{color:var(--gray-900);font-size:24px;font-weight:700}.header-right{align-items:center;gap:16px;display:flex}.notification-btn{cursor:pointer;color:var(--gray-600);background:0 0;border:none;border-radius:10px;padding:10px;transition:all .2s;position:relative}.notification-btn:hover{background:var(--gray-100)}.notification-badge{background:var(--danger);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.user-menu{cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:6px 12px 6px 6px;transition:all .2s;display:flex}.user-menu:hover{background:var(--gray-100)}.user-avatar{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;font-weight:600;display:flex}.user-info{display:none}.user-name{color:var(--gray-900);font-size:14px;font-weight:600}.user-role{color:var(--gray-500);text-transform:capitalize;font-size:12px}.page-content{flex:1;padding:24px;overflow-y:auto}.mobile-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}.mobile-overlay.open{display:block}.grid{gap:20px;display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.card{border-radius:var(--border-radius);box-shadow:var(--shadow);background:#fff;overflow:hidden}.card-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.card-title{color:var(--gray-900);font-size:18px;font-weight:600}.card-body{padding:24px}.stat-card{border-radius:var(--border-radius);box-shadow:var(--shadow);background:#fff;align-items:flex-start;gap:16px;padding:24px;display:flex}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.stat-icon.blue{background:var(--primary-light);color:var(--primary)}.stat-icon.green{background:var(--success-light);color:var(--success)}.stat-icon.red{background:var(--danger-light);color:var(--danger)}.stat-icon.orange{background:var(--warning-light);color:var(--warning)}.stat-icon.purple{color:#9333ea;background:#f3e8ff}.stat-content{flex:1}.stat-label{color:var(--gray-500);margin-bottom:8px;font-size:14px}.stat-value{color:var(--gray-900);margin-bottom:4px;font-size:28px;font-weight:700}.stat-change{align-items:center;gap:4px;font-size:13px;display:flex}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--danger)}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{border:1px solid var(--gray-300);color:var(--gray-700);background:0 0}.btn-outline:hover:not(:disabled){background:var(--gray-100)}.btn-sm{padding:8px 16px;font-size:14px}.btn-lg{padding:14px 28px;font-size:16px}.btn-icon{padding:10px}.btn-icon svg{width:20px;height:20px}.form-group{margin-bottom:20px}.form-label{color:var(--gray-700);margin-bottom:8px;font-size:14px;font-weight:600;display:block}.form-label.required:after{content:" *";color:var(--danger)}.form-input,.form-select,.form-textarea{border:1px solid var(--gray-300);background:#fff;border-radius:10px;width:100%;padding:12px 16px;font-size:15px;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-input::placeholder{color:var(--gray-400)}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;padding-right:40px}.form-textarea{resize:vertical;min-height:120px}.input-group{gap:12px;display:flex}.input-group .form-input,.input-group .form-select{flex:1}.table-container{border-radius:var(--border-radius);box-shadow:var(--shadow);overflow-x:auto}.table{border-collapse:collapse;background:#fff;width:100%;font-size:14px}.table th{background:var(--gray-50);text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);border-bottom:1px solid var(--gray-200);white-space:nowrap;padding:16px;font-size:12px;font-weight:700}.table td{border-bottom:1px solid var(--gray-200);color:var(--gray-700);padding:16px}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--gray-50)}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;display:inline-flex}.badge-dot{border-radius:50%;width:8px;height:8px}.badge-success{background:var(--success-light);color:var(--success)}.badge-success .badge-dot{background:var(--success)}.badge-warning{background:var(--warning-light);color:#92400e}.badge-warning .badge-dot{background:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-danger .badge-dot{background:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.badge-info .badge-dot{background:var(--info)}.room-available{background:var(--success)!important;color:#fff!important}.room-occupied{background:var(--danger)!important;color:#fff!important}.room-blocked{background:var(--warning)!important;color:#fff!important}.room-maintenance{background:var(--gray-400)!important;color:#fff!important}.tabs{border-bottom:1px solid var(--gray-200);gap:8px;margin-bottom:24px;display:flex;overflow-x:auto}.tab{color:var(--gray-500);cursor:pointer;white-space:nowrap;border-bottom:2px solid #0000;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--border-radius);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-xl);background:#fff;overflow-y:auto}.modal-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:20px;font-weight:700}.modal-close{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-radius:8px;padding:8px}.modal-close:hover{background:var(--gray-100);color:var(--gray-600)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--gray-200);justify-content:flex-end;gap:12px;padding:20px 24px;display:flex}.login-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{border-radius:var(--border-radius);box-shadow:var(--shadow-xl);background:#fff;width:100%;max-width:420px;padding:40px}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:16px;font-size:28px;font-weight:700;display:inline-flex}.login-title{color:var(--gray-900);text-align:center;font-size:24px;font-weight:700}.login-subtitle{color:var(--gray-500);text-align:center;margin-top:8px;font-size:15px}.login-form{margin-top:32px}.password-field{position:relative}.password-toggle{cursor:pointer;color:var(--gray-400);background:0 0;border:none;padding:8px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.password-toggle:hover{color:var(--gray-600)}.login-btn{width:100%;margin-top:24px}.login-demo{border-top:1px solid var(--gray-200);text-align:center;margin-top:24px;padding-top:24px}.login-demo-title{color:var(--gray-500);margin-bottom:12px;font-size:13px}.login-demo-creds{color:var(--gray-600);font-size:13px;line-height:1.8}.room-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;display:grid}.room-card{text-align:center;cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;padding:16px;transition:all .2s}.room-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.room-card.selected{border-color:var(--primary)}.room-card.available{background:var(--success-light);border-color:var(--success)}.room-card.occupied{background:var(--danger-light);border-color:var(--danger)}.room-card.blocked{background:var(--warning-light);border-color:var(--warning)}.room-card.maintenance{background:var(--gray-100);border-color:var(--gray-400)}.room-number{margin-bottom:8px;font-size:20px;font-weight:700}.room-type{color:var(--gray-500);margin-bottom:8px;font-size:12px}.room-price{color:var(--gray-700);font-size:14px;font-weight:600}.room-status{border-radius:20px;margin-top:8px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.filters-bar{border-radius:var(--border-radius);background:#fff;flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:24px;padding:20px;display:flex}.filter-group{flex:1;min-width:200px}.filter-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:13px;font-weight:600}.notification-panel{border-radius:var(--border-radius);width:380px;max-height:500px;box-shadow:var(--shadow-xl);z-index:150;background:#fff;position:fixed;top:80px;right:24px;overflow:hidden}.notification-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.notification-title{font-size:16px;font-weight:700}.notification-list{max-height:400px;overflow-y:auto}.notification-item{border-bottom:1px solid var(--gray-200);cursor:pointer;gap:12px;padding:16px 20px;transition:background .2s;display:flex}.notification-item:hover{background:var(--gray-50)}.notification-item.unread{background:var(--primary-light)}.notification-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.notification-content{flex:1}.notification-text{color:var(--gray-700);margin-bottom:4px;font-size:14px}.notification-time{color:var(--gray-400);font-size:12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.w-full{width:100%}.h-full{height:100%}.text-center{text-align:center}.text-right{text-align:right}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-xs{font-size:12px}.text-sm{font-size:14px}.text-base{font-size:16px}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.text-3xl{font-size:30px}.text-gray-400{color:var(--gray-400)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-gray-900{color:var(--gray-900)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.bg-white{background:#fff}.bg-gray-50{background:var(--gray-50)}.bg-gray-100{background:var(--gray-100)}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.ml-auto{margin-left:auto}.p-4{padding:16px}.p-6{padding:24px}.px-4{padding-left:16px;padding-right:16px}.py-2{padding-top:8px;padding-bottom:8px}.rounded-lg{border-radius:var(--border-radius)}.shadow{box-shadow:var(--shadow)}.shadow-md{box-shadow:var(--shadow-md)}.hidden{display:none}.block{display:block}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.cursor-pointer{cursor:pointer}@media (width<=1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.menu-btn{display:block}.page-title{font-size:20px}}@media (width<=768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(1,1fr)}.header{height:60px;padding:0 16px}.page-content,.card-header,.card-body,.stat-card{padding:16px}.stat-value{font-size:22px}.login-box{padding:24px}.login-title{font-size:22px}.room-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.filters-bar{flex-direction:column}.filter-group{width:100%}.notification-panel{width:auto;left:16px;right:16px}.modal{max-height:calc(100vh - 32px);margin:16px}.input-group{flex-direction:column}}@media (width>=769px){.user-info{display:block}}@media (width>=1025px){.sidebar{transform:translate(0)!important}.main-content{margin-left:var(--sidebar-width)}.mobile-overlay{display:none!important}}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.animate-slide-in{animation:.3s ease-out slideIn}.react-hot-toast{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}
