:root{color-scheme:light;--bg: #eef2f4;--surface: #ffffff;--surface-soft: #f7f9fa;--line: #dbe3e7;--text: #18242b;--muted: #66757d;--accent: #0c7b6b;--accent-strong: #075b50;--warning: #b7791f;--danger: #b84242;--info: #2c6f9f;--shadow: 0 18px 48px rgba(22, 37, 44, .12)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.68}.app-shell{display:grid;grid-template-columns:270px minmax(0,1fr);min-height:100vh}.login-shell{display:grid;place-items:center;min-height:100vh;padding:24px;background:#16252b}.login-panel{width:min(420px,100%);background:var(--surface);border:1px solid var(--line);padding:22px}.center-select-panel{width:min(760px,100%);background:var(--surface);border:1px solid var(--line);padding:22px}.center-select-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.center-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.center-option{min-height:116px;border:1px solid var(--line);background:var(--surface-soft);color:var(--text);padding:14px;text-align:left}.center-option:hover{border-color:#9bc8bf;background:#edf6f1}.center-option strong,.center-option span,.center-option small{display:block}.center-option span,.center-option small{color:var(--muted);margin-top:5px}.login-brand{padding:0 0 20px;color:var(--text)}.login-brand span{color:var(--muted)}.login-form{display:grid;gap:14px}.login-form label{display:grid;gap:6px;color:var(--muted);font-size:13px}.login-form input{min-height:42px;border:1px solid var(--line);background:var(--surface-soft);color:var(--text);padding:0 10px}.sidebar{background:#16252b;color:#f7fafb;padding:22px 16px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center;padding:4px 8px 24px}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(255,255,255,.22);background:#0c7b6b;font-weight:800}.brand strong,.brand span{display:block}.brand span{color:#a9bdc4;font-size:13px;margin-top:2px}.nav-list{display:grid;gap:5px}.nav-item{display:grid;grid-template-columns:34px 1fr;align-items:center;width:100%;min-height:42px;border:0;background:transparent;color:#cfe0e5;text-align:left;padding:7px 10px}.nav-item svg,.icon-button svg,.search svg,.entity-card svg,.setting-card svg{color:currentColor;flex:0 0 auto}.nav-item:hover,.nav-item.active{background:#ffffff1a;color:#fff}.icon{display:grid;place-items:center;width:26px;height:26px;color:#9ed5ca}.main{min-width:0;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px}.eyebrow{margin:0 0 4px;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:0}h1,h2,h3,p{margin-top:0}h1{margin-bottom:0;font-size:28px;line-height:1.18}h2{margin-bottom:4px;font-size:22px}h3{margin-bottom:0;font-size:16px}.top-actions{display:flex;align-items:center;gap:10px}.search{display:flex;align-items:center;gap:8px;min-width:min(390px,42vw);height:42px;background:var(--surface);border:1px solid var(--line);padding:0 12px}.search input{width:100%;border:0;outline:0;background:transparent}.icon-button,.user-pill{display:grid;place-items:center;width:42px;height:42px;border:1px solid var(--line);background:var(--surface);color:var(--text)}.user-pill{background:#d9ece8;border-color:#c8dfda;color:var(--accent-strong);font-weight:800}.api-pill{display:inline-flex;align-items:center;min-height:32px;border:1px solid var(--line);background:var(--surface);color:var(--muted);padding:0 10px;font-size:13px}.api-pill.online{background:#edf6f1;border-color:#c9e1d8;color:var(--accent-strong)}.api-pill.fallback{background:#fff6dd;border-color:#ead495;color:var(--warning)}.persistence-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;border:1px solid var(--line);background:var(--surface);padding:12px 14px}.persistence-banner span{color:var(--muted);font-size:13px}.persistence-banner.mysql{background:#edf6f1;border-color:#c9e1d8}.persistence-banner.seed,.persistence-banner.unavailable{background:#fff6dd;border-color:#ead495}.view{display:none}.view.active{display:block}.toolbar{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:18px}.toolbar p{margin-bottom:0;color:var(--muted)}.segmented{display:flex;border:1px solid var(--line);background:var(--surface);padding:3px}.segmented button,.tabs button{border:0;background:transparent;padding:8px 13px;color:var(--muted)}.segmented .selected,.tabs .active{background:#d9ece8;color:var(--accent-strong)}.primary-button,.ghost-button{min-height:38px;border:1px solid transparent;padding:0 14px}.primary-button{background:var(--accent);color:#fff}.ghost-button{background:var(--surface-soft);border-color:var(--line);color:var(--text)}.ghost-button.danger{color:var(--danger)}.full{width:100%}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}.metric-card,.panel,.table-panel,.invoice-detail,.room-card,.entity-card,.setting-card{background:var(--surface);border:1px solid var(--line);box-shadow:0 1px #ffffffb3}.metric-card{padding:16px;min-height:112px}.metric-card strong{display:block;font-size:30px;margin:8px 0 4px}.metric-label,.metric-card small,.status,.amount-row span{color:var(--muted)}.work-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.55fr);gap:16px}.access-grid{display:grid;grid-template-columns:minmax(320px,.8fr) minmax(0,1.2fr);gap:16px;margin-bottom:16px}.access-tables{grid-template-columns:minmax(0,1fr) minmax(0,.95fr)}.panel{padding:16px}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.occupancy-board{display:grid;grid-template-columns:96px minmax(96px,1fr);gap:5px;overflow-x:auto}.occ-cell{min-height:34px;display:grid;place-items:center;background:var(--surface-soft);border:1px solid var(--line);font-size:12px;white-space:nowrap}.occ-cell.label{justify-content:start;padding-left:8px;font-weight:700}.occ-cell.free,.legend .free{background:#edf6f1}.occ-cell.occupied,.legend .occupied{background:#bfe3da}.occ-cell.reserved,.legend .reserved{background:#f4dfad}.occ-cell.blocked,.legend .blocked{background:#d5dce0}.legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;color:var(--muted);font-size:13px}.legend span{display:inline-flex;align-items:center;gap:6px}.legend i{width:14px;height:14px;border:1px solid var(--line)}.task-list{display:grid;gap:10px;margin:0;padding-left:22px}.task-list li{padding-left:4px}.task-list span{display:block;color:var(--muted);margin-top:3px;font-size:13px}.session-card{display:grid;grid-template-columns:58px 1fr;gap:12px;align-items:center}.session-avatar{display:grid;place-items:center;width:54px;height:54px;background:#d9ece8;color:var(--accent-strong);border:1px solid #c8dfda}.session-card strong,.session-card span,.profile-list span,.muted{display:block}.session-card span,.profile-list span,.muted{color:var(--muted);font-size:13px;margin-top:3px}.profile-list{display:grid;gap:8px}.profile-list article{display:flex;justify-content:space-between;align-items:center;gap:12px;border:1px solid var(--line);background:var(--surface-soft);padding:10px}.access-form-panel{margin-bottom:16px}.access-form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.access-form label,.access-form fieldset{display:grid;gap:6px;color:var(--muted);font-size:13px}.access-form input,.access-form select,.access-form textarea{width:100%;min-height:38px;border:1px solid var(--line);background:var(--surface-soft);color:var(--text);padding:0 10px}.access-form textarea{min-height:110px;padding:10px;resize:vertical}.full-field{grid-column:1 / -1}.access-form fieldset{grid-column:1 / -1;margin:0;border:1px solid var(--line);padding:10px}.access-form legend{padding:0 4px;color:var(--text);font-weight:700}.role-checks{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.check-row{display:flex!important;align-items:center;min-height:34px;border:1px solid var(--line);background:var(--surface);padding:0 9px}.check-row input{width:auto;min-height:auto}.form-actions{grid-column:1 / -1;display:flex;align-items:center;gap:12px}.form-message{color:var(--muted);font-size:13px}.form-message.error{color:var(--danger)}.tabs{display:inline-flex;border:1px solid var(--line);background:var(--surface);padding:3px;margin-bottom:12px}.table-panel{overflow-x:auto}.maintenance-layout{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(380px,.7fr);gap:16px;align-items:start;margin-bottom:16px}.booking-list-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;align-items:start;margin-bottom:16px}.booking-search-panel{display:grid;grid-template-columns:minmax(260px,1.2fr) repeat(4,minmax(135px,.55fr)) auto auto;align-items:end;gap:10px;margin-bottom:12px}.booking-search-panel label{display:grid;gap:6px;color:var(--muted);font-size:13px}.booking-search-panel input{min-height:38px;border:1px solid var(--line);background:#fff;padding:0 10px}.booking-search-panel .status{align-self:center;white-space:nowrap}.booking-table-panel{max-height:314px;overflow:auto}.booking-table-panel thead th{position:sticky;top:0;z-index:1}.maintenance-stack{display:grid;gap:18px}.maintenance-tabs{margin-bottom:16px}.maintenance-title{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:14px}.row-actions-cell{width:86px;min-width:86px;padding-left:10px;padding-right:10px;vertical-align:middle}.booking-actions-cell{width:220px;min-width:220px;padding-left:10px;padding-right:10px;vertical-align:middle}.row-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;white-space:nowrap}.action-icon-button{display:grid;place-items:center;width:34px;height:34px;border:1px solid var(--line);background:var(--surface-soft);color:var(--text)}.action-icon-button:hover{background:#d9ece8;border-color:#c8dfda;color:var(--accent-strong)}.action-icon-button.danger{color:var(--danger)}.action-icon-button.danger:hover{background:#fff0f0;border-color:#efc4c4}.small-action-button{min-height:34px;border:1px solid #c8dfda;background:#edf6f1;color:var(--accent-strong);padding:0 10px;white-space:nowrap}.small-action-button.danger{border-color:#efc4c4;background:#fff0f0;color:var(--danger)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;padding:24px;background:#16252c5c}.modal-panel{width:min(760px,100%);max-height:calc(100vh - 48px);overflow:auto;box-shadow:var(--shadow)}.modal-panel:has(.booking-manual-form){width:min(1100px,100%)}.user-form{grid-template-columns:repeat(2,minmax(0,1fr))}.booking-manual-form{grid-template-columns:1fr;gap:14px}.form-block{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:12px;border:1px solid var(--line);background:var(--surface-soft)}.form-block h4{grid-column:1 / -1;margin:0 0 2px}.form-block .full-field{grid-column:1 / -1}.checkbox-label{display:inline-flex;align-items:center;gap:8px;color:var(--text)}.checkbox-label input{width:16px;height:16px}.booking-manual-form textarea{min-height:76px;resize:vertical}.inline-actions,.document-actions{align-items:end}.table-title{padding:14px 14px 0}.table-title h3{margin-bottom:3px}.table-title span{color:var(--muted);font-size:13px}table{width:100%;border-collapse:collapse;min-width:720px}th,td{text-align:left;padding:13px 14px;border-bottom:1px solid var(--line);vertical-align:middle}td{line-height:1.28}th{background:var(--surface-soft);color:var(--muted);font-size:13px;font-weight:700}tr:last-child td{border-bottom:0}.badge{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border:1px solid;font-size:12px}.badge.reserva{background:#eef5fb;border-color:#c9ddec;color:var(--info)}.badge.recepcion{background:#edf6f1;border-color:#c9e1d8;color:var(--accent-strong)}.badge.pendiente{background:#fff6dd;border-color:#ead495;color:var(--warning)}.badge.danger{background:#fff0f0;border-color:#f0c0c0;color:var(--danger)}.room-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}.sex-pill,.sex-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:24px;min-width:34px;border:1px solid var(--line);background:#fff;color:var(--muted);padding:0 8px;font-size:12px;font-weight:700}.sex-pill.male,.sex-toggle.male{background:#e7f3ff;border-color:#b9d8f2;color:#1e628f}.sex-pill.female,.sex-toggle.female{background:#fff4ca;border-color:#e8d17d;color:#83620a}.sex-toggle{width:100%;min-height:38px;cursor:pointer}.sex-toggle:disabled{cursor:not-allowed;opacity:.72}.inline-status{margin-top:7px}.room-layout,.cards-grid,.settings-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.filter-panel,.invoice-form{display:grid;grid-template-columns:minmax(220px,.5fr) minmax(180px,.35fr) auto;align-items:end;gap:12px;margin-bottom:16px}.invoice-form{grid-template-columns:minmax(280px,1fr) auto minmax(180px,.6fr)}.filter-panel label,.invoice-form label{display:grid;gap:6px;color:var(--muted);font-size:13px}.filter-panel select,.filter-panel input,.invoice-form select{min-height:38px;border:1px solid var(--line);background:#fff;padding:0 10px}.availability-summary{display:grid;grid-template-columns:repeat(4,minmax(72px,1fr));gap:10px}.availability-summary .amount-row{padding:0;border-bottom:0}.room-card,.entity-card,.setting-card{padding:15px}.room-head,.entity-card header,.setting-card header{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:12px}.beds{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.bed{min-height:28px;display:grid;place-items:center;background:var(--surface-soft);border:1px solid var(--line);font-size:12px;gap:2px;padding:4px;overflow:hidden}.bed small{max-width:100%;overflow:hidden;color:var(--text);font-size:10px;text-overflow:ellipsis;white-space:nowrap}.bed.used{background:#bfe3da}.bed.blocked{background:#d5dce0}.bed.extra-bed{border-style:dashed;background:#f4dfad}.room-foot{margin:12px 0 0;color:var(--muted);font-size:13px}.occupancy-list,.guest-panel{margin-top:16px}.guest-layout{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:16px;align-items:start}.guest-list-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:14px}.guest-table{margin-top:14px}.guest-table-scroll{margin-top:0;max-height:156px;overflow:auto}.guest-table-scroll thead th{position:sticky;top:0;z-index:1}.assignment-panel{border-left:1px solid var(--line);padding-left:16px}.closed-summary{border-left:0;padding-left:0}.guest-modal-form{grid-template-columns:1fr}.assignment-panel h4{margin-bottom:12px}.compact-form{gap:10px}.invoice-grid,.invoice-stack{display:grid;gap:16px}.invoice-grid{grid-template-columns:minmax(0,1fr) 320px}.invoice-stack{grid-template-columns:minmax(0,1fr)}.invoice-detail{padding:16px}.invoice-detail .ghost-button{margin-top:8px}.invoice-line-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;border-bottom:1px solid var(--line)}.invoice-line-row .amount-row{border-bottom:0}.invoice-line-form{display:grid;grid-template-columns:minmax(0,1fr) 70px 100px;gap:8px;margin:12px 0}.invoice-line-form label{display:grid;gap:5px;color:var(--muted);font-size:12px}.invoice-line-form input{min-height:36px;border:1px solid var(--line);background:var(--surface-soft);padding:0 9px}.invoice-line-form .form-actions{grid-column:1 / -1}.invoice-detail-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.history-filter{display:grid;grid-template-columns:170px 170px minmax(160px,1fr) minmax(160px,1fr);align-items:end;gap:12px;margin-bottom:16px}.history-filter label{display:grid;gap:6px;color:var(--muted);font-size:13px}.history-filter input{min-height:38px;border:1px solid var(--line);background:var(--surface-soft);padding:0 10px}.selected-row{background:#f2f8f6}.link-button{border:0;background:transparent;padding:0;color:var(--accent-strong);font-weight:700;cursor:pointer}.amount-row{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}.amount-row.total{border-bottom:0;margin-bottom:10px;font-size:18px}.entity-card p,.setting-card p{color:var(--muted);margin-bottom:12px}.card-actions{display:flex;gap:8px}@media(max-width:1080px){.app-shell{grid-template-columns:82px minmax(0,1fr)}.brand div:last-child,.nav-item span:last-child{display:none}.nav-item{grid-template-columns:1fr;justify-items:center}.metrics-grid,.room-layout,.cards-grid,.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.work-grid,.invoice-grid,.access-grid,.access-form,.form-block,.booking-search-panel,.maintenance-layout{grid-template-columns:1fr}.role-checks{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.app-shell{display:block}.sidebar{position:static;height:auto}.nav-list{grid-template-columns:repeat(4,1fr)}.main{padding:16px}.topbar,.toolbar{align-items:stretch;flex-direction:column}.top-actions{flex-wrap:wrap}.search{min-width:100%}.metrics-grid,.room-layout,.cards-grid,.settings-grid{grid-template-columns:1fr}.segmented,.tabs{overflow-x:auto}.persistence-banner,.form-actions{align-items:stretch;flex-direction:column}.role-checks{grid-template-columns:1fr}}
