.dashboard{max-width:1400px;margin:0 auto;padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.dashboard-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.dashboard-header h1{margin:0;font-size:2rem;color:#1a1a1a}.header-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.date-selector{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.date-selector input[type=date]{padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.875rem}.date-nav-btn{padding:.5rem .75rem;background-color:#fff;color:#2563eb;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:1.25rem;font-weight:600;transition:all .2s;line-height:1;min-width:40px}.date-nav-btn:hover{background-color:#2563eb;color:#fff;border-color:#2563eb}.date-nav-btn:active{transform:scale(.95)}.refresh-btn{padding:.5rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.refresh-btn:hover{background-color:#1d4ed8}.logout-btn{padding:.5rem 1rem;background-color:#dc2626;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.logout-btn:hover{background-color:#b91c1c}.card{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.total-occupancy{margin-bottom:2rem}.total-occupancy .card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.total-occupancy h2{margin:0 0 1.5rem;font-size:1.5rem}.occupancy-stats{display:flex;flex-direction:column;gap:1rem}.main-stat{font-size:3rem;font-weight:700;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.main-stat .occupied{color:#fff}.main-stat .separator{opacity:.7}.main-stat .total{opacity:.9}.occupancy-rate{display:flex;flex-direction:column;gap:.5rem}.rate-bar{height:12px;background-color:#ffffff4d;border-radius:6px;overflow:hidden}.rate-fill{height:100%;background-color:#34d399;border-radius:6px;transition:width .3s ease}.rate-text{font-size:1.125rem;font-weight:600}.detail-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:.5rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-item .label{font-size:.875rem;opacity:.9}.stat-item .value{font-size:1.125rem;font-weight:600}.occupancy-by-type h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1a1a1a}.room-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.room-type-card h3{margin:0 0 1rem;font-size:1.25rem;color:#1a1a1a}.room-type-card .main-stat{font-size:2rem;color:#1a1a1a;margin-bottom:.5rem}.room-type-card .main-stat .occupied,.room-type-card .main-stat .separator,.room-type-card .main-stat .total{color:#1a1a1a;opacity:1}.room-type-card .rate-bar{background-color:#e5e7eb}.room-type-card .rate-fill{background-color:#2563eb}.room-type-card .rate-text{color:#374151;font-size:1rem}.room-type-card .stat-item .label{color:#6b7280}.room-type-card .stat-item .value{color:#1a1a1a}.loading,.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;font-size:1.25rem;color:#6b7280}.error{color:#dc2626}.error h3{margin:0 0 .5rem;font-size:1.5rem}.error button{margin-top:1rem;padding:.5rem 1rem;background-color:#dc2626;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.error button:hover{background-color:#b91c1c}.weekly-occupancy{margin-top:2rem}.weekly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.weekly-header h2{margin:0;font-size:1.5rem;color:#1a1a1a}.week-navigation{display:flex;gap:.5rem;align-items:center;justify-content:space-between;width:100%}.week-nav-btn{padding:.5rem .75rem;background-color:#fff;color:#667eea;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:1.25rem;font-weight:600;transition:all .2s;line-height:1;min-width:40px}.week-nav-btn:hover{background-color:#667eea;color:#fff;border-color:#667eea}.week-nav-btn:active{transform:scale(.95)}.week-label{padding:.5rem 1rem;font-weight:600;color:#374151;min-width:200px;text-align:center}.chart-container{height:350px;width:100%}.lead-time-section{margin-top:2rem}.lead-time-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.lead-time-header h2{margin:0;font-size:1.5rem;color:#1a1a1a}.lead-time-navigation{display:flex;gap:.5rem;align-items:center;width:100%;justify-content:space-between}.lead-time-table-container{overflow-x:auto;width:100%}.lead-time-table{width:100%;border-collapse:collapse;font-size:.875rem}.lead-time-table thead{background-color:#f3f4f6}.lead-time-table th{padding:.75rem;text-align:center;font-weight:600;color:#374151;border:1px solid #e5e7eb}.lead-time-table td{padding:.75rem;text-align:center;border:1px solid #e5e7eb;color:#1a1a1a}.lead-time-table .date-cell{font-weight:600;background-color:#f9fafb;text-align:left}.lead-time-table tbody tr:hover{background-color:#f9fafb}@media (max-width: 768px){.dashboard{padding:1rem}.dashboard-header{flex-direction:column;align-items:flex-start}.main-stat{font-size:2rem}.room-types-grid{grid-template-columns:1fr}.detail-stats{gap:.5rem}.stat-item .label{font-size:.75rem}.stat-item .value{font-size:1rem}.weekly-header{flex-direction:column;align-items:flex-start}.weekly-header h2{font-size:1.25rem}.week-label{min-width:150px;font-size:.875rem}.chart-container{height:300px}.lead-time-header{flex-direction:column;align-items:flex-start}.lead-time-header h2{font-size:1.25rem}.lead-time-table{font-size:.75rem}.lead-time-table th,.lead-time-table td{padding:.5rem .25rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-box{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 10px 40px #0003;width:100%;max-width:420px}.login-box h1{margin:0 0 .5rem;font-size:1.75rem;color:#1a1a1a;text-align:center}.login-subtitle{margin:0 0 2rem;color:#6b7280;text-align:center;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:#374151}.form-group input{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed}.error-message{padding:.75rem;background-color:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#dc2626;font-size:.875rem;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-btn{padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-info{margin:0;text-align:center;font-size:.75rem;color:#9ca3af}@media (max-width: 480px){.login-box{padding:2rem 1.5rem}.login-box h1{font-size:1.5rem}}*{box-sizing:border-box}body{margin:0;padding:0;background-color:#f9fafb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}#root,.App{min-height:100vh}
