:root{--primary: #ff8a3c;--primary-dark: #e5711f;--primary-soft: #fff1e3;--line-green: #06c755;--line-green-dark: #05a647;--bg: #fff8f0;--card: #ffffff;--text: #2d1d0f;--muted: #8c7260;--border: #f1e5d4;--shadow: 0 4px 14px rgba(255, 138, 60, .12)}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Noto Sans TC,sans-serif;background:var(--bg);color:var(--text)}h1,h2,h3{margin:0}.container{max-width:960px;margin:0 auto;padding:12px 16px}.hero{background:linear-gradient(135deg,#ff8a3c,#ffb070 60%,#ffd39a);color:#fff;padding:18px 16px 22px;box-shadow:0 2px 10px #ff8a3c40}.hero-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;gap:14px}.hero-logo{width:56px;height:56px;border-radius:50%;background:#fff;color:var(--primary-dark);font-weight:800;font-size:1.35rem;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #00000026}.hero h1{font-size:1.3rem;letter-spacing:1px}.hero p{margin:2px 0 0;font-size:.82rem;opacity:.92}.hero-hours{display:flex;align-items:center;gap:6px;margin-top:4px!important;font-size:.85rem!important;opacity:1!important}.shop-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.shop-dot.on{background:#4ade80;box-shadow:0 0 8px #4ade80e6}.shop-dot.off{background:#f87171}.hero-bypass{background:#ffffff40;padding:1px 8px;border-radius:999px;font-size:.75rem;margin-left:4px}.cat-tabs{position:sticky;top:0;z-index:20;background:#fff8f0f2;-webkit-backdrop-filter:saturate(1.4) blur(8px);backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--border);display:flex;gap:8px;padding:10px 12px;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.cat-tabs::-webkit-scrollbar{height:0}.chip{flex:0 0 auto;padding:7px 14px;border-radius:999px;background:#fff;border:1.5px solid var(--border);font-size:.85rem;cursor:pointer;color:var(--text);display:inline-flex;align-items:center;gap:5px;transition:all .15s}.chip:hover{border-color:var(--primary);color:var(--primary-dark)}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #ff8a3c66}.cat-title{font-size:1.1rem;margin:14px 0 10px;display:flex;align-items:center;gap:8px;color:var(--primary-dark)}.cat-title:after{content:"";flex:1;height:1px;background:linear-gradient(to right,var(--border),transparent)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:0;overflow:hidden;display:flex;flex-direction:column;transition:transform .12s,box-shadow .12s}.card-btn{text-align:left;cursor:pointer;font:inherit;color:inherit;width:100%}.card-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--primary)}.card-btn:active{transform:translateY(0)}.card-body{padding:12px 12px 8px;flex:1}.card h3{font-size:.95rem;line-height:1.3}.card-desc{color:var(--muted);font-size:.78rem;margin-top:4px}.card-footer{display:flex;justify-content:space-between;align-items:center;padding:8px 12px 12px}.price{color:var(--primary-dark);font-weight:700;font-size:1rem}.add-ico{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;font-size:1rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #ff8a3c59}.btn{background:var(--primary);color:#fff;border:0;border-radius:10px;padding:11px 16px;font-weight:600;cursor:pointer;font:inherit;transition:background .15s,transform .08s}.btn:hover{background:var(--primary-dark)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.pay{background:var(--line-green)}.btn.pay:hover{background:var(--line-green-dark)}.btn.ghost{background:#fff;color:var(--text);border:1px solid var(--border)}.btn.ghost:hover{background:var(--primary-soft);border-color:var(--primary);color:var(--primary-dark)}.btn.sm{padding:5px 10px;font-size:.8rem;font-weight:500}.btn.full{width:100%;padding:13px;margin-top:10px;font-size:1rem}.qty{display:inline-flex;align-items:center;gap:8px}.qty button{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);background:#fff;font-size:1rem;cursor:pointer;color:var(--text)}.qty button:hover{background:var(--primary-soft);border-color:var(--primary)}.qty.big button{width:44px;height:44px;font-size:1.3rem}.qty.big span{min-width:40px;text-align:center;font-size:1.2rem;font-weight:700}.float-cart{position:fixed;bottom:14px;left:14px;right:14px;background:var(--line-green);color:#fff;border:0;border-radius:14px;padding:14px 18px;font-weight:700;font-size:1rem;display:flex;justify-content:space-between;align-items:center;gap:10px;box-shadow:0 6px 18px #06c75566;cursor:pointer;z-index:40;max-width:930px;margin:0 auto}.float-cart:hover{background:var(--line-green-dark)}.fc-left{display:flex;align-items:center;gap:10px}.fc-badge{background:#fff;color:var(--line-green);border-radius:999px;min-width:24px;height:24px;padding:0 7px;display:inline-flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700}.float-cart.static{position:sticky;bottom:0;background:#fff;color:var(--text);border-top:1px solid var(--border);border-radius:0;box-shadow:0 -2px 10px #0000000f;padding:12px 16px;max-width:none}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 16px;background:var(--primary);color:#fff;box-shadow:0 2px 8px #ff8a3c4d}.topbar h1{font-size:1.1rem;flex:1;text-align:center}.topbar .btn.ghost{background:#fff3;color:#fff;border-color:#ffffff4d}.topbar .btn.ghost:hover{background:#ffffff4d}.lines{list-style:none;margin:0;padding:0;display:grid;gap:10px}.line{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;box-shadow:0 1px 3px #00000008}.empty{text-align:center;padding:60px 16px;color:var(--muted)}input,textarea,select{width:100%;padding:11px 12px;border:1.5px solid var(--border);border-radius:10px;font:inherit;background:#fff;color:var(--text)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff8a3c26}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:100;animation:fadeIn .15s ease}.modal{background:#fff;width:100%;max-width:480px;border-radius:18px 18px 0 0;padding:22px;position:relative;max-height:90vh;overflow-y:auto;animation:slideUp .22s cubic-bezier(.2,.9,.3,1.2)}.modal-close{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;border:0;background:#f3f3f3;font-size:1.3rem;cursor:pointer;line-height:1}.modal-close:hover{background:var(--primary-soft);color:var(--primary-dark)}.modal h2{color:var(--text)}.modal-label{display:block;font-size:.85rem;color:var(--muted);margin:14px 0 6px;font-weight:500}@media (min-width: 720px){.backdrop{align-items:center;padding:20px}.modal{border-radius:18px}.hero-logo{width:64px;height:64px;font-size:1.5rem}.hero h1{font-size:1.5rem}}.admin-tabs{display:flex;gap:4px;margin:12px 0 16px;border-bottom:2px solid var(--border)}.admin-tabs button{background:transparent;border:0;padding:10px 18px;cursor:pointer;font:inherit;font-size:.95rem;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px}.admin-tabs button.active{color:var(--primary-dark);border-bottom-color:var(--primary);font-weight:600}.table-wrap{overflow-x:auto;background:#fff;border-radius:10px;border:1px solid var(--border)}table.data{width:100%;border-collapse:collapse}table.data thead{background:var(--primary-soft)}table.data th{text-align:left;padding:12px 14px;font-size:1rem;color:var(--primary-dark);font-weight:700}table.data td{padding:12px 14px;font-size:1.02rem;border-top:1px solid var(--border)}table.data tbody tr:hover{background:#fffaf4}table.data tbody tr.row-unpaid{background:#fff3cd}table.data tbody tr.row-unpaid:hover{background:#ffe8a8}table.data tbody tr.row-unpaid td{font-weight:600}.badge{padding:4px 12px;border-radius:999px;font-size:.88rem;font-weight:700}.badge.ok{background:#dcf7e3;color:#1a8f3f}.badge.warn{background:#fef3c7;color:#a16207}.badge.off{background:#ffe0e0;color:#b02a2a}.badge.muted{background:#f1f1f1;color:#666}.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;align-items:center;font-size:1rem}.filters input,.filters select{width:auto;padding:10px 12px;font-size:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pay-tile{background:#fff;border:2px solid var(--border);border-radius:12px;padding:14px 10px;cursor:pointer;text-align:center;transition:transform .08s ease,border-color .15s ease,box-shadow .15s ease,background .15s ease;position:relative}.pay-tile:hover{border-color:#e8c9a0}.pay-tile:active{transform:scale(.98)}.pay-tile .pay-icon{font-size:1.8rem;line-height:1;margin-bottom:6px}.pay-tile .pay-title{font-weight:700;font-size:1rem;color:var(--text)}.pay-tile .pay-sub{font-size:.78rem;color:var(--muted);margin-top:2px}.pay-tile.active{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 4px 14px #ff8a3c40}.pay-tile.active:after{content:"✓";position:absolute;top:6px;right:8px;width:20px;height:20px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.pay-tile.line.active{border-color:var(--line-green);background:#e7f9ee;box-shadow:0 4px 14px #06c75540}.pay-tile.line.active:after{background:var(--line-green)}.admin-split{display:grid;grid-template-columns:1fr 360px;gap:16px;align-items:start}.admin-split-main{min-width:0}.admin-split-side{position:sticky;top:12px}@media (max-width: 900px){.admin-split{grid-template-columns:1fr}.admin-split-side{position:static;order:-1}}.mode-toggle{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}.mode-tile{padding:18px 14px;border:2px solid var(--border);border-radius:12px;background:#fff;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .15s}.mode-tile:hover:not(:disabled){border-color:var(--primary)}.mode-tile:disabled{opacity:.5;cursor:wait}.mode-tile.active{border-color:var(--primary);background:var(--primary-soft)}.mode-tile .mode-icon{font-size:1.8rem}.mode-tile .mode-title{font-weight:700;color:var(--primary-dark)}.mode-tile .mode-sub{font-size:.82rem;color:var(--muted)}.admin-cat-tabs{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0 14px;padding:8px;background:var(--card);border:1px solid var(--border);border-radius:10px}.admin-cat-tab{background:transparent;border:1px solid transparent;color:var(--muted);padding:6px 12px;border-radius:999px;font-size:.85rem;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.admin-cat-tab:hover{background:var(--primary-soft);color:var(--primary-dark)}.admin-cat-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px #ff8a3c59}.opt-group{margin-top:12px}.opt-group-title{font-weight:700;font-size:.95rem;margin-bottom:6px;display:flex;align-items:center;gap:8px}.opt-group-hint{font-weight:400;font-size:.72rem;color:var(--muted)}.opt-items{display:flex;flex-wrap:wrap;gap:6px}.opt-chip{background:#fff;border:1.5px solid var(--border);border-radius:999px;padding:6px 12px;font-size:.85rem;cursor:pointer;color:var(--text);transition:border-color .15s,background .15s,transform .08s}.opt-chip:hover{border-color:#e8c9a0}.opt-chip:active{transform:scale(.97)}.opt-chip.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark);font-weight:600}.opt-delta{font-size:.75rem;color:var(--primary-dark);margin-left:2px}.opt-chip-admin{display:inline-flex;align-items:center;gap:6px;background:var(--primary-soft);color:var(--primary-dark);border-radius:999px;padding:4px 10px;font-size:.85rem}.opt-chip-admin button{background:transparent;border:none;cursor:pointer;color:#b02a2a;font-size:1rem;line-height:1;padding:0;width:auto}
