:root{--primary: #D32F2F;--primary-hover: #B71C1C;--primary-light: #FFEBEE;--primary-soft: rgba(211, 47, 47, .08);--accent: #1A1A1A;--accent-hover: #000000;--text-primary: #111827;--text-secondary: #4B5563;--text-tertiary: #9CA3AF;--text-inverse: #FFFFFF;--bg-primary: #FFFFFF;--bg-secondary: #F9FAFB;--bg-tertiary: #F3F4F6;--bg-surface: #FFFFFF;--border-light: #E5E7EB;--border-medium: #D1D5DB;--border-focus: #D32F2F;--status-free: #059669;--status-free-bg: #ECFDF5;--status-seated: #2563EB;--status-seated-bg: #EFF6FF;--status-late: #D97706;--status-late-bg: #FFFBEB;--status-overdue: #DC2626;--status-overdue-bg: #FEF2F2;--status-reserved: #7C3AED;--status-reserved-bg: #F5F3FF;--status-manual: #0891B2;--status-manual-bg: #ECFEFF;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-hover: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .2s cubic-bezier(.4, 0, .2, 1);--font-heading: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--nav-height: 70px}*,*:before,*:after{box-sizing:border-box}html{height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100%;font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{margin:0;font-family:var(--font-heading);font-weight:600;color:var(--text-primary);line-height:1.2;letter-spacing:-.02em}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1rem}p{margin:0;color:var(--text-secondary)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast);font-weight:500}a:hover{color:var(--primary-hover)}.card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal),transform var(--transition-normal);overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card-header{background:transparent;border-bottom:1px solid var(--border-light);padding:var(--spacing-lg)}.card-body{padding:var(--spacing-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-family:var(--font-body);font-size:.9rem;font-weight:500;line-height:1.5;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(1px)}.btn:focus{outline:none;box-shadow:0 0 0 3px var(--primary-light)}.btn-primary,button.btn.btn-primary{background-color:var(--primary);border-color:var(--primary);color:var(--text-inverse)}.btn-primary:hover,button.btn.btn-primary:hover{background-color:var(--primary-hover);border-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-outline-primary,button.btn.btn-outline-primary{background-color:transparent;border-color:var(--border-medium);color:var(--text-primary);box-shadow:none}.btn-outline-primary:hover,button.btn.btn-outline-primary:hover{background-color:var(--bg-tertiary);border-color:var(--border-medium);color:var(--text-primary)}.form-control,.form-select{display:block;width:100%;padding:.75rem 1rem;font-size:.95rem;font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.form-control:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-label{margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.table{width:100%;margin-bottom:0;color:var(--text-primary);border-collapse:separate;border-spacing:0}.table th{background-color:var(--bg-secondary);color:var(--text-secondary);font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;padding:1rem;border-bottom:1px solid var(--border-light)}.table td{padding:1rem;vertical-align:middle;border-bottom:1px solid var(--border-light);color:var(--text-secondary)}.table tr:last-child td{border-bottom:none}.table-hover tbody tr:hover{background-color:var(--bg-tertiary)}.badge{display:inline-flex;align-items:center;padding:.25em .75em;font-size:.75em;font-weight:600;line-height:1;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.025em}.text-muted{color:var(--text-tertiary)!important}.text-primary{color:var(--primary)!important}.bg-white{background-color:var(--bg-surface)!important}.shadow-sm{box-shadow:var(--shadow-sm)!important}.rounded-lg{border-radius:var(--radius-lg)!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.layout-container{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-secondary)}.route-container{flex:1;padding:var(--spacing-lg);background-color:var(--bg-secondary)}.dashboard-container{background-color:var(--bg-secondary)}.card{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}.reservation-container,.form-container{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.dashboard-columns{display:grid;grid-template-columns:minmax(300px,.8fr) minmax(520px,1.6fr);gap:var(--spacing-md);align-items:start}.dashboard-columns .reservations-main-section,.dashboard-columns .tables-main-section{margin:0;padding:0;border:none}@media (max-width: 991px){.dashboard-columns{grid-template-columns:1fr}}.table-card{position:relative;background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);width:100%;min-height:160px;padding:var(--spacing-md);transition:border-color var(--transition-fast)}.table-card:hover{border-color:var(--border-medium)}.table-card-main-info{flex-grow:1}.table-card-status-info{text-align:right;min-width:70px}.table-card-delete-button{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);color:var(--text-tertiary);opacity:0;transition:all var(--transition-fast);background:none;border:none;padding:var(--spacing-xs);cursor:pointer;z-index:10}.table-card:hover .table-card-delete-button{opacity:1}.table-card-delete-button:hover{color:var(--status-overdue)}.table-card-button{color:var(--primary);opacity:0;transition:opacity var(--transition-fast)}.table-card:hover .table-card-button{opacity:1}.table-card.table-filled{background-color:var(--status-seated-bg);border-color:var(--status-seated)}.table-card.upcoming-reserved{background-color:var(--status-reserved-bg);border-color:var(--status-reserved);border-style:dashed}.table-card.table-late{background-color:var(--status-late-bg);border-color:var(--status-late);border-style:dashed}.table-card.table-overdue-cancellation{background-color:var(--status-overdue-bg);border-color:var(--status-overdue)}.table-card.table-manually-occupied{background-color:var(--status-manual-bg);border-color:var(--status-manual);border-style:dashed}body.modal-open{overflow:hidden}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);z-index:1050}.modal-card{position:relative;background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 20px 50px #0f172a33;max-height:90vh;width:min(1100px,95vw);overflow-y:auto}.modal-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);border:none;background:transparent;color:var(--text-tertiary);font-size:1.5rem;line-height:1;padding:var(--spacing-xs);cursor:pointer}.modal-close:hover{color:var(--text-secondary)}.status-label{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;border-radius:var(--radius-full)}.status-free{background-color:var(--status-free-bg);color:var(--status-free)}.status-seated{background-color:var(--status-seated-bg);color:var(--status-seated)}.status-manually-occupied{background-color:var(--status-manual-bg);color:var(--status-manual)}.status-upcoming,.status-reserved{background-color:var(--status-reserved-bg);color:var(--status-reserved)}.status-late{background-color:var(--status-late-bg);color:var(--status-late)}.status-overdue---cancel{background-color:var(--status-overdue-bg);color:var(--status-overdue)}.guest-info{font-size:.8125rem;color:var(--text-secondary);word-break:break-word}.next-reservation-warning,.manual-conflict-warning{background-color:var(--status-late-bg);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-top:var(--spacing-sm)!important;border-left:3px solid var(--status-late)}.next-reservation-warning p,.manual-conflict-warning p{margin-bottom:var(--spacing-xs)!important;font-size:.8125rem}.next-reservation-warning strong,.manual-conflict-warning strong{color:var(--status-late)}.action-buttons-container{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.action-buttons-container button{font-size:.75rem;padding:.25rem .625rem}.action-buttons-container .btn-icon{background:none;border:none;color:var(--text-tertiary);padding:var(--spacing-xs);cursor:pointer;transition:color var(--transition-fast)}.action-buttons-container .btn-icon:hover{color:var(--status-overdue)}.manual-occupy-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;display:flex;justify-content:center;align-items:center;z-index:1050}.manual-occupy-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);width:90%;max-width:380px;overflow:hidden;z-index:1051}.manual-occupy-modal .card-header{padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-light)}.manual-occupy-modal .card-header h5{margin:0 0 var(--spacing-xs) 0;font-weight:600}.manual-occupy-modal .card-header p{font-size:.8125rem;color:var(--text-secondary);margin:0}.manual-occupy-modal .card-body{padding:var(--spacing-lg)}.manual-occupy-modal .card-footer{padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg-secondary);border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.manual-occupy-modal .input-group .form-control{text-align:center}.input-group .btn svg{vertical-align:middle}.join-tooltip{position:absolute;top:50%;left:102%;transform:translateY(-50%);background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);z-index:1050;min-width:180px;max-width:400px}.join-tooltip h6{margin:0 0 var(--spacing-sm) 0;font-weight:600;font-size:.8125rem;color:var(--text-primary);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-light)}.join-tooltip ul{list-style:none;padding:0;margin:0}.join-tooltip li{padding:var(--spacing-xs) 0;font-size:.8125rem;color:var(--text-secondary);white-space:nowrap}.dashboard-reservations-list-scrollable{max-height:50vh;overflow-y:auto;padding:var(--spacing-md);background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.dashboard-tables-scrollable{padding:var(--spacing-md);background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);max-height:60vh;overflow:auto}.dashboard-reservations-list-scrollable::-webkit-scrollbar{width:6px}.dashboard-reservations-list-scrollable::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.dashboard-reservations-list-scrollable::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}.dashboard-reservations-list-scrollable::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.tables-container{display:flex;flex-wrap:wrap;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--radius-lg)}.tables-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-md)}.tables-grid-item{min-width:220px;display:flex}.table-map-board{position:relative;min-width:100%;min-height:100%;border-radius:var(--radius-lg);background-color:transparent}.table-map-board.is-editing{outline:2px dashed var(--border-medium);outline-offset:-2px;touch-action:none}.table-map-wrapper{position:relative;min-height:100%}.table-map-toolbar{position:sticky;top:0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-sm);z-index:2;background:linear-gradient(180deg,#f9fafbf2,#f9fafb99,#f9fafb00)}.table-map-toolbar-group{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.table-map-toolbar-actions{margin-left:auto}.table-map-toolbar-panel{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.toolbar-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.toolbar-controls{display:flex;align-items:center;gap:var(--spacing-xs)}.fixture-picker-group{display:flex;gap:var(--spacing-xs)}.fixture-picker{border:1px solid var(--border-light);background-color:var(--bg-primary);width:32px;height:32px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.fixture-picker.active{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.fixture-swatch{display:block;width:18px;height:12px;border:2px solid var(--text-secondary);border-radius:4px}.fixture-swatch.square{width:14px;height:14px}.fixture-swatch.circle{border-radius:999px;width:14px;height:14px}.fixture-swatch.triangle{width:16px;height:14px;clip-path:polygon(50% 0%,0% 100%,100% 100%)}.fixture-swatch.pentagon{width:16px;height:14px;clip-path:polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%)}.toolbar-field{display:flex;flex-direction:column;gap:.25rem;font-size:.7rem;color:var(--text-tertiary)}.toolbar-field input,.toolbar-controls select{border:1px solid var(--border-light);border-radius:var(--radius-md);padding:.3rem .5rem;font-size:.75rem;background-color:var(--bg-primary);color:var(--text-primary)}.toolbar-actions{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.table-map-canvas{position:relative;min-width:100%;min-height:100%;border-radius:var(--radius-lg);--table-map-grid-size: 24px;background-color:var(--bg-secondary);background-image:repeating-linear-gradient(to bottom,transparent 0,transparent calc(var(--table-map-grid-size) - 1px),rgba(15,23,42,.04) calc(var(--table-map-grid-size) - 1px),rgba(15,23,42,.04) var(--table-map-grid-size)),repeating-linear-gradient(to right,transparent 0,transparent calc(var(--table-map-grid-size) - 1px),rgba(15,23,42,.04) calc(var(--table-map-grid-size) - 1px),rgba(15,23,42,.04) var(--table-map-grid-size))}.table-map-node{position:absolute;width:180px;min-height:120px;padding:var(--spacing-sm);border-radius:var(--radius-lg);border:1px solid var(--border-light);background-color:var(--bg-primary);box-shadow:0 8px 20px #0f172a14;-webkit-user-select:none;user-select:none}.table-map-node.table-filled{background-color:var(--status-seated-bg);border-color:var(--status-seated)}.table-map-node.upcoming-reserved{background-color:var(--status-reserved-bg);border-color:var(--status-reserved);border-style:dashed}.table-map-node.table-late{background-color:var(--status-late-bg);border-color:var(--status-late);border-style:dashed}.table-map-node.table-overdue-cancellation{background-color:var(--status-overdue-bg);border-color:var(--status-overdue)}.table-map-node.table-manually-occupied{background-color:var(--status-manual-bg);border-color:var(--status-manual);border-style:dashed}.table-map-node.is-editing{cursor:grab;touch-action:none}.table-map-node.is-dragging{cursor:grabbing;box-shadow:0 12px 24px #0f172a2e}.table-map-fixture{position:absolute;border:2px solid var(--border-medium);border-radius:var(--radius-md);background-color:#ffffffd1;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xs);font-size:.75rem;font-weight:600;-webkit-user-select:none;user-select:none}.table-map-fixture.circle{border-radius:999px}.table-map-fixture.triangle{clip-path:polygon(50% 0%,0% 100%,100% 100%)}.table-map-fixture.pentagon{clip-path:polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%)}.table-map-fixture.is-editing{cursor:move;touch-action:none}.table-map-fixture.is-selected{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.table-map-fixture.is-dragging{cursor:grabbing}.table-map-fixture-label{pointer-events:none}.fixture-handle{position:absolute;width:12px;height:12px;background-color:var(--primary);border-radius:4px;border:2px solid #fff;box-shadow:0 2px 6px #0f172a33}.fixture-handle-nw{top:-8px;left:-8px;cursor:nwse-resize}.fixture-handle-ne{top:-8px;right:-8px;cursor:nesw-resize}.fixture-handle-sw{bottom:-8px;left:-8px;cursor:nesw-resize}.fixture-handle-se{bottom:-8px;right:-8px;cursor:nwse-resize}.table-map-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.table-map-name{font-weight:600;color:var(--text-primary)}.table-map-meta{font-size:.75rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.table-map-guest{font-size:.8125rem;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.table-map-time{font-size:.75rem;color:var(--text-secondary)}.table-map-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.table-map-actions .btn{font-size:.7rem;padding:.2rem .4rem}.table-map-hint{font-size:.6875rem;color:var(--text-tertiary);margin-top:var(--spacing-xs)}.pill-button.danger{border-color:var(--status-overdue);background-color:var(--status-overdue-bg);color:var(--status-overdue)}@media (min-width: 992px){.dashboard-container{display:flex;flex-direction:column;height:calc(100vh - var(--nav-height) - (var(--spacing-lg) * 2));overflow:hidden}.dashboard-columns{flex:1 1 auto;min-height:0;height:100%;align-items:stretch}.reservations-main-section,.tables-main-section{display:flex;flex-direction:column;min-height:0;height:100%}.dashboard-reservations-list-scrollable,.dashboard-tables-scrollable{flex:1 1 0;max-height:none;min-height:0;height:100%;overflow:auto}}.tables-main-section .loading-placeholder{width:100%;display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl);min-height:200px}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);border:none;font-size:.875rem}.alert-danger{background-color:var(--status-overdue-bg);color:var(--status-overdue)}.alert-success{background-color:var(--status-free-bg);color:var(--status-free)}.alert-warning{background-color:var(--status-late-bg);color:var(--status-late)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.page-header h1{font-size:1.5rem}.date-navigation{display:flex;align-items:center;gap:var(--spacing-sm)}.date-navigation .btn{padding:.375rem .75rem}.date-display{font-weight:600;color:var(--text-primary);min-width:180px;text-align:center}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.section-header h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.section-title{display:flex;align-items:center;gap:var(--spacing-sm)}.section-pill{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);background-color:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-full)}.section-time-pill{color:var(--text-primary);background:linear-gradient(135deg,#eef6ff,#f6fbff);border-color:#cfe0ff;font-weight:500}.section-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.icon-button{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.icon-button i{font-size:.95rem;line-height:1}.icon-button:hover{background-color:var(--bg-tertiary);border-color:var(--border-medium);color:var(--text-primary)}.segmented-control{display:inline-flex;align-items:center;border:1px solid var(--border-light);border-radius:var(--radius-full);overflow:hidden;background-color:var(--bg-primary)}.segmented-control-btn{border:none;background:transparent;color:var(--text-secondary);padding:.25rem .6rem;font-size:.75rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.segmented-control-btn+.segmented-control-btn{border-left:1px solid var(--border-light)}.segmented-control-btn:hover,.segmented-control-btn.segmented-control-active{background-color:var(--bg-tertiary);color:var(--text-primary)}.segmented-control-btn:disabled{opacity:.5;cursor:not-allowed;background-color:transparent}.pill-button{border:1px solid var(--border-light);background-color:var(--bg-primary);color:var(--text-secondary);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.pill-button:hover,.pill-button-active{background-color:var(--bg-tertiary);border-color:var(--border-medium);color:var(--text-primary)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-tertiary)}.empty-state p{color:var(--text-tertiary);font-size:.875rem}.form-page{max-width:600px;margin:0 auto}.form-page .form-container{padding:var(--spacing-xl)}.form-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-light)}.two-column-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--spacing-lg)}@media (max-width: 991px){.two-column-layout{grid-template-columns:1fr}}.time-display{font-size:.875rem;color:var(--text-secondary);font-weight:500}html:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg-secondary);z-index:-1}.loading-wrapper{display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl)}.loader{width:32px;height:32px;border:3px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loader-dots{display:flex;gap:6px}.loader-dots span{width:8px;height:8px;background-color:var(--primary);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.loader-dots span:nth-child(1){animation-delay:-.32s}.loader-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.p-bold{font-weight:600}a{text-decoration:none}.reservation-list-item{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem}.reservation-details-section{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1.25rem;flex:1 1 auto;min-width:0}.reservation-list-item .detail-item{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.reservation-list-item .detail-item i{color:#6c757d;font-size:1rem;flex-shrink:0}.reservation-list-item .detail-item span{white-space:nowrap}.detail-time{min-width:65px}.detail-name,.detail-phone{min-width:100px}.detail-status{min-width:60px}.action-buttons-section{display:flex;align-items:center;gap:.5rem;flex-shrink:0;margin-left:auto}.linked-tables-section{flex-basis:100%}.cancel{color:var(--status-overdue, #dc3545);background:none;border:none;padding:.25rem;cursor:pointer;transition:all .15s ease}.cancel:hover{background-color:#dc35451a;border-radius:.25rem}.table-selectable{cursor:pointer;transition:all var(--transition-fast)}.table-selectable:hover{border-color:var(--primary)}.table-selected{background-color:var(--primary-light);border:2px solid var(--primary)}.table-selected:hover{background-color:var(--primary-light);border-color:var(--primary-hover)}.table-selected:after{content:"";position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:20px;height:20px;background-color:var(--primary);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E");background-size:14px;background-repeat:no-repeat;background-position:center}.settings-page{max-width:800px;margin:0 auto}.settings-header{margin-bottom:var(--spacing-lg)}.settings-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.settings-header p{color:var(--text-secondary);font-size:.875rem}.settings-card{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}.schedule-table{width:100%;border-collapse:collapse}.schedule-table th,.schedule-table td{padding:var(--spacing-md);vertical-align:middle;text-align:left;border-bottom:1px solid var(--border-light)}.schedule-table th{background-color:var(--bg-secondary);font-weight:600;font-size:.8125rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.schedule-table tr:last-child td{border-bottom:none}.schedule-table tr:hover td{background-color:var(--bg-secondary)}.schedule-day-name{font-weight:500;color:var(--text-primary);min-width:100px}.schedule-status-col{width:80px;text-align:center}.schedule-table th.schedule-status-col{text-align:center}.schedule-table td .form-control,.schedule-table td .form-select{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md);border-color:var(--border-light)}.schedule-table td .form-control:focus,.schedule-table td .form-select:focus{border-color:var(--primary)}.schedule-table input[type=time]{min-width:120px}.schedule-table .form-select{min-width:130px}.schedule-table td.schedule-status-col .form-check{display:flex;justify-content:center;margin:0}.schedule-table td .form-check-input{width:2.5em;height:1.25em;margin:0;cursor:pointer}.schedule-table td .form-check-input:checked{background-color:var(--primary);border-color:var(--primary)}.schedule-actions-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg-secondary);border-top:1px solid var(--border-light)}@media (max-width: 768px){.schedule-table th,.schedule-table td{padding:var(--spacing-sm);font-size:.8125rem}.schedule-table input[type=time]{min-width:100px}.schedule-table .form-select{min-width:110px}}.table-combos-page{max-width:1300px;padding:var(--spacing-md)}.table-combos-header{margin-bottom:var(--spacing-lg)}.table-combos-header-row{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.table-combos-header h2{font-size:1.65rem;margin-bottom:var(--spacing-xs)}.table-combos-header p{color:var(--text-secondary);max-width:760px}.table-combos-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.table-combos-card{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.table-combos-card-header{margin-bottom:var(--spacing-md)}.table-combos-card-header h3{font-size:1.125rem;margin-bottom:.2rem}.table-combos-card-header p{font-size:.875rem;color:var(--text-secondary)}.combo-create-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.combo-setting-panel{border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-secondary);padding:.75rem}.combo-setting-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.combo-setting-input{max-width:110px}.combo-table-picker{border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-sm);max-height:340px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-sm);background:linear-gradient(180deg,#fff,#fafafa)}.combo-table-chip{border:1px solid var(--border-light);background-color:var(--bg-primary);border-radius:var(--radius-md);padding:.55rem .6rem;text-align:left;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.combo-table-chip:hover{border-color:var(--border-medium);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.combo-table-chip.selected{border-color:var(--primary);background-color:var(--primary-light)}.combo-table-chip-name{display:block;font-weight:600;color:var(--text-primary);font-size:.88rem}.combo-table-chip-meta{font-size:.75rem;color:var(--text-secondary)}.combo-preview{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:.75rem}.combo-preview-row{display:flex;justify-content:space-between;font-size:.875rem;color:var(--text-secondary)}.combo-preview-row strong{color:var(--text-primary)}.combo-selected-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);min-height:30px}.combo-selected-pill{font-size:.75rem;background-color:var(--primary-light);color:var(--primary);border-radius:var(--radius-full);padding:.2rem .65rem;border:1px solid rgba(211,47,47,.2)}.combo-muted{color:var(--text-tertiary);font-size:.85rem}.combo-create-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.combo-empty-state{border:1px dashed var(--border-medium);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center;color:var(--text-secondary)}.combo-empty-state small{display:block;margin-top:.45rem;color:var(--text-tertiary)}.combo-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:620px;overflow-y:auto;padding-right:2px}.combo-list-item{border:1px solid var(--border-light);border-radius:var(--radius-md);padding:.75rem;background-color:#fff}.combo-list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:var(--spacing-sm)}.combo-list-item-header h4{font-size:.95rem;margin:0}.combo-list-item-actions{display:flex;gap:var(--spacing-xs)}.combo-metrics{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:.5rem}.combo-metric-badge{font-size:.72rem;padding:.15rem .5rem;border-radius:var(--radius-full);border:1px solid var(--border-light);color:var(--text-secondary);background-color:var(--bg-secondary)}.combo-metric-badge.emphasis{color:var(--primary);border-color:#d32f2f40;background-color:var(--primary-light)}.combo-tables{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.combo-table-pill{font-size:.74rem;border-radius:var(--radius-full);padding:.16rem .52rem;background-color:var(--bg-tertiary);color:var(--text-secondary)}@media (max-width: 1000px){.table-combos-header-row{flex-direction:column;align-items:flex-start}.table-combos-layout{grid-template-columns:1fr}}.navbar{background-color:var(--bg-primary);border-bottom:1px solid var(--border-light);padding:.75rem 0;min-height:var(--nav-height);position:sticky;top:0;z-index:100}.navbar .container-lg,.navbar .container-fluid{display:flex;align-items:center;justify-content:space-between}.navbar-brand{display:flex;align-items:center;padding:0;margin:0}.navbar-brand img{height:36px;width:auto}.active-location-pill{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--border-light);background:var(--bg-secondary);border-radius:999px;padding:.35rem .9rem;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.active-location-pill:hover{border-color:var(--primary);background:var(--bg-tertiary)}.active-location-label{color:var(--text-secondary)}.active-location-name{color:var(--text-primary);max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar .settings-icon,.navbar .logout-icon{color:var(--text-secondary)!important;padding:.5rem;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.navbar .settings-icon:hover,.navbar .logout-icon:hover{color:var(--primary)!important;background-color:var(--bg-tertiary)}.navbar .d-flex.align-items-center{gap:.25rem}@media (max-width: 992px){.active-location-label{display:none}}@media (max-width: 768px){.active-location-pill{max-width:190px;font-size:.8rem;padding:.32rem .75rem}.active-location-name{max-width:120px}}button.btn.btn-light{background-color:var(--bg-primary);border:1px solid var(--border-light);color:var(--text-primary)}button.btn.btn-light:hover{background-color:var(--bg-tertiary);border-color:var(--border-medium)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);padding:var(--spacing-lg)}.login-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:400px}.login-logo{margin-bottom:var(--spacing-xl)}.login-logo img{height:72px;width:auto}.login-card{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--spacing-xl);width:100%}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0 0 var(--spacing-xs) 0}.login-header p{color:var(--text-secondary);font-size:.875rem;margin:0}.login-form .form-group{margin-bottom:var(--spacing-md)}.login-form .form-label{display:block;color:var(--text-secondary);font-size:.8125rem;font-weight:500;margin-bottom:var(--spacing-xs)}.login-form .form-input{width:100%;padding:.75rem 1rem;font-size:.9375rem;font-family:inherit;border:1px solid var(--border-light);border-radius:var(--radius-md);transition:border-color var(--transition-fast);background-color:var(--bg-primary);box-sizing:border-box}.login-form .form-input:focus{outline:none;border-color:var(--primary)}.login-form .form-input::placeholder{color:var(--text-tertiary)}.login-form .form-input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.login-error{background-color:var(--status-overdue-bg);border-left:3px solid var(--status-overdue);color:var(--status-overdue);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.875rem}.login-button{width:100%;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;font-family:inherit;color:var(--text-inverse);background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.login-button:hover,.login-button:active{background-color:var(--primary-hover)}.login-button:disabled{background-color:var(--text-tertiary);cursor:not-allowed}.login-footer{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-light)}.login-footer p{color:var(--text-tertiary);font-size:.8125rem;margin:0}@media (max-width: 480px){.login-card{padding:var(--spacing-lg)}.login-logo img{height:56px}.login-header h2{font-size:1.25rem}}
