.hidden{display:none!important}#service-grid-view{padding:16px;overflow:auto}.svc-floor-grid{display:grid;gap:12px}.svc-floor-cell{display:flex;align-items:stretch}.svc-table-card{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;padding:8px;border-radius:16px;border:2px solid transparent;transition:all .2s ease;background:var(--bg-card);box-shadow:0 2px 8px #0000000f;width:100%}.svc-table-card:hover{border-color:#2d5a274d;box-shadow:0 6px 20px #0000001a}.svc-table-card.some-served{border-color:#fbbf2480;background:#fbbf240a}.svc-table-card.all-served{border-color:#22c55e66;background:#22c55e0a}.svc-seat-row{display:flex;gap:6px;justify-content:center}.svc-mid-row{display:flex;align-items:stretch;gap:6px;width:100%;flex:1}.svc-seat-col{display:flex;flex-direction:column;gap:6px;align-items:center}.svc-table-surface{flex:1;background:#f1f5f9;border-radius:12px;padding:6px 2px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:60px;min-height:40px;border:1px solid #e2e8f0}body.light-mode .svc-table-surface{background:#f8fafc}.svc-table-label{font-size:12px;font-weight:800;color:#374151;text-transform:uppercase;letter-spacing:.5px;text-align:center}.svc-table-count{font-size:13px;font-weight:800;color:#64748b;margin-top:1px}.svc-unseated-avatar-wrap{position:relative;display:inline-flex}.svc-unseated-check{position:absolute;top:-4px;right:-4px;width:14px;height:14px;background:#22c55e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:900;border:1.5px solid white;box-shadow:0 1px 3px #0003;z-index:5}.svc-unseated-avatars{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin-top:4px;padding:0 4px;max-width:120px}.svc-unseated-avatar{width:36px;height:36px;border-radius:8px;border:1.5px solid white;box-shadow:0 2px 4px #0000001a;object-fit:cover;background:#f1f5f9;transition:all .2s ease}.svc-unseated-avatar.served,.svc-unseated-initials.served{filter:grayscale(1);opacity:.45}.svc-unseated-initials{width:36px;height:36px;border-radius:8px;background:#e2e8f0;color:#475569;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;border:1.5px solid white;box-shadow:0 2px 4px #0000001a;transition:all .2s ease}.svc-unseated-initials.served{background:#f1f5f9;color:#94a3b8;opacity:.6}.svc-unseated-overflow{width:36px;height:36px;border-radius:8px;background:#cbd5e1;color:#475569;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;border:1.5px solid white;box-shadow:0 2px 4px #0000001a}.svc-table-empty{font-size:11px;font-weight:600;color:var(--text-secondary)}.svc-seat-chip{width:52px;height:52px;border-radius:50%;border:2px dashed #d1d5db;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0;transition:all .15s;background:transparent;overflow:visible}.svc-seat-chip.sideways{width:48px;height:48px}.svc-seat-chip.empty{background:var(--bg-main)}.svc-seat-chip.occupied{border:2px solid #0065bd;background:#fff}.svc-seat-chip.occupied.is-seated{border-color:#0ea5e9;box-shadow:0 0 0 2px #0ea5e92e}.svc-seat-chip.occupied.is-ordered{border-color:#f59e0b}.svc-seat-chip.occupied.is-seated.is-ordered{border-color:#0ea5e9;box-shadow:0 0 0 2px #f59e0b40}.svc-seat-chip.occupied.served{border-color:#22c55e;opacity:.6}.svc-chip-avatar{width:100%;height:100%;object-fit:cover;object-position:top;border-radius:50%}.svc-seat-chip-stack{display:inline-flex;align-items:center;flex-shrink:0}.svc-seat-chip-stack .svc-seat-chip{box-shadow:0 0 0 2px var(--bg-card, #fff)}.svc-seat-chip-stack .svc-seat-chip+.svc-seat-chip{margin-left:-22px}.svc-seat-chip-stack.sideways{flex-direction:column}.svc-seat-chip-stack.sideways .svc-seat-chip+.svc-seat-chip{margin-left:0;margin-top:-22px}.svc-chip-initials{font-size:11px;font-weight:800;color:#0065bd;letter-spacing:.3px}.svc-chip-badges{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);display:flex;gap:2px;z-index:5;pointer-events:none}.svc-chip-badge{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;border:1.5px solid white;box-shadow:0 1px 3px #0003;pointer-events:none}.svc-chip-badge .material-symbols-outlined{font-size:11px;font-variation-settings:"FILL" 1,"wght" 700;line-height:1}.svc-chip-badge.is-seated{background:#0ea5e9}.svc-chip-badge.is-ordered{background:#f59e0b}.svc-chip-badge.is-done{position:absolute;top:-6px;right:-6px;background:#22c55e;width:18px;height:18px;z-index:5}.svc-chip-badge.is-done .material-symbols-outlined{font-size:13px}#table-residents-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:4px}.details-resident-row{display:flex;flex-direction:column;background:var(--bg-card);border:1.5px solid var(--border);border-radius:16px;overflow:hidden;transition:all .2s ease;width:100%}.details-resident-row.served{border-color:#22c55e;background:#22c55e0d}.details-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;gap:16px;background:var(--bg-light);border-bottom:1px solid var(--border)}.details-resident-row.served .details-card-header{background:#22c55e1a}.details-card-diagram{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px}.details-card-main{flex:1;display:flex;gap:12px;align-items:center;min-width:0}.details-avatar{width:120px;height:120px;border-radius:14px;object-fit:cover;object-position:top;border:2px solid var(--bg-card);box-shadow:0 2px 4px #0000001a;flex-shrink:0}.details-avatar-fallback{width:120px;height:120px;border-radius:14px;background:var(--bg-light);color:var(--text-secondary);font-size:34px;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-card);box-shadow:0 2px 4px #0000001a;flex-shrink:0}.details-res-info{display:flex;flex-direction:column;min-width:0}.details-res-name{font-size:18px;font-weight:800;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.details-res-seat{font-size:11px;font-weight:700;color:var(--text-secondary);opacity:.8;letter-spacing:.5px;margin-top:2px;text-transform:uppercase}.details-round-badge{display:inline-block;margin-top:4px;padding:2px 8px;font-size:10px;font-weight:800;letter-spacing:.5px;color:#0065bd;background:#dbeafe;border-radius:999px;width:fit-content}.details-card-body{padding:12px;flex:1;display:flex;flex-direction:column;gap:12px}.details-diet-pill{align-self:flex-start;padding:4px 10px;background:#fee2e2;color:#dc2626;border-radius:20px;font-size:11px;font-weight:800;letter-spacing:.3px;text-transform:uppercase}.details-notes{font-size:13px;color:var(--text-primary);line-height:1.4;padding:8px 12px;background:#f59e0b1a;border-left:4px solid #f59e0b;border-radius:4px}.details-menu-empty{font-size:13px;color:var(--text-secondary);font-style:italic;text-align:center}.details-card-footer{border-top:1px solid var(--border);background:var(--bg-light)}.details-resident-row.served .details-card-footer{background:#22c55e1a}.details-serve-btn{width:100%;background:#0065bd;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:800;letter-spacing:.5px;cursor:pointer;transition:background .2s;padding:12px 0}.details-serve-btn:hover{background:#00529b}.details-take-order-btn{width:100%;background:var(--primary-uber);color:#fff;border:none;font-size:14px;font-weight:800;letter-spacing:.5px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px var(--primary-uber-dim);display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 0}.details-take-order-btn:hover{background:#244b20;box-shadow:0 6px 16px #2d5a274d;transform:translateY(-1px)}.details-take-order-btn:active{transform:translateY(0);box-shadow:0 2px 8px var(--primary-uber-dim)}.details-served-confirmation,.details-undo-serve-btn{width:100%;background:transparent;border:none;display:block;text-align:center;color:#16a34a;font-weight:800;font-size:14px;letter-spacing:.5px;padding:12px 0;cursor:pointer;transition:all .2s ease}.details-undo-serve-btn:hover{background:#22c55e1a}.details-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(0,0,0,.1);border-top-color:currentColor;border-radius:50%;animation:details-spin .6s linear infinite}@keyframes details-spin{to{transform:rotate(360deg)}}.details-modal-divider{grid-column:1 / -1;font-size:11px;font-weight:800;color:var(--text-secondary);letter-spacing:1px;text-transform:uppercase;padding:20px 0 4px;border-top:1px solid var(--border);text-align:center}.mini-seat-diagram{position:relative;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.mini-table-icon{width:24px;height:24px;background:#cbd5e1;border-radius:5px;border:2px solid #94a3b8}.mini-seat-dot{position:absolute;width:8px;height:8px;background:#f1f5f9;border-radius:50%;border:1.5px solid #cbd5e1}.seat-top{top:0;left:50%;transform:translate(-50%)}.seat-left{left:0;top:50%;transform:translateY(-50%)}.seat-right{right:0;top:50%;transform:translateY(-50%)}.seat-bottom{bottom:0;left:50%;transform:translate(-50%)}.mini-seat-diagram[data-side=top] .seat-top,.mini-seat-diagram[data-side=left] .seat-left,.mini-seat-diagram[data-side=right] .seat-right,.mini-seat-diagram[data-side=bottom] .seat-bottom{background:#3b82f6;border-color:#2563eb;width:12px;height:12px;z-index:2}body.dark-mode .mini-table-icon{background:#475569;border-color:#64748b}body.dark-mode .mini-seat-dot{background:#1e293b;border-color:#475569}.details-resident-card{flex:1;background:var(--bg-main);border:1px solid var(--border-color);border-radius:12px;padding:14px 16px}.details-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.details-res-name{font-size:18px;font-weight:800;color:var(--text-primary)}.details-res-room{font-size:12px;font-weight:600;color:var(--text-secondary);margin-top:2px}.details-served-badge{flex-shrink:0;background:#dcfce7;color:#166534;font-size:11px;font-weight:800;padding:6px 12px;border-radius:8px;letter-spacing:.5px;white-space:nowrap}.details-serve-btn{flex-shrink:0;background:#0065bd;color:#fff;border:none;border-radius:8px;padding:18px 16px;font-size:11px;font-weight:800;letter-spacing:.5px;cursor:pointer;white-space:nowrap;font-family:inherit}.details-serve-btn:hover{background:#0052a3}.details-diet-pill{font-size:11px;font-weight:800;color:#d97706;background:#d9770614;border-radius:6px;padding:4px 8px;display:inline-block}.details-notes{font-size:12px;font-weight:600;color:var(--text-secondary);line-height:1.4}.details-menu-list{display:flex;flex-direction:column;gap:6px}.details-menu-item{font-size:16px;font-weight:600;color:var(--text-primary);border-bottom:1px solid #dddddd;padding-bottom:8px}.details-menu-item:last-child{border-bottom:none;padding-bottom:0}.details-menu-empty{font-size:14px;color:var(--text-secondary);font-style:italic}:root{--bg-main: #000000;--bg-card: #141414;--bg-sidebar: #000000;--bg-hover: #242424;--bg-light: #1f1f1f;--primary-uber: #2D5A27;--primary-uber-dim: rgba(45, 90, 39, .2);--alert-uber: #FFB74D;--alert-uber-dim: rgba(255, 183, 77, .15);--text-primary: #FFFFFF;--text-secondary: #A6A6A6;--border-color: rgba(0, 0, 0, .12);--border: var(--border-color);--accent-blue: #276EF1;--sidebar-width: 90px;--header-height: 80px;--touch-target: 64px;--radius-lg: 20px;--radius-md: 12px;--shadow-main: 0 8px 24px rgba(0, 0, 0, .5);--font-family: "Inter", -apple-system, sans-serif}body.light-mode{--bg-main: #F6F6F6;--bg-card: #FFFFFF;--bg-sidebar: #FFFFFF;--bg-hover: #F0F0F0;--bg-light: #F9FAFB;--text-primary: #000000;--text-secondary: #545454;--border-color: rgba(0, 0, 0, .12);--border: var(--border-color);--shadow-main: 0 4px 12px rgba(0, 0, 0, .08)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;transition:background-color .3s ease,color .3s ease,border-color .3s ease}body{margin:0;padding:0;background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-family);overflow:hidden;height:100vh;height:100dvh;width:100vw}#app{display:flex;height:100vh;height:100dvh;width:100vw}.sidebar{width:var(--sidebar-width);background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;padding:30px 0;z-index:1000}.sidebar-logo{width:48px;height:48px;background-color:transparent;margin-bottom:40px;display:flex;align-items:center;justify-content:center}.sidebar-logo img{width:100%;height:100%;object-fit:contain}.nav-item{width:64px;height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:12px;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:10px;font-weight:600;gap:4px}.nav-item svg{width:24px;height:24px}.nav-item.active{background-color:var(--text-primary);color:var(--bg-main)}body.light-mode .nav-item.active{background-color:#000;color:#fff}.nav-item.bottom{margin-top:auto}.main-stage{flex:1;display:flex;flex-direction:column;padding:0 24px 24px;overflow:hidden}.view-header{height:80px;display:flex;align-items:center;justify-content:space-between}.view-header h1{font-size:24px;font-weight:800;margin:0;letter-spacing:-.5px}.status-pill{display:inline-flex;align-items:center;gap:8px;background-color:var(--primary-uber-dim);color:var(--primary-uber);padding:4px 12px;border-radius:100px;font-size:12px;font-weight:700;letter-spacing:.5px;margin-left:12px;border:1px solid rgba(6,193,103,.2);vertical-align:middle}.pulse-dot{width:8px;height:8px;background-color:var(--primary-uber);border-radius:50%;position:relative}.status-pill-printer{background-color:#2563eb26;color:#2563eb;border-color:#2563eb40}.status-pill-printer .pulse-dot{background-color:#2563eb}.status-pill-printer.is-disconnected{background-color:#7878781f;color:#6b7280;border-color:#78787833;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.status-pill-printer.is-disconnected:hover{background-color:#2563eb1f;color:#2563eb;border-color:#2563eb40}.status-pill-printer.is-disconnected:hover .pulse-dot{background-color:#2563eb}.status-pill-printer.is-disconnected .pulse-dot{background-color:#9ca3af}.status-pill-printer.is-disconnected .pulse-dot:after{display:none}.status-pill-printer.is-reconnecting{background-color:#2563eb26;color:#2563eb;border-color:#2563eb40;cursor:progress}.status-pill-printer.is-reconnecting .pulse-dot{background-color:#2563eb}.status-pill-printer.is-reconnecting .pulse-dot:after{display:block;background-color:inherit}.printer-modal-spinner{width:28px;height:28px;border:3px solid rgba(37,99,235,.2);border-top-color:#2563eb;border-radius:50%;animation:printer-modal-spin .9s linear infinite;align-self:center}@keyframes printer-modal-spin{to{transform:rotate(360deg)}}.pulse-dot:after{content:"";position:absolute;width:100%;height:100%;background-color:inherit;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1);opacity:.8}to{transform:scale(3);opacity:0}}.prep-filter-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.service-controls-sticky{position:-webkit-sticky;position:sticky;top:0;z-index:100;background-color:var(--bg-main);margin-bottom:16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:32px;justify-content:flex-start;width:100%}.filter-group{display:flex;align-items:center;gap:16px}.filter-label{font-weight:800;font-size:13px;color:var(--text-secondary);white-space:nowrap}.date-navigator-wrap{display:flex;align-items:center;gap:16px}.date-navigator{display:flex;align-items:center;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:2px;gap:2px}.date-nav-btn{width:40px;height:40px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center}.date-nav-week{opacity:.5;width:36px}.date-nav-week:hover{opacity:1}.date-display{min-width:120px;text-align:center;font-weight:800;font-size:16px;letter-spacing:.5px}.today-jump-btn{background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:10px;font-weight:800;letter-spacing:.5px;padding:8px 16px}.today-jump-btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.meal-toggle{display:flex;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:4px;gap:4px}.meal-option{padding:0 24px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:12px;font-weight:800;cursor:pointer;color:var(--text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1)}.meal-option.active{background-color:var(--text-primary);color:var(--bg-main);box-shadow:0 4px 12px #0003}body.light-mode .meal-option.active{background-color:#000;color:#fff}.meal-toggle-compact .meal-option{padding:0 12px;min-width:42px}.settings-time-input{height:44px;padding:0 14px;border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-card);color:var(--text-primary);font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;min-width:140px}.settings-time-input:focus{outline:none;border-color:var(--text-primary)}#ordering-meal-toggle .meal-option[data-meal=breakfast].active{background-color:#d97706;color:#fff;box-shadow:0 4px 12px #d9770659}#ordering-meal-toggle .meal-option[data-meal=lunch].active{background-color:#0284c7;color:#fff;box-shadow:0 4px 12px #0284c759}#ordering-meal-toggle .meal-option[data-meal=dinner].active{background-color:#7c3aed;color:#fff;box-shadow:0 4px 12px #7c3aed59}.view-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;display:none;min-height:0}.view-content.active{display:block}#view-content-ordering.active{display:flex;flex-direction:column;overflow:hidden;min-height:0;flex:1}.uber-card{background-color:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);box-shadow:var(--shadow-main);overflow:hidden;position:relative}.grid-3{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;align-content:start}.table-separator{grid-column:1 / -1;display:flex;align-items:center;gap:16px;margin:20px 0 0}.table-separator-line{flex:1;height:1px;background-color:var(--border-color)}.table-separator-text{font-size:24px;font-weight:800;color:#000;letter-spacing:1px;white-space:nowrap;text-transform:uppercase}.grid-prep{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:40px}.section-header{display:flex;gap:10px;align-items:center;padding:12px 0;margin-bottom:16px;border-bottom:1px solid var(--border-color);font-size:14px;font-weight:800;letter-spacing:1px;color:var(--text-secondary)}.type-badge{font-size:11px;font-weight:900;padding:4px 12px;border-radius:8px;letter-spacing:.8px;text-transform:uppercase;background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-color);box-shadow:0 1px 3px #0000001a}.section-header.set .type-badge{background-color:var(--primary-uber-dim);border-color:#2d5a274d;color:var(--primary-uber)}.section-header.alert .type-badge{background-color:var(--alert-uber-dim);border-color:#ff8a004d;color:var(--alert-uber)}.prep-card.set-item{border-style:dashed}.prep-card{padding:20px 24px;display:flex;flex-direction:column;justify-content:space-between;min-height:140px;height:auto;transition:all .2s ease}.prep-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px #0000001a}.prep-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.prep-card-category{font-size:11px;font-weight:800;letter-spacing:.5px;color:var(--text-secondary);text-transform:uppercase}.prep-card-type-pill{font-size:10px;font-weight:900;padding:3px 8px;border-radius:6px;background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-color)}.prep-card[data-type=set] .prep-card-type-pill{background-color:var(--primary-uber-dim);color:var(--primary-uber);border-color:#2d5a2733}.prep-card[data-type=alert] .prep-card-type-pill{background-color:var(--alert-uber-dim);color:var(--alert-uber);border-color:#ff8a0033}.prep-card .count{font-size:40px;font-weight:950;line-height:1;margin-bottom:4px}.prep-card .label{font-size:16px;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.prep-card .diet-breakdown{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color)}.prep-card .diet-tag{font-size:16px;font-weight:700;padding:5px 12px;border-radius:6px;background:var(--bg-hover);color:var(--text-secondary);white-space:nowrap}.prep-card.warning{background-color:var(--alert-uber);color:#000;border:none}.prep-card.warning .diet-breakdown{border-top-color:#00000026}.prep-card.warning .diet-tag{background:#0000001a;color:#000}.service-card{display:flex;flex-direction:column;cursor:pointer;border:2px solid transparent;transition:all .25s cubic-bezier(.4,0,.2,1);overflow:hidden}.service-action-toast{position:fixed;top:80px;right:28px;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:900;letter-spacing:.8px;pointer-events:none;opacity:0;transform:translateY(-8px) scale(.9);transition:opacity .18s ease,transform .18s ease;z-index:1000;color:#fff;box-shadow:0 4px 16px #00000040}.service-action-toast.toast-visible{opacity:1;transform:translateY(0) scale(1)}.service-card:hover:not(.no-table){transform:translateY(-4px);box-shadow:0 12px 32px #00000026;border-color:var(--primary-uber-dim)}.service-card:active:not(.no-table){transform:scale(.98)}.service-card.no-table{cursor:not-allowed;opacity:.5}.service-card .card-header{display:flex;align-items:center;gap:14px;padding:8px;background:#f0f0f0}.service-card .resident-img{width:56px;height:56px;border-radius:12px;object-fit:cover;object-position:top;background-color:var(--bg-hover);flex-shrink:0}.header-info{display:flex;flex-direction:column;gap:3px;overflow:hidden}.name{font-size:14px;font-weight:800;color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-number{font-size:12px;font-weight:700;color:var(--text-secondary);letter-spacing:.5px}.seated-service-chip{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:800;letter-spacing:.5px;color:#16a34a;background:#22c55e1f;border:1px solid rgba(34,197,94,.3);border-radius:5px;padding:2px 6px;width:fit-content}.seated-service-chip .seated-duration{font-variant-numeric:tabular-nums;padding-left:5px;margin-left:1px;border-left:1px solid currentColor;opacity:.85}.seated-service-chip.is-warn{color:#b45309;background:#f59e0b24;border-color:#f59e0b66}.seated-service-chip.is-urgent{color:#b91c1c;background:#ef444424;border-color:#ef444473;animation:seated-urgent-pulse 1.8s ease-in-out infinite}@keyframes seated-urgent-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 3px #ef44442e}}.service-card.served .card-header,.service-card.served .body{opacity:.4}.served-check{position:absolute;top:10px;right:10px;width:26px;height:26px;background-color:#22c55e;color:#fff;border-radius:50%;display:none;align-items:center;justify-content:center;font-size:14px;font-weight:900;z-index:10;box-shadow:0 4px 12px #22c55e66;border:2px solid var(--bg-card)}.service-card.served .served-check{display:flex}.served-check-icon{position:relative;z-index:1;line-height:1}.served-countdown{position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;width:calc(100% + 14px);height:calc(100% + 14px);pointer-events:none;display:none;transform:rotate(-90deg);overflow:visible;filter:drop-shadow(0 1px 2px rgba(22,163,74,.35))}.service-card.serving-grace .served-countdown{display:block}.served-countdown-ring{fill:none;stroke:#16a34a;stroke-width:5;stroke-linecap:round;stroke-dasharray:113.1;stroke-dashoffset:0;animation:served-countdown-spin 10s linear forwards}@keyframes served-countdown-spin{0%{stroke-dashoffset:0}to{stroke-dashoffset:113.1}}.service-card .body{padding:12px 16px 16px}.resident-menu-list{display:flex;flex-direction:column;gap:6px}.menu-item-row{font-size:18px;font-weight:700;padding:7px 0;border-bottom:1px solid var(--border-color);background:none}.menu-item-row.last{border-bottom:none}.menu-item-row.selectable{color:var(--text-primary);text-transform:uppercase;display:flex;align-items:center;gap:8px;background:none}.menu-item-row.selectable:before{content:"";width:7px;height:7px;border-radius:50%;background-color:var(--primary-uber);flex-shrink:0}.menu-item-row.set{color:var(--text-secondary)}.diet-alert-pill{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:#d97706;padding:4px 0 8px;animation:diet-pulse 2s ease-in-out infinite}.allergy-alert-pill{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:#dc2626;padding:2px 0 8px}.notes-alert-pill{padding:8px;background:#f0f0f0;color:#333;font-size:16px;font-weight:500;border-radius:4px;line-height:1.3;width:fit-content;margin-bottom:8px}@keyframes diet-pulse{0%,to{opacity:1}50%{opacity:.4}}.settings-container{max-width:600px;margin:40px 0}.settings-row{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:24px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}.settings-info h3{margin:0 0 4px;font-size:20px}.settings-info p{margin:0;color:var(--text-secondary);font-size:14px}.switch{position:relative;display:inline-block;width:60px;height:34px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color);transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--primary-uber)}input:checked+.slider:before{transform:translate(26px)}.logout-btn-wrap{margin-top:60px;padding-top:40px;border-top:1px solid var(--border-color)}.logout-btn{width:100%;height:64px;background-color:var(--bg-card);border:2px solid #E22020;color:#e22020;border-radius:16px;font-size:16px;font-weight:800;letter-spacing:1px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.logout-btn:hover{background-color:#e22020;color:#fff;box-shadow:0 8px 20px #e220204d}.logout-btn:active{transform:scale(.98)}.ordering-layout{display:grid;grid-template-columns:360px 1fr;grid-template-rows:1fr;flex:1;min-height:0;overflow:hidden;position:relative;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.resident-list{background-color:transparent;border:none;border-right:1px solid var(--border-color);border-radius:0;display:flex;flex-direction:column;overflow:hidden;min-height:0}.resident-list-controls{padding:12px 16px;background:var(--bg-card);border-bottom:1px solid var(--border-color);flex-shrink:0}.ordering-status-jump{margin-top:10px;display:flex;gap:8px;width:100%}.status-jump-btn{flex:1;min-width:0;height:36px;padding:0 10px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-family:inherit;font-size:12px;font-weight:800;letter-spacing:.5px;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-flex;align-items:center;justify-content:center;gap:6px}.status-jump-btn .material-symbols-outlined{font-size:16px;font-variation-settings:"FILL" 1,"wght" 700}.status-jump-btn .status-jump-count{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--bg-hover);color:var(--text-primary);font-size:11px;font-weight:800;letter-spacing:0;display:inline-flex;align-items:center;justify-content:center;line-height:1}.status-jump-btn.is-needs-order .status-jump-count{background:#fed7aa;color:#7c2d12}.status-jump-btn.is-needs-seat .status-jump-count{background:#fde68a;color:#78350f}.status-jump-btn.is-ready .status-jump-count{background:#bbf7d0;color:#14532d}.status-jump-btn:hover{background:var(--bg-hover)}.status-jump-btn.is-needs-order:hover{background:#fed7aa;color:#7c2d12;border-color:#fb923c}.status-jump-btn.is-needs-seat:hover{background:#fde68a;color:#78350f;border-color:#fbbf24}.status-jump-btn.is-ready:hover{background:#bbf7d0;color:#14532d;border-color:#86efac}#unassigned-list{flex:1;overflow-y:auto;overflow-x:hidden}.res-item{padding:10px 24px 10px 8px;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;align-items:center;gap:16px;transition:background-color .2s ease;min-height:73px;position:relative}.res-item:hover{background-color:var(--bg-hover)}.res-item.active{background-color:var(--primary-uber-dim);border-left:6px solid var(--primary-uber)}.res-item .avatar{width:48px;height:48px;border-radius:50%;background-color:var(--bg-hover);object-fit:cover}.list-header{background-color:var(--bg-main);padding:12px 24px;font-size:11px;font-weight:800;color:var(--text-secondary);letter-spacing:1px;position:-webkit-sticky;position:sticky;top:0;z-index:10;width:100%;display:flex;align-items:center;gap:8px}.list-header-icon{font-size:16px;font-variation-settings:"FILL" 1,"wght" 700}.list-header.is-needs-selection{background-color:#fed7aa!important;color:#7c2d12;border-top:1px solid #fb923c;border-bottom:1px solid #fb923c}.list-header.is-completed{margin-top:12px;border-top:1px solid #86efac;padding-top:16px;padding-bottom:12px;background-color:#bbf7d0!important;color:#14532d;border-bottom:1px solid #86efac}.res-item.is-done{opacity:1}.check-badge{position:absolute;bottom:-2px;right:-2px;background-color:var(--primary-uber);color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;border:2px solid var(--bg-card)}.list-header.is-awaiting-seat{margin-top:12px;border-top:1px solid #fbbf24;padding-top:16px;padding-bottom:12px;background-color:#fde68a!important;color:#78350f;border-bottom:1px solid #fbbf24}.res-item.is-awaiting-seat:not(.active){box-shadow:inset 3px 0 #d97706}.res-meta-right{position:absolute;top:10px;right:12px;display:flex;flex-direction:column;align-items:flex-end;gap:6px;pointer-events:none;z-index:2}.res-item .res-meta-right+.info{padding-right:80px}.res-location{font-size:12px;font-weight:900;letter-spacing:.3px;white-space:nowrap}.progress-dots{display:flex;gap:6px}.progress-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1.5px solid #d1d5db;background:transparent;color:#9ca3af;transition:background .2s ease,color .2s ease,border-color .2s ease}.progress-dot .material-symbols-outlined{font-size:14px;font-variation-settings:"FILL" 1,"wght" 600}.progress-dot.lit{background:#16a34a;border-color:#15803d;color:#fff;box-shadow:0 1px 3px #16a34a59}.progress-dot.dim{background:#fff;border-style:dashed}@keyframes res-item-flash-ready{0%{background-color:#16a34a47}60%{background-color:#16a34a24}to{background-color:transparent}}.res-item.flash-ready{animation:res-item-flash-ready 1.4s ease-out}.family-order-tag{display:inline-flex;align-items:center;gap:4px;background-color:#eef2ff;color:#4f46e5;font-size:9px;font-weight:900;padding:2px 6px;border-radius:4px;letter-spacing:.5px;text-transform:uppercase}#meal-tiles{display:flex;flex-direction:column;position:relative;background-color:transparent;border:none;border-radius:0;overflow:hidden;min-height:0;min-width:0}.menu-entry-scroller{flex:1;overflow-y:auto;overflow-anchor:none;padding:20px 60px}.menu-custom-notes-wrap{margin-top:10px;padding:0 4px 40px}.notes-label{font-size:14px;font-weight:900;color:var(--text-secondary);letter-spacing:1px;margin-bottom:8px;padding-left:2px}.notes-input{width:100%;min-height:100px;background:var(--bg-hover);border:1.5px solid var(--border-color);border-radius:12px;padding:14px;color:var(--text-primary);font-family:inherit;font-size:15px;font-weight:500;line-height:1.5;resize:none;transition:all .2s ease}.notes-input:focus{outline:none;border-color:var(--primary-uber);background:var(--bg-card);box-shadow:0 0 0 4px var(--primary-uber-dim)}.notes-alert-pill.meal-notes{background:#fff9ea!important;color:#92400e!important;border-left:4px solid #f59e0b!important;font-weight:700!important;box-shadow:0 1px 3px #00000014}.details-notes.meal-note-item{background:#fff9ea!important;color:#92400e!important;border-left:4px solid #f59e0b!important;font-weight:700!important;margin-top:6px!important}.notes-input::placeholder{color:var(--text-secondary);opacity:.5}.menu-entry-section{margin-bottom:30px}.section-title{font-size:16px;font-weight:800;color:#000;margin-bottom:16px;letter-spacing:.5px}.menu-entry-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.menu-entry-btn{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s ease;font-size:18px}.menu-entry-btn.active{border-color:var(--primary-uber);background-color:var(--primary-uber-dim)}.radio-cir{width:24px;height:24px;border:2px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--primary-uber);flex-shrink:0}.menu-entry-btn.active .radio-cir{border-color:#fff;background-color:#fff}.menu-entry-btn.disabled{opacity:.35;cursor:not-allowed}.menu-entry-btn.auto-included{border-color:#22c55e;background-color:#22c55e14;pointer-events:none;opacity:.85}.menu-entry-btn.auto-included .radio-cir{border-color:#22c55e;background-color:#22c55e;color:#fff}.auto-section-badge{font-size:11px;font-weight:800;letter-spacing:1px;color:#16a34a;background:#22c55e1f;padding:2px 8px;border-radius:6px;margin-left:8px;vertical-align:middle}.confirm-btn-container{background:var(--bg-card);padding:10px 60px;border-top:1px solid var(--border-color);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px}body.light-mode .confirm-btn-container{background:#fffc}.order-action-btns{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end}.seated-btn{height:54px;border-radius:12px;font-size:13px;font-weight:800;letter-spacing:.5px;padding:0 20px;border:1.5px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:all .15s;white-space:nowrap;flex-shrink:0}.seated-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.seated-btn.is-seated{border-color:#22c55e;color:#22c55e;background:#22c55e14}.seated-btn:disabled{opacity:.5;cursor:not-allowed}.history-content{padding:20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:24px}.history-empty{padding:60px 20px;text-align:center;color:var(--text-secondary);font-size:14px;font-weight:600}.history-select{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:12px;font-weight:700;padding:6px 12px;height:38px;cursor:pointer}.hist-resident-section{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.hist-resident-name{padding:12px 16px;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background-color:var(--bg-hover);border-bottom:1px solid var(--border-color)}.hist-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 16px;border-bottom:1px solid var(--border-color);font-size:13px}.hist-row-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.hist-row-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.hist-type-badge{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:20px;white-space:nowrap}.hist-type-order{background-color:var(--primary-uber-dim);color:var(--primary-uber)}.hist-type-table{background-color:#0284c726;color:#0284c7}.hist-type-served{background-color:#10b98126;color:#10b981}.hist-type-unserved{background-color:#6b72801f;color:var(--text-secondary)}.hist-meal-label{font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.hist-detail{font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hist-time{font-size:11px;color:var(--text-secondary);white-space:nowrap}.hist-round{font-size:10px;font-weight:800;color:var(--text-secondary);background-color:var(--bg-hover);padding:2px 7px;border-radius:10px;white-space:nowrap}@media(max-width:824px){.ordering-layout{grid-template-columns:1fr;grid-template-rows:300px 1fr;gap:0}.resident-list{border-right:none;border-bottom:2px solid var(--border-color)}}.confirm-order-btn{height:54px;border-radius:12px;font-size:15px;font-weight:800;letter-spacing:.5px;border:1px solid;display:flex;align-items:center;justify-content:center;gap:10px;transition:opacity .15s;padding:0 20px}@keyframes btn-spin{to{transform:rotate(360deg)}}.confirm-order-btn.btn-saving{opacity:.75;cursor:not-allowed;pointer-events:none}.confirm-order-btn.btn-saving:before{content:"";display:block;width:20px;height:20px;border:3px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:btn-spin .7s linear infinite;flex-shrink:0}.selection-resident-header{padding:12px 30px 8px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-main);position:relative}.selection-resident-header .diet-alert-pill{position:absolute;top:12px;right:30px;margin:0!important}.selection-resident-header .res-info{display:flex;flex-direction:column;min-width:0}.selection-resident-header .selection-resident-photo{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border-color);background-color:var(--bg-card)}.selection-resident-header .res-name{font-size:18px;font-weight:800}.selection-resident-header .res-room{font-size:14px;font-weight:600;color:var(--text-secondary)}.selection-table-box{text-align:left;display:flex;flex-direction:column;align-items:flex-start}.selection-table-label{font-size:11px;font-weight:800;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:4px}.selection-table-value{font-size:20px;font-weight:900;color:var(--primary-uber)}.no-table-btn{padding:10px 18px;border:2px dashed var(--primary-uber);border-radius:10px;color:var(--primary-uber);font-size:13px;font-weight:800;cursor:pointer;background-color:var(--primary-uber-dim);transition:all .2s ease}.no-table-btn:hover{background-color:var(--primary-uber);color:#fff}.table-picker-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:var(--bg-main);z-index:500;display:flex;flex-direction:column;padding:20px}.table-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;align-content:start;flex:1;overflow-y:auto;margin-top:20px}.table-picker-cell{height:80px;border:2px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.table-picker-cell:hover{border-color:var(--primary-uber);background-color:var(--primary-uber-dim)}.table-picker-cell .p-name{font-size:16px;font-weight:900}.table-picker-cell .p-pos{font-size:10px;font-weight:700;opacity:.5}.table-picker-cell-reset{border-style:dashed;border-color:var(--text-secondary);opacity:.7;text-align:center}.table-picker-cell-reset:hover{border-color:var(--text-secondary);background-color:#0000000a;opacity:1}.seat-at-table-chip{font-size:10px;font-weight:800;color:var(--primary-uber);background-color:var(--primary-uber-dim);padding:3px 8px;border-radius:6px;letter-spacing:.5px;cursor:pointer;margin-top:2px;white-space:nowrap}.seat-at-table-chip:hover{opacity:.8}.menu-day-selector{display:flex;gap:8px;margin-bottom:16px;background-color:var(--bg-card);padding:8px;border-radius:var(--radius-md);border:1px solid var(--border-color);overflow-x:auto}.day-tab{flex:1;min-width:100px;padding:8px;text-align:center;border-radius:8px;cursor:pointer;transition:all .2s ease}.day-tab-nav{display:flex;align-items:center;justify-content:center;width:60px;font-size:24px;font-weight:900;color:var(--primary-uber);cursor:pointer;background-color:var(--bg-hover);border-radius:8px;transition:background-color .2s ease}.day-tab-nav:active{background-color:var(--primary-uber-dim)}.day-tab .tab-name{font-size:11px;font-weight:800;color:var(--text-secondary);display:block;margin-bottom:2px}.day-tab .tab-date{font-size:16px;font-weight:900}.day-tab.active{background-color:var(--primary-uber);color:#fff}.day-tab.active .tab-name{color:#fffc}.menu-detail-card{padding:40px}.detail-header{margin-bottom:40px;border-bottom:2px solid var(--border-color);padding-bottom:20px}.detail-day{font-size:32px;font-weight:900;margin:0;color:var(--primary-uber)}.detail-date{font-size:18px;font-weight:600;color:var(--text-secondary)}.meal-large-section{margin-bottom:40px}.meal-title{font-size:20px;font-weight:900;margin-bottom:8px;display:flex;align-items:center;gap:12px}.meal-title .icon{font-size:24px}.meal-hours{font-size:13px;font-weight:600;color:var(--text-secondary);margin-top:-4px;margin-bottom:12px;letter-spacing:.04em}.meal-sections-container{display:flex;flex-direction:column;gap:16px;padding-left:12px}.menu-sub-section{border-left:3px solid var(--primary-uber-dim);padding-left:16px}.sub-section-title{font-size:11px;font-weight:800;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.sub-section-items{font-size:18px;font-weight:700;line-height:1.4;color:var(--text-primary)}.guest-count-header{display:inline-flex;align-items:center;background-color:var(--alert-uber-dim);color:var(--alert-uber);font-size:11px;font-weight:800;padding:3px 8px;border-radius:4px;margin-bottom:10px;letter-spacing:.5px}.guest-info-section{margin-top:12px;padding-top:12px;border-top:1px dashed var(--border-color)}.guest-divider{font-size:10px;font-weight:800;color:var(--text-secondary);letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.guest-count-pill{margin-left:auto;background-color:var(--alert-uber-dim);color:var(--alert-uber);font-size:11px;font-weight:800;padding:3px 10px;border-radius:100px;letter-spacing:.5px;flex-shrink:0}.party-tabs{display:flex;border-bottom:1px solid var(--border-color);padding:12px 20px 0;gap:4px;flex-shrink:0;background-color:var(--bg-card)}.party-tab{padding:10px 18px;font-size:11px;font-weight:800;cursor:pointer;border-radius:8px 8px 0 0;color:var(--text-secondary);border:1px solid transparent;border-bottom:none;display:flex;align-items:center;gap:6px;letter-spacing:.5px;transition:color .15s ease,background-color .15s ease}.party-tab.active{background-color:var(--bg-main);color:var(--text-primary);border-color:var(--border-color)}.party-tab-check{color:var(--primary-uber);font-size:12px}.nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.nav-icon-wrap svg{width:24px;height:24px}.nav-badge{position:absolute;top:-6px;right:-8px;background-color:var(--alert-uber);color:#000;font-size:10px;font-weight:900;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.nav-badge.hidden{display:none}.all-served-banner{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;margin-bottom:24px;background-color:var(--primary-uber-dim);border:1px solid var(--primary-uber);border-radius:var(--radius-lg);color:var(--primary-uber);text-align:center}.all-served-title{font-size:24px;font-weight:900;letter-spacing:1px}.all-served-sub{font-size:14px;font-weight:600;opacity:.7}.tables-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 0 16px;flex-shrink:0}.tables-legend{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.5px}.legend-dot{width:12px;height:12px;border-radius:3px;margin-left:12px}.legend-empty{background-color:var(--bg-card);border:1px solid var(--border-color)}.legend-placed{background-color:var(--primary-uber)}.tables-grid-wrap{flex:1;overflow:auto;display:flex;flex-direction:column;align-items:stretch;padding-bottom:20px}.tables-grid{display:grid;grid-template-columns:repeat(var(--tbl-cols, 12),1fr);grid-template-rows:repeat(var(--tbl-rows, 8),1fr);gap:8px;min-width:720px;min-height:420px;width:100%;height:100%}.tbl-cell{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;min-height:72px;transition:background-color .15s ease,border-color .15s ease,transform .1s ease;position:relative;-webkit-user-select:none;user-select:none}.tbl-cell:hover{background-color:var(--bg-hover);border-color:var(--text-secondary);transform:scale(1.03)}.tbl-cell.tbl-placed{background-color:var(--primary-uber);border-color:var(--primary-uber);color:#fff}.tbl-cell.tbl-placed:hover{background-color:#3a7233;border-color:#3a7233}.tbl-cell.tbl-readonly{cursor:default}.tbl-cell.tbl-readonly:hover{background-color:var(--bg-card);border-color:var(--border-color);transform:none}.tbl-cell.tbl-readonly.tbl-placed:hover{background-color:var(--primary-uber);border-color:var(--primary-uber)}.tbl-plus{font-size:22px;font-weight:300;color:var(--border-color);line-height:1;transition:color .15s ease}.tbl-cell:hover .tbl-plus{color:var(--text-secondary)}.tbl-label{font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#fff;text-align:center;padding:0 6px;line-height:1.2}.tbl-pos{font-size:9px;font-weight:600;color:#fff9;margin-top:3px;letter-spacing:.5px}.transition-modal{text-align:center;max-width:560px;width:90%;padding:40px;display:flex;flex-direction:column;gap:20px}.transition-eyebrow{font-size:11px;font-weight:800;letter-spacing:2px;color:var(--text-secondary)}.transition-meals{display:flex;align-items:center;justify-content:center;gap:20px;margin:12px 0;flex-wrap:wrap}.transition-meal-name{font-size:28px;font-weight:900;letter-spacing:-.5px;white-space:nowrap}.transition-meal-name.from{color:var(--text-secondary);text-decoration:line-through;opacity:.5}.transition-meal-name.to{color:var(--text-primary)}.transition-arrow{font-size:28px;font-weight:900;color:var(--primary-uber)}.transition-sub{font-size:15px;font-weight:600;color:var(--text-secondary);line-height:1.4}.new-day-date{font-size:30px;font-weight:900;letter-spacing:-.5px;color:var(--primary-uber);line-height:1.2}.transition-stay-btn{flex:1;height:54px;border-radius:12px;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);font-size:13px;font-weight:800;letter-spacing:1px;cursor:pointer;font-family:var(--font-family);transition:border-color .2s,color .2s}.transition-stay-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.transition-switch-btn{flex:1;height:54px;border-radius:12px;background:var(--primary-uber);border:none;color:#fff;font-size:13px;font-weight:800;letter-spacing:1px;cursor:pointer;font-family:var(--font-family);transition:opacity .2s;padding:16px}.transition-switch-btn:hover{opacity:.85}.table-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:9000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.table-modal-overlay.hidden{display:none}.table-modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;width:560px;max-width:90vw;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-main)}.table-modal-title{font-size:20px;font-weight:800;letter-spacing:.5px;color:var(--text-primary)}.table-modal-sub{font-size:13px;font-weight:600;color:var(--text-secondary);margin-top:-8px}.table-name-input{background:var(--bg-main);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:var(--font-family);font-size:15px;font-weight:600;padding:14px 16px;outline:none;transition:border-color .15s}.table-name-input:focus{border-color:var(--primary-uber)}.table-modal-actions{display:flex;gap:12px;margin-top:4px}.details-round-notice{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fef3c7;border:1px solid #fde68a;border-radius:10px;flex-wrap:wrap}.details-round-notice-text{flex:1;min-width:240px;font-size:13px;font-weight:600;color:#78350f;line-height:1.35}#details-round-toggle{flex-shrink:0}.table-ctx-menu{position:fixed;z-index:9100;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-main);display:flex;flex-direction:column;min-width:160px}.table-ctx-menu.hidden{display:none}.table-ctx-menu button{background:none;border:none;color:var(--text-primary);font-family:var(--font-family);font-size:12px;font-weight:700;letter-spacing:.5px;padding:14px 20px;text-align:left;cursor:pointer;transition:background-color .1s}.table-ctx-menu button:hover{background-color:var(--bg-hover)}#ctx-remove{color:#ff453a}#ctx-remove:hover{background-color:#ff453a1a}.front-indicator{display:flex;flex-direction:column;align-items:center;flex-shrink:0;margin-bottom:4px;gap:0}.front-indicator-bar{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:var(--primary-uber);border-radius:12px 12px 0 0;padding:10px 20px}.front-indicator-icon{display:flex;align-items:center;color:#fff;opacity:.9}.front-indicator-label{font-size:13px;font-weight:800;letter-spacing:2.5px;color:#fff;white-space:nowrap;text-transform:uppercase}.front-indicator-arrows{display:flex;justify-content:space-around;width:100%;padding:4px 24px 6px;margin-bottom:6px;background:linear-gradient(180deg,color-mix(in srgb,var(--primary-uber) 18%,transparent),transparent);border-radius:0 0 6px 6px}.front-indicator-arrows span{font-size:14px;color:var(--primary-uber);opacity:.55;line-height:1}.front-indicator-line{display:none}#checkin-content.hidden{display:none!important}.checkin-disabled-state{margin:60px auto;max-width:520px;padding:56px 36px;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;box-shadow:var(--shadow-main);display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}.checkin-disabled-state.hidden{display:none!important}.checkin-disabled-state .disabled-icon{font-size:56px;color:var(--text-secondary);background-color:var(--bg-hover);width:104px;height:104px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.checkin-disabled-state h2{font-size:24px;font-weight:900;color:var(--text-primary);margin:0;letter-spacing:-.5px}.checkin-disabled-state p{font-size:15px;font-weight:600;color:var(--text-secondary);line-height:1.5;margin:0 0 20px;max-width:380px}.checkin-disabled-state .go-settings-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border:none;border-radius:100px;background-color:var(--primary-uber);color:#fff;font-size:14px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;font-family:inherit;cursor:pointer;box-shadow:0 4px 12px var(--primary-uber-dim);transition:transform .08s ease,box-shadow .15s ease,background-color .15s ease}.checkin-disabled-state .go-settings-btn:hover{background-color:#244a20;box-shadow:0 6px 16px var(--primary-uber-dim);transform:translateY(-1px)}.checkin-disabled-state .go-settings-btn:active{transform:translateY(0) scale(.98)}.checkin-disabled-state .go-settings-btn .material-symbols-outlined{font-size:18px}.checkin-toolbar{padding:12px 0;margin-bottom:16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:16px}.checkin-toolbar .search-box-wrap{flex:1}.search-box-wrap{position:relative;max-width:600px;display:flex;align-items:center}.search-icon{position:absolute;left:20px;width:20px;height:20px;color:var(--text-secondary);pointer-events:none}#checkin-search{width:100%;height:44px;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:0 60px 0 54px;font-size:16px;font-weight:600;color:var(--text-primary);transition:all .2s ease}#checkin-search:focus{outline:none;border-color:var(--primary-uber);box-shadow:0 0 0 4px var(--primary-uber-dim)}.voice-btn{position:absolute;right:8px;width:44px;height:44px;background-color:transparent;border:none;border-radius:10px;color:var(--primary-uber);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.voice-btn:hover{background-color:var(--primary-uber-dim)}.voice-btn.recording{background-color:#e22020;color:#fff;animation:pulse-red 1.5s infinite}@keyframes pulse-red{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.checkin-facility-filter{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-left:auto}.checkin-facility-filter:empty{display:none}.checkin-facility-chip{padding:8px 18px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:100px;border:1px solid var(--border-color);background-color:var(--bg-card);font-size:12px;font-weight:800;letter-spacing:.5px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;text-transform:uppercase}.checkin-facility-chip:hover{border-color:var(--text-secondary);color:var(--text-primary)}.checkin-facility-chip.selected{background-color:var(--text-primary);color:var(--bg-main);border-color:var(--text-primary)}body.light-mode .checkin-facility-chip.selected{background-color:#000;color:#fff;border-color:#000}.checkin-window-strip{display:flex;flex-wrap:wrap;gap:8px;padding:12px 4px 20px;align-items:center}.checkin-window-strip:empty{display:none}.checkin-window-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 14px;min-width:92px;border:1px solid var(--border-color);border-radius:12px;background-color:var(--bg-card);cursor:pointer;transition:all .15s ease}.checkin-window-chip:hover{border-color:var(--text-secondary)}.checkin-window-chip.selected{border-color:var(--text-primary);background-color:var(--text-primary);color:var(--bg-main)}body.light-mode .checkin-window-chip.selected{background-color:#000;color:#fff}.checkin-window-chip.is-current:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background-color:var(--primary-uber);margin-bottom:2px;box-shadow:0 0 8px var(--primary-uber)}.checkin-window-chip-label{font-size:12px;font-weight:800;letter-spacing:.4px}.checkin-window-chip-meta{font-size:10px;font-weight:700;opacity:.7;letter-spacing:.3px}.checkin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;padding-bottom:60px}.checkin-window-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;width:100%}.checkin-window-pill{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-color);background-color:transparent;font-size:10px;font-weight:900;color:var(--text-secondary)}.checkin-window-pill.is-checked{background-color:var(--primary-uber);border-color:var(--primary-uber);color:#fff}.checkin-window-pill.is-missed{background-color:transparent;border-color:var(--alert-uber);color:var(--alert-uber)}.checkin-window-pill.is-away{background-color:var(--bg-hover, #f3f4f6);border-color:var(--border-color);color:var(--text-secondary)}.checkin-window-pill.is-current{border-color:var(--text-primary);border-style:dashed}.checkin-window-pill.is-selected{box-shadow:0 0 0 2px var(--text-primary)}.checkin-resident-card{padding:16px 14px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:20px;position:relative;background-color:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-main)}.checkin-resident-card:hover{border-color:var(--primary-uber-dim)}.checkin-status-indicator{position:absolute;top:10px;right:10px;width:18px;height:18px;border-radius:50%;background-color:transparent;border:2px solid var(--border-color)}.checkin-resident-card.is-checked-in{background-color:var(--primary-uber-dim);border-color:var(--primary-uber)}.checkin-resident-card.is-checked-in .checkin-status-indicator{background-color:var(--primary-uber);box-shadow:0 0 15px var(--primary-uber);border-color:var(--primary-uber)}.checkin-resident-card.is-checked-in .checkin-status-indicator:after{content:"✓";color:#fff;font-size:12px;font-weight:900;display:flex;align-items:center;justify-content:center;height:100%}.resident-photo{width:110px;height:110px;border-radius:16px;object-fit:cover;background-color:var(--bg-hover);box-shadow:0 6px 12px #0000001a}.resident-info{flex:none;width:100%}.resident-info .name{font-size:18px;font-weight:900;color:var(--text-primary);text-transform:none;margin-bottom:2px;letter-spacing:-.5px;line-height:1.15}.resident-info .room{font-size:14px;font-weight:700;color:var(--text-secondary);background-color:var(--bg-hover);display:inline-block;padding:3px 12px;border-radius:100px}.checkin-action{margin-top:2px;width:100%}.checkin-btn{width:100%;min-height:44px;padding:6px 10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background-color:var(--primary-uber);color:#fff;border-radius:10px;line-height:1.1}.checkin-btn-primary{font-size:16px;font-weight:800;letter-spacing:-.2px}.checkin-btn-secondary{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;opacity:.85}.checkin-resident-card.is-checked-in .checkin-btn{background-color:var(--text-secondary);opacity:.5}.checkin-note-actions{display:flex;gap:10px;margin-top:14px}.checkin-note-btn{flex:1;height:52px;border-radius:12px;font-size:14px;font-weight:800;letter-spacing:.6px;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .08s ease,box-shadow .15s ease,background-color .15s ease,border-color .15s ease;-webkit-tap-highlight-color:transparent}.checkin-note-btn:active{transform:scale(.98)}.checkin-note-btn-cancel{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.checkin-note-btn-cancel:hover{background:var(--bg-hover);border-color:var(--text-secondary)}.checkin-note-btn-confirm{background:var(--primary-uber);border:1px solid var(--primary-uber);color:#fff;box-shadow:0 4px 12px var(--primary-uber-dim)}.checkin-note-btn-confirm:hover{background:#244a20;box-shadow:0 6px 16px var(--primary-uber-dim);transform:translateY(-1px)}.checkin-note-btn-confirm:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px var(--primary-uber-dim)}.checkin-note-btn-confirm svg{flex-shrink:0}.checkin-note-btn:disabled{cursor:default;opacity:.85;transform:none!important}.checkin-note-btn.is-loading{pointer-events:none;position:relative;color:transparent!important}.checkin-note-btn.is-loading>*{visibility:hidden}.checkin-note-btn.is-loading:after{content:"";position:absolute;top:50%;left:50%;width:22px;height:22px;margin:-11px 0 0 -11px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:checkin-confirm-spin .7s linear infinite;visibility:visible}@keyframes checkin-confirm-spin{to{transform:rotate(360deg)}}.checkin-away-tag{position:absolute;top:10px;left:10px;padding:3px 8px;background:var(--alert-uber, #ef4444);color:#fff;border-radius:6px;font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;line-height:1;box-shadow:0 2px 4px #00000026;z-index:2;pointer-events:none}.last-checkin-time{margin-top:-2px;font-size:11px;font-weight:700;color:var(--text-secondary);letter-spacing:.5px;opacity:.8}.checkin-resident-card.is-checked-in .last-checkin-time{color:var(--primary-uber);opacity:1}.voice-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000e6;z-index:10000;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease}.voice-overlay.hidden{display:none;opacity:0}.voice-overlay-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:24px}.voice-pulse-circle{width:120px;height:120px;background-color:var(--primary-uber);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;position:relative;box-shadow:0 0 50px var(--primary-uber-dim)}.voice-pulse-circle svg{width:60px;height:60px}.voice-pulse-circle:after{content:"";position:absolute;width:100%;height:100%;background-color:inherit;border-radius:50%;animation:voice-pulse 1.5s infinite}@keyframes voice-pulse{0%{transform:scale(1);opacity:.8}to{transform:scale(2);opacity:0}}.voice-overlay-content h2{font-size:48px;font-weight:900;margin:0;color:#fff}.voice-overlay-content p{font-size:20px;color:var(--text-secondary)}.cancel-voice-btn{background:transparent;border:2px solid white;color:#fff;padding:16px 40px;border-radius:100px;font-size:16px;font-weight:800;cursor:pointer;margin-top:40px;transition:all .2s}.cancel-voice-btn:hover{background:#fff;color:#000}.confetti{position:fixed;width:10px;height:10px;background-color:red;z-index:9999;pointer-events:none;border-radius:2px}.clear-search-btn{position:absolute;right:60px;width:32px;height:32px;background-color:var(--bg-hover);border:none;border-radius:50%;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;transition:all .2s}.clear-search-btn:hover{background-color:var(--border-color);color:var(--text-primary)}.clear-search-btn.hidden{display:none}.table-row-item{display:flex;align-items:center;gap:16px}.table-row-icon{width:44px;height:44px;border-radius:12px;background-color:var(--bg-hover);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.res-item.active .table-row-icon{background-color:var(--primary-uber-dim);color:var(--primary-uber)}.table-seat-badge{min-width:32px;height:32px;border-radius:100px;background-color:var(--primary-uber);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;padding:0 10px;flex-shrink:0}.table-seat-badge.empty{background-color:var(--bg-hover);color:var(--text-secondary)}.table-search-wrap{display:flex;align-items:center;gap:12px;padding:16px 24px;border-bottom:1px solid var(--border-color);background-color:var(--bg-hover);flex-shrink:0}.table-search-input{flex:1;background:transparent;border:none;outline:none;font-size:15px;font-weight:600;color:var(--text-primary);font-family:inherit}.table-search-input::placeholder{color:var(--text-secondary);font-weight:500}.table-resident-scroller{flex:1;overflow-y:auto;min-height:0}.table-assign-chip{font-size:11px;font-weight:800;padding:3px 10px;border-radius:100px;background-color:var(--bg-hover);color:var(--text-secondary);letter-spacing:.5px;flex-shrink:0}.table-assign-chip.here{background-color:var(--primary-uber-dim);color:var(--primary-uber)}.table-back-btn{background:var(--bg-hover);border:1px solid var(--border-color);border-radius:8px;padding:8px 14px;font-size:11px;font-weight:800;color:var(--text-primary);cursor:pointer;font-family:inherit;letter-spacing:.5px;transition:background-color .15s ease;flex-shrink:0}.table-back-btn:hover{background-color:var(--border-color)}.table-add-bar{padding:12px 20px;border-bottom:1px solid var(--border-color);flex-shrink:0;background-color:var(--bg-card)}.table-add-btn{background:transparent;border:1.5px dashed var(--primary-uber);color:var(--primary-uber);border-radius:10px;padding:10px 20px;font-size:12px;font-weight:800;cursor:pointer;font-family:inherit;letter-spacing:.5px;width:100%;transition:background-color .15s ease}.table-add-btn:hover{background-color:var(--primary-uber-dim)}.table-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.table-popup{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px #00000073;border:1px solid var(--border-color)}.table-popup-header{padding:24px;border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0}.table-popup-close{background:var(--bg-hover);border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:14px;font-weight:800;color:var(--text-primary);font-family:inherit;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .15s}.table-popup-close:hover{background-color:var(--border-color)}.table-popup-list{flex:1;overflow-y:auto;min-height:0}.table-popup-item{display:flex;align-items:center;gap:14px;padding:14px 20px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background-color .15s}.table-popup-item:hover{background-color:var(--bg-hover)}.table-popup-item.checked{background-color:var(--primary-uber-dim)}.popup-checkbox{width:22px;height:22px;border-radius:6px;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;color:#fff}.popup-checkbox.checked{background-color:var(--primary-uber);border-color:var(--primary-uber)}.table-popup-footer{padding:16px 20px;border-top:1px solid var(--border-color);flex-shrink:0;background-color:var(--bg-card)}.history-content{padding:8px 0}.hist-resident-section{margin-bottom:20px;background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;box-shadow:0 1px 3px #0000000d}.hist-resident-name{background-color:var(--bg-hover);padding:16px 24px;font-size:16px;font-weight:800;color:var(--text-primary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px;position:-webkit-sticky;position:sticky;top:0;z-index:5;width:100%}.history-table-header{display:grid;grid-template-columns:140px 100px 160px 1fr 120px 60px;padding:12px 24px;background:var(--bg-hover);border-bottom:1px solid var(--border-color);font-size:11px;font-weight:800;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.hist-row{display:grid;grid-template-columns:140px 100px 160px 1fr 120px 60px;padding:14px 24px;border-bottom:1px solid var(--border-color);align-items:center;transition:background-color .15s;font-size:13.5px;color:var(--text-primary);background-color:var(--bg-card)!important;margin:0!important;border-radius:0!important}.hist-row:hover{background-color:var(--bg-hover)!important}.hist-row:last-child{border-bottom:none}.hist-type-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px;width:fit-content;text-transform:uppercase;letter-spacing:.3px}.hist-type-badge.selection{background:#eff6ff;color:#1e40af}.hist-type-badge.served{background:#f0fdf4;color:#166534}.hist-type-badge.table{background:#fdf2f8;color:#9d174d}.hist-meal-label{font-weight:700;color:var(--text-secondary)}.hist-time{color:var(--text-secondary);font-size:12px;font-weight:500}.hist-detail{color:var(--text-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:20px}.hist-staff{color:var(--text-secondary);font-size:12px;font-weight:500}.hist-round{font-weight:800;color:var(--text-secondary);text-align:right;font-size:12px}.history-empty{padding:80px;text-align:center;color:var(--text-secondary);font-weight:600}.uber-toggle{position:relative;display:inline-block;width:44px;height:24px}.uber-toggle input{opacity:0;width:0;height:0}.uber-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#e2e8f0;transition:.3s cubic-bezier(.4,0,.2,1);border-radius:24px}.uber-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s cubic-bezier(.4,0,.2,1);border-radius:50%;box-shadow:0 1px 3px #0000001a}input:checked+.uber-slider{background-color:var(--primary-uber)}input:checked+.uber-slider:before{transform:translate(20px)}.printer-view-container{max-width:820px;margin:0 auto;padding:24px;display:flex;flex-direction:column;gap:16px}.printer-card{background:var(--bg-main);border:1px solid var(--border-color);border-radius:16px;padding:20px 24px}.printer-card-head{margin-bottom:16px}.printer-card-head h3{margin:0 0 4px;font-size:16px;font-weight:800;color:var(--text-primary);letter-spacing:.3px}.printer-subtitle{margin:0;color:var(--text-secondary);font-size:13px;font-weight:500}.printer-status-row{display:flex;align-items:center;gap:12px;padding:10px 0}.printer-status-body{flex:1;min-width:0}#printer-disconnect-btn{height:36px;padding:0 14px;font-size:12px}.printer-status-row+.printer-status-row{border-top:1px solid var(--border-color)}.printer-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;background-color:var(--text-secondary)}.printer-dot.ok{background-color:#10b981}.printer-dot.warn{background-color:#f59e0b}.printer-dot.err{background-color:#ef4444}.printer-status-title{font-size:14px;font-weight:700;color:var(--text-primary)}.printer-status-meta{font-size:12px;color:var(--text-secondary);font-weight:500;margin-top:2px}.printer-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}.printer-scan-spinner{display:inline-block;width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:printer-spin .8s linear infinite}#printer-scan-btn .printer-scan-spinner,#printer-scan-btn.is-scanning .printer-scan-icon{display:none}#printer-scan-btn.is-scanning .printer-scan-spinner{display:inline-block}.printer-scanning-state{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text-secondary)}@keyframes printer-spin{to{transform:rotate(360deg)}}.printer-btn-primary{width:auto;padding:0 18px;height:44px;border-radius:10px;background:var(--text-primary);color:var(--bg-main);border:none;font-size:13px;font-weight:800;letter-spacing:1px;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.printer-btn-primary:hover:not(:disabled){opacity:.9}.printer-btn-secondary{width:auto;padding:0 18px;height:44px;border-radius:10px;background:transparent;color:var(--text-primary);border:1px solid var(--border-color);font-size:13px;font-weight:800;letter-spacing:1px;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.printer-btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.printer-btn-primary:disabled,.printer-btn-secondary:disabled{opacity:.4;cursor:not-allowed}.printer-device-list{display:flex;flex-direction:column;gap:8px}.printer-device-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-hover)}.printer-device-row.connected{border-color:#10b981;background:#10b98114}.printer-device-info{display:flex;flex-direction:column;gap:2px}.printer-device-name{font-size:14px;font-weight:700;color:var(--text-primary)}.printer-device-id{font-size:11px;color:var(--text-secondary);font-family:monospace}.printer-device-row .printer-btn-primary,.printer-device-row .printer-btn-secondary{height:36px;padding:0 14px;font-size:12px}.printer-empty{text-align:center;padding:24px;color:var(--text-secondary);font-size:13px;font-weight:500;background:var(--bg-hover);border:1px dashed var(--border-color);border-radius:12px}.printer-log{background:#0f172a;color:#e2e8f0;font-family:monospace;font-size:12px;padding:12px 14px;border-radius:12px;max-height:220px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.printer-log-line{margin:0;padding:2px 0}.printer-log-line.info{color:#93c5fd}.printer-log-line.ok{color:#86efac}.printer-log-line.err{color:#fca5a5}
