:root{--background:#f5f7f4;--surface:#fbfcfa;--surface-strong:#fff;--text:#181818;--muted:#626a61;--line:#dce3dc;--accent:#1b1b1b;--accent-soft:#e8f1ea;--success:#23835c;--danger:#d73650;--warning:#8a5a00;--shadow:0 20px 60px #19241c24}*{box-sizing:border-box}html,body{background:var(--background);min-height:100%;color:var(--text);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}button:disabled{cursor:not-allowed}.app-shell{background:var(--background);min-height:100dvh}.phone-frame{background:var(--surface);width:min(100%,430px);min-height:100dvh;box-shadow:var(--shadow);margin:0 auto;position:relative}.topbar{z-index:10;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fbfcfaf5;border-bottom:1px solid #dce3dcd1;padding:16px 16px 12px;position:sticky;top:0}.restaurant-row{align-items:center;gap:12px;display:flex}.brand-mark{background:var(--accent);color:#fff;border-radius:8px;place-items:center;width:44px;height:44px;font-weight:800;display:grid}.restaurant-name{letter-spacing:0;max-width:300px;margin:0;font-size:18px;font-weight:800;line-height:1.18}.table-name{color:var(--muted);margin:3px 0 0;font-size:13px}.search-row{gap:8px;margin-top:14px;display:flex}.search-input{border:1px solid var(--line);width:100%;height:42px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 12px}.search-input:focus,.checkout-form input:focus,.checkout-form textarea:focus{border-color:var(--success);box-shadow:0 0 0 3px #23835c1f}.category-tabs{scrollbar-width:none;gap:8px;padding:12px 16px 4px;display:flex;overflow-x:auto}.category-tabs::-webkit-scrollbar{display:none}.chip{border:1px solid var(--line);height:36px;color:var(--muted);cursor:pointer;background:#fff;border-radius:999px;flex:none;padding:0 14px}.chip-active{border-color:var(--accent);background:var(--accent);color:#fff}.content{padding:8px 16px 140px}.section-title{justify-content:space-between;align-items:baseline;margin:12px 0;display:flex}.section-title h2{margin:0;font-size:18px}.section-title span{color:var(--muted);font-size:12px}.menu-list{gap:10px;display:grid}.menu-card{border:1px solid var(--line);background:var(--surface-strong);border-radius:8px;grid-template-columns:74px minmax(0,1fr) auto;align-items:center;gap:12px;min-height:98px;padding:10px;display:grid}.menu-card-disabled{opacity:.58}.item-art{color:#26352b;background:linear-gradient(135deg,#23835c2e,#1b1b1b0f),#eef4ef;border-radius:8px;place-items:center;width:74px;height:74px;font-weight:800;display:grid}.item-name{margin:0;font-size:15px;font-weight:800}.item-desc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:4px 0 8px;font-size:12px;display:-webkit-box;overflow:hidden}.item-price{font-size:14px;font-weight:800}.item-unavailable{height:24px;color:var(--danger);background:#d736501a;border-radius:999px;align-items:center;margin-top:8px;padding:0 8px;font-size:11px;font-weight:800;display:inline-flex}.add-button,.qty-button,.primary-button,.secondary-button,.ghost-button{cursor:pointer;border:0;border-radius:8px}.add-button{background:var(--accent);color:#fff;width:38px;height:38px;font-size:22px;line-height:1}.add-button:disabled{color:#7d887d;background:#ccd4cc}.cart-bar{z-index:20;width:min(100%,430px);padding:12px 16px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fbfcfaf7;margin:0 auto;position:fixed;bottom:0;left:0;right:0}.cart-summary{justify-content:space-between;align-items:center;gap:12px;display:flex}.cart-summary strong{font-size:15px;display:block}.cart-summary span{color:var(--muted);font-size:12px}.primary-button,.secondary-button,.ghost-button{height:46px;padding:0 16px;font-weight:800}.primary-button{background:var(--accent);color:#fff}.primary-button:disabled{cursor:not-allowed;background:#b8b1aa}.secondary-button{border:1px solid var(--line);color:var(--text);background:#fff}.secondary-button:disabled{color:var(--muted);cursor:not-allowed}.ghost-button{color:var(--muted);background:0 0}.cart-panel{border:1px solid var(--line);background:#fff;border-radius:8px;max-height:min(68dvh,620px);margin-top:12px;overflow:auto}.cart-line{border-bottom:1px solid var(--line);grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:12px;display:grid}.cart-line:last-child{border-bottom:0}.cart-line h3{margin:0;font-size:14px}.cart-line p{color:var(--muted);margin:4px 0 0;font-size:12px}.qty-control{align-items:center;gap:8px;display:flex}.qty-button{border:1px solid var(--line);background:#fff;width:30px;height:30px}.cart-empty{padding:16px 12px}.cart-empty strong,.empty-state strong{margin-bottom:4px;font-size:15px;display:block}.cart-empty p,.empty-state p{color:var(--muted);margin:0;font-size:13px;line-height:1.45}.checkout-form{border-top:1px solid var(--line);gap:10px;padding:12px;display:grid}.checkout-form input,.checkout-form textarea{border:1px solid var(--line);width:100%;color:var(--text);background:#fff;border-radius:8px;outline:none}.checkout-form input{height:42px;padding:0 12px}.checkout-form textarea{resize:vertical;min-height:74px;padding:10px 12px}.form-error{color:var(--danger);background:#d7365014;border:1px solid #d7365047;border-radius:8px;margin:0;padding:10px 12px;font-size:13px;line-height:1.45}.totals{border-top:1px solid var(--line);gap:8px;padding:12px;display:grid}.total-row{color:var(--muted);justify-content:space-between;gap:16px;font-size:13px;display:flex}.total-row-strong{color:var(--text);font-size:16px;font-weight:900}.status-card,.empty-state{border:1px solid var(--line);background:#fff;border-radius:8px;padding:18px}.status-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.status-pill{height:30px;color:var(--success);background:#23835c1f;border-radius:999px;align-items:center;padding:0 10px;font-size:12px;font-weight:800;display:inline-flex}.status-order-number{color:var(--muted);font-size:12px;font-weight:800}.status-card h2{margin:14px 0 6px;font-size:22px;line-height:1.16}.status-card p{color:var(--muted);margin:0;line-height:1.45}.status-meta,.status-error{margin:8px 0 0;font-size:12px}.status-meta{color:var(--muted)}.status-error{color:var(--danger)}.status-items{border:1px solid var(--line);background:#f7faf7;border-radius:8px;gap:8px;margin-top:16px;padding:12px;display:grid}.status-item{justify-content:space-between;gap:12px;font-size:13px;display:flex}.status-item span{min-width:0}.status-item strong{flex:none}.status-actions{grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;display:grid}.error-page{place-items:center;min-height:100dvh;padding:24px;display:grid}.error-page article{border:1px solid var(--line);background:#fff;border-radius:8px;width:min(100%,390px);padding:22px}.error-page h1{margin:0 0 8px;font-size:22px;line-height:1.15}.error-page p{color:var(--muted);margin:0 0 18px;line-height:1.45}.loading-shell{background:var(--background);min-height:100dvh}.loading-frame{background:var(--surface);width:min(100%,430px);min-height:100dvh;box-shadow:var(--shadow);margin:0 auto;padding:16px}.skeleton{background:#e6ece6;border-radius:8px;position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,#0000,#ffffffb8,#0000);animation:1.1s infinite skeleton-shimmer;position:absolute;inset:0}.skeleton-header{height:72px;margin-bottom:18px}.skeleton-chip-row{gap:8px;margin-bottom:18px;display:flex}.skeleton-chip{width:88px;height:36px}.skeleton-card{height:98px;margin-bottom:10px}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width:360px){.menu-card{grid-template-columns:62px minmax(0,1fr) 36px;gap:10px}.item-art{width:62px;height:62px}.primary-button,.secondary-button,.ghost-button{padding:0 12px}.status-actions{grid-template-columns:1fr}}
