:root{font-family:Inter,system-ui,sans-serif;color:#102030;background:#f8f8f8}*{box-sizing:border-box}body{margin:0}.container{max-width:1100px;margin:0 auto;padding:0 1rem}.section{padding:2rem 1rem}.topbar{background:#102030;color:#fff;padding:1rem 0;position:sticky;top:0}.nav-wrapper{display:flex;justify-content:space-between;align-items:center;gap:1rem}nav a{color:#dce8ff;text-decoration:none;margin-left:1rem;font-weight:600}nav a.active{color:#fff;border-bottom:2px solid #f7c15e}.auth-actions{display:flex;align-items:center;gap:.5rem}.auth-actions button{border:1px solid #dce8ff;background:transparent;color:#fff;border-radius:8px;padding:.4rem .65rem;cursor:pointer}.auth-user{color:#dce8ff;font-size:.9rem}.hero{background:linear-gradient(#102030b3,#102030b3),url(https://images.unsplash.com/photo-1468824357306-a439d58ccb1c?auto=format&fit=crop&w=1800&q=80) center/cover;color:#fff;padding:5rem 1rem}.hero h2{max-width:700px;font-size:2.4rem;margin:0}.hero p{max-width:700px}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;padding:0}.features li{list-style:none;background:#fff;padding:1rem;border-radius:10px;box-shadow:0 2px 10px #10203014}.room-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.room-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #1020301a}.room-card img{width:100%;height:200px;object-fit:cover}.room-content{padding:1rem}.room-status{display:inline-block;margin:0 0 .75rem;padding:.25rem .6rem;border-radius:999px;font-size:.85rem;font-weight:700}.room-status.available{background:#def7e8;color:#176d3f}.room-status.reserved{background:#fde6e6;color:#9f1f1f}.room-book-btn{display:inline-block;margin-top:.5rem;background:#102030;color:#fff;text-decoration:none;border:1px solid #102030;padding:.55rem .9rem;border-radius:8px;font-weight:600;cursor:pointer}.room-book-btn:disabled{opacity:.65;cursor:not-allowed}.booking-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a141e73;display:grid;place-items:center;padding:1rem;z-index:1000}.booking-modal{width:min(520px,100%);background:#fff;border-radius:12px;padding:1rem;box-shadow:0 10px 34px #00000047}.booking-modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.booking-modal-header h3{margin:0}.booking-modal-close{border:1px solid #ccd5df;background:#fff;border-radius:8px;padding:.4rem .7rem;cursor:pointer}.booking-form{display:grid;gap:.75rem;max-width:480px}.booking-form input,.booking-form select,.booking-form button{padding:.75rem;border-radius:8px;border:1px solid #ccc}.booking-form button{background:#102030;color:#fff;cursor:pointer;border-color:#102030}.message{margin-top:1rem;font-weight:600}.footer{border-top:1px solid #ddd;padding:1rem 0;margin-top:2rem}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#08121e80;display:grid;place-items:center;padding:1rem;z-index:1100}.auth-modal{width:min(430px,100%);background:#fff;border-radius:12px;padding:1rem;box-shadow:0 10px 35px #00000047}.auth-form{display:grid;gap:.6rem}.auth-form input,.auth-form button{padding:.7rem;border-radius:8px;border:1px solid #cad2de}.auth-form button{background:#102030;color:#fff;cursor:pointer}.admin-page{padding:2rem 1rem;display:grid;gap:1.5rem}.admin-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.admin-form{display:grid;gap:.6rem;max-width:760px}.admin-form input,.admin-form textarea,.admin-form button{padding:.65rem;border-radius:8px;border:1px solid #c8cfdb}.admin-form textarea{min-height:90px;resize:vertical}.admin-list{display:grid;gap:.8rem}.admin-card{background:#fff;border:1px solid #dde3ef;border-radius:10px;padding:.9rem;display:grid;gap:.55rem}.admin-row{display:flex;flex-wrap:wrap;gap:.5rem}.admin-images{display:flex;flex-wrap:wrap;gap:.75rem}.admin-images figure{margin:0;display:grid;gap:.3rem;width:140px}.admin-images img{width:140px;height:90px;object-fit:cover;border-radius:8px;border:1px solid #d9dfeb}.error-text{color:#b01818;font-weight:600}
