:root{--ink:#17212b;--muted:#667085;--line:#e6eaf0;--canvas:#f5f7fa;--surface:#fff;--brand:#0f766e;--brand-dark:#0a5b55;--brand-soft:#e5f7f4;--danger:#c2413b;--danger-soft:#fff0ef;--warning:#a25d00;--shadow:0 10px 30px rgba(21,36,50,.08);font-family:Inter,"Noto Sans Thai",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink)}
*{box-sizing:border-box}html,body{margin:0;min-height:100%;background:var(--canvas)}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}a{color:var(--brand);font-weight:700;text-decoration:none}.toast{position:fixed;z-index:1000;top:max(18px,env(safe-area-inset-top));left:50%;transform:translateX(-50%);background:#17212b;color:white;padding:12px 18px;border-radius:12px;box-shadow:var(--shadow);max-width:92vw}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top right,#b5e9e3,transparent 35%),linear-gradient(140deg,#f8fbfb,#e9f7f5)}.auth-card{width:min(410px,100%);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);padding:34px;border-radius:24px;text-align:center}.auth-card h1{margin:12px 0 2px;font-size:29px;letter-spacing:-1px}.auth-card p{color:var(--muted);margin:0 0 28px}.auth-card small{display:block;color:var(--muted);margin-top:18px;line-height:1.6}.brand-mark{margin:auto;width:68px;height:68px;display:grid;place-items:center;background:var(--brand);color:#fff;font-weight:900;font-size:36px;border-radius:20px;box-shadow:0 10px 24px #0f766e44}.brand-mark.small{width:40px;height:40px;border-radius:13px;font-size:22px;margin:0}.auth-card label,.field{display:grid;text-align:left;gap:7px;color:#344054;font-size:14px;font-weight:700;margin:14px 0}.auth-card input,.field input,.field select,.field textarea,.form-grid input,.form-grid select,.inline-form input{border:1px solid #d5dbe4;border-radius:10px;padding:12px;background:white;color:var(--ink);width:100%;outline:none}.field textarea{min-height:70px;resize:vertical}.auth-card input:focus,.field input:focus,.field select:focus,.field textarea:focus,.form-grid input:focus,.form-grid select:focus,.inline-form input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0f766e19}.btn{border:1px solid var(--line);background:#fff;color:#273444;border-radius:10px;padding:10px 14px;font-weight:800;white-space:nowrap}.btn:hover{filter:brightness(.98)}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:var(--brand-dark)}.btn.danger-outline{color:var(--danger);border-color:#f2c4c0;background:#fff}.btn.wide{width:100%;padding:13px}.text-btn{border:0;background:transparent;color:var(--brand);font-weight:800;padding:8px}.icon-btn{border:1px solid var(--line);background:#fff;border-radius:10px;width:38px;height:38px;font-size:20px;line-height:1}.app-shell{display:grid;grid-template-columns:242px 1fr;min-height:100vh}.sidebar{background:#102d2b;color:#eaf8f6;display:flex;flex-direction:column;padding:18px 13px;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:7px 9px 24px}.sidebar-brand strong{display:block;font-size:17px;letter-spacing:.1px}.sidebar-brand small,.sidebar-bottom small{display:block;color:#aac8c4;font-size:12px;margin-top:3px}.sidebar nav{display:grid;gap:5px}.nav-btn{position:relative;background:transparent;border:0;border-radius:10px;color:#d2e4e1;text-align:left;padding:12px 13px;font-size:14px;display:flex;gap:10px;align-items:center}.nav-btn:hover,.nav-btn.active{background:#23524d;color:white}.nav-btn hr{border:0;border-top:1px solid #35615c;margin:9px 4px}.badge{margin-left:auto;background:#f97362;color:#fff;border-radius:99px;padding:2px 7px;font-size:11px}.sidebar-bottom{margin-top:auto;border-top:1px solid #35615c;padding:16px 9px 5px}.sidebar-bottom strong{font-size:14px;display:block}.sidebar-bottom .text-btn{color:#b9d4d0;padding-left:0;margin-top:7px}.main-content{min-width:0}.topbar{height:72px;padding:0 28px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:15px;position:sticky;top:0;z-index:20}.topbar h2{font-size:20px;margin:0;letter-spacing:-.4px}.top-actions{margin-left:auto}.topbar #mobile-menu{display:none}.view-root{padding:26px;max-width:1600px;margin:auto}.loading,.empty,.error-card{padding:28px;border:1px dashed #cbd5df;border-radius:14px;text-align:center;color:var(--muted);background:#fff}.error-card{color:var(--danger);border-color:#f0bbb5;background:var(--danger-soft)}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.summary-card{padding:20px;background:#fff;border:1px solid var(--line);box-shadow:0 4px 12px rgba(18,34,50,.03);border-radius:16px}.summary-card span,.summary-card small{display:block;color:var(--muted);font-size:13px}.summary-card strong{display:block;font-size:29px;letter-spacing:-1px;margin:9px 0}.summary-card.alert strong{color:var(--danger)}.panel{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 4px 16px rgba(20,38,55,.03);padding:18px}.summary-grid+.panel{margin-top:18px}.panel-head{display:flex;align-items:flex-start;gap:14px;justify-content:space-between;margin-bottom:16px}.panel-head h3{margin:0;font-size:17px}.panel-head p,.panel-head small{margin:5px 0 0;color:var(--muted);font-size:13px}.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.steps div{background:var(--brand-soft);border-radius:12px;padding:14px;color:#155d57;font-weight:700}.steps b{display:inline-grid;place-items:center;background:var(--brand);color:#fff;border-radius:99px;width:24px;height:24px;margin-right:5px}.pos-layout{display:grid;grid-template-columns:minmax(260px,.7fr) minmax(370px,1.25fr) minmax(290px,.75fr);gap:16px;align-items:start}.table-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.table-card{border:1px solid var(--line);background:#fff;border-radius:12px;text-align:left;padding:12px;min-height:102px;display:grid;gap:5px;transition:.15s}.table-card:hover,.table-card.selected{border-color:var(--brand);background:#f4fffd;box-shadow:0 0 0 2px #0f766e17}.table-card.occupied{border-color:#f1bf6f;background:#fffbf2}.table-card strong{font-size:16px}.table-card small{color:var(--muted);font-size:12px}.table-card em{font-style:normal;font-weight:800;color:var(--brand);font-size:12px}.table-card.occupied em{color:#a66300}.table-card b{font-size:11px;color:#a66300}.category-tabs{display:flex;overflow:auto;gap:8px;margin-bottom:12px;padding-bottom:4px}.chip{border:1px solid var(--line);border-radius:20px;background:#fff;padding:7px 12px;white-space:nowrap;color:#475467;font-weight:700;font-size:13px}.chip.active{background:var(--brand);border-color:var(--brand);color:white}.pos-items{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;max-height:63vh;overflow:auto;padding-right:3px}.pos-item{border:1px solid var(--line);border-radius:11px;background:#fff;padding:14px;text-align:left;min-height:72px;display:flex;flex-direction:column;justify-content:space-between;gap:7px}.pos-item:hover{border-color:var(--brand);background:#f4fffd}.pos-item span{font-weight:800}.pos-item b{font-size:13px;color:var(--brand)}.cart-panel-pos{position:sticky;top:88px}.cart-items{display:grid;gap:2px;max-height:390px;overflow:auto}.cart-line{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;border-bottom:1px solid #eef1f4;padding:11px 0}.cart-line strong,.cart-line small{display:block}.cart-line strong{font-size:14px}.cart-line small{font-size:12px;color:var(--muted);margin-top:3px}.cart-line>b{font-size:13px}.qty-control{display:flex;align-items:center;gap:7px}.qty-control button{background:#f0f5f5;border:0;color:#205c57;border-radius:7px;width:26px;height:26px;font-weight:900;font-size:17px}.qty-control span{min-width:14px;text-align:center;font-weight:800}.cart-total{display:flex;align-items:baseline;justify-content:space-between;padding:17px 0 10px;margin-top:5px;border-top:2px solid var(--ink);font-weight:700}.cart-total strong{font-size:22px}.muted{color:var(--muted);font-size:12px;line-height:1.5;display:block}.payment-list{display:grid;gap:12px}.payment-card{border:1px solid var(--line);border-radius:14px;padding:15px;display:grid;grid-template-columns:1fr 120px auto;gap:16px;align-items:center}.payment-card.needs-review{border-color:#f4bd7e;background:#fffdf8}.payment-card h3{margin:9px 0 4px;font-size:16px}.payment-card p{margin:0;color:var(--muted);font-size:13px}.payment-proof{text-align:center;font-size:11px;color:var(--muted)}.payment-proof img{max-height:80px;max-width:105px;border:1px solid var(--line);border-radius:8px;display:block;margin:auto}.payment-actions{display:grid;gap:7px}.status-pill{display:inline-block;border-radius:99px;padding:4px 9px;font-size:11px;font-weight:900;background:#f0f2f5;color:#506070}.status-pill.SLIP_UPLOADED{background:#fff0d5;color:#965b00}.status-pill.PAID{background:#e3f8ef;color:#0f7a4d}.status-pill.REJECTED{background:#ffe9e7;color:#b83a32}.kitchen-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;color:var(--muted);font-size:13px}.ticket-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.ticket-card{background:#fff;border:1px solid var(--line);border-top:5px solid #8aa0ae;border-radius:15px;padding:16px;min-height:205px;display:flex;flex-direction:column}.ticket-card.NEW{border-top-color:#d98400}.ticket-card.PREPARING{border-top-color:#1572c8}.ticket-card.READY{border-top-color:#0e9c66}.ticket-card header{display:flex;justify-content:space-between;color:var(--muted);font-size:12px}.ticket-card header strong{color:var(--ink)}.ticket-card h3{font-size:18px;margin:13px 0 8px}.ticket-card p{white-space:pre-wrap;line-height:1.7;margin:0;font-size:15px;font-weight:700}.ticket-card small{color:var(--muted);margin-top:10px}.ticket-card footer{margin-top:auto;padding-top:16px}.admin-grid{display:grid;grid-template-columns:minmax(310px,.75fr) minmax(420px,1.25fr);gap:16px;align-items:start}.admin-grid h3{margin:0 0 13px;font-size:17px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.form-grid label{display:grid;gap:6px;color:#475467;font-weight:700;font-size:13px}.form-grid .full{grid-column:1/-1}.form-grid .check{display:flex;align-items:center;gap:8px}.form-grid .check input{width:auto}.form-grid button{align-self:end}.inline-form{display:flex;gap:8px}.panel hr{border:0;border-top:1px solid var(--line);margin:20px 0}.data-list{display:grid}.data-row{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid #eef1f4}.data-row>div{flex:1}.data-row strong,.data-row small{display:block}.data-row small{color:var(--muted);font-size:12px;margin-top:4px}.data-row>b{font-size:14px}.state{border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800}.state.on{color:#08784e;background:#e7f8ee}.state.off{color:#8c3242;background:#ffe9ed}.qr-table-list{display:grid;gap:10px}.qr-table-card{display:grid;grid-template-columns:100px 1fr auto;gap:13px;align-items:center;border-bottom:1px solid #eef1f4;padding:10px 0}.tiny-qr{width:92px;height:92px;background:#fff;padding:2px;border:1px solid #eef1f4}.qr-table-card h3{margin:0;font-size:16px}.qr-table-card p{margin:5px 0;color:var(--muted);font-size:13px}.qr-actions{display:grid;gap:6px;justify-items:end}.customer-body{background:#f6f8fb;min-height:100vh;padding-bottom:80px}.customer-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:calc(13px + env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) 13px max(16px,env(safe-area-inset-left));background:#0f766e;color:white;box-shadow:0 3px 12px #004c4450}.customer-header strong,.customer-header small{display:block}.customer-header small{opacity:.78;font-size:12px;margin-top:2px}.cart-float{border:1px solid #ffffff66;background:#ffffff16;color:#fff;padding:9px 12px;border-radius:10px;font-weight:800}.cart-float b{display:inline-grid;place-items:center;min-width:19px;height:19px;background:white;color:var(--brand);border-radius:99px;font-size:11px;margin-left:3px}.customer-main{max-width:920px;margin:auto;padding:20px 16px}.notice-card{padding:22px;background:#fff9e9;border:1px solid #f1c677;border-radius:16px;text-align:center}.notice-card h2{margin:0 0 8px}.notice-card p{margin:0;color:#79530a}.menu-section h2{font-size:19px;margin:20px 0 11px}.customer-menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.customer-menu-card{display:grid;grid-template-columns:92px 1fr;gap:12px;min-height:120px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;box-shadow:0 3px 10px rgba(20,35,50,.03)}.customer-menu-card img{width:92px;height:92px;object-fit:cover;border-radius:10px;background:#eef2f5}.customer-menu-card h3{margin:0;font-size:16px}.customer-menu-card p{color:var(--muted);font-size:12px;line-height:1.4;margin:5px 0}.price-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px}.price-row strong{color:var(--brand);font-size:14px}.drawer[hidden],.modal[hidden]{display:none}.drawer{position:fixed;inset:0;z-index:50}.drawer-backdrop{position:absolute;inset:0;background:#12202a80}.drawer-content{position:absolute;right:0;top:0;height:100%;width:min(440px,100%);background:#fff;padding:20px;box-shadow:-10px 0 28px #11223322;display:flex;flex-direction:column}.drawer-content>header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:13px}.drawer-content h2{margin:0;font-size:20px}.drawer-content .cart-items{flex:1;max-height:none;margin:14px 0}.modal{position:fixed;inset:0;z-index:70;background:#11212b82;display:grid;place-items:center;padding:16px}.modal-box{position:relative;background:#fff;border-radius:18px;width:min(470px,100%);max-height:92vh;overflow:auto;box-shadow:var(--shadow)}.modal-close{position:absolute;right:10px;top:10px;border:0;background:#edf2f5;width:32px;height:32px;border-radius:50%;font-size:22px}.payment-box{padding:26px}.payment-head{text-align:center}.payment-head span{font-size:12px;color:var(--muted);font-weight:800}.payment-head h2{margin:6px 0 10px;font-size:21px}.payment-head p{margin:0;color:var(--muted);font-size:13px}.payment-total{font-size:30px;color:var(--brand);display:block;margin:4px 0 13px}.qr-box{width:232px;height:232px;margin:10px auto;padding:6px;border:1px solid var(--line);border-radius:12px;display:grid;place-items:center}.payment-box .muted{text-align:center;margin-bottom:10px}.file-field{display:block;border:1px dashed #9ba9b8;border-radius:10px;padding:11px;font-weight:700;color:#465466}.file-field input{display:block;margin-top:7px;width:100%}.payment-box .text-btn{display:block;margin:6px auto}.payment-box #order-status{text-align:center}.customer-body .status-pill{margin:4px}.customer-body .status-pill.PENDING{background:#eef2f5}.customer-body .status-pill.EXPIRED{background:#f2f4f7;color:#667085}
@media (max-width:1200px){.pos-layout{grid-template-columns:minmax(250px,.8fr) minmax(400px,1.2fr)}.cart-panel-pos{grid-column:1/-1;position:static}.cart-panel-pos .cart-items{max-height:240px}.summary-grid{grid-template-columns:repeat(2,1fr)}.ticket-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:820px){.app-shell{display:block}.sidebar{position:fixed;z-index:90;left:0;top:0;width:260px;transform:translateX(-100%);transition:.2s;height:100dvh;box-shadow:20px 0 30px #0003}.app-shell.mobile-open .sidebar{transform:translateX(0)}.topbar{height:62px;padding:0 15px}.topbar #mobile-menu{display:inline-grid;place-items:center}.view-root{padding:15px}.pos-layout,.admin-grid{grid-template-columns:1fr}.pos-menu-panel{order:2}.table-panel{order:1}.cart-panel-pos{order:3}.table-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.ticket-grid{grid-template-columns:repeat(2,1fr)}.steps{grid-template-columns:repeat(2,1fr)}.payment-card{grid-template-columns:1fr auto}.payment-actions{grid-column:1/-1;grid-template-columns:1fr 1fr}.qr-table-card{grid-template-columns:92px 1fr}.qr-actions{grid-column:1/-1;grid-template-columns:1fr 1fr;display:grid}.qr-actions .btn,.qr-actions .text-btn{width:100%;text-align:center;border:1px solid var(--line);border-radius:10px}.customer-menu-grid{grid-template-columns:1fr}}
@media (max-width:520px){.summary-grid{grid-template-columns:1fr 1fr;gap:9px}.summary-card{padding:14px}.summary-card strong{font-size:22px}.table-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pos-items{grid-template-columns:1fr}.ticket-grid{grid-template-columns:1fr}.payment-card{grid-template-columns:1fr}.payment-proof{text-align:left}.payment-proof img{margin:0}.payment-actions{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.customer-main{padding:13px}.customer-menu-card{grid-template-columns:72px 1fr}.customer-menu-card img{width:72px;height:72px}.customer-menu-card{padding:10px;min-height:102px}.customer-menu-card p{display:none}.price-row{margin-top:8px}.drawer-content{padding:16px}.topbar h2{font-size:18px}.sidebar{width:82vw}.steps{grid-template-columns:1fr}.inline-form{display:grid}.app-shell{min-height:100dvh}}
@media print{.sidebar,.topbar,.btn,.text-btn,.icon-btn{display:none!important}.view-root{padding:0}.panel{box-shadow:none;border:0}.app-shell{display:block}}
/* v1.1.3: a persistent native-login error, visible after redirect */
.login-error{margin:0 0 14px;padding:11px 12px;border:1px solid #f2b8b5;border-radius:10px;background:#fff0ef;color:#a32621;font-weight:700;font-size:13px;line-height:1.45;text-align:left}
/* v1.1.5 Developer console and optional slip-bot controls */
.developer-nav{padding-top:8px}.developer-page{display:grid;gap:16px}.developer-hero{display:flex;justify-content:space-between;gap:18px;align-items:center;background:linear-gradient(135deg,#ecfdf8,#eff6ff)}.developer-hero h3{font-size:24px;margin:5px 0}.developer-hero p{margin:0;color:var(--muted);line-height:1.5}.eyebrow{font-size:11px;letter-spacing:.12em;color:#0f766e;font-weight:900}.system-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.developer-form{max-width:860px}.switch-row{display:flex!important;align-items:center;justify-content:space-between;gap:18px;padding:13px 14px;border:1px solid var(--line);border-radius:12px;background:#fbfefd}.switch-row span{display:grid;gap:4px}.switch-row small{font-weight:500;color:var(--muted);line-height:1.45}.switch-row input{width:46px!important;height:25px;accent-color:var(--brand);flex:0 0 auto}.bot-contract{padding:14px;border:1px dashed #94bdb7;border-radius:12px;background:#f6fffd;display:grid;gap:7px}.bot-contract code{display:block;white-space:normal;overflow-wrap:anywhere;padding:8px 10px;background:#112c2a;color:#e6fffb;border-radius:8px;font-size:12px}.bot-contract small{color:var(--muted);line-height:1.5}.developer-note p{margin:16px 0 0}.empty-state{text-align:center;padding:42px}.empty-state h3{margin:0 0 8px}.empty-state p{color:var(--muted);margin:0}@media(max-width:680px){.developer-hero{display:grid}.system-chips{justify-content:flex-start}.switch-row{align-items:flex-start}.switch-row input{margin-top:4px}}
