@import"https://fonts.googleapis.com/css2?family=Sarabun:wght@400;500;600;700;800&display=swap";:root{--ink: #1a1a1a;--ink-soft: #4a4a4a;--ink-mute: #767676;--ink-faint: #a3a3a3;--paper: #fafaf7;--surface: #ffffff;--surface-2: #f6f4ee;--line: #ebe8df;--line-soft: #f3f0e9;--accent: #c8553d;--accent-2: #e07453;--accent-soft:#fdf2ed;--accent-ink: #7a2818;--teal: #0f6e56;--teal-2: #138468;--teal-soft: #e1f5ee;--teal-ink: #0a4636;--amber: #b8740b;--amber-soft: #faeeda;--amber-ink: #6b3f04;--green: #16a34a;--green-soft: #dcfce7;--green-ink: #065f46;--red: #dc2626;--red-soft: #fee2e2;--blue: #1d4ed8;--blue-soft: #dbeafe;--blue-ink: #1e3a8a;--purple: #7c3aed;--purple-soft:#ede9fe;--purple-ink: #5b21b6;--shadow-sm: 0 1px 2px rgba(40,30,20,.04), 0 1px 3px rgba(40,30,20,.06);--shadow: 0 2px 4px rgba(40,30,20,.04), 0 6px 16px rgba(40,30,20,.06);--shadow-lg: 0 4px 12px rgba(40,30,20,.06), 0 16px 40px rgba(40,30,20,.1);--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;font-family:Sarabun,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans Thai,sans-serif;color:var(--ink);background:var(--paper)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased}body{min-height:100vh;line-height:1.45;font-size:15px;background:var(--paper)}button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#d8d4c8;border-radius:4px}::-webkit-scrollbar-track{background:transparent}.container{max-width:780px;margin:0 auto;padding:24px 16px}.stub{max-width:520px;margin:80px auto;padding:32px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-sm)}.stub h1{font-size:22px;margin-bottom:8px}.stub .eyebrow{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:12px}.stub p{color:var(--ink-soft);margin-bottom:16px}.stub code{font-family:monospace;background:#f0ede5;padding:2px 6px;border-radius:3px;font-size:13px}.pill{display:inline-block;padding:4px 12px;border-radius:99px;background:var(--teal-soft);color:var(--teal);font-size:12px;font-weight:500}.app-shell{display:grid;grid-template-rows:56px 1fr;height:100vh;background:var(--paper)}.topbar{display:flex;align-items:center;gap:12px;padding:0 16px;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm);z-index:10}.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:17px;letter-spacing:-.01em}.brand-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;box-shadow:0 4px 10px #c8553d4d;overflow:hidden;flex-shrink:0}img.brand-mark{background:none;object-fit:cover}.brand-name span{color:var(--accent)}.shop-meta{display:flex;align-items:center;gap:8px;padding-left:12px;margin-left:4px;border-left:1px solid var(--line);color:var(--ink-soft);font-size:13px}.shop-meta strong{color:var(--ink);font-weight:600}.topbar-spacer{flex:1}.pill-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;font-size:13px;color:var(--ink-soft);transition:background .15s,transform .12s,border-color .15s}.pill-btn:hover{background:var(--line-soft);transform:translateY(-1px)}.pill-btn:disabled{opacity:.5;cursor:not-allowed}.pill-btn.alert{background:var(--accent-soft);border-color:#f5cdbf;color:var(--accent-ink);font-weight:600}.pill-btn.success{background:var(--teal-soft);border-color:#b9e6d4;color:var(--teal-ink);font-weight:600}.pill-btn.warn{background:var(--amber-soft);border-color:#fde68a;color:var(--amber-ink);font-weight:600}.pill-btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:0;font-weight:600;box-shadow:0 4px 10px #c8553d40}.pill-btn .dot{width:8px;height:8px;border-radius:50%;background:currentColor}.pill-btn strong{font-weight:800}.user-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;background:linear-gradient(135deg,var(--teal),var(--teal-2));color:#fff;border-radius:999px;font-size:12px;font-weight:600;box-shadow:0 4px 10px #0f6e5640;position:relative}.user-chip.manager{background:linear-gradient(135deg,var(--amber),#d97706);box-shadow:0 4px 10px #b8740b40}.user-chip .avatar{width:28px;height:28px;border-radius:50%;background:#ffffff40;display:inline-flex;align-items:center;justify-content:center;font-size:13px}.user-chip-meta{display:flex;flex-direction:column;line-height:1.1;align-items:flex-start}.user-chip-meta small{font-size:9px;opacity:.85;letter-spacing:.06em}.user-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20}.user-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:21;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:6px;min-width:200px}.user-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border-radius:8px;font-size:13px;color:var(--ink-soft);text-align:left;transition:background .12s}.user-menu button:hover{background:var(--surface-2);color:var(--ink)}.user-menu button.danger:hover{background:var(--red-soft);color:var(--red)}.user-menu .divider{height:1px;background:var(--line);margin:4px 0}@keyframes scanFlashIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.cashier-main{display:grid;grid-template-columns:88px 1fr 360px;height:calc(100vh - 56px);overflow:hidden}@media(max-width:1280px){.cashier-main{grid-template-columns:76px 1fr 320px}}@media(max-width:900px){.cashier-main{grid-template-columns:60px 1fr 280px}.rail .cat span{font-size:10px}}.rail{background:var(--surface);border-right:1px solid var(--line);padding:12px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.cat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;border-radius:var(--radius-sm);color:var(--ink-mute);font-size:11px;font-weight:500;line-height:1.2;text-align:center;transition:background .15s,color .15s;border:1.5px solid transparent}.cat .icon{font-size:22px}.cat:hover{background:var(--surface-2);color:var(--ink)}.cat.active{background:var(--accent-soft);color:var(--accent-ink);border-color:#f5cdbf;font-weight:700}.cat.active .icon{transform:scale(1.05)}.cat-count{font-size:10px;color:var(--ink-faint)}.cat.active .cat-count{color:var(--accent)}.menu-pane{display:flex;flex-direction:column;padding:16px;overflow:hidden}.menu-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}.menu-head h2{font-size:18px;font-weight:800}.menu-head .count{color:var(--ink-mute);font-size:13px;font-weight:500}.search{margin-left:auto;flex:0 0 240px;display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow-sm);transition:border-color .15s}.search:focus-within{border-color:var(--accent)}.search input{flex:1;border:0;background:transparent;outline:none;font-size:13px;color:var(--ink)}.search input::placeholder{color:var(--ink-faint)}.subtype-pills{display:flex;gap:6px;padding:8px 4px 10px;overflow-x:auto;border-bottom:1px solid var(--line-soft);margin-bottom:8px;scrollbar-width:thin}.subtype-pills::-webkit-scrollbar{height:6px}.subtype-pills::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.subtype-pills .pill{flex:0 0 auto;padding:6px 12px;border:1.5px solid var(--line);background:#fff;color:var(--ink-soft);border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.subtype-pills .pill:hover{background:var(--surface-2)}.subtype-pills .pill.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 6px #c8553d33}.menu-pane .menu-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,130px));gap:8px;align-content:start;padding-right:4px;justify-content:start}.item{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .15s;text-align:left;display:flex;flex-direction:column;border:1px solid var(--line-soft);position:relative}.item:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#e0d9c8}.item:active{transform:translateY(0)}.item-img{aspect-ratio:1 / 1;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:22px;position:relative;overflow:hidden}.item-img img{width:100%;height:100%;object-fit:cover}.item-img.tone-1{background:linear-gradient(135deg,#fef3c7,#fed7aa)}.item-img.tone-2{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.item-img.tone-3{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}.item-img.tone-4{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.item-img.tone-5{background:linear-gradient(135deg,#fef3c7,#fde68a)}.item-img.tone-6{background:linear-gradient(135deg,#f5e6d3,#e7c9a0)}.item-img.tone-7{background:linear-gradient(135deg,#fee2e2,#fecaca)}.item-img.tone-8{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.item-body{padding:5px 7px 7px}.item-name{font-size:11.5px;font-weight:600;line-height:1.2;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.item-price{font-size:12.5px;font-weight:800;color:var(--accent);margin-top:2px}.item-meta{display:flex;align-items:center;gap:3px;font-size:9px;color:var(--ink-mute);margin-top:2px}.badge{position:absolute;top:8px;right:8px;padding:3px 8px;border-radius:999px;background:#fffffff0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:10px;font-weight:700;color:var(--accent-ink);box-shadow:var(--shadow-sm)}.badge.hot{background:var(--accent);color:#fff}.badge.new{background:var(--teal);color:#fff}.item.unavail{opacity:.45;cursor:not-allowed}.item.unavail:after{content:"หมด";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:var(--ink-soft);background:#fff9}.cart{background:var(--surface);border-left:1px solid var(--line);display:flex;flex-direction:column;box-shadow:-4px 0 16px #281e140a}.cart-head{padding:14px 18px 10px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line-soft)}.cart-head h3{font-size:17px;font-weight:800}.cart-head .badge-count{padding:2px 9px;background:var(--accent);color:#fff;border-radius:999px;font-size:11px;font-weight:700}.cart-head .clear-btn{margin-left:auto;font-size:12px;color:var(--ink-mute)}.cart-head .clear-btn:hover{color:var(--accent)}.cart-attach{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px 18px;border-bottom:1px solid var(--line-soft)}.attach-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;background:var(--surface-2);border:1.5px dashed var(--line);border-radius:var(--radius-sm);text-align:left;font-size:12px;color:var(--ink-mute);transition:border-color .15s,background .15s}.attach-btn:hover{border-color:var(--accent)}.attach-btn.set{background:var(--accent-soft);border-style:solid;border-color:#f5cdbf;color:var(--accent-ink)}.attach-btn .label{font-size:11px;opacity:.85;font-weight:500}.attach-btn .value{font-size:13px;font-weight:700}.cart-items{flex:1;overflow-y:auto;padding:8px 14px}.cart-empty{text-align:center;color:var(--ink-mute);font-size:13px;padding:60px 20px}.cart-empty-icon{font-size:40px;opacity:.3;margin-bottom:8px}.cart-row{display:flex;gap:10px;padding:10px 4px;border-bottom:1px solid var(--line-soft)}.cart-row:last-child{border-bottom:0}.cart-row-body{flex:1;min-width:0}.cart-row-name{font-size:13.5px;font-weight:600;color:var(--ink)}.cart-row-meta{font-size:11px;color:var(--ink-mute);margin-top:1px}.cart-row-foot{display:flex;align-items:center;justify-content:space-between;margin-top:6px;gap:8px}.qty{display:inline-flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:8px;background:var(--surface);overflow:hidden}.qty button{width:26px;height:26px;color:var(--ink-soft);font-size:16px;transition:background .12s}.qty button:hover{background:var(--surface-2)}.qty span{width:26px;text-align:center;font-size:13px;font-weight:600}.cart-row-price{font-size:13.5px;font-weight:700;color:var(--accent);font-feature-settings:"tnum"}.cart-row-remove{font-size:11px;color:var(--ink-faint);padding:2px 6px;border-radius:4px}.cart-row-remove:hover{background:var(--red-soft);color:var(--red)}.cart-foot{border-top:1px solid var(--line);background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);padding:14px 18px 18px}.total-row{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;color:var(--ink-soft);margin-bottom:4px}.total-row .amount{font-weight:700;font-feature-settings:"tnum"}.total-row.discount .amount{color:var(--green)}.total-row.grand{font-size:17px;font-weight:800;color:var(--ink);margin-top:8px;padding-top:10px;border-top:1.5px dashed var(--line)}.total-row.grand .amount{font-size:26px;color:var(--accent)}.checkout{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:14px;padding:16px 20px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:17px;font-weight:800;border-radius:var(--radius);box-shadow:0 8px 20px #c8553d59;transition:transform .12s,box-shadow .15s,opacity .15s;letter-spacing:.01em}.checkout:hover{transform:translateY(-1px);box-shadow:0 10px 24px #c8553d66}.checkout:active{transform:translateY(0)}.checkout:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.checkout .total-amount{font-size:19px}.cashier-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--ink-mute);font-size:14px}.cashier-loading .spinner{width:40px;height:40px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-stage{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(135deg,#fdf2ed 0%,var(--paper) 50%,#e1f5ee 100%);background-attachment:fixed}.auth-card{background:var(--surface);border-radius:24px;box-shadow:var(--shadow-lg);padding:32px 30px;width:100%;max-width:420px;position:relative;overflow:hidden}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent),var(--amber),var(--teal))}.auth-card.wide{max-width:480px}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}.auth-brand .brand-mark{width:44px;height:44px;border-radius:12px;font-size:22px;box-shadow:0 6px 16px #c8553d59}.auth-brand .brand-name{font-size:19px;font-weight:800}.auth-brand .brand-tag{font-size:11px;color:var(--ink-mute)}.scene-label{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:var(--accent-soft);color:var(--accent-ink);border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.08em;margin-bottom:12px}.scene-label .num{width:16px;height:16px;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:10px}.scene-title{font-size:22px;font-weight:800;letter-spacing:-.01em;margin-bottom:6px}.scene-sub{font-size:13px;color:var(--ink-mute);margin-bottom:22px}.field{margin-bottom:12px}.field label.label-row{font-size:12px;font-weight:700;color:var(--ink-soft);margin-bottom:6px;display:block}.field input[type=email],.field input[type=text],.field input[type=password],.field input[type=number],.field select{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;background:var(--surface);font-size:14px;transition:border-color .15s,box-shadow .15s;color:var(--ink)}.field input:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px #c8553d1f}.field-row{display:flex;align-items:center;justify-content:space-between;margin-top:4px;font-size:11px}.field-row a{color:var(--accent);font-weight:600}.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 18px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:700;font-size:14px;border-radius:10px;box-shadow:0 4px 12px #c8553d4d;transition:transform .12s,box-shadow .15s,opacity .15s;white-space:nowrap}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px #c8553d66}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 16px;background:#fff;color:var(--ink);border:1.5px solid var(--line);border-radius:10px;font-weight:600;font-size:14px;transition:background .15s,border-color .15s}.btn-google:hover{background:var(--surface-2);border-color:var(--ink-mute)}.btn-ghost{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px 16px;background:var(--surface-2);color:var(--ink-soft);border-radius:10px;font-weight:600;font-size:13px;white-space:nowrap}.btn-ghost:hover{background:var(--line-soft);color:var(--ink)}.divider{display:flex;align-items:center;gap:10px;margin:16px 0;font-size:11px;color:var(--ink-faint);font-weight:600;letter-spacing:.06em}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}.error-text{color:var(--red);font-size:12.5px;margin:8px 0}.footer-link{text-align:center;font-size:12px;color:var(--ink-mute);margin-top:14px}.owner-pill{display:flex;align-items:center;gap:10px;padding:10px 12px;background:linear-gradient(135deg,var(--green-soft),#c4f0d6);border:1px solid #86efac;border-radius:12px;margin-bottom:14px}.owner-pill .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px}.owner-pill .info{flex:1;min-width:0}.owner-pill .info .nm{font-size:13px;font-weight:700;color:var(--green-ink)}.owner-pill .info .em{font-size:11px;color:var(--green);opacity:.85}.owner-pill .switch{font-size:11px;color:var(--ink-mute);padding:4px 8px;border-radius:6px;transition:background .12s}.owner-pill .switch:hover{background:#fff;color:var(--ink)}.shop-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.shop-tile{display:flex;align-items:center;gap:12px;padding:14px;background:var(--surface-2);border:1.5px solid var(--line);border-radius:var(--radius);text-align:left;transition:border-color .15s,background .15s,transform .12s;width:100%}.shop-tile:hover{border-color:var(--accent);background:#fff;transform:translateY(-1px)}.shop-tile.active{border-color:var(--accent);background:var(--accent-soft)}.shop-tile .shop-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;background:linear-gradient(135deg,#fed7aa,#fb923c);color:#7c2d12}.shop-tile .shop-icon.tone-2{background:linear-gradient(135deg,#d4f4dd,#86efac);color:#14532d}.shop-tile .shop-icon.tone-3{background:linear-gradient(135deg,#ddd6fe,#a78bfa);color:#4c1d95}.shop-tile .shop-icon.tone-4{background:linear-gradient(135deg,#fce7f3,#f9a8d4);color:#831843}.shop-tile .shop-info{flex:1;min-width:0}.shop-tile .shop-name{font-size:14.5px;font-weight:700;color:var(--ink)}.shop-tile .shop-meta{font-size:11px;color:var(--ink-mute);margin-top:2px}.shop-tile .arrow-r{color:var(--ink-faint);font-size:18px;flex-shrink:0}.shop-tile.active .arrow-r{color:var(--accent)}.shop-banner{background:linear-gradient(135deg,var(--teal-soft),#d4ecdf);border:1px solid #b9e6d4;border-radius:var(--radius);padding:10px 12px;margin-bottom:14px;display:flex;align-items:center;gap:10px}.shop-banner .icon{width:32px;height:32px;border-radius:9px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.shop-banner .info{flex:1;min-width:0}.shop-banner .nm{font-size:13px;font-weight:800;color:var(--teal-ink)}.shop-banner .mt{font-size:11px;color:var(--teal)}.shop-banner .change{font-size:10px;color:var(--teal);padding:4px 8px;border-radius:6px}.shop-banner .change:hover{background:#fff}.label-tiny{font-size:11px;font-weight:700;color:var(--ink-soft);margin-bottom:6px}.cashier-tiles{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:14px}.cashier-tile{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface-2);border:1.5px solid var(--line);border-radius:10px;transition:border-color .15s,background .15s}.cashier-tile:hover{border-color:var(--accent);background:#fff}.cashier-tile.selected{border-color:var(--accent);background:var(--accent-soft)}.cashier-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0}.cashier-avatar.t1{background:linear-gradient(135deg,#c8553d,#e07453)}.cashier-avatar.t2{background:linear-gradient(135deg,#0f6e56,#138468)}.cashier-avatar.t3{background:linear-gradient(135deg,#b8740b,#d97706)}.cashier-avatar.t4{background:linear-gradient(135deg,#7c3aed,#9333ea)}.cashier-avatar.t5{background:linear-gradient(135deg,#1d4ed8,#3b82f6)}.cashier-tile-meta{display:flex;flex-direction:column;min-width:0;line-height:1.1}.cashier-tile-meta .nm{font-size:12.5px;font-weight:700}.cashier-tile-meta .rl{font-size:9px;color:var(--ink-mute);letter-spacing:.04em}.cashier-tile.selected .rl{color:var(--accent);font-weight:700}.pin-display{display:flex;gap:12px;justify-content:center;margin:14px 0}.pin-dot{width:14px;height:14px;border-radius:50%;background:var(--line);transition:background .15s,transform .12s}.pin-dot.filled{background:var(--accent);transform:scale(1.15)}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.pin-key{aspect-ratio:1.5 / 1;background:var(--surface-2);border:1.5px solid var(--line);border-radius:12px;font-size:22px;font-weight:700;color:var(--ink);transition:background .12s,transform .12s}.pin-key:hover:not(:disabled){background:#fff;transform:translateY(-1px)}.pin-key:active:not(:disabled){background:var(--accent-soft)}.pin-key:disabled{opacity:.5;cursor:not-allowed}.pin-key.action{background:transparent;color:var(--ink-mute);border-color:transparent;font-size:14px}.pin-key.action:hover{background:var(--line-soft)}.pin-key.del{color:var(--accent);font-size:18px}.pin-key.submit{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-color:transparent;font-size:13px;font-weight:800;box-shadow:0 4px 10px #c8553d4d}.pin-key.submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 14px #c8553d66;background:linear-gradient(135deg,var(--accent-2),var(--accent))}.pin-key.submit:disabled{opacity:.4}.cash-input{display:flex;align-items:baseline;justify-content:center;gap:12px;padding:22px 18px;background:var(--accent-soft);border:2px solid #f5cdbf;border-radius:var(--radius);margin:12px 0}.cash-input .currency{font-size:24px;font-weight:800;color:var(--accent-ink)}.cash-input input{border:0;background:transparent;font-size:42px;font-weight:800;color:var(--accent);letter-spacing:-.02em;text-align:center;width:220px;font-feature-settings:"tnum";outline:none}.quick-amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}.quick-amount{padding:10px 8px;background:var(--surface-2);border:1.5px solid var(--line);border-radius:8px;font-weight:700;font-size:13px;color:var(--ink-soft);transition:border-color .15s,background .15s}.quick-amount:hover{border-color:var(--accent);background:#fff;color:var(--accent)}.create-cashier-form{padding:14px;border:1.5px dashed var(--accent);border-radius:10px;background:var(--accent-soft);margin-top:6px}.create-cashier-form .form-title{font-size:13px;font-weight:800;color:var(--accent-ink);margin-bottom:10px}.owner-self-card{display:flex;align-items:center;gap:12px;width:100%;padding:16px 18px;background:linear-gradient(135deg,var(--amber),#d97706);color:#fff;border:0;border-radius:var(--radius);box-shadow:0 6px 16px #b8740b59;transition:transform .12s,box-shadow .15s;text-align:left;margin-bottom:14px}.owner-self-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px #b8740b73}.owner-self-card:disabled{opacity:.6;cursor:wait;transform:none}.owner-self-card .crown{width:44px;height:44px;border-radius:50%;background:#ffffff38;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.owner-self-card .info{flex:1}.owner-self-card .lbl{font-size:11px;opacity:.9;letter-spacing:.06em;font-weight:700}.owner-self-card .nm{font-size:17px;font-weight:800;margin-top:2px}.owner-self-card .arr{font-size:22px;opacity:.9}.handover-note{display:flex;align-items:center;gap:8px;margin:18px 0 8px;font-size:11px;color:var(--ink-faint);font-weight:700;letter-spacing:.06em}.handover-note:before,.handover-note:after{content:"";flex:1;height:1px;background:var(--line)}.pay-stage{min-height:100vh;background:var(--paper);display:flex;flex-direction:column}.pay-topbar{height:56px;display:flex;align-items:center;gap:12px;padding:0 16px;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}.pay-topbar .crumb{color:var(--ink-mute);font-size:13px;padding-left:12px;margin-left:4px;border-left:1px solid var(--line)}.pay-topbar .crumb strong{color:var(--ink);font-weight:600}.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:24px;max-width:1500px;width:100%;margin:0 auto;flex:1}@media(max-width:1100px){.pay-grid{grid-template-columns:1fr;max-width:700px}}.scene-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}.scene-head{padding:16px 20px;background:linear-gradient(135deg,#1e3a5f,#0f172a);color:#fff;display:flex;align-items:center;gap:12px}.scene-head.success{background:linear-gradient(135deg,var(--green),#059669)}.scene-head h2{font-size:18px;font-weight:800;flex:1}.scene-head .scene-tag{padding:3px 10px;background:#ffffff29;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.06em}.scene-body{padding:20px;flex:1;overflow-y:auto}.order-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.meta-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--surface-2);border-radius:999px;font-size:12px;color:var(--ink-soft);font-weight:600}.meta-chip.gold{background:var(--amber-soft);color:var(--amber)}.order-list{background:var(--surface-2);border-radius:var(--radius);padding:12px 14px;margin-bottom:14px}.order-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px dashed var(--line);font-size:13px}.order-row:last-child{border-bottom:0}.order-row .qty-pill{flex:0 0 28px;height:24px;border-radius:6px;background:var(--accent-soft);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px}.order-row .name{flex:1}.order-row .name small{color:var(--ink-mute);font-size:11px;display:block}.order-row .price{font-weight:700;color:var(--ink);font-feature-settings:"tnum"}.totals{padding:4px 4px 0}.totals .total-row.discount,.totals .total-row.discount .amount{color:var(--green)}.totals .total-row.grand .amount{font-size:32px}.tender-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.tender-tile{display:flex;align-items:center;gap:12px;padding:14px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius);text-align:left;transition:border-color .15s,background .15s,transform .12s}.tender-tile:hover{border-color:var(--accent);transform:translateY(-1px)}.tender-tile.selected{border-color:var(--accent);background:var(--accent-soft)}.tender-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px}.tender-icon.cash{background:var(--accent-soft);color:var(--accent)}.tender-icon.qr{background:var(--teal-soft);color:var(--teal)}.tender-icon.card{background:var(--blue-soft);color:var(--blue)}.tender-icon.gift{background:var(--purple-soft);color:var(--purple)}.tender-name{font-size:14px;font-weight:700}.tender-meta{font-size:11px;color:var(--ink-mute);margin-top:2px}.section-label{font-size:11px;font-weight:800;color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase;margin:14px 0 8px}.quick-cash{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.quick-cash button{flex:1;min-width:80px;padding:10px;background:var(--surface-2);border:1.5px solid var(--line);border-radius:8px;font-weight:700;font-size:13px;transition:border-color .15s}.quick-cash button:hover{border-color:var(--accent)}.quick-cash button.exact{background:var(--teal-soft);border-color:#b9e6d4;color:var(--teal-ink)}.received-input{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--surface);border:2px solid var(--accent);border-radius:var(--radius);margin-bottom:14px}.received-input label{font-size:12px;color:var(--ink-mute);font-weight:600}.received-input input{flex:1;border:0;outline:none;background:transparent;text-align:right;font-size:24px;font-weight:800;color:var(--ink);font-feature-settings:"tnum"}.change-display{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:var(--green-soft);border-radius:var(--radius);margin-bottom:14px}.change-display .label{font-size:13px;font-weight:700;color:var(--green)}.change-display .amount{font-size:24px;font-weight:800;color:#047857;font-feature-settings:"tnum"}.confirm-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:18px;background:linear-gradient(135deg,var(--green),#059669);color:#fff;font-size:17px;font-weight:800;border-radius:var(--radius);box-shadow:0 8px 20px #16a34a59;transition:transform .12s,box-shadow .15s}.confirm-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #16a34a73}.confirm-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.ghost-link{width:100%;padding:12px;background:transparent;color:var(--ink-mute);font-size:13px;font-weight:600;border-radius:8px;border:1.5px dashed var(--line);transition:border-color .15s,color .15s;margin-bottom:12px}.ghost-link:hover{border-color:var(--accent);color:var(--accent)}.qr-display{background:linear-gradient(135deg,var(--teal-soft),white);border:1.5px solid #b9e6d4;border-radius:var(--radius);padding:16px;margin-bottom:14px}.qr-amount{background:var(--surface);border-radius:10px;padding:12px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm)}.qr-amount .lbl{font-size:12px;color:var(--ink-mute);font-weight:600}.qr-amount .val{font-size:26px;font-weight:800;color:var(--accent);font-feature-settings:"tnum";letter-spacing:-.02em}.qr-img-wrap{display:flex;justify-content:center;align-items:center;background:#fff;padding:12px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:14px}.qr-img{width:240px;height:240px;object-fit:contain;display:block}.qr-instructions{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.qr-instructions .step{display:flex;align-items:center;gap:10px;padding:7px 10px;background:var(--surface);border-radius:8px;font-size:13px;color:var(--ink-soft)}.qr-instructions .step .num{flex:0 0 22px;height:22px;border-radius:50%;background:var(--teal);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}.qr-instructions .step strong{color:var(--accent);font-weight:800}.qr-hint{text-align:center;font-size:11px;color:var(--ink-mute);padding-top:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:min(440px,100%);max-height:92vh;overflow-y:auto;padding:20px 22px;position:relative}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-head h3{font-size:17px;font-weight:800;display:flex;align-items:center;gap:8px}.modal-head .close{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;color:var(--ink-mute)}.modal-head .close:hover{background:var(--surface-2);color:var(--ink)}.split-total{text-align:center;font-size:13px;color:var(--ink-mute);margin-bottom:14px}.split-total strong{color:var(--accent);font-size:24px;font-weight:800;font-feature-settings:"tnum"}.split-n{display:flex;gap:8px;justify-content:center;margin-bottom:14px}.split-n button{width:56px;height:56px;border-radius:12px;border:2px solid var(--line);background:var(--surface);font-size:22px;font-weight:800;color:var(--ink);transition:border-color .15s,background .15s,transform .12s}.split-n button:hover{border-color:var(--accent);transform:translateY(-1px)}.split-n button.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink)}.split-share-label{text-align:center;font-size:12px;color:var(--ink-mute);margin-bottom:10px}.split-share-label strong{color:var(--accent);font-weight:800;font-feature-settings:"tnum"}.split-rows{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto;padding:4px;margin-bottom:14px}.split-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface-2);border-radius:10px}.split-row .person-num{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:800;font-size:12px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.split-row .amt{flex:1;font-size:15px;font-weight:700;font-feature-settings:"tnum"}.split-row select{padding:6px 10px;border:1px solid var(--line);border-radius:6px;background:#fff;font-size:13px;color:var(--ink)}.modal-foot{display:flex;gap:8px}.modal-foot button{padding:12px 16px;border-radius:8px;font-weight:700;font-size:14px}.modal-foot .cancel{flex:1;background:var(--surface-2);color:var(--ink-soft)}.modal-foot .cancel:hover{background:var(--line-soft)}.modal-foot .submit{flex:2;background:linear-gradient(135deg,var(--green),#059669);color:#fff;box-shadow:0 4px 12px #16a34a4d}.modal-foot .submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #16a34a66}.modal-foot .submit:disabled{opacity:.5;cursor:not-allowed}.modal-hint{margin-top:12px;padding:8px 12px;background:var(--surface-2);border-radius:8px;font-size:11px;color:var(--ink-mute);text-align:center}.modal-error{background:var(--red-soft);color:var(--red);border:1px solid #fca5a5;padding:9px 12px;border-radius:8px;font-size:12.5px;margin-bottom:12px}.collect-progress{display:flex;gap:6px;justify-content:center;margin-bottom:16px}.collect-dot{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;background:var(--surface-2);color:var(--ink-mute);border:2px solid var(--line);transition:all .2s}.collect-dot.done{background:var(--green);color:#fff;border-color:var(--green)}.collect-dot.active{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.1);box-shadow:0 4px 12px #c8553d66}.collect-header{text-align:center;margin-bottom:18px}.collect-header .scene-tag{display:inline-block;padding:3px 12px;background:var(--accent-soft);color:var(--accent-ink);border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.06em;margin-bottom:6px}.collect-header h3{font-size:17px;font-weight:800}.collect-header .sub{font-size:12px;color:var(--ink-mute);margin-top:4px}.collect-amount-card{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-radius:var(--radius);padding:18px;margin-bottom:14px;text-align:center;box-shadow:0 8px 20px #c8553d4d}.collect-amount-card .lbl{font-size:11px;opacity:.9;letter-spacing:.06em;font-weight:700}.collect-amount-card .method{font-size:12px;opacity:.85;margin-bottom:4px;font-weight:600}.collect-amount-card .val{font-size:38px;font-weight:800;letter-spacing:-.02em;line-height:1.1;font-feature-settings:"tnum"}.collect-method-content{margin-bottom:14px}.received-mini{display:flex;align-items:baseline;gap:8px;background:var(--surface-2);border:2px solid var(--accent);border-radius:10px;padding:12px 14px;margin-bottom:10px}.received-mini label{font-size:11px;color:var(--ink-mute);font-weight:600}.received-mini input{flex:1;border:0;background:transparent;outline:none;text-align:right;font-size:22px;font-weight:800;color:var(--ink);font-feature-settings:"tnum"}.quick-cash-mini{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.quick-cash-mini button{flex:1;min-width:70px;padding:8px 6px;background:var(--surface-2);border:1.5px solid var(--line);border-radius:8px;font-weight:700;font-size:12px;transition:border-color .15s}.quick-cash-mini button:hover{border-color:var(--accent)}.quick-cash-mini button.exact{background:var(--teal-soft);border-color:#b9e6d4;color:var(--teal-ink)}.change-mini{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;background:var(--green-soft);border-radius:8px;margin-bottom:10px}.change-mini .lbl{font-size:12px;font-weight:700;color:var(--green)}.change-mini .val{font-size:18px;font-weight:800;color:#047857;font-feature-settings:"tnum"}.qr-mini{background:var(--surface-2);border-radius:10px;padding:12px;text-align:center;margin-bottom:10px}.qr-mini img{max-width:180px;height:auto;border-radius:8px}.qr-mini-empty{background:var(--amber-soft);color:var(--amber-ink);padding:14px;border-radius:10px;font-size:12px;text-align:center;margin-bottom:10px}.collect-foot{display:flex;gap:8px}.collect-foot button{padding:12px 16px;border-radius:10px;font-weight:700;font-size:13px}.collect-foot .back{flex:1;background:var(--surface-2);color:var(--ink-soft)}.collect-foot .back:hover{background:var(--line-soft)}.collect-foot .next{flex:2;background:linear-gradient(135deg,var(--green),#059669);color:#fff;box-shadow:0 4px 12px #16a34a4d}.collect-foot .next:hover:not(:disabled){transform:translateY(-1px)}.collect-foot .next:disabled{opacity:.5;cursor:not-allowed}.collected-summary{background:var(--green-soft);border-radius:10px;padding:10px 12px;margin-bottom:12px;font-size:12px;color:var(--green-ink)}.collected-summary strong{font-weight:800}.owner-shell{display:grid;grid-template-columns:248px 1fr;grid-template-rows:56px 1fr;grid-template-areas:"topbar topbar" "sidebar main";height:100vh}.owner-shell .topbar{grid-area:topbar}.owner-shell .own-side{grid-area:sidebar}.owner-shell .own-main{grid-area:main;padding:24px 28px;overflow-y:auto;background:var(--paper)}.shop-switcher{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;font-size:13px;color:var(--ink-soft);cursor:pointer;transition:background .15s}.shop-switcher:hover{background:var(--line-soft)}.shop-switcher strong{color:var(--ink);font-weight:700}.shop-switcher .chev{color:var(--ink-faint);font-size:11px}.own-side{background:var(--surface);border-right:1px solid var(--line);overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column}.nav-group{margin-bottom:18px}.nav-label{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);padding:0 12px 8px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;margin-bottom:1px;border-radius:var(--radius-sm);color:var(--ink-soft);font-size:14px;font-weight:500;width:100%;transition:background .15s,color .15s;text-align:left}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:700}.nav-item .icon{font-size:17px;width:20px;text-align:center}.nav-item .badge{margin-left:auto;font-size:10px;font-weight:700;padding:2px 7px;background:var(--accent);color:#fff;border-radius:999px}.wallet-card{margin-top:auto;background:linear-gradient(135deg,#1e3a5f,#0f172a);color:#fff;border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}.wallet-card .lbl{font-size:10px;letter-spacing:.08em;text-transform:uppercase;opacity:.7}.wallet-card .amt{font-size:22px;font-weight:800;margin:4px 0 8px}.wallet-card .amt span{font-size:14px;opacity:.7}.wallet-card .meta{font-size:11px;opacity:.85;margin-bottom:10px}.wallet-card .topup-btn{display:block;width:100%;padding:8px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);color:#fff;border-radius:8px;font-size:12px;font-weight:600;transition:background .15s}.wallet-card .topup-btn:hover{background:#fff3}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}.page-head h1{font-size:24px;font-weight:800;letter-spacing:-.01em}.page-head .sub{color:var(--ink-mute);font-size:13px;margin-top:2px}.page-head .actions{display:flex;gap:8px;flex-wrap:wrap}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}@media(max-width:1280px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm);position:relative;transition:box-shadow .15s,transform .15s}.kpi:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.kpi .kpi-icon{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.kpi.revenue .kpi-icon{background:var(--accent-soft);color:var(--accent)}.kpi.orders .kpi-icon{background:var(--teal-soft);color:var(--teal)}.kpi.avg .kpi-icon{background:var(--blue-soft);color:var(--blue)}.kpi.cust .kpi-icon{background:var(--amber-soft);color:var(--amber)}.kpi-label{font-size:11px;color:var(--ink-mute);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.kpi-value{font-size:26px;font-weight:800;margin-top:4px;letter-spacing:-.02em;font-feature-settings:"tnum"}.kpi-trend{display:inline-flex;align-items:center;gap:4px;margin-top:6px;font-size:12px;font-weight:600}.kpi-trend.up{color:var(--green)}.kpi-trend.down{color:var(--accent)}.kpi-trend.flat{color:var(--ink-mute)}.kpi-trend small{color:var(--ink-mute);font-weight:500}.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm)}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}.card-head h3{font-size:15px;font-weight:800}.card-head .more-link{font-size:12px;color:var(--accent);font-weight:600}.row-2{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:22px}.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:22px}@media(max-width:1280px){.row-2{grid-template-columns:1fr}.row-3{grid-template-columns:1fr 1fr}}.chart{height:200px;width:100%;background:linear-gradient(180deg,transparent 0%,var(--surface-2) 100%);border-radius:var(--radius-sm);padding:16px 8px 8px;position:relative}.chart svg{width:100%;height:100%}.chart .bar{fill:url(#bar-grad)}.chart .bar.peak{fill:url(#bar-peak)}.chart-x{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-mute);margin-top:4px;padding:0 4px}.activity-list{display:flex;flex-direction:column;gap:2px}.activity-row{display:flex;gap:12px;padding:10px 4px;border-bottom:1px solid var(--line-soft)}.activity-row:last-child{border-bottom:0}.activity-icon{flex:0 0 32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}.activity-icon.sale{background:var(--green-soft);color:var(--green-ink)}.activity-icon.refund{background:var(--accent-soft);color:var(--accent-ink)}.activity-icon.void{background:var(--red-soft);color:var(--red)}.activity-icon.invoice{background:var(--purple-soft);color:var(--purple)}.activity-icon.staff{background:var(--teal-soft);color:var(--teal)}.activity-icon.shift{background:var(--blue-soft);color:var(--blue)}.activity-body{flex:1;min-width:0}.activity-text{font-size:13px;color:var(--ink);line-height:1.45}.activity-text strong{font-weight:700}.activity-time{font-size:11px;color:var(--ink-mute);margin-top:2px}.top-list{display:flex;flex-direction:column;gap:10px}.top-row{display:flex;align-items:center;gap:12px}.top-rank{flex:0 0 28px;height:28px;background:var(--accent-soft);color:var(--accent-ink);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}.top-row.gold .top-rank{background:linear-gradient(135deg,#fde68a,#fbbf24);color:#78350f}.top-row.silver .top-rank{background:linear-gradient(135deg,#e5e5e5,#a3a3a3);color:#1a1a1a}.top-row.bronze .top-rank{background:linear-gradient(135deg,#fed7aa,#fb923c);color:#7c2d12}.top-info{flex:1;min-width:0}.top-name{font-size:13px;font-weight:600}.top-meta{font-size:11px;color:var(--ink-mute)}.top-bar{margin-top:4px;height:4px;border-radius:999px;background:var(--line);overflow:hidden}.top-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:999px}.donut-wrap{display:flex;gap:14px;align-items:center}.donut{flex:0 0 100px}.tender-legend{flex:1;display:flex;flex-direction:column;gap:8px}.legend-row{display:flex;align-items:center;gap:8px;font-size:12px}.legend-dot{width:10px;height:10px;border-radius:3px;flex:0 0 10px}.legend-row .pct{margin-left:auto;font-weight:700;color:var(--ink);font-feature-settings:"tnum"}.stock-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line-soft);font-size:13px}.stock-row:last-child{border-bottom:0}.stock-name{flex:1}.stock-qty{padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;background:var(--amber-soft);color:var(--amber-ink)}.stock-qty.low{background:var(--red-soft);color:var(--red)}.section-eyebrow{font-size:13px;font-weight:800;color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase;margin:22px 0 10px}.quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:22px}.quick-tile{display:flex;gap:12px;align-items:center;padding:14px 16px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink);transition:transform .12s,box-shadow .15s,border-color .15s;cursor:pointer;text-align:left}.quick-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--accent-soft)}.quick-tile .q-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:22px;flex-shrink:0}.quick-tile .q-name{font-weight:700;font-size:14px;color:var(--ink)}.quick-tile .q-desc{font-size:11.5px;color:var(--ink-mute);margin-top:2px}.empty-state{padding:40px 20px;text-align:center;color:var(--ink-mute);font-size:13px}.empty-state .icon{font-size:36px;margin-bottom:8px;opacity:.4}@media(max-width:900px){.owner-shell{grid-template-columns:80px 1fr}.nav-item span:not(.icon):not(.badge){display:none}.nav-label,.wallet-card{display:none}.nav-item{justify-content:center}}.toolbar{display:flex;gap:8px;align-items:center;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:10px 14px;margin-bottom:18px;box-shadow:var(--shadow-sm);flex-wrap:wrap}.toolbar .search{flex:1;min-width:220px;box-shadow:none;background:var(--surface-2);border-color:transparent}.toolbar>.btn-primary,.toolbar>.btn-ghost,.page-head .actions>.btn-primary,.page-head .actions>.btn-ghost,.tr>.btn-primary,.tr>.btn-ghost,.tr .btn-primary,.tr .btn-ghost{width:auto;padding:8px 14px;font-size:12.5px;border-radius:8px;white-space:nowrap;box-shadow:none}.page-head .actions>.btn-primary{padding:9px 18px;font-size:13px}.toolbar>input[type=date],.toolbar>input[type=month],.toolbar>select{padding:7px 12px;border-radius:8px;border:1px solid var(--line);background:var(--surface-2);font-size:13px}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:2px}.seg button{padding:5px 14px;border-radius:999px;font-size:12px;font-weight:700;color:var(--ink-mute)}.seg button.on{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;font-size:12px;color:var(--ink-soft);font-weight:600}.filter-chip.on{background:var(--accent-soft);color:var(--accent-ink);border-color:#f5cdbf}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.stat{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:12px}.stat .stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.stat-val{font-size:22px;font-weight:800;line-height:1;letter-spacing:-.02em;font-feature-settings:"tnum"}.stat-label{font-size:11px;color:var(--ink-mute);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-top:3px}.tone-accent .stat-icon{background:var(--accent-soft);color:var(--accent)}.tone-teal .stat-icon{background:var(--teal-soft);color:var(--teal)}.tone-amber .stat-icon{background:var(--amber-soft);color:var(--amber)}.tone-blue .stat-icon{background:var(--blue-soft);color:var(--blue)}.tone-purple .stat-icon{background:var(--purple-soft);color:var(--purple)}.tone-green .stat-icon{background:var(--green-soft);color:var(--green)}@media(max-width:1100px){.stats-row{grid-template-columns:repeat(2,1fr)}}.table-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.tr{display:flex;gap:12px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--line-soft);transition:background .12s;font-size:13px}.tr:hover{background:var(--surface-2)}.tr:last-child{border-bottom:0}.tr.head{background:var(--surface-2);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute)}.tr.head:hover{background:var(--surface-2)}.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700}.pill-success{background:var(--green-soft);color:var(--green)}.pill-warn{background:var(--amber-soft);color:var(--amber)}.pill-danger{background:var(--red-soft);color:var(--red)}.pill-info{background:var(--blue-soft);color:var(--blue)}.pill-mute{background:var(--surface-2);color:var(--ink-mute)}.pill-purple{background:var(--purple-soft);color:var(--purple)}.icon-btn{width:28px;height:28px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-mute);font-size:14px;transition:background .12s,color .15s}.icon-btn:hover{background:var(--surface-2);color:var(--ink)}.icon-btn.del:hover{background:var(--red-soft);color:var(--red)}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.menu-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;transition:transform .12s,box-shadow .15s;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.menu-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.menu-card.oos{opacity:.6}.menu-card-hero{position:relative;width:100%;aspect-ratio:16 / 10;background:var(--surface-2);display:grid;place-items:center;overflow:hidden}.menu-card-hero img{width:100%;height:100%;object-fit:cover}.menu-card-hero .placeholder{font-size:44px;opacity:.35}.menu-card-hero .badges{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;align-items:flex-end}.menu-card-hero .badges .role-pill{font-size:10px;padding:3px 8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 1px 3px #00000026}.menu-card-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px;flex:1}.menu-card-name{font-weight:700;font-size:14.5px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.menu-card-meta{font-size:11px;color:var(--ink-mute);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.menu-card-meta .dot{color:var(--line)}.menu-card-price{margin-top:auto;padding-top:4px;font-size:18px;font-weight:800;color:var(--accent);font-feature-settings:"tnum"}.menu-card-actions{display:flex;gap:4px;padding:10px 12px;border-top:1px solid var(--line-soft);background:var(--surface)}.menu-card-actions>button.menu-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 8px;border-radius:8px;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--ink-soft);white-space:nowrap;transition:background .12s,color .12s}.menu-card-actions>button.menu-btn:hover:not(:disabled){background:var(--line-soft);color:var(--ink)}.menu-card-actions>button.menu-btn.toggle.on{color:var(--teal)}.menu-card-actions>button.menu-btn.toggle.off{color:#92400e}.menu-card-actions>button.menu-btn.icon{flex:0 0 36px;padding:7px 0}.menu-card-actions>button.menu-btn.del{color:#991b1b}.menu-card-actions>button.menu-btn.del:hover:not(:disabled){background:#fee2e2;color:#991b1b}.menu-card-actions>button.menu-btn:disabled{opacity:.4;cursor:not-allowed}.branch-row{display:grid;grid-template-columns:44px minmax(0,1.6fr) 1fr 80px 100px;gap:12px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line-soft);font-size:13px}.branch-row:last-child{border-bottom:0}.branch-row.head{background:var(--surface-2);font-size:11px;font-weight:800;color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase;padding:8px 14px;border-bottom:1px solid var(--line)}.branch-row.total{background:var(--surface-2);font-weight:700;border-top:1px solid var(--line)}.branch-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:18px}.branch-info .nm{font-weight:700;font-size:14px}.branch-info .meta{font-size:11px;color:var(--ink-mute);margin-top:2px}.branch-num{text-align:right;font-weight:700;font-feature-settings:"tnum"}.branch-num small{display:block;font-size:10px;font-weight:500;color:var(--ink-mute);margin-top:2px}.trend-pill{display:inline-block;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700}.trend-pill.up{background:var(--green-soft);color:var(--green-ink)}.trend-pill.down{background:var(--accent-soft);color:var(--accent)}.hm-card{padding:16px 18px}.heatmap{display:grid;grid-template-columns:28px repeat(24,1fr);gap:3px;margin-top:10px}.hm-h-label,.hm-d-label{font-size:9px;color:var(--ink-mute);display:flex;align-items:center;justify-content:center;font-feature-settings:"tnum"}.hm-d-label{font-weight:700;font-size:11px}.hm-cell{aspect-ratio:1 / 1;border-radius:3px;background:var(--surface-2);transition:transform .12s;cursor:help}.hm-cell:hover{transform:scale(1.4);z-index:2}.hm-0{background:var(--surface-2)}.hm-1{background:#fce7d4}.hm-2{background:#f8c4a3}.hm-3{background:#f09870}.hm-4{background:#d6764e}.hm-5{background:#b04a2c}.hm-legend{display:flex;align-items:center;gap:8px;margin-top:14px;font-size:11px;color:var(--ink-mute)}.hm-legend .scale{display:inline-flex;gap:2px}.hm-legend .scale>span{width:14px;height:12px;border-radius:2px}.bs-list{display:flex;flex-direction:column;gap:10px}.bs-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-radius:8px;transition:background .12s}.bs-row:hover{background:var(--surface-2)}.bs-rank{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:800;background:var(--surface-2);color:var(--ink-mute);flex-shrink:0}.bs-row.gold .bs-rank{background:linear-gradient(135deg,#fbbf24,#d4a017);color:#fff}.bs-row.silver .bs-rank{background:linear-gradient(135deg,#cbd5e1,#94a3b8);color:#fff}.bs-row.bronze .bs-rank{background:linear-gradient(135deg,#d97706,#854f0b);color:#fff}.bs-thumb{width:36px;height:36px;border-radius:8px;background:var(--surface-2);display:grid;place-items:center;font-size:18px;flex-shrink:0}.bs-info{flex:1;min-width:0}.bs-name{font-weight:700;font-size:13.5px}.bs-meta{font-size:11px;color:var(--ink-mute);margin-top:2px}.bs-bar{height:4px;background:var(--surface-2);border-radius:2px;margin-top:4px;overflow:hidden}.bs-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:2px}.big-chart{height:280px;padding:16px 4px 4px;position:relative}.big-chart svg{width:100%;height:100%}.chart-tooltip{position:absolute;background:#000000d9;color:#fff;padding:6px 10px;border-radius:6px;font-size:11px;font-weight:600;pointer-events:none;white-space:nowrap;z-index:2}.chart-tooltip strong{color:#ffd599;font-size:14px}.shifts-layout{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:14px;align-items:flex-start}@media(max-width:1100px){.shifts-layout{grid-template-columns:1fr}}.shifts-list-card,.shifts-detail-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.shifts-list-card .tr.head{padding:10px 16px;font-size:10px}.shifts-list-card .tr.shifts-row{padding:12px 16px;cursor:pointer;position:relative}.shifts-list-card .tr.shifts-row.selected{background:var(--accent-soft)}.shifts-list-card .tr.shifts-row.selected:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}.shifts-list-card .tr.shifts-row:hover:not(.selected){background:var(--surface-2)}.shifts-detail-card{position:sticky;top:80px}.shifts-detail-inner{padding:16px 18px}.shifts-detail-head{padding-bottom:12px;border-bottom:1px solid var(--line-soft);margin-bottom:14px}.shifts-section{margin-bottom:14px}.shifts-section-title{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:8px}.shifts-grand{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0 4px;margin-top:6px;border-top:2px dashed var(--line);font-feature-settings:"tnum"}.shifts-grand>span:first-child{font-weight:700;font-size:14px}.shifts-grand>span:last-child{font-weight:800;font-size:22px;color:var(--accent)}.shifts-expected-row{display:flex;justify-content:space-between;padding:10px 12px;margin-top:6px;background:var(--teal-soft);border-radius:8px;font-weight:700;font-feature-settings:"tnum";color:var(--teal-ink, var(--teal))}.shifts-expected-row>span:last-child{font-weight:800}.shifts-detail-actions{display:flex;gap:10px;padding-top:14px;border-top:1px solid var(--line-soft);margin-top:14px}.staff-card-body{padding:16px 16px 14px;display:flex;flex-direction:column;gap:12px;flex:1}.staff-card-head{display:flex;align-items:center;gap:12px}.staff-avatar-lg{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-size:20px;font-weight:800;flex-shrink:0}.staff-name{font-weight:700;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.staff-meta{font-size:12px;color:var(--ink-mute);display:flex;align-items:center;gap:6px}.cashier-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.cashier-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s;position:relative}.cashier-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.cashier-card.locked{opacity:.85;border-color:#fca5a5;background:linear-gradient(135deg,var(--red-soft),white 40%)}.cashier-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}.big-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff;flex-shrink:0}.ba-1{background:linear-gradient(135deg,#c8553d,#e07453)}.ba-2{background:linear-gradient(135deg,#0f6e56,#138468)}.ba-3{background:linear-gradient(135deg,#b8740b,#d97706)}.ba-4{background:linear-gradient(135deg,#7c3aed,#9333ea)}.ba-5{background:linear-gradient(135deg,#1d4ed8,#3b82f6)}.role-pill{display:inline-block;margin-top:4px;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700}.role-pill.manager{background:var(--amber-soft);color:var(--amber)}.role-pill.cashier{background:var(--teal-soft);color:var(--teal)}.role-pill.owner{background:linear-gradient(135deg,var(--amber),#d97706);color:#fff}.cashier-actions{display:flex;gap:6px;margin-top:12px}.cashier-actions button{flex:1;padding:7px;border:1px solid var(--line);background:var(--surface);border-radius:8px;font-size:12px;font-weight:600;color:var(--ink-soft);transition:background .12s,border-color .15s,color .15s}.cashier-actions button:hover{background:var(--surface-2);border-color:var(--accent);color:var(--accent)}.cashier-actions button.danger:hover{background:var(--red-soft);border-color:var(--red);color:var(--red)}.add-card{background:transparent;border:2px dashed var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--ink-mute);cursor:pointer;transition:border-color .15s,color .15s,background .15s;min-height:200px;width:100%}.add-card:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.add-card .add-icon{width:56px;height:56px;border-radius:50%;background:var(--surface);border:2px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800}.add-card .add-label{font-size:14px;font-weight:700}.gc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.gc-card{background:linear-gradient(135deg,#7c3aed,#5b21b6 60%,#4c1d95);color:#fff;border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}.gc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.gc-card.depleted{background:linear-gradient(135deg,#6b7280,#4b5563);opacity:.7}.gc-card.expired{background:linear-gradient(135deg,#991b1b,#7f1d1d);opacity:.6}.gc-card:before{content:"";position:absolute;top:-50%;right:-30%;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.15),transparent 70%)}.gc-card-head{display:flex;justify-content:space-between;align-items:flex-start;position:relative}.gc-status{padding:3px 10px;border-radius:999px;background:#fff3;font-size:10px;font-weight:800;letter-spacing:.06em}.gc-status.active{background:var(--green)}.gc-code{font-family:Menlo,Consolas,monospace;font-size:13px;font-weight:800;margin:14px 0 6px;letter-spacing:.04em;position:relative}.gc-balance{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1;margin-top:4px;font-feature-settings:"tnum";position:relative}.gc-balance .of{font-size:13px;opacity:.7;font-weight:600}.gc-meta{margin-top:12px;padding-top:10px;border-top:1px dashed rgba(255,255,255,.3);font-size:11px;opacity:.85;line-height:1.5;position:relative}.gc-progress{height:4px;border-radius:999px;background:#ffffff40;margin-top:8px;overflow:hidden}.gc-progress-fill{height:100%;background:#fff;border-radius:999px}.issue-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}@media(max-width:1100px){.issue-grid{grid-template-columns:repeat(2,1fr)}}.issue-tile{background:linear-gradient(135deg,var(--purple),#6d28d9);color:#fff;border-radius:var(--radius);padding:18px;text-align:center;box-shadow:0 4px 12px #7c3aed40;cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}.issue-tile:hover{transform:translateY(-3px);box-shadow:0 8px 20px #7c3aed66}.issue-tile:before{content:"🎁";position:absolute;top:-10px;right:-10px;font-size:80px;opacity:.12}.issue-tile .amt{font-size:28px;font-weight:800;letter-spacing:-.02em}.issue-tile .lbl{font-size:11px;opacity:.85;margin-top:4px;letter-spacing:.04em;text-transform:uppercase;font-weight:700}.issue-tile.custom{background:#fff;color:var(--purple);border:2px dashed var(--purple);box-shadow:none}.invoice-num{font-family:Menlo,Consolas,monospace;font-size:13px;font-weight:800;color:var(--purple);letter-spacing:-.02em}.invoice-type{display:inline-block;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:800}.invoice-type.full{background:var(--purple-soft);color:var(--purple)}.invoice-type.abbr{background:var(--surface-2);color:var(--ink-mute)}.channel-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700}.channel-pill.pos{background:var(--accent-soft);color:var(--accent-ink)}.channel-pill.line{background:var(--green-soft);color:var(--green-ink)}.channel-pill.app{background:var(--blue-soft);color:var(--blue-ink)}.channel-pill.deliv{background:var(--amber-soft);color:var(--amber-ink)}.qr-prompt{padding:18px;background:linear-gradient(135deg,var(--teal-soft),white);border:1.5px dashed #b9e6d4;border-radius:var(--radius);margin-bottom:14px;text-align:center}.qr-prompt .icon{font-size:36px;margin-bottom:8px}.qr-prompt .amount{font-size:24px;font-weight:800;color:var(--teal-ink)}.qr-prompt .hint{font-size:11px;color:var(--ink-mute);margin-top:6px}.gc-lookup{padding:12px;background:var(--purple-soft);border-radius:var(--radius);margin-bottom:14px}.gc-lookup .row{display:flex;gap:8px}.gc-lookup input{flex:1;padding:10px 12px;border:1.5px solid var(--line);border-radius:8px;font-family:Menlo,Consolas,monospace;text-transform:uppercase;font-size:14px}.gc-lookup .check-btn{padding:10px 18px;background:var(--purple);color:#fff;border-radius:8px;font-weight:700;font-size:13px}.gc-lookup .result{margin-top:10px;padding:10px;border-radius:8px}.gc-lookup .result.ok{background:var(--green-soft);color:var(--green-ink)}.gc-lookup .result.short{background:var(--red-soft);color:var(--red)}.gc-lookup .result .amt{font-size:20px;font-weight:800;font-feature-settings:"tnum"}.gc-lookup .result .meta{font-size:11px;opacity:.85;margin-top:4px}.receipt-paper{max-width:380px;margin:0 auto;background:#fff;padding:24px 24px 28px;border-radius:4px;box-shadow:0 0 0 1px var(--line-soft),0 1px 3px #281e140a,0 12px 28px #281e141a;font-family:Sarabun,monospace;font-size:12px;color:var(--ink);position:relative}.receipt-paper:after{content:"";position:absolute;bottom:-8px;left:0;right:0;height:12px;background:radial-gradient(circle at 8px 0px,transparent 6px,white 6px) repeat-x;background-size:16px 12px}.receipt-head{text-align:center;padding-bottom:14px;border-bottom:1.5px dashed var(--line)}.receipt-shop{font-size:16px;font-weight:800}.receipt-addr{font-size:11px;color:var(--ink-mute);margin-top:4px;line-height:1.4}.receipt-type{margin-top:8px;padding:4px 10px;background:var(--surface-2);border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.04em;display:inline-block}.receipt-type.full{background:var(--purple-soft);color:var(--purple-ink)}.receipt-meta{margin:12px 0 14px;display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;font-size:11px}.receipt-meta .label{color:var(--ink-mute)}.receipt-meta .value{font-weight:700;text-align:right}.receipt-items{padding:12px 0;border-top:1.5px dashed var(--line);border-bottom:1.5px dashed var(--line)}.receipt-line{display:flex;justify-content:space-between;gap:8px;padding:4px 0;font-size:12px}.receipt-line .iname{flex:1}.receipt-line .iname small{display:block;color:var(--ink-mute);font-size:10px;padding-left:8px}.receipt-line .iprice{font-weight:700;font-feature-settings:"tnum"}.receipt-totals{padding:12px 0}.receipt-totals .line{display:flex;justify-content:space-between;padding:3px 0;font-size:12px}.receipt-totals .grand{font-size:16px;font-weight:800;color:var(--accent);margin-top:8px;padding-top:8px;border-top:1.5px dashed var(--line)}.receipt-payment{font-size:11px;padding-top:8px;border-top:1px dashed var(--line)}.receipt-payment .line{display:flex;justify-content:space-between;padding:2px 0}.receipt-foot{text-align:center;padding-top:14px;margin-top:10px;border-top:1.5px dashed var(--line)}.receipt-foot strong{font-size:12px;font-weight:700}.receipt-foot small{display:block;font-size:10px;color:var(--ink-mute);line-height:1.5;margin-top:4px}.receipt-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:20px}.action-tile{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius);color:var(--ink-soft);transition:border-color .15s,background .15s,transform .12s}.action-tile:hover{border-color:var(--accent);transform:translateY(-1px)}.action-tile .icon{font-size:20px}.action-tile .label{font-size:12px;font-weight:700;color:var(--ink)}.action-tile .desc{font-size:10px;color:var(--ink-mute)}.success-banner{background:var(--green-soft);border:1px solid #86efac;border-radius:var(--radius);padding:14px;margin-bottom:14px;text-align:center;color:var(--green-ink)}.success-banner .big-tick{font-size:36px;line-height:1;margin-bottom:4px}.success-banner .label{font-size:14px;font-weight:800}.success-banner .meta{font-size:12px;margin-top:6px;opacity:.9}.new-order-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;margin-top:14px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:16px;font-weight:800;border-radius:var(--radius);box-shadow:0 8px 20px #c8553d59}.new-order-btn:hover{transform:translateY(-1px)}.kds-app{min-height:100vh;background:#0f1419;color:#e5e7eb;display:flex;flex-direction:column}.kds-topbar{height:64px;display:flex;align-items:center;gap:12px;padding:0 20px;background:#1c2330;border-bottom:1px solid #34404f}.kds-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:#fff}.kds-brand-mark{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}.kds-brand span{color:var(--accent-2)}.kds-crumb{color:#9ca3af;font-size:14px;padding-left:14px;margin-left:4px;border-left:1px solid #34404f}.kds-crumb strong{color:#fff;font-weight:700}.kds-stat{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#252e3d;border:1px solid #34404f;border-radius:999px;font-size:13px;color:#9ca3af;font-weight:600}.kds-stat strong{color:#fff;font-size:15px;font-weight:800}.kds-stat.urgent{background:#ef444426;border-color:var(--red);color:#fff}.kds-stat.urgent strong{color:var(--red)}.kds-back{padding:8px 14px;background:#252e3d;border:1px solid #34404f;border-radius:8px;color:#cbd5e1;font-size:13px;font-weight:600}.kds-back:hover{background:#2f3a4a;color:#fff}.kds-stage{padding:18px 20px;flex:1;overflow-y:auto}.kds-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.kds-empty{text-align:center;padding:80px 20px;font-size:18px;color:#94a3b8}.kds-order{background:#1c2330;border:2px solid #4b5563;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 2px 4px #0003,0 6px 16px #0000004d;transition:transform .15s}.kds-order:hover{transform:translateY(-2px)}.kds-order.warning{border-color:var(--amber);box-shadow:0 0 0 3px #fbbf2433}.kds-order.urgent{border-color:var(--red);box-shadow:0 0 0 3px #ef444440;animation:kds-pulse 1.6s ease-in-out infinite}.kds-order.ready{border-color:var(--teal);box-shadow:0 0 0 3px #22c55e33}@keyframes kds-pulse{0%,to{box-shadow:0 0 0 3px #ef444440}50%{box-shadow:0 0 0 6px #ef444466}}.kds-order-head{padding:12px 16px;display:flex;align-items:center;gap:10px;color:#fff}.kds-order.normal .kds-order-head{background:linear-gradient(135deg,#374151,#1f2937)}.kds-order.warning .kds-order-head{background:linear-gradient(135deg,var(--amber),#d97706)}.kds-order.urgent .kds-order-head{background:linear-gradient(135deg,var(--red),#dc2626)}.kds-order.ready .kds-order-head{background:linear-gradient(135deg,var(--teal),var(--teal-2))}.kds-order-num{font-size:18px;font-weight:800;letter-spacing:-.02em}.kds-meta-pill{padding:3px 10px;background:#fff3;border-radius:999px;font-size:11px;font-weight:700}.kds-timer{margin-left:auto;display:flex;align-items:center;gap:4px;font-size:17px;font-weight:800;font-feature-settings:"tnum"}.kds-order-info{padding:8px 16px;display:flex;flex-wrap:wrap;gap:6px;background:#252e3d;border-bottom:1px solid #34404f}.kds-info-chip{padding:3px 10px;background:#ffffff0f;border:1px solid #34404f;border-radius:999px;font-size:11px;color:#cbd5e1;font-weight:600}.kds-info-chip strong{color:#fff}.kds-items{padding:12px 16px;flex:1;display:flex;flex-direction:column;gap:8px}.kds-item-line{display:flex;gap:10px;padding:8px 10px;background:#252e3d;border-radius:8px}.kds-item-qty{flex:0 0 28px;height:28px;border-radius:6px;background:#c8553d33;color:var(--accent-2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800}.kds-item-body{flex:1;min-width:0}.kds-item-name{font-size:15px;font-weight:700;color:#fff;line-height:1.25}.kds-item-mods{font-size:12px;color:var(--amber);margin-top:3px;line-height:1.3}.kds-item-note{font-size:12px;color:#93c5fd;font-style:italic;margin-top:3px}.kds-order-foot{padding:10px 16px;background:#252e3d;border-top:1px solid #34404f;display:flex;gap:8px}.kds-action{flex:1;padding:12px;border-radius:8px;font-size:13px;font-weight:700;transition:transform .12s}.kds-action.bump{background:linear-gradient(135deg,var(--amber),#d97706);color:#fff;box-shadow:0 4px 12px #f59e0b4d}.kds-action.serve{background:linear-gradient(135deg,var(--teal),var(--teal-2));color:#fff;box-shadow:0 4px 12px #22c55e4d}.kds-action.recall{background:#1c2330;color:#cbd5e1;border:1px solid #34404f;flex:0 0 auto;padding:12px 16px}.kds-action:hover:not(:disabled){transform:translateY(-1px)}.kds-action:disabled{opacity:.5;cursor:not-allowed}.shift-summary-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:14px}.shift-line{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;padding:5px 0;color:var(--ink-soft)}.shift-line .vl{font-weight:700;font-feature-settings:"tnum";color:var(--ink)}.shift-line.bold{margin-top:6px;padding-top:8px;border-top:1.5px dashed var(--line);font-size:14px;font-weight:800;color:var(--ink)}.shift-line.bold .vl{font-size:18px;color:var(--accent)}.variance-banner{margin-top:10px;padding:12px 14px;border-radius:10px;display:flex;justify-content:space-between;align-items:center}.variance-banner.zero{background:var(--green-soft);color:var(--green-ink)}.variance-banner.over{background:var(--blue-soft);color:var(--blue-ink)}.variance-banner.short{background:var(--red-soft);color:var(--red)}.variance-banner .lbl{font-size:13px;font-weight:700}.variance-banner .vl{font-size:22px;font-weight:800;font-feature-settings:"tnum"}.close-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;margin-top:14px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:15px;font-weight:800;border-radius:var(--radius);box-shadow:0 6px 16px #c8553d59}.close-btn:disabled{opacity:.5}.zr-paper{max-width:420px;margin:0 auto;background:#fff;padding:24px;border-radius:4px;box-shadow:var(--shadow);font-family:Sarabun,monospace;font-size:12px}.zr-head{text-align:center;padding-bottom:12px;border-bottom:1.5px dashed var(--line)}.zr-title{font-size:16px;font-weight:800;letter-spacing:.06em}.zr-subtitle{font-size:11px;color:var(--ink-mute);margin-top:4px;line-height:1.5}.zr-section{padding:10px 0;border-bottom:1px dashed var(--line)}.zr-section:last-child{border-bottom:0}.zr-section-title{font-size:10px;font-weight:800;letter-spacing:.08em;color:var(--ink-mute);text-transform:uppercase;margin-bottom:6px}.zr-line{display:flex;justify-content:space-between;font-size:13px;padding:3px 0;color:var(--ink-soft)}.zr-line.bold{font-weight:800;color:var(--ink);margin-top:4px;padding-top:6px;border-top:1px dashed var(--line)}.zr-line.green .vl{color:var(--green)}.zr-line.red .vl{color:var(--red)}
