:root{--gold:#c99b2e;--black:#101010;--muted:#6b7280;--bg:#f8f6f0;--white:#fff;--green:#12805c;--red:#b91c1c}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:#171717}.app{display:flex;min-height:100vh}.sidebar{width:270px;background:#0e0e0e;color:white;padding:24px;position:fixed;inset:0 auto 0 0}.brand{font-size:22px;font-weight:900;color:var(--gold);letter-spacing:.5px}.brand small{display:block;color:#ddd;font-size:12px;margin-top:4px}.nav{margin-top:35px;display:grid;gap:10px}.nav a{color:white;text-decoration:none;padding:13px 14px;border-radius:14px;display:block}.nav a.active,.nav a:hover{background:var(--gold);color:#111}.main{margin-left:270px;width:calc(100% - 270px);padding:28px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.pill{background:white;border:1px solid #eee;padding:10px 14px;border-radius:999px;box-shadow:0 8px 25px #0000000c}.grid{display:grid;gap:18px}.cards{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:white;border-radius:24px;padding:22px;box-shadow:0 12px 40px #00000010;border:1px solid #eee}.card h3{margin:0;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.08em}.card .value{font-size:30px;font-weight:900;margin-top:10px}.btn{border:0;border-radius:14px;padding:12px 16px;background:var(--black);color:white;font-weight:800;cursor:pointer}.btn.gold{background:var(--gold);color:#111}.btn.ghost{background:white;color:#111;border:1px solid #ddd}.form{display:grid;gap:14px}.form.two{grid-template-columns:repeat(2,1fr)}input,select,textarea{width:100%;border:1px solid #ddd;border-radius:14px;padding:13px;background:white;font:inherit}label{font-weight:800;font-size:13px}.room-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.room-card{background:white;border-radius:24px;overflow:hidden;box-shadow:0 12px 35px #00000010;border:1px solid #eee}.room-img{height:160px;background:linear-gradient(135deg,#111,#c99b2e);display:flex;align-items:center;justify-content:center;color:white;font-size:40px;font-weight:900}.room-body{padding:18px}.price{font-size:24px;font-weight:900;color:#111}.old{text-decoration:line-through;color:#999;font-size:15px;margin-right:7px}.table-wrap{overflow:auto;background:white;border-radius:24px;border:1px solid #eee}table{width:100%;border-collapse:collapse;min-width:950px}th,td{text-align:left;padding:15px;border-bottom:1px solid #eee;font-size:14px}th{background:#111;color:white}.status{padding:7px 10px;border-radius:999px;font-weight:900;font-size:12px;color:white;display:inline-block}.status.vacant{background:var(--gold);color:white}.status.checked_in{background:var(--green)}.status.due_checkout{background:var(--red)}.status.out_of_service{background:#111}.status.reserved{background:#334155}.board{grid-template-columns:repeat(5,minmax(0,1fr))}.board-card{padding:18px;border-radius:20px;color:white;font-weight:900}.board-card small{display:block;opacity:.85;margin-top:4px}.hero{min-height:100vh;background:linear-gradient(135deg,#090909 0%,#1e1b16 45%,#c99b2e 130%);color:white;padding:40px}.hero-inner{max-width:1180px;margin:auto}.hero h1{font-size:58px;line-height:1.02;margin:70px 0 15px;max-width:760px}.hero p{font-size:18px;color:#eee;max-width:680px}.booking-panel{margin-top:35px;background:white;color:#111;border-radius:28px;padding:24px;box-shadow:0 25px 60px #0000004a}.steps{display:flex;gap:8px;margin-bottom:18px}.step{height:8px;flex:1;background:#eee;border-radius:999px}.step.active{background:var(--gold)}.hidden{display:none!important}.summary{background:#111;color:white;border-radius:22px;padding:20px}.modal{position:fixed;inset:0;background:#0008;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:white;border-radius:26px;padding:26px;max-width:620px;width:100%}@media(max-width:980px){.sidebar{position:static;width:100%}.app{display:block}.main{margin:0;width:100%}.cards,.room-grid,.board,.form.two{grid-template-columns:1fr}.hero h1{font-size:38px}}
.status.checked_out{background:#64748b}.modal{z-index:9999;backdrop-filter:blur(4px)}.modal-content{position:relative;box-shadow:0 25px 80px #00000040}.modal-content h2{margin:0 0 10px}.modal-message{line-height:1.65;color:#333}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.modal-x{position:absolute;right:18px;top:14px;border:0;background:transparent;font-size:28px;cursor:pointer;color:#555}.btn:disabled,.btn.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.discount-badge{display:inline-block;padding:6px 10px;border-radius:999px;background:#f8f0d9;color:#7a560b;font-weight:900;font-size:12px}.muted{color:var(--muted)}
.status.pending_reservation{background:#f59e0b;color:#111}.status.expired{background:#7f1d1d}.checkline{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #ddd;border-radius:14px;padding:13px;font-weight:900}.checkline input{width:auto}.modal-content .form{margin-top:12px}
.status.partial_reservation{background:#8b5cf6;color:#fff}.blocked-room{opacity:.78}.blocked-room .room-img{filter:grayscale(.75)}.split{display:flex;align-items:center;justify-content:space-between;gap:10px}.modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.modal-grid p{margin:4px 0}@media(max-width:700px){.modal-grid{grid-template-columns:1fr}}
#modalHost{position:relative;z-index:99999}.modal.is-open{display:flex!important}.modal-content{max-height:90vh;overflow:auto}.topbar .actions{display:flex;gap:10px;align-items:center}.alert-inline{padding:12px 14px;border-radius:14px;background:#fff7e6;border:1px solid #f0d08a;color:#6b4a00;margin:10px 0}.status.pending_reservation{background:#f59e0b;color:#111}.status.partial_reservation{background:#8b5cf6;color:#fff}.status.expired{background:#7f1d1d}.status.checked_out{background:#64748b}.status.reserved{background:#334155}.status.checked_in{background:#12805c}.status.due_checkout{background:#b91c1c}.status.vacant{background:#c99b2e;color:#fff}
