:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#17211d;background:#f5f7f6;--bg: #f5f7f6;--panel: #ffffff;--panel-soft: #eef4f1;--line: #d7e0dc;--text: #17211d;--muted: #64726c;--accent: #0f6d4e;--accent-2: #1667a8;--danger: #b42318;--warning: #a16207;--shadow: 0 10px 30px rgba(22, 33, 29, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.62}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:#fff;color:var(--text)}textarea{min-height:140px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}label{display:grid;gap:6px;color:var(--muted);font-size:.9rem}label input,label select,label textarea{color:var(--text);font-size:1rem}table{width:100%;border-collapse:collapse;min-width:720px}th,td{border-bottom:1px solid var(--line);padding:11px 10px;text-align:left;vertical-align:top}th{color:var(--muted);font-size:.82rem;font-weight:700}td small{display:block;margin-top:4px;color:var(--muted)}.topbar{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:minmax(190px,1fr) auto minmax(240px,1fr);gap:18px;align-items:center;padding:14px clamp(16px,4vw,36px);background:#fffffff2;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{display:flex;align-items:center;min-width:0;gap:10px}.brand img{width:40px;height:40px;border-radius:8px;object-fit:contain}.brand strong,.brand span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand span{color:var(--muted);font-size:.82rem}.tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}.tabs button{border:1px solid transparent;border-radius:8px;padding:9px 12px;background:transparent;color:var(--muted);font-weight:700}.tabs button.active{border-color:#b7d6ca;background:#e3f2ec;color:var(--accent)}.top-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px;min-width:0}.place-select{display:flex;align-items:center;gap:8px;min-width:min(260px,100%)}.place-select span{color:var(--muted);font-size:.82rem;font-weight:700}.place-pill,.user-chip{border:1px solid var(--line);border-radius:8px;padding:8px 10px;background:#fff;color:var(--muted);font-size:.86rem}.app-shell{width:min(1480px,100%);margin:0 auto;padding:24px clamp(14px,3vw,28px) 48px}.panel,.login-card,.profile-card,.table-card,.subpanel{border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow)}.panel{padding:clamp(16px,2vw,22px)}.subpanel{margin-top:18px;padding:16px;box-shadow:none}.section-title{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:16px}.section-title--compact{align-items:center;margin-bottom:10px}.section-title h2,.section-title h3,.subpanel h3{margin:0}.section-title p,.muted{color:var(--muted)}.section-title p{margin:4px 0 0}.btn{border:1px solid var(--accent);border-radius:8px;padding:10px 14px;background:var(--accent);color:#fff;font-weight:800}.btn--ghost{border-color:var(--line);background:#fff;color:var(--text)}.btn--sm{padding:7px 10px;font-size:.86rem}.danger{color:var(--danger)}.button-row,.actions-row,.row-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.form-grid,.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.compact-field{width:140px}.res-layout,.client-layout{display:grid;grid-template-columns:minmax(360px,.92fr) minmax(480px,1.35fr);gap:18px;align-items:start}.availability-panel{position:sticky;top:88px}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.calendar{display:grid;grid-template-columns:repeat(7,minmax(38px,1fr));gap:6px}.cal-head{color:var(--muted);font-size:.78rem;font-weight:800;text-align:center}.calendar button{aspect-ratio:1;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);font-weight:800}.calendar button.avail{border-color:#78b79d;background:#e8f6ef}.calendar button.full{border-color:#e4b3ae;background:#fff1ef}.calendar button.selected{outline:3px solid rgba(15,109,78,.22);border-color:var(--accent)}.calendar button.past{color:#9aa5a0;background:#f2f4f3}.slots-block{margin-top:20px}.slot-list{display:grid;gap:8px;max-height:320px;overflow:auto}.slot-list button{display:grid;grid-template-columns:auto auto 1fr;gap:10px;align-items:center;border:1px solid var(--line);border-radius:8px;padding:10px;background:#fff;color:var(--text);text-align:left}.slot-list strong,.badge{border-radius:8px;padding:4px 8px;background:var(--panel-soft);color:var(--accent);font-size:.8rem}.reservation-group{border-top:1px solid var(--line);padding-top:10px;margin-top:12px}.reservation-group summary{display:flex;justify-content:space-between;list-style:none;cursor:pointer;color:var(--text);font-weight:800}.table-wrap{overflow-x:auto}.editor-panel{margin-bottom:18px;box-shadow:none}.search-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-bottom:10px}.profile-card{margin:16px 0;padding:16px;box-shadow:none}.metric-grid span{color:var(--muted)}.metric-grid strong{display:block;margin-top:4px;color:var(--text)}.config-panel{max-width:1180px}.sala-layout{display:grid;grid-template-columns:minmax(520px,1.4fr) minmax(320px,.8fr);gap:18px;align-items:start}.sala-reservations{grid-column:1 / -1}.room-canvas{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#f8faf9}.room-canvas svg{display:block;width:100%;min-height:460px}.room-outline{fill:#fff;stroke:#a6b2ad;stroke-width:.04}.table-shape{fill:#e5f2ec;stroke:var(--accent);stroke-width:.04}.table-shape.occupied{fill:#eef4ff;stroke:var(--accent-2)}.room-canvas text{fill:var(--text);font-size:.28px;font-weight:800;pointer-events:none}.table-list{display:grid;gap:12px;max-height:620px;overflow:auto}.table-card{padding:12px;box-shadow:none}.table-editor{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(420px,100%);padding:28px}.login-card img{width:58px;height:58px;object-fit:contain}.login-card h1{margin:14px 0 6px}.login-card p{color:var(--muted)}.login-card label{margin:14px 0}.form-status,.error-text{color:var(--danger)}.empty-state{border:1px dashed var(--line);border-radius:8px;padding:32px;background:#fff;color:var(--muted);text-align:center}.error-state h2{color:var(--text)}.toast-stack{position:fixed;right:18px;bottom:18px;z-index:50;display:grid;gap:10px;width:min(360px,calc(100vw - 36px))}.toast{border:1px solid var(--line);border-left:4px solid var(--accent-2);border-radius:8px;padding:12px 14px;background:#fff;box-shadow:var(--shadow)}.toast.ok{border-left-color:var(--accent)}.toast.error{border-left-color:var(--danger)}@media(max-width:1100px){.topbar,.res-layout,.client-layout,.sala-layout{grid-template-columns:1fr}.availability-panel{position:static}.top-actions{justify-content:flex-start}}@media(max-width:720px){.topbar{padding:12px}.tabs{justify-content:flex-start;overflow-x:auto}.form-grid,.metric-grid,.search-row,.table-editor{grid-template-columns:1fr}.section-title{display:grid}.room-canvas svg{min-height:320px}}
