:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#f9fafb;background-color:#030712;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#030712}*{box-sizing:border-box}.kds-root{display:flex;flex-direction:column;height:100vh;background:#030712;color:#f9fafb;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px}.kds-note-highlight{display:inline-block;padding:2px 6px;margin:0 2px;border-radius:6px;background:#fef3c7;color:#b91c1c;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.kds-header{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 20px;border-bottom:1px solid #1f2937;background:#030712}.kds-header-left{display:flex;flex-direction:column;gap:2px}.kds-header-title{font-size:28px;font-weight:700}.kds-header-meta{display:inline-flex;align-items:center;gap:8px}.kds-header-dot{width:6px;height:6px;border-radius:999px;background:#475569}.kds-header-subtitle{font-size:18px;color:#9ca3af}.kds-header-subtitle--updated{font-size:14px;color:#6b7280}.kds-header-tabs{display:inline-flex;gap:8px}.kds-layout-selector{display:inline-flex;align-items:center;gap:8px;margin-left:12px}.kds-layout-selector__label{font-size:16px;color:#9ca3af;text-transform:uppercase;letter-spacing:.08em}.kds-layout-selector__options{display:inline-flex;gap:8px}.kds-layout-btn{padding:8px 14px;border-radius:12px;border:1px solid #374151;background:#0f172a;color:#e5e7eb;font-size:14px;font-weight:600}.kds-layout-btn--active{border-color:#22d3ee;background:#0ea5e9;color:#fdf2f8;box-shadow:0 0 10px #0ea5e959}.kds-tab{padding:10px 18px;border-radius:999px;border:1px solid #374151;background:#111827;color:#e5e7eb;font-size:16px;font-weight:600}.kds-tab--active{border-color:#3b82f6;background:#1d4ed8}.kds-header-right{display:flex;align-items:center;gap:10px}.kds-connection,.kds-realtime-pill,.kds-sound-toggle,.kds-backlog-pill{padding:6px 12px;border-radius:999px;font-size:14px}.kds-connection--ok{background:#064e3b;color:#a7f3d0}.kds-connection--error{background:#7f1d1d;color:#fecaca}.kds-realtime-pill{background:#111827;color:#e5e7eb;border:1px solid #4b5563}.kds-sound-toggle{border:1px solid #4b5563;background:#111827;color:#e5e7eb;cursor:pointer}.kds-backlog-pill--medium{background:#78350f;border-color:#f59e0b;color:#fed7aa}.kds-backlog-pill--high{background:#7f1d1d;border-color:#ef4444;color:#fecaca}.kds-error-banner{background:#7f1d1d;color:#fecaca;padding:8px 16px;font-size:16px}.kds-stale-banner{background:#78350f;color:#ffedd5;padding:8px 16px;font-size:16px}.kds-loading{padding:8px 16px;font-size:16px;color:#e5e7eb}.kds-main{flex:1;padding:24px 32px;overflow:auto}.kds-grid-wrapper{position:relative}.kds-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.kds-grid-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 20%,#37415159,#0f172ae6);pointer-events:none}.kds-grid-overlay-text{display:inline-flex;align-items:center;gap:12px;padding:10px 18px;border-radius:999px;background:#020617e6;border:1px solid #3b82f6;box-shadow:0 10px 25px #00000073;font-size:16px;color:#e5e7eb}.kds-grid-overlay-spinner{width:20px;height:20px;border-radius:999px;border:2px solid rgba(156,163,175,.6);border-top-color:#3b82f6;animation:kds-spin .7s linear infinite}@keyframes kds-spin{to{transform:rotate(360deg)}}.kds-ticket{display:flex;flex-direction:column;background:#111827;border-radius:16px;border:2px solid #1f2937;padding:20px;min-height:280px;animation:kds-ticket-fade-in .18s ease-out}.kds-ticket--normal{border-color:#22c55e}.kds-ticket--warning{border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b40}.kds-ticket--danger{border-color:#f97316;box-shadow:0 0 0 2px #f9731659}.kds-ticket--critical{border-color:#dc2626;animation:kds-critical-blink 1.2s steps(2) infinite}@keyframes kds-critical-blink{0%{box-shadow:0 0 0 3px #dc2626e6}49%{box-shadow:0 0 0 1px #dc262680}50%{box-shadow:0 0 0 3px #fcd34de6}to{box-shadow:0 0 0 1px #fcd34d66}}.kds-ticket--in-progress{box-shadow:0 0 0 1px #3b82f6b3}@keyframes kds-ticket-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.kds-ticket-header{display:flex;justify-content:space-between;margin-bottom:10px}.kds-ticket-mesa{font-size:24px;font-weight:700}.kds-ticket-tags{display:flex;gap:6px;margin-top:6px}.kds-ticket-id{font-size:16px;color:#9ca3af}.kds-ticket-body{flex:1;margin-bottom:16px;max-height:320px;overflow-y:auto}.kds-ticket-notes{margin-top:10px;font-size:16px;color:#e5e7eb;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-clamp:3;overflow:hidden;text-overflow:ellipsis}.kds-ticket-notes-label{font-weight:600;margin-right:6px}.kds-item-row{display:flex;align-items:flex-start;padding:10px 0;transition:background-color .18s ease,transform .18s ease}.kds-item-row--done{background:#022c22;animation:kds-item-check .22s ease-out}.kds-item-checkbox{width:40px;display:flex;justify-content:center;padding-top:10px}.kds-item-checkbox-inner{width:28px;height:28px;border-radius:999px;border:2px solid #6b7280;transition:border-color .18s ease,background-color .18s ease}.kds-item-checkbox-inner--active{border-color:#22c55e;background:#22c55e}@keyframes kds-item-check{0%{background:#22c55e26;transform:scale(.98)}to{background:#022c22;transform:scale(1)}}.kds-item-content{flex:1;margin-left:6px}.kds-item-main{display:flex;gap:12px;align-items:baseline}.kds-item-qty{font-weight:700;font-size:24px}.kds-item-name{font-size:24px;font-weight:700}.kds-item-modifiers{margin-top:10px;display:flex;flex-wrap:wrap;gap:10px}.kds-chip{font-size:16px;padding:6px 12px;border-radius:999px;background:#374151;color:#e5e7eb}.kds-chip--alert{background:#fef3c7;color:#b91c1c;border:1px solid #f87171;font-weight:700;letter-spacing:.05em}.kds-chip--origin{background:#1d4ed8;color:#e5e7eb}.kds-chip--takeaway{background:#047857;color:#ecfdf5;border:1px solid #22c55e;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:6px 12px;box-shadow:0 0 0 1px #10b98180}.kds-chip--allergy{background:#fee2e2;color:#b91c1c;border:1px solid #ef4444;font-weight:700}.kds-chip--status{background:#1e40af;color:#bfdbfe}.kds-ticket-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px}.kds-ticket-timer{display:flex;flex-direction:column;gap:6px}.kds-ticket-timer-value{font-size:26px;font-weight:700}.kds-ticket-timer-label{font-size:16px;color:#9ca3af;letter-spacing:.04em;text-transform:uppercase}.kds-btn{border:none;border-radius:999px;padding:16px 24px;font-size:18px;font-weight:600;cursor:pointer;min-height:52px}.kds-btn--primary{background:#ef7320;color:#f9fafb}.kds-btn--secondary{background:#111827;color:#e5e7eb;border:1px solid #4b5563}.kds-empty{padding:40px;text-align:center;color:#9ca3af;font-size:24px}.kds-modal-backdrop{position:fixed;inset:0;background:#0f172acc;display:flex;align-items:center;justify-content:center}.kds-modal{background:#111827;border-radius:16px;padding:20px;max-width:480px;width:90%;border:1px solid #374151}.kds-modal-title{margin:0 0 6px;font-size:24px;font-weight:700}.kds-modal-subtitle{margin:0 0 16px;font-size:16px;color:#9ca3af}.kds-modal-section{margin-top:12px}.kds-modal-section h3{margin:0 0 6px;font-size:16px}.kds-modal-chips{display:flex;flex-wrap:wrap;gap:6px}.kds-modal-close{margin-top:20px;width:100%}.kds-fullscreen-overlay{position:fixed;inset:0;background:#0f172ae6;display:flex;align-items:center;justify-content:center;z-index:40}.kds-fullscreen-modal{background:#020617;border-radius:20px;padding:24px 20px;max-width:480px;width:90%;border:1px solid #1f2937;box-shadow:0 20px 40px #000000b3}.kds-fullscreen-title{margin:0 0 12px;font-size:24px;font-weight:700}.kds-fullscreen-text{margin:0 0 20px;font-size:16px;color:#9ca3af}.kds-fullscreen-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}.kds-undo-toast{position:fixed;left:50%;bottom:20px;transform:translate(-50%);background:#111827;border-radius:999px;border:1px solid #4b5563;padding:10px 14px;display:flex;align-items:center;gap:12px;font-size:16px}.kds-undo-close{background:transparent;border:none;color:#9ca3af;cursor:pointer}.kds-session-warning{position:fixed;right:20px;bottom:20px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;background:#0f172af2;border:1px solid #f97316;border-radius:20px;padding:18px 24px;box-shadow:0 20px 40px #0009;max-width:480px;z-index:45}.kds-session-warning__text{flex:1;min-width:260px}.kds-session-warning__title{margin:0 0 6px;font-size:20px;font-weight:700;color:#fdba74}.kds-session-warning__subtitle{margin:0;font-size:16px;color:#f8fafc}.kds-session-warning__error{margin:12px 0 0;font-size:16px;color:#fecaca}.kds-session-warning__actions{display:flex;flex-direction:column;gap:12px;align-items:flex-end}.kds-session-warning__countdown{font-size:28px;font-weight:700;color:#f97316;font-variant-numeric:tabular-nums}.kds-ticket--delivered{opacity:.7}.kds-login-card{background:#111827;border-radius:16px;border:1px solid #1f2937;padding:32px 24px;max-width:420px;width:90%}.kds-login-logo{display:block;max-width:90px;margin:0 auto 14px}.kds-login-title{margin:0 0 6px;font-size:26px;font-weight:700;text-align:center}.kds-login-subtitle{margin:0 0 20px;font-size:16px;color:#9ca3af;text-align:center}.kds-login-form{display:flex;flex-direction:column;gap:16px}.kds-login-label{display:flex;flex-direction:column;gap:6px;font-size:16px}.kds-login-input{border-radius:10px;border:1px solid #4b5563;padding:12px 14px;background:#020617;color:#f9fafb}.kds-login-input:focus{outline:none;border-color:#3b82f6}.kds-login-button{margin-top:12px;width:100%}@media(min-width:640px){.kds-main{padding:20px}.kds-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.kds-ticket{min-height:240px}.kds-ticket-body{max-height:320px}}@media(min-width:1024px){.kds-grid{grid-template-columns:repeat(3,minmax(420px,1fr));gap:24px}.kds-ticket{min-height:280px;padding:16px}.kds-ticket-mesa{font-size:26px}.kds-item-qty,.kds-item-name,.kds-ticket-timer-value{font-size:18px}.kds-ticket-body{max-height:300px}}
