:root{--rose: #f97316;--rose-dark: #ea580c;--rose-soft: #fff3ea;--primary: #18181b;--primary-dark: #0f1115;--ink: #18181b;--muted: #5c5f66;--line: #e5e5e5;--bg: #ffffff;--ok: #15803d;--warn: #b45309;--bad: #b42318;--card: #ffffff;--accent: var(--rose);--surface: #ffffff;--surface-2: #fafafa;--on-primary: #ffffff;--on-accent: #ffffff;--on-danger: #ffffff;--border: var(--line);--danger: var(--bad);--success: var(--ok);--warning: var(--warn);--ring: #f97316;--shadow-sm: 0 1px 2px rgba(24,24,27,.06), 0 1px 3px rgba(24,24,27,.06);--shadow-md: 0 2px 6px rgba(24,24,27,.08), 0 6px 16px rgba(24,24,27,.1);--shadow-lg: 0 4px 12px rgba(24,24,27,.1), 0 16px 36px rgba(24,24,27,.14);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--font-display: ui-rounded, "Segoe UI", system-ui, -apple-system, "Helvetica Neue", sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--bg);color:var(--ink);font-size:16px;-webkit-font-smoothing:antialiased}h1,h2,.name,.section-title{font-family:var(--font-display)}.tnum,.price,.stat .v,.total-bar .v,.receipt .grand,.data-table td.num,.cell-input{font-variant-numeric:tabular-nums}.icon{display:inline-block;vertical-align:middle;flex:none}.ico-inline{vertical-align:-.18em}.ico-ok{color:var(--success)}.spin{animation:icon-spin 1s linear infinite}@keyframes icon-spin{to{transform:rotate(360deg)}}.app{max-width:480px;margin:0 auto;min-height:100%;background:var(--bg);display:flex;flex-direction:column;position:relative}.topbar{position:sticky;top:0;z-index:20;background:var(--primary);color:#fff;padding:14px 18px calc(14px + env(safe-area-inset-top));display:flex;align-items:center;gap:10px}.topbar .logo{font-size:22px}.brand-logo{font-family:var(--font-display);font-weight:800;letter-spacing:-.04em;line-height:1;color:currentColor}.brand-logo .brand-logo-accent{color:var(--rose)}.topbar h1{font-size:18px;margin:0;font-weight:700;letter-spacing:.2px}.topbar .sub{font-size:12px;opacity:.85;margin-top:1px}.topbar .back{background:#fff3;border:none;color:#fff;width:34px;height:34px;border-radius:var(--radius-sm);font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.topbar .back:hover{background:#ffffff4d}.content{flex:1;padding:16px 16px 96px}.section-title{font-size:13px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin:var(--space-5) var(--space-1) var(--space-2);font-weight:700}.card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.card+.card{margin-top:var(--space-3)}.row{display:flex;align-items:center;justify-content:space-between;gap:10px}.stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.stat{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.stat .v{font-family:var(--font-display);font-size:26px;font-weight:800;color:var(--ink)}.stat .l{font-size:12px;color:var(--muted);margin-top:2px}.stat.primary{background:var(--primary);border-color:var(--primary)}.stat.primary .v,.stat.primary .l{color:var(--on-primary)}.quick{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-top:var(--space-3)}.quick button{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:var(--surface);font-size:15px;font-weight:600;color:var(--ink);transition:box-shadow .2s ease,transform .15s ease}.quick button:hover{box-shadow:var(--shadow-md)}.quick button:active{transform:translateY(1px)}.quick button .ico{color:var(--accent);display:inline-flex}.li{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.li:hover{box-shadow:var(--shadow-md)}.li+.li{margin-top:var(--space-2)}.li .avatar{width:42px;height:42px;border-radius:50%;flex:none;background:var(--rose-soft);color:var(--rose-dark);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:16px}.li .grow{flex:1;min-width:0}.li .name{font-weight:600}.li .meta{font-size:13px;color:var(--muted)}.li .meta .icon{color:var(--muted)}.li .price{font-weight:700;color:var(--ink)}.chev{color:var(--muted);display:inline-flex;align-items:center}.badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px}.badge.open{background:#f3f4f6;color:#3f3f46}.badge.in_progress{background:#f5ecdc;color:var(--warn)}.badge.done{background:#e6f0ea;color:var(--ok)}.badge.closed{background:#f3f4f6;color:var(--muted)}.badge.success{background:#e6f0ea;color:var(--ok)}.badge.failed{background:#f4e6e8;color:var(--bad)}.badge.pending{background:#f5ecdc;color:var(--warn)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:15px;border-radius:var(--radius-md);border:none;font-size:16px;font-weight:700;background:var(--accent);color:var(--on-primary);box-shadow:var(--shadow-sm);transition:filter .15s ease,box-shadow .2s ease,transform .1s ease}.btn:hover{filter:brightness(1.06);box-shadow:var(--shadow-md)}.btn:active{transform:translateY(1px);box-shadow:var(--shadow-sm)}.btn .icon{flex:none}.btn.secondary{background:var(--rose-soft);color:var(--rose-dark);box-shadow:none}.btn.secondary:hover{box-shadow:var(--shadow-sm);filter:none;background:#ffe9d6}.btn.ghost{background:var(--surface);color:var(--ink);border:1px solid var(--border);box-shadow:none}.btn.ghost:hover{background:var(--surface-2);filter:none;box-shadow:var(--shadow-sm)}.btn.dark{background:var(--ink);color:var(--on-primary)}.btn:disabled{opacity:.45;box-shadow:none}.btn:disabled:hover{filter:none;box-shadow:none}.btn-row{display:flex;gap:var(--space-3);margin-top:var(--space-3)}label{font-size:13px;color:var(--muted);font-weight:600;display:block;margin:var(--space-3) 2px var(--space-2)}input,select{width:100%;padding:13px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:16px;background:#fff;color:var(--ink);transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--rose-soft)}button,a,input,select,textarea,.li[onclick],.pay,.chip,.pinkey,.tabbar button{outline:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.li:focus-visible,.pay:focus-visible,.chip:focus-visible,.pinkey:focus-visible,.tabbar button:focus-visible,.quick button:focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:var(--radius-sm)}input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:0}.svc{display:flex;align-items:center;justify-content:space-between;padding:13px 14px;border:1px solid var(--line);border-radius:12px;background:#fff}.svc+.svc{margin-top:8px}.svc .cat{font-size:12px;color:var(--rose-dark);background:var(--rose-soft);padding:2px 8px;border-radius:6px;margin-left:6px}.svc button{background:var(--rose-soft);color:var(--rose-dark);border:none;width:36px;height:36px;border-radius:var(--radius-sm);font-size:20px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease}.svc button:hover:not(:disabled){background:#ffe9d6}.total-bar{display:flex;justify-content:space-between;align-items:center;padding:14px 4px;border-top:2px dashed var(--line);margin-top:8px}.total-bar .t{font-size:14px;color:var(--muted)}.total-bar .v{font-family:var(--font-display);font-size:26px;font-weight:800;color:var(--rose-dark)}.pay-grid{display:grid;gap:var(--space-3)}.pay{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);font-weight:600;box-shadow:var(--shadow-sm);cursor:pointer;transition:border-color .15s ease,box-shadow .2s ease}.pay:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.pay .ico{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--rose-soft);color:var(--rose-dark);display:flex;align-items:center;justify-content:center;font-size:20px}.pay .desc{font-size:12px;color:var(--muted);font-weight:500}.receipt{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--border);box-shadow:var(--shadow-md)}.receipt h2{text-align:center;margin:0 0 2px}.receipt .shop{text-align:center;color:var(--muted);font-size:13px;margin-bottom:16px}.receipt .rl{display:flex;justify-content:space-between;padding:7px 0;font-size:15px}.receipt .div{border-top:1px dashed var(--line);margin:10px 0}.receipt .grand{font-size:22px;font-weight:800}.receipt .thanks{text-align:center;color:var(--rose-dark);margin-top:18px;font-weight:600}.line-chat{background:#9bb8c0;border-radius:16px;padding:14px}.line-bubble{background:#fff;border-radius:12px;padding:12px 14px;font-size:14px;max-width:85%;box-shadow:0 1px 2px #0000001a}.line-bubble.me{background:#bcd9a3;margin-left:auto}.line-head{color:#fff;font-size:13px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:30;max-width:480px;margin:0 auto;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -2px 12px #2b23300d;display:flex;padding:var(--space-2) var(--space-2) calc(var(--space-2) + env(safe-area-inset-bottom))}.tabbar button{flex:1;background:none;border:none;padding:var(--space-2) var(--space-1);display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;color:var(--muted);font-weight:600;transition:color .15s ease}.tabbar button.active{color:var(--rose-dark)}.tabbar .tico{display:inline-flex;align-items:center;justify-content:center;line-height:0}.tabbar .tico .icon{width:22px;height:22px}.fab{position:fixed;bottom:84px;right:50%;transform:translate(220px);background:var(--primary);color:var(--on-primary);border:none;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:25;transition:filter .15s ease,transform .1s ease,box-shadow .2s ease}.fab:hover{filter:brightness(1.12);box-shadow:var(--shadow-lg)}.fab:active{transform:translate(220px) translateY(1px)}@media (max-width: 480px){.fab{right:18px;transform:none}.fab:active{transform:translateY(1px)}}.userchip{display:flex;align-items:center;gap:8px}.userchip .who{text-align:right;line-height:1.15}.userchip .uname{font-size:13px;font-weight:700;color:#fff}.userchip .urole{font-size:11px;opacity:.85}.userchip .logout{background:#fff3;border:none;color:#fff;width:34px;height:34px;border-radius:var(--radius-sm);font-size:17px;flex:none;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.userchip .logout:hover{background:#ffffff52}.rolebadge{vertical-align:middle}.badge.role-owner{background:var(--rose-soft);color:var(--rose-dark)}.badge.role-staff{background:#f3f4f6;color:#3f3f46}.login{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--bg)}.login-head{background:var(--primary);color:#fff;text-align:center;padding:calc(34px + env(safe-area-inset-top)) 18px 30px}.login-head .login-logo{font-size:44px}.login-head h1{margin:8px 0 2px;font-size:22px;font-weight:800}.login-head .sub{font-size:13px;opacity:.9}.login-body{flex:1;padding:16px 16px calc(24px + env(safe-area-inset-bottom))}.pin-dots{display:flex;justify-content:center;gap:14px;margin:18px 0 4px}.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--rose);background:transparent}.pin-dot.filled{background:var(--rose)}.pin-err{text-align:center;color:var(--bad);font-weight:700;font-size:14px;margin:8px 0}.pinpad{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-top:18px}.pinkey{height:68px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);color:var(--ink);font-size:26px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:transform .1s ease,box-shadow .15s ease,filter .15s ease}.pinkey:hover:not(:disabled){box-shadow:var(--shadow-md)}.pinkey:active{transform:translateY(1px);box-shadow:var(--shadow-sm)}.pinkey.ok{background:var(--accent);color:var(--on-primary);border:none}.pinkey.ok:hover:not(:disabled){filter:brightness(1.06)}.pinkey.ghost{background:var(--bg);color:var(--muted);box-shadow:none}.pinkey:disabled{opacity:.45;box-shadow:none}.audit-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.chip{background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;transition:background .15s ease,color .15s ease,border-color .15s ease}.chip:hover{border-color:var(--accent);color:var(--rose-dark)}.chip.active{background:var(--accent);color:var(--on-primary);border-color:var(--accent)}.chip.active:hover{color:var(--on-primary)}.timeline{position:relative;padding-left:6px}.tl-row{display:flex;gap:12px;padding:4px 0}.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--rose);flex:none;margin-top:6px;box-shadow:0 0 0 3px var(--rose-soft)}.tl-body{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow-sm)}.note-warn{margin-top:var(--space-3);padding:var(--space-3);border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--warning);background:#f5ecdc;border:1px solid #e7d6b8;display:flex;align-items:center;gap:var(--space-2)}.note-warn .icon{flex:none}.note-ok{padding:var(--space-3);border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--success);background:#e6f0ea;border:1px solid #c6e0d2}.note-ok b{color:var(--rose-dark);font-size:18px;letter-spacing:1px}.shop-code-banner{margin-bottom:14px}.empty{text-align:center;color:var(--muted);padding:var(--space-6) var(--space-5)}.empty .big{font-size:40px;margin-bottom:var(--space-2);display:flex;align-items:center;justify-content:center;color:var(--muted)}.empty .big .icon{opacity:.7}.toast{position:fixed;bottom:150px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:12px 18px;border-radius:var(--radius-sm);font-size:14px;z-index:50;max-width:90%;box-shadow:var(--shadow-lg)}.spacer{height:8px}.muted{color:var(--muted)}.center{text-align:center}.manage-hint{margin-bottom:12px}.data-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);font-size:15px}.data-table thead th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:700;padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--line)}.data-table tbody td{padding:13px 16px;border-bottom:1px solid var(--line);color:var(--ink);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--surface-2)}.data-table td.strong{font-weight:600}.data-table th.num,.data-table td.num{text-align:right}.data-table th.act,.data-table td.act{text-align:right;white-space:nowrap}.data-table .cell-input{width:110px;padding:8px 10px;text-align:right;display:inline-block}.app.lean .btn{padding:17px;font-size:17px;min-height:52px}.app.lean .svc{padding:16px}.app.lean .svc button{width:48px;height:48px;font-size:22px}.app.lean .pay{padding:18px;min-height:64px}.app.lean .quick button{padding:20px;font-size:16px;min-height:88px}.app.lean .li{padding:16px}.app.lean .tabbar button{padding:8px 6px;font-size:12px;min-height:56px}.app.lean .tabbar .tico{font-size:24px}.app.lean .tabbar .tico .icon{width:24px;height:24px}.app.lean .svc button .icon{width:22px;height:22px}.app.lean input,.app.lean select{padding:15px 14px;font-size:17px;min-height:52px}.app.lean .total-bar .v{font-size:28px}@media (min-width: 768px){.app.wide{max-width:none;width:100%}.app.wide .content{padding:24px 28px 96px}.app.wide .stats.wide-grid{grid-template-columns:repeat(4,1fr);gap:14px}.app.wide .stat .v{font-size:28px}.app.wide .quick{grid-template-columns:repeat(4,minmax(0,1fr));max-width:none}.app.wide .data-table{width:100%}.app.wide .tabbar{max-width:none}}@media (min-width: 1280px){.app.wide .content{padding:28px 40px 96px}.app.wide .stats.wide-grid{gap:18px}}@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}
