:root{--bg:#f5f6f8;--card:#fff;--pri:#2563eb;--ok:#16a34a;--warn:#d97706;--err:#dc2626;--mut:#6b7280;--bd:#e5e7eb}
*{box-sizing:border-box}body{margin:0;font-family:system-ui,Arial,sans-serif;background:var(--bg);color:#111}
.topbar{display:flex;justify-content:space-between;align-items:center;background:#1e293b;color:#fff;padding:.7rem 1.2rem;flex-wrap:wrap;gap:.5rem}
.topbar a{color:#fff;text-decoration:none;margin-left:1rem}.topbar .brand{font-weight:700;font-size:1.2rem;margin:0}
.topbar nav a:hover{text-decoration:underline}
.container{max-width:960px;margin:1.5rem auto;padding:0 1rem}
.footer{text-align:center;color:var(--mut);padding:2rem;font-size:.9rem}
.card{background:var(--card);border:1px solid var(--bd);border-radius:10px;padding:1.2rem;margin-bottom:1rem}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.room h2{margin:.2rem 0}.muted{color:var(--mut);font-size:.9rem}.price{font-size:.9rem}
.btn,button{cursor:pointer}.btn{display:inline-block;background:var(--pri);color:#fff;padding:.5rem .9rem;border-radius:8px;text-decoration:none}
.form{display:flex;flex-direction:column;gap:.7rem;max-width:380px}
.form label{display:flex;flex-direction:column;font-size:.9rem;gap:.25rem}
.form input{padding:.5rem;border:1px solid var(--bd);border-radius:6px}
.form .check{flex-direction:row;align-items:center;gap:.4rem}
.form button{background:var(--pri);color:#fff;border:0;padding:.6rem;border-radius:8px}
.alert{background:#fee2e2;color:var(--err);padding:.7rem;border-radius:8px}
.ok{background:#dcfce7;color:var(--ok);padding:.7rem;border-radius:8px}
.dateform{margin:1rem 0;display:flex;gap:.8rem;align-items:center}
.dateform input{padding:.4rem;border:1px solid var(--bd);border-radius:6px}
.legend{display:flex;gap:.5rem;margin:.5rem 0 1rem;flex-wrap:wrap}
.legend .slot{cursor:default}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.5rem}
.slot-form{margin:0}
.slot{display:block;width:100%;text-align:center;padding:.5rem;border-radius:6px;border:1px solid var(--bd);font-size:.85rem;text-decoration:none;color:#111}
.slot.free{background:#dcfce7;border-color:#86efac}.slot.free:hover{background:#bbf7d0}
button.slot.free{cursor:pointer}
.slot.confirmed{background:#e5e7eb;color:var(--mut)}
.slot.requested{background:#fef3c7;color:#92400e}
.slot.blocked{background:#fee2e2;color:#991b1b}
.table{width:100%;border-collapse:collapse;background:#fff}
.table th,.table td{border:1px solid var(--bd);padding:.5rem;text-align:left;font-size:.9rem}
.badge{padding:.15rem .5rem;border-radius:99px;font-size:.8rem}
.badge.requested{background:#fef3c7;color:#92400e}.badge.confirmed{background:#dcfce7;color:#166534}
.badge.rejected{background:#fee2e2;color:#991b1b}.badge.cancelled{background:#e5e7eb;color:#6b7280}
.link{background:none;border:0;color:var(--err);cursor:pointer;text-decoration:underline;padding:0}

.room-desc{margin:.5rem 0 1rem;line-height:1.5}
.room-desc ul,.room-desc ol{margin:.4rem 0 .4rem 1.2rem}
.weekgrid{border-collapse:collapse;width:100%;font-size:.8rem}
.weekgrid th,.weekgrid td{border:1px solid var(--bd);padding:2px;text-align:center;vertical-align:middle}
.weekgrid th{background:#f1f5f9}
.weekgrid .timecol{white-space:nowrap;background:#f8fafc;font-weight:600}
.weekgrid .slot{display:block;padding:.3rem;border-radius:4px;font-size:.72rem}
.slot.closed{background:#f3f4f6;color:#cbd5e1}
.weekgrid td a.slot.free{cursor:pointer}
