:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.navbar{background-color:#1a1a1a;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:1000}.nav-brand{font-size:1.5rem;font-weight:700}.nav-brand a{color:#fff;text-decoration:none}.nav-links{display:flex;align-items:center;gap:1.5rem}.nav-links a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .3s}.nav-links a:hover{background-color:#ffffff1a}.user-info{color:#fff;margin-right:1rem}.logout-btn{background-color:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background-color .3s}.logout-btn:hover{background-color:#c82333}@media (max-width: 768px){.navbar{padding:1rem;flex-direction:column;gap:1rem}.nav-links{flex-direction:column;width:100%;gap:.5rem}.nav-links a{width:100%;text-align:center}.user-info{text-align:center;margin:.5rem 0}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:2rem}.auth-box{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:var(--card-shadow);width:100%;max-width:400px}.auth-box h2{margin-bottom:1.5rem;color:var(--text-color);font-size:1.5rem;font-weight:600;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.auth-button{margin-top:.5rem;width:100%;padding:.75rem;font-size:1rem;font-weight:500}.auth-switch{margin-top:1.5rem;text-align:center;color:var(--text-color);font-size:.95rem}.switch-button{background:none;border:none;color:var(--primary-color);font-weight:500;padding:0;margin-left:.5rem;cursor:pointer}.switch-button:hover{color:var(--secondary-color);text-decoration:underline}@media (max-width: 480px){.auth-container{padding:1rem}.auth-box{padding:1.5rem}}.rooms-container{width:100%;max-width:1440px;margin:0 auto;padding:0 1rem}.filters{display:flex;gap:1.5rem;margin-bottom:2.5rem;background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:var(--card-shadow);align-items:center;flex-wrap:wrap}.filters select,.filters input{min-width:200px;max-width:300px;flex:1}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;margin-bottom:2rem}.room-card{background:#fff;border-radius:.75rem;overflow:hidden;box-shadow:var(--card-shadow);transition:transform var(--transition-speed),box-shadow var(--transition-speed);height:100%;display:flex;flex-direction:column}.room-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.room-image{position:relative;width:100%;padding-top:66.67%;overflow:hidden}.room-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform var(--transition-speed)}.room-card:hover .room-image img{transform:scale(1.05)}.room-info{padding:1.5rem;flex:1;display:flex;flex-direction:column}.room-info h3{margin:0;color:var(--text-color);font-size:1.25rem;font-weight:600}.room-type{color:var(--text-color);opacity:.8;margin:.75rem 0;font-size:1rem}.room-cost{font-size:1.5rem;font-weight:600;color:var(--primary-color);margin:.75rem 0}.room-status{display:inline-block;padding:.5rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:500;margin:.75rem 0;text-align:center}.room-status[data-status=empty]{background-color:#d1fae5;color:#059669}.room-status[data-status=occupied]{background-color:#fee2e2;color:#dc2626}.room-status[data-status=locked]{background-color:#fef3c7;color:#d97706}.view-button{width:100%;margin-top:auto;padding:.75rem;font-weight:500;border-radius:.5rem}.view-button:disabled{background-color:var(--border-color);cursor:not-allowed}.no-rooms{text-align:center;padding:3rem 2rem;color:var(--text-color);background:#fff;border-radius:.75rem;box-shadow:var(--card-shadow);margin-top:2rem;font-size:1.125rem}.loading{text-align:center;padding:3rem;color:var(--text-color);font-size:1.125rem}@media (max-width: 768px){.rooms-container{padding:1rem}.filters{padding:1.25rem;gap:1rem;margin-bottom:2rem}.rooms-grid{gap:1.5rem}}@media (max-width: 480px){.rooms-container{padding:.75rem}.filters{flex-direction:column;padding:1rem}.filters select,.filters input{min-width:100%}.rooms-grid{grid-template-columns:1fr;gap:1rem}.room-info{padding:1.25rem}}.room-list{padding:2rem;max-width:1440px;margin:0 auto}.room-list h1{margin-bottom:2rem;color:var(--text-color);font-size:2rem;font-weight:600}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.room-card{background:#fff;border-radius:.75rem;overflow:hidden;box-shadow:var(--card-shadow);transition:transform .2s ease}.room-card:hover{transform:translateY(-4px)}.room-image{width:100%;object-fit:cover}.room-info{padding:1.5rem}.room-info h2{margin:0;color:var(--text-color);font-size:1.5rem;font-weight:600}.room-type{color:var(--text-color);opacity:.8;margin:.5rem 0}.room-price{font-size:1.25rem;font-weight:600;color:var(--primary-color);margin:.5rem 0}.room-status{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500;margin:.5rem 0}.empty{background-color:#e6f4ea;color:#1e7e34}.occupied{background-color:#fff3cd;color:#856404}.maintenance{background-color:#f8d7da;color:#721c24}.view-btn,.admin-view-btn{width:100%;padding:.75rem;margin-top:1rem;border-radius:.5rem;font-weight:500;transition:all .2s ease}.view-btn{background-color:var(--primary-color);color:#fff}.admin-view-btn{background-color:var(--secondary-color);color:#fff}.view-btn:disabled,.admin-view-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;border-radius:1rem;padding:2rem;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.modal-header h2{margin:0;color:var(--text-color);font-size:1.5rem;font-weight:600}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-color);cursor:pointer;padding:.5rem}.room-details{display:flex;flex-direction:column;gap:1rem}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:var(--background-color);border-radius:.5rem}.detail-row span:first-child{font-weight:500;color:var(--text-color)}.status-badge{padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500}.edit-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:var(--text-color)}.form-group input,.form-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem}.form-actions{display:flex;gap:1rem;margin-top:1rem}.save-btn,.cancel-btn,.edit-btn{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;transition:all .2s ease}.save-btn{background-color:var(--primary-color);color:#fff;flex:1}.cancel-btn{background-color:var(--danger-color);color:#fff;flex:1}.edit-btn{background-color:var(--secondary-color);color:#fff;width:100%;margin-top:1rem}@media (max-width: 768px){.room-list{padding:1rem}.room-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.modal{width:95%;padding:1.5rem}}@media (max-width: 480px){.room-list h1{font-size:1.5rem}.room-info h2{font-size:1.25rem}.form-actions{flex-direction:column}}.booking-container{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;width:100%;max-width:1440px;margin:0 auto;padding:0 1rem}.room-preview{background:#fff;border-radius:.75rem;overflow:hidden;box-shadow:var(--card-shadow);height:fit-content;position:sticky;top:2rem}.room-image{position:relative;width:100%;overflow:hidden;padding:0}.room-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.room-details{padding:2rem}.room-details h2{margin:0;color:var(--text-color);font-size:1.75rem;font-weight:600}.room-type{color:var(--text-color);opacity:.8;margin:1rem 0;font-size:1.125rem}.room-cost{font-size:1.75rem;font-weight:600;color:var(--primary-color);margin:1rem 0}.booking-form{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:var(--card-shadow)}.booking-form h3{margin:0 0 2rem;color:var(--text-color);font-size:1.5rem;font-weight:600}.date-picker{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.form-group{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.form-group label{font-weight:500;color:var(--text-color);font-size:1rem}.price-summary{background-color:var(--background-color);padding:1.5rem;border-radius:.75rem;margin:2rem 0}.price-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;color:var(--text-color);font-size:1.125rem}.price-row.total{border-top:2px solid var(--border-color);margin-top:1rem;padding-top:1.5rem;font-weight:600;font-size:1.375rem}.book-button{width:100%;padding:1rem;font-size:1.125rem;font-weight:500;margin-top:1.5rem;border-radius:.75rem}.book-button:hover:not(:disabled){transform:translateY(-2px)}.error-message{margin-bottom:2rem}@media (max-width: 1024px){.booking-container{padding:1.5rem;gap:2rem}.room-details,.booking-form{padding:1.5rem}}@media (max-width: 768px){.booking-container{grid-template-columns:1fr;padding:1rem}.room-preview{position:static}.date-picker{grid-template-columns:1fr;gap:1rem}.room-details h2,.room-cost{font-size:1.5rem}.booking-form h3{font-size:1.25rem;margin-bottom:1.5rem}.price-row{font-size:1rem}.price-row.total{font-size:1.25rem}.book-button{padding:.875rem;font-size:1rem}}@media (max-width: 480px){.booking-container{padding:.75rem}.room-details,.booking-form{padding:1.25rem}.price-summary{padding:1.25rem;margin:1.5rem 0}}.dashboard{padding:2rem;max-width:1440px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2rem;font-weight:600;color:var(--text-color);margin:0}.dashboard-header p{font-size:1.125rem;color:var(--text-color);opacity:.8;margin-top:.5rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.summary-card{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:var(--card-shadow)}.summary-card h3{font-size:1rem;font-weight:500;color:var(--text-color);opacity:.8;margin:0}.summary-card .number{font-size:2rem;font-weight:600;color:var(--primary-color);margin:.5rem 0 0}.bookings-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:var(--card-shadow)}.bookings-section h2{font-size:1.5rem;font-weight:600;color:var(--text-color);margin:0 0 1.5rem}.no-bookings{text-align:center;padding:3rem 2rem}.no-bookings p{font-size:1.125rem;color:var(--text-color);opacity:.8;margin-bottom:1.5rem}.book-now-btn{background-color:var(--primary-color);color:#fff;padding:.75rem 2rem;border-radius:.5rem;font-weight:500;transition:all .2s ease}.book-now-btn:hover{transform:translateY(-2px)}.bookings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.booking-card{background:var(--background-color);border-radius:.75rem;overflow:hidden;transition:transform .2s ease}.booking-card:hover{transform:translateY(-4px)}.booking-image{width:100%;height:200px;overflow:hidden}.booking-image img{width:100%;height:100%;object-fit:cover}.booking-info{padding:1.5rem}.booking-info h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.booking-info .room-type{color:var(--text-color);opacity:.8;margin:.5rem 0}.booking-dates{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0}.booking-dates span{font-size:.875rem;color:var(--text-color);opacity:.8}.booking-dates p{margin:.25rem 0 0;font-weight:500;color:var(--text-color)}.booking-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}.booking-status{padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500}.booking-status.confirmed{background-color:#e6f4ea;color:#1e7e34}.booking-status.pending{background-color:#fff3cd;color:#856404}.booking-status.cancelled{background-color:#f8d7da;color:#721c24}.booking-amount{font-weight:600;color:var(--primary-color)}.cancel-booking-btn{width:100%;margin-top:1rem;padding:.75rem;background-color:var(--danger-color);color:#fff;border-radius:.5rem;font-weight:500;transition:all .2s ease}.cancel-booking-btn:hover{opacity:.9}.loading,.error{text-align:center;padding:3rem;background:#fff;border-radius:1rem;box-shadow:var(--card-shadow);margin-top:2rem}.error{color:var(--danger-color)}@media (max-width: 768px){.dashboard{padding:1rem}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.bookings-section{padding:1.5rem}.bookings-grid{grid-template-columns:1fr}}@media (max-width: 480px){.dashboard-header h1,.summary-card .number{font-size:1.5rem}.booking-dates{grid-template-columns:1fr}}.room-management{padding:2rem;max-width:1200px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header h2{margin:0;color:#333}.add-btn{background:#4caf50;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:500}.add-btn:hover{background:#45a049}.room-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf5033}.form-buttons{display:flex;gap:1rem;margin-top:1.5rem}.submit-btn,.cancel-btn{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-weight:500}.submit-btn{background:#4caf50;color:#fff}.submit-btn:hover{background:#45a049}.cancel-btn{background:#f44336;color:#fff}.cancel-btn:hover{background:#da190b}.rooms-table{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:1rem;text-align:left;border-bottom:1px solid #ddd}th{background:#f5f5f5;font-weight:600;color:#333}tr:hover{background:#f9f9f9}.status{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.status.empty{background:#e8f5e9;color:#2e7d32}.status.occupied{background:#ffebee;color:#c62828}.status.maintenance{background:#fff3e0;color:#ef6c00}.delete-btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;background:#f44336;color:#fff;font-size:.875rem}.delete-btn:hover{background:#da190b}.error{color:#f44336;padding:1rem;background:#ffebee;border-radius:4px;margin-bottom:1rem}@media (max-width: 768px){.room-management{padding:1rem}.header{flex-direction:column;gap:1rem;text-align:center}.form-buttons{flex-direction:column}.submit-btn,.cancel-btn{width:100%}th,td{padding:.75rem;font-size:.875rem}}:root{--primary-color: #2563eb;--secondary-color: #1e40af;--background-color: #f8fafc;--text-color: #1f2937;--border-color: #e5e7eb;--error-color: #ef4444;--success-color: #10b981;--card-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--transition-speed: .2s}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:var(--text-color);background-color:var(--background-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;width:100vw;padding:2rem;min-width:320px;max-width:1440px;margin:0 auto;padding-left:max(2rem,calc((100vw - 1440px)/2 + 2rem));padding-right:max(2rem,calc((100vw - 1440px)/2 + 2rem))}.error-message{color:var(--error-color);background-color:#fee2e2;border:1px solid #fecaca;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;font-size:.95rem}.success-message{color:var(--success-color);background-color:#d1fae5;border:1px solid #a7f3d0;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;font-size:.95rem}.loading{display:flex;justify-content:center;align-items:center;min-height:300px;font-size:1.125rem;color:var(--text-color)}button{cursor:pointer;padding:.75rem 1.5rem;border-radius:.5rem;border:none;font-size:1rem;font-weight:500;transition:all var(--transition-speed);background-color:var(--primary-color);color:#fff}button:hover:not(:disabled){background-color:var(--secondary-color);transform:translateY(-1px)}button:disabled{opacity:.7;cursor:not-allowed}input,select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;transition:all var(--transition-speed);background-color:#fff;color:var(--text-color)}input::placeholder{color:#9ca3af}input:focus,select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb33}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1em;padding-right:2.5rem}.section{background:#fff;border-radius:.75rem;box-shadow:var(--card-shadow);padding:2rem}@media (max-width: 768px){.main-content{padding:1rem}.section{padding:1.5rem}button{padding:.625rem 1.25rem}}@media (max-width: 480px){.main-content{padding:.75rem}.section{padding:1.25rem}}
