:root{color:#1f2937;background:#f6f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink: #111827;--muted: #64748b;--line: #d9e0ea;--surface: #ffffff;--available: #ffffff;--checked-in: #1f9d5b;--housekeeping: #d83a3a;--primary: #2563eb;--warning: #b45309}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}.app-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:32px 0 56px}.login-shell{display:grid;min-height:100vh;place-items:center;padding:24px}.login-panel{display:grid;width:min(100%,420px);gap:18px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 24px 70px #0f172a29;padding:26px}.login-panel h1{margin:0;color:var(--ink);font-size:2rem;line-height:1.05}.app-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:22px}.app-kicker{margin:0 0 6px;color:#0f766e;font-size:.82rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.app-header h1{margin:0;color:var(--ink);font-size:clamp(2rem,6vw,3.35rem);line-height:1}.summary-strip{display:grid;grid-template-columns:repeat(3,minmax(110px,1fr));gap:8px;min-width:min(100%,430px)}.summary-strip span{display:flex;min-height:58px;flex-direction:column;justify-content:center;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted);padding:10px 12px;font-size:.82rem}.summary-strip strong{color:var(--ink);font-size:1.3rem}.setup-banner{display:flex;align-items:center;gap:10px;border:1px solid #f3d58b;border-radius:8px;background:#fff7df;color:#754b00;margin-bottom:18px;padding:12px 14px}.setup-banner--error{border-color:#fecaca;background:#fff1f2;color:#9f1239}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:18px;padding:14px 0}.role-switcher,.segmented-group{display:inline-grid;grid-auto-flow:column;gap:4px;border:1px solid var(--line);border-radius:8px;background:#e8edf5;padding:4px}.role-switcher button,.segmented-group button{display:inline-flex;min-height:36px;align-items:center;justify-content:center;gap:8px;border:0;border-radius:6px;background:transparent;color:#334155;padding:0 12px;font-weight:800}.role-switcher button.is-active,.segmented-group button.is-active{background:#fff;color:var(--ink);box-shadow:0 1px 3px #0f172a24}.session-pill{display:inline-flex;min-height:42px;align-items:center;gap:9px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:0 12px}.session-pill span{font-weight:850}.session-pill strong{color:var(--muted);font-size:.84rem}.role-note{color:var(--muted);font-size:.9rem;text-align:right}.dashboard-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,420px);align-items:start;gap:24px}.side-stack{display:grid;gap:16px;position:sticky;top:16px}.work-panel{border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 14px 34px #0f172a14}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line);padding:18px}.panel-kicker{margin:0 0 4px;color:var(--muted);font-size:.76rem;font-weight:850;text-transform:uppercase}.panel-header h2{display:flex;align-items:center;gap:8px;margin:0;color:var(--ink);font-size:1.15rem;line-height:1.25}.room-grid-wrap{display:grid;gap:24px}.floor-section{padding:22px 0 0;border-top:1px solid var(--line)}.floor-section__header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.floor-section h2{margin:0;color:var(--ink);font-size:1rem}.floor-section__header span{color:var(--muted);font-size:.9rem}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(126px,1fr));gap:12px}.room-tile{display:flex;position:relative;min-height:116px;flex-direction:column;justify-content:space-between;border:1px solid var(--line);border-radius:8px;background:var(--available);color:var(--ink);padding:14px;text-align:left;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.room-tile:hover,.room-tile:focus-visible{border-color:#2563eb;box-shadow:0 14px 30px #0f172a1f;outline:none;transform:translateY(-2px)}.room-tile--selected{border-color:#f59e0b;box-shadow:inset 0 0 0 3px #fbbf24,0 14px 30px #0f172a1f}.room-tile--checked-in{border-color:#157f48;background:var(--checked-in);color:#fff}.room-tile--housekeeping{border-color:#b91c1c;background:var(--housekeeping);color:#fff}.room-tile__number{font-size:2rem;font-weight:850;line-height:1}.room-tile__status,.room-tile__guest{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.room-tile__status{font-size:.82rem;font-weight:750}.room-tile__guest{opacity:.88;font-size:.78rem}.room-tile__header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.room-tile__alert{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#fbbf24;color:#b45309;flex-shrink:0}.room-tile__duration{margin-top:4px;font-family:Monaco,Menlo,monospace;font-size:.75rem;font-weight:600;color:#64748b;letter-spacing:.5px}.room-tile__duration--alert{color:#b45309;font-weight:700;animation:pulse-warning 2s cubic-bezier(.4,0,.6,1) infinite}.room-tile--alert-23{border-color:#b45309;box-shadow:0 0 0 2px #b453091a}.room-tile--overdue-24{border-color:#dc2626;box-shadow:0 0 0 2px #dc26261a}.room-tile--overdue-24 .room-tile__duration{color:#dc2626;font-weight:700;animation:pulse-error 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.6}}@keyframes pulse-error{0%,to{opacity:1}50%{opacity:.5}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0f172a6b;padding:18px;z-index:10}.room-modal{width:min(100%,460px);border:1px solid rgb(255 255 255 / .4);border-radius:8px;background:#fff;box-shadow:0 24px 70px #0f172a47}.room-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;border-bottom:1px solid var(--line);padding:22px}.room-modal__eyebrow{color:var(--muted);font-size:.78rem;font-weight:800;text-transform:uppercase}.room-modal h2{display:flex;align-items:center;gap:8px;margin:3px 0 0;color:var(--ink);font-size:1.75rem}.icon-button{display:inline-grid;width:40px;height:40px;place-items:center;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}.room-form{display:grid;gap:16px;padding:18px}.form-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field{display:grid;gap:8px}.field>span{color:var(--ink);font-size:.88rem;font-weight:750}.field__control{display:grid;grid-template-columns:22px 1fr;align-items:center;gap:10px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;color:var(--muted);padding:0 12px}.field__control:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb29}.field input{width:100%;min-height:46px;border:0;outline:0;background:transparent;color:var(--ink)}.field select{width:100%;min-height:46px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;color:var(--ink);padding:0 12px}.field input:disabled{color:#94a3b8;cursor:not-allowed}.pricing-summary{display:grid;gap:7px;border:1px solid #c7d2fe;border-radius:8px;background:#eef2ff;color:#334155;padding:12px;font-size:.9rem}.pricing-summary strong{color:#1e3a8a;font-size:1rem}.form-message{margin:0;font-size:.9rem}.form-message--error{color:#b91c1c}.room-form__actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;padding-top:4px}.room-form__actions--wide{grid-template-columns:1fr}.button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px;padding:0 14px;font-weight:800}.button:disabled{cursor:not-allowed;opacity:.65}.button--primary{background:var(--primary);color:#fff}.button--secondary{background:#e2e8f0;color:#0f172a}.button--warning{background:#fef3c7;color:var(--warning)}.history-list{display:grid;gap:10px;padding:0 18px 18px}.history-item{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:12px}.history-item div{display:grid;gap:3px}.history-item span{color:var(--muted);font-size:.82rem}.history-actions{display:grid;gap:8px}.empty-state{margin:0;color:var(--muted);font-size:.9rem}.icon-button--danger{border-color:#fecaca;color:#b91c1c}.view-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px}.view-tab{display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted);padding:10px 14px;font-weight:700;cursor:pointer;transition:all .16s ease}.view-tab:hover{border-color:var(--primary)}.view-tab--active{border-color:var(--primary);background:var(--primary);color:#fff}.daily-report{display:grid;gap:20px}.daily-report__header{display:flex;align-items:center;justify-content:space-between;gap:16px}.daily-report__title{margin:0;color:var(--ink);font-size:1.5rem}.daily-report__date-nav{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:8px}.daily-report__date-display{text-align:center;min-width:140px}.daily-report__date-label{font-weight:800;color:var(--ink);font-size:.95rem}.daily-report__date-full{color:var(--muted);font-size:.82rem}.daily-report__loading{text-align:center;color:var(--muted);padding:32px 0}.daily-report__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-card{display:grid;gap:8px;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:16px}.stat-card--primary{border-color:var(--primary);box-shadow:inset 0 0 0 1px #2563eb1a}.stat-card__label{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:.82rem;font-weight:600}.stat-card__value{color:var(--ink);font-size:1.8rem;font-weight:800;line-height:1}.daily-report__checkouts{display:grid;gap:14px}.daily-report__section-title{margin:0;color:var(--ink);font-size:1.1rem}.daily-report__empty{text-align:center;color:var(--muted);padding:32px 16px;background:#f8fafc;border-radius:8px}.checkouts-table{display:grid;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--surface)}.checkouts-table__header{display:grid;grid-template-columns:80px 1fr 140px 140px;gap:12px;background:#f8fafc;border-bottom:1px solid var(--line);padding:12px;font-weight:700;font-size:.82rem;color:var(--muted)}.checkouts-table__row{display:grid;grid-template-columns:80px 1fr 140px 140px;gap:12px;align-items:center;border-bottom:1px solid var(--line);padding:12px}.checkouts-table__row:last-child{border-bottom:none}.checkouts-table__cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;color:var(--ink)}.checkouts-table__cell--room{text-align:center;font-weight:700}.checkouts-table__cell--amount{text-align:right;font-weight:600;color:#1f9d5b}.button--icon{background:transparent;border:1px solid var(--line);color:var(--ink);padding:6px 10px;min-height:38px;transition:all .16s ease}.button--icon:hover:not(:disabled){border-color:var(--primary);background:#eff6ff}@media (max-width: 760px){.app-shell{width:min(100% - 20px,680px);padding-top:22px}.app-header{align-items:stretch;flex-direction:column}.toolbar,.dashboard-layout{grid-template-columns:1fr}.toolbar{align-items:stretch;flex-direction:column}.role-note{text-align:left}.side-stack{position:static}.summary-strip{grid-template-columns:repeat(3,minmax(0,1fr));min-width:0}.summary-strip span{min-height:64px;padding:9px}.room-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.room-form__actions,.form-grid-2,.daily-report__stats{grid-template-columns:1fr}.daily-report__date-nav{flex-wrap:wrap}.checkouts-table__header,.checkouts-table__row{grid-template-columns:60px 1fr 100px 100px;gap:8px;padding:10px}.checkouts-table__cell{font-size:.8rem}}
