:root{--primary: #2563EB;--primary-dark: #1D4ED8;--primary-light: #3B82F6;--secondary: #64748B;--secondary-dark: #475569;--background: #F8FAFC;--surface: #FFFFFF;--text-primary: #1E293B;--text-secondary: #64748B;--border: #E2E8F0;--success: #10B981;--warning: #F59E0B;--danger: #EF4444;--info: #06B6D4;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--transition: all .2s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--background);color:var(--text-primary);line-height:1.5}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.25rem;color:var(--text-secondary)}@keyframes toastSlideIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--surface);border-right:1px solid var(--border);padding:1.5rem 1rem;display:flex;flex-direction:column}.sidebar-logo{display:flex;align-items:center;gap:.75rem;padding:0 .75rem;margin-bottom:2rem}.sidebar-logo h1{font-size:1.5rem;font-weight:700;color:var(--primary)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius);color:var(--text-secondary);text-decoration:none;font-weight:500;transition:var(--transition)}.nav-item:hover{background:var(--background);color:var(--text-primary)}.nav-item.active{background:var(--primary);color:#fff}.nav-section{padding:1rem .75rem .5rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.top-bar{height:64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 2rem}.top-bar-left,.top-bar-right{display:flex;align-items:center;gap:1rem}.page-content{flex:1;padding:2rem;overflow-y:auto}.page-header{margin-bottom:2rem}.page-title{font-size:1.75rem;font-weight:600;color:var(--text-primary)}.page-subtitle{color:var(--text-secondary);margin-top:.25rem}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card-title{font-size:1.125rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:var(--transition);text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--background);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-icon{padding:.5rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .875rem;font-size:.9375rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-primary);transition:var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:100px}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.table th{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--background)}.table tbody tr:hover{background:var(--background)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:9999px}.badge-success{background:#10b9811a;color:var(--success)}.badge-warning{background:#f59e0b1a;color:var(--warning)}.badge-danger{background:#ef44441a;color:var(--danger)}.badge-info{background:#06b6d41a;color:var(--info)}.badge-neutral{background:var(--background);color:var(--text-secondary)}.grid{display:grid;gap:1.5rem}.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)}@media(max-width:1024px){.grid-cols-4,.grid-cols-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid-cols-4,.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}}.stat-card{display:flex;flex-direction:column;gap:.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.875rem;color:var(--text-secondary)}.stat-change{font-size:.8125rem}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--danger)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1.125rem;font-weight:600}.modal-body{padding:1.5rem}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--background)}.auth-card{width:100%;max-width:400px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem}.auth-logo{text-align:center;margin-bottom:2rem}.auth-logo h1{font-size:1.75rem;font-weight:700;color:var(--primary)}.auth-divider{text-align:center;margin:1.5rem 0;color:var(--text-secondary);font-size:.875rem}.calendar-container{height:calc(100vh - 250px);min-height:500px}.rbc-calendar{background:var(--surface);border-radius:var(--radius-lg);padding:1rem}.rbc-toolbar{margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.rbc-toolbar button{color:var(--text-primary);border:1px solid var(--border);background:var(--surface);padding:.375rem .875rem;font-size:.875rem;font-weight:500;line-height:1.5;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.rbc-toolbar button:hover{background:var(--background);border-color:var(--secondary)}.rbc-toolbar button:focus{outline:none;box-shadow:0 0 0 3px #2563eb26}.rbc-toolbar button.rbc-active{background:var(--primary);color:#fff;border-color:var(--primary)}.rbc-toolbar button.rbc-active:hover{background:var(--primary-dark)}.rbc-btn-group{display:flex}.rbc-btn-group button{border-radius:0}.rbc-btn-group button:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.rbc-btn-group button:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.rbc-btn-group button:only-child{border-radius:var(--radius-sm)}.rbc-btn-group button+button{margin-left:-1px}.rbc-toolbar-label{font-size:1.125rem;font-weight:600;color:var(--text-primary);flex:1;text-align:center}.rbc-event{background:var(--primary)}.rbc-event.rbc-selected{background:var(--primary-dark)}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.room-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center;transition:var(--transition)}.room-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}.room-number{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.room-type{font-size:.8125rem;color:var(--text-secondary);margin-top:.25rem}.room-price{font-size:1rem;font-weight:600;color:var(--primary);margin-top:.5rem}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.5rem}.status-available{background:var(--success)}.status-occupied{background:var(--danger)}.status-maintenance{background:var(--warning)}.status-cleaning{background:var(--info)}.empty-state{text-align:center;padding:3rem 1.5rem}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-state-text{color:var(--text-secondary);margin-bottom:1.5rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:.875rem}.text-muted{color:var(--text-secondary)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
