.table-map{--grid-w: 6;--grid-h: 6;--cell-size: 90px;--gap: 8px;display:grid;grid-template-columns:repeat(var(--grid-w, 6),var(--cell-size));grid-template-rows:repeat(var(--grid-h, 6),var(--cell-size));gap:var(--gap);padding:16px;background-color:var(--color-surface-variant);border-radius:var(--radius-lg);width:fit-content;margin:0 auto;border:1px solid var(--color-border);box-shadow:var(--shadow-inner)}.table-map-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:center;margin-bottom:16px;width:100%;padding:12px;background-color:var(--color-bg-subtle);border-radius:var(--radius-md)}.table-map-controls__group{display:flex;align-items:center;gap:8px}.table-map-controls__group span{font-size:14px;font-weight:500}.table-map-controls__input{width:60px!important}.grid-cell{border:1px dashed var(--color-border-subtle);border-radius:4px;width:var(--cell-size);height:var(--cell-size);z-index:1}.table-item{width:var(--cell-size);height:var(--cell-size);background-color:var(--color-primary);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;cursor:grab;-webkit-user-select:none;user-select:none;font-size:13px;font-weight:600;box-shadow:var(--shadow-md);transition:transform .2s,box-shadow .2s,background-color .2s;z-index:2;padding:8px;text-align:center}.table-item:hover{transform:scale(1.05);box-shadow:var(--shadow-lg);background-color:var(--color-primary-dark)}.table-item--dragging{opacity:.6;cursor:grabbing;transform:scale(1.1)}.table-item__label{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;line-height:1.2;max-width:100%}.table-item__seats{font-size:11px;opacity:.9;margin-top:4px}.table-map-container{display:flex;flex-direction:column;gap:16px;align-items:center}.unplaced-tables{display:flex;flex-wrap:wrap;gap:8px;padding:16px;background-color:var(--color-bg-subtle);border-radius:var(--radius-md);width:100%;min-height:80px}.unplaced-tables__title{width:100%;font-size:14px;font-weight:500;margin-bottom:8px}.unplaced-tables__empty{width:100%;display:flex;align-items:center;justify-content:center;padding:12px;color:var(--color-text-muted);font-size:14px;font-style:italic;border:1px dashed var(--color-border-subtle);border-radius:var(--radius-sm)}:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;--color-bg: #f8fafc;--color-surface: #ffffff;--color-muted: #64748b;--color-text: #0f172a;--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-primary-soft: #eff6ff;--color-border: #e2e8f0;--color-border-hover: #cbd5e1;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px}.stack{display:flex;flex-direction:column}.stack-sm{gap:var(--space-2)}.stack-md{gap:var(--space-4)}.stack-lg{gap:var(--space-6)}.row{display:flex;align-items:center}.row-sm{gap:var(--space-2)}.row-md{gap:var(--space-4)}.surface-bordered{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);background:var(--color-surface)}.text-muted{color:var(--color-muted);font-size:.9rem}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.font-bold{font-weight:700}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;background:var(--color-bg);color:var(--color-text);line-height:1.5}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#0f172a33;border-radius:999px}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#f8fafc;padding:40px 24px;display:flex;flex-direction:column;gap:32px;border-right:1px solid rgba(255,255,255,.05)}.sidebar__brand{display:flex;align-items:center;gap:14px;padding:0 8px}.sidebar__logo{width:40px;height:40px;border-radius:var(--radius-md);object-fit:contain;background:#ffffff14;padding:6px;box-shadow:0 4px 12px #0003}.sidebar__title{margin:0;font-weight:700;font-size:1.1rem;letter-spacing:-.01em}.sidebar__subtitle{margin:2px 0 0;color:#ffffff80;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.sidebar__nav{display:flex;flex-direction:column;gap:6px}.sidebar__link{color:#f8fafc99;padding:12px 14px;border-radius:var(--radius-md);display:flex;align-items:center;gap:12px;font-weight:500;transition:all .2s ease}.sidebar__link:hover{background:#f8fafc0d;color:#fff}.sidebar__link--active{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #3b82f640}.sidebar__footer{margin-top:auto;font-size:.8rem;color:#f8fafc66;padding:0 8px}.app-shell__content{display:flex;flex-direction:column;padding:40px;gap:32px;max-width:1400px;margin:0 auto;width:100%}.app-shell__main{flex:1}.top-bar{display:flex;justify-content:space-between;align-items:center}.top-bar__eyebrow{margin:0;color:var(--color-muted);font-size:.9rem}.top-bar__heading{margin:2px 0 0}.top-bar__actions{display:flex;gap:12px;align-items:center}.btn{border:none;border-radius:var(--radius-md);padding:10px 20px;background:var(--color-primary);color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:.95rem}.btn:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn:active{transform:translateY(0)}.btn--ghost{background:transparent;color:var(--color-muted)}.btn--ghost:hover{background:#0000000d;color:var(--color-text);box-shadow:none}.btn--outline{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn--outline:hover{background:#fff;border-color:var(--color-border-hover)}.input{position:relative}.input__field{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 16px;background:var(--color-surface);color:var(--color-text);font-size:.95rem;transition:all .2s ease;outline:none}.input__field:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-soft)}.input__field::placeholder{color:#94a3b8}.input--with-icon .input__field{padding-left:44px}.input__icon{position:absolute;top:50%;left:16px;transform:translateY(-50%);color:var(--color-muted);pointer-events:none}.select{position:relative}.select__field{width:100%;border-radius:var(--radius-md);border:1px solid var(--color-border);padding:12px 40px 12px 16px;background:var(--color-surface);-webkit-appearance:none;-moz-appearance:none;appearance:none;font-size:.95rem;transition:all .2s ease;outline:none}.select__field:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-soft)}.select__chevron{position:absolute;top:50%;right:16px;transform:translateY(-50%);bottom:auto;pointer-events:none;color:var(--color-muted)}.badge{padding:6px 12px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em;display:inline-flex;align-items:center;gap:6px}.badge--success{background:#f0fdf4;color:var(--color-success);border:1px solid #dcfce7}.badge--warning{background:#fffbeb;color:var(--color-warning);border:1px solid #fef3c7}.badge--danger{background:#fef2f2;color:var(--color-danger);border:1px solid #fee2e2}.badge--default{background:#f8fafc;color:var(--color-muted);border:1px solid var(--color-border)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:box-shadow .3s ease}.card:hover{box-shadow:var(--shadow-md)}.card__header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}.card__title{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:-.01em}.card__subtitle{margin:4px 0 0;color:var(--color-muted);font-size:.95rem}.card__body{display:flex;flex-direction:column;gap:16px}.table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface)}.table-wrapper table{width:100%;border-collapse:collapse}.table-wrapper th{text-align:left;padding:16px 20px;background:#f8fafc;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);border-bottom:1px solid var(--color-border)}.table-wrapper td{padding:16px 20px;border-bottom:1px solid var(--color-border);font-size:.95rem}.table-row--clickable{cursor:pointer;transition:background-color .2s ease}.table-row--clickable:hover{background-color:#f8fafc}.simple-table{width:100%;border-collapse:collapse}.simple-table th,.simple-table td{text-align:left;padding:12px 0;border-bottom:1px solid var(--color-border)}.grid{display:grid;gap:20px}.grid--2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid--3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.page-stack{display:flex;flex-direction:column;gap:24px}.stat-value{font-size:2.25rem;margin:0}.stat-hint{margin:4px 0 0;color:var(--color-muted)}.pill{border-radius:var(--radius-pill);padding:4px 10px;background:#0f172a14;font-size:.85rem}.pill--soft{background:var(--color-primary-soft);color:var(--color-primary)}.filters{display:flex;gap:10px}.table-cell__primary{font-weight:600}.table-cell__muted{color:var(--color-muted);font-size:.9rem}.table-actions{display:flex;gap:8px}.table-row--clickable:hover{background-color:var(--color-primary-soft)}.empty-row{text-align:center;padding:24px!important;color:var(--color-muted)}.definition-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.definition-list dt{font-size:.9rem;color:var(--color-muted)}.definition-list dd{margin:4px 0 0;font-weight:600}.form{display:flex;flex-direction:column;gap:16px}.form__field,.form__checkbox{display:flex;flex-direction:column;gap:6px;font-weight:600}.form__checkbox{flex-direction:row;align-items:center;font-weight:500}.textarea{border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:12px;font-family:inherit}.color-input{width:80px;height:44px;border:none;border-radius:var(--radius-sm);padding:0}.field-hint{color:var(--color-muted);font-size:.85rem}.field-hint--error{color:var(--color-danger)}.top-bar__auth{display:flex;align-items:center;gap:8px}.top-bar__user{font-size:.9rem;color:var(--color-muted)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,#f8fafc,#e2e8f0);padding:24px}.login-screen__card{width:min(440px,100%);background:var(--color-surface);border-radius:var(--radius-xl);padding:48px;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:24px;border:1px solid rgba(255,255,255,.5)}.login-screen__eyebrow{margin:0;color:var(--color-primary);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.login-screen__title{margin:4px 0 0;font-size:1.75rem;font-weight:800;letter-spacing:-.025em}.login-screen__muted{margin:0;color:var(--color-muted);font-size:.95rem;line-height:1.6}.login-screen__error{margin:0;color:var(--color-danger);font-weight:600;padding:12px;background:#fef2f2;border-radius:var(--radius-md);font-size:.9rem}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-weight:500;color:var(--color-muted)}.calendar{width:100%}.calendar__header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar__day-header{text-align:center;font-weight:600;font-size:.85rem;color:var(--color-muted);padding:8px 4px}.calendar__body{display:flex;flex-direction:column;gap:4px}.calendar__week{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar__day{min-height:100px;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px;background:var(--color-surface);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:4px}.calendar__day:hover{background:#fff;border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px);z-index:10}.calendar__day--today{border-color:var(--color-primary);background:var(--color-primary-soft);box-shadow:inset 0 0 0 1px var(--color-primary)}.calendar__day--out-of-range{opacity:.3;background:#f1f5f9;pointer-events:none}.calendar__day-number{font-weight:700;font-size:1rem;color:var(--color-text)}.calendar__day-reservations{display:flex;flex-wrap:wrap;gap:2px;margin-top:auto}.calendar__day-badge{min-width:18px;height:18px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#fff;padding:0 4px}.calendar-time-view{width:100%}.calendar-time-view__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.calendar-time-view__header h3{margin:0;font-size:1.25rem}.calendar-time-view__timeline{position:relative;min-height:500px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);margin-bottom:16px;overflow:hidden;box-shadow:var(--shadow-sm)}.calendar-time-view__lanes{position:relative;width:100%;height:100%;min-height:400px}.calendar-time-view__lane{position:relative;width:100%;min-height:70px;margin-bottom:8px}.calendar-time-view__table-rows{position:relative;width:100%;min-height:400px;padding:8px 0}.calendar-time-view__table-row{display:grid;grid-template-columns:180px 1fr;gap:12px;min-height:80px;margin-bottom:2px;padding:2px 12px;border-bottom:1px solid var(--color-border);align-items:start}.calendar-time-view__table-row:last-child{border-bottom:none}.calendar-time-view__table-row--unassigned{border-top:2px solid var(--color-border);margin-top:16px;padding-top:16px}.calendar-time-view__table-label{display:flex;flex-direction:column;gap:2px;padding-right:12px;border-right:1px solid var(--color-border);min-width:180px;position:sticky;left:0;background:var(--color-surface);z-index:5}.calendar-time-view__table-name{font-weight:600;font-size:.9rem;color:var(--color-text)}.calendar-time-view__table-seats{font-size:.75rem;color:var(--color-muted)}.calendar-time-view__table-reservations{position:relative;width:100%;min-height:95px}.calendar-time-view__reservation{position:absolute;top:0;height:100%;min-height:70px;border-radius:var(--radius-sm);padding:4px 10px;color:#fff;font-size:.85rem;display:flex;flex-direction:column;justify-content:flex-start;gap:6px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000001a;box-sizing:border-box}.calendar-time-view__reservation:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;z-index:10}.calendar-time-view__reservation-name{font-weight:700;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;min-height:1.3em;display:block}.calendar-time-view__reservation-time{font-weight:500;font-size:.85rem;opacity:.95}.calendar-time-view__reservation-details{font-size:.8rem;opacity:.9}.calendar-time-view__hours{display:grid;grid-template-columns:repeat(var(--hour-count, 13),1fr);gap:4px;font-size:.75rem;color:var(--color-muted);text-align:center}.calendar-time-view__hour{padding:4px 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal{width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.form__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.form__actions{display:flex;gap:12px;margin-top:8px}@media (max-width: 960px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;flex-wrap:wrap;gap:12px}.app-shell__content{padding:16px}.top-bar{flex-direction:column;align-items:flex-start;gap:12px}.filters{flex-direction:column}.calendar__day{min-height:60px;padding:4px}.calendar__day-number{font-size:.8rem}.calendar__day-badge{min-width:16px;height:16px;font-size:.65rem}}
