html,body{background-color:#f7f8fa;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;height:100%;overflow:hidden;-webkit-font-smoothing:antialiased}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}.custom-header{background:#fff;padding:10px 15px;border-bottom:1px solid #eee;height:60px;flex-shrink:0;z-index:20;display:flex;align-items:center;justify-content:space-between}.shop-name{font-size:18px;font-weight:800;color:#333}.shop-info{font-size:12px;color:#666;display:flex;align-items:center;gap:10px}.app-container{display:flex;height:calc(100vh - 60px);width:100%;overflow:hidden;position:relative}.app-sidebar{width:80px;flex-shrink:0;background:#f5f5f5;overflow-y:auto;border-right:1px solid #e8e8e8;padding-bottom:80px}.sidebar-item{padding:12px 5px;text-align:center;border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;min-height:65px;transition:background .15s}.sidebar-item:active{background:#e8e8e8}.sidebar-item.active{background:#fff;border-left:3px solid #ff4b33;position:relative}.cat-name-main{font-size:12px;font-weight:600;color:#333;margin-bottom:2px;line-height:1.2}.cat-name-sub{font-size:10px;color:#888;line-height:1.2}.sidebar-item.active .cat-name-main,.sidebar-item.active .cat-name-sub{color:#ff4b33}.app-content{flex:1;background:#fff;overflow-y:auto;padding-bottom:80px}.section-header{background:#f8f8f8;font-weight:600;font-size:14px;padding:10px 12px;position:sticky;top:0;z-index:10;border-bottom:1px solid #eee;color:#333}.product-grid{display:flex;flex-direction:column}.product-item{display:flex;padding:12px 15px;border-bottom:1px solid #f0f0f0;position:relative;align-items:flex-start;gap:12px}.prod-img-box{flex-shrink:0}.prod-img-box img{width:85px;height:85px;object-fit:cover;border-radius:8px;background:#f5f5f5}.prod-info{flex:1;display:flex;flex-direction:column;min-height:85px;padding-right:40px}.prod-title{font-weight:600;font-size:15px;color:#222;margin-bottom:4px;line-height:1.3}.prod-sub{font-size:12px;color:#999;margin-bottom:6px;line-height:1.3}.prod-price{font-weight:700;color:#ff4b33;font-size:16px;margin-top:auto}.btn-wrapper{position:absolute;right:15px;bottom:15px;display:flex;align-items:center}.circle-plus{width:30px;height:30px;background:#fff;border:1.5px solid #ddd;border-radius:50%;color:#666;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px #00000014}.circle-plus:active{background:#007bff;color:#fff;border-color:#007bff}.qty-ctrl{display:flex;align-items:center;gap:6px}.qty-btn{width:28px;height:28px;background:#fff;border:1.5px solid #ff6b4a;border-radius:6px;color:#ff6b4a;font-weight:600;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.qty-btn:active{background:#ff6b4a;color:#fff}.qty-num{min-width:30px;height:28px;text-align:center;font-size:15px;font-weight:600;color:#333;border:1px solid #e0e0e0;border-radius:6px;display:flex;align-items:center;justify-content:center;background:#fff}.bottom-nav-bar{position:fixed;bottom:0;left:0;width:100%;height:60px;background:#fff;box-shadow:0 -2px 10px #00000014;display:flex;justify-content:space-between;align-items:center;padding:0 20px;z-index:999}.nav-btn{background:none;border:none;padding:8px;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center}.nav-price-display{display:flex;align-items:center;cursor:pointer}.price-num{font-size:22px;font-weight:800;color:#333;margin:0 4px}.price-unit{font-size:13px;font-weight:500;color:#888}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:10000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.modal-overlay.center{align-items:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cart-modal,.user-modal{background:#fff;width:100%;max-width:480px;max-height:90vh;border-radius:16px 16px 0 0;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{padding:14px 18px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:#fff}.modal-header h2{margin:0;font-size:17px;font-weight:700;color:#333;display:flex;align-items:center;gap:8px}.modal-count-badge{background:#007bff;color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}.modal-close{width:32px;height:32px;background:none;border:none;font-size:26px;color:#999;cursor:pointer;line-height:1}.modal-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.cart-list{padding:0 16px}.cart-item-card{display:flex;padding:14px 0;border-bottom:1px solid #f0f0f0;position:relative;gap:12px}.cart-item-img{width:65px;height:65px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#f5f5f5}.cart-item-details{flex:1;display:flex;flex-direction:column;gap:3px;padding-right:30px}.cart-item-name{font-size:14px;font-weight:600;color:#333;line-height:1.3}.cart-item-desc{font-size:12px;color:#999}.cart-item-price{font-size:14px;color:#ff4b33;font-weight:600;margin-top:2px}.cart-qty-bar{display:flex;align-items:center;gap:0;margin-top:8px;width:fit-content;border:1px solid #e0e0e0;border-radius:20px;overflow:hidden}.qty-minus,.qty-plus{width:32px;height:32px;background:#fff;border:none;font-size:18px;color:#007bff;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.qty-minus:active,.qty-plus:active{background:#f5f5f5}.qty-value{min-width:36px;height:32px;text-align:center;font-size:14px;font-weight:600;color:#333;display:flex;align-items:center;justify-content:center}.cart-item-remove{position:absolute;top:14px;right:0;background:none;border:none;color:#ff4b33;font-size:20px;cursor:pointer;padding:5px}.cart-empty{padding:50px 20px;text-align:center}.cart-empty p{color:#999;font-size:14px}.cart-summary{padding:14px 18px 24px;border-top:1px solid #eee;flex-shrink:0;background:#fff}.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:15px;color:#666}.cart-total-val{font-size:22px;font-weight:800;color:#333}.cart-total-val small{font-size:13px;font-weight:500}.cart-action-btns{display:flex;gap:12px}.cart-btn-dine{flex:1;padding:14px;background:linear-gradient(135deg,#4facfe,#007bff);color:#fff;border:none;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #007bff4d}.cart-btn-dine:active{transform:scale(.98)}.cart-btn-dine:disabled{background:#ccc;box-shadow:none}.cart-btn-delivery{flex:1;padding:14px;background:linear-gradient(135deg,#ff8a5b,#ff6b4a);color:#fff;border:none;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #ff6b4a4d}.cart-btn-delivery:active{transform:scale(.98)}.cart-btn-delivery:disabled{background:#ccc;box-shadow:none}.table-modal{background:#fff;border-radius:16px;padding:24px 20px;width:90%;max-width:340px;text-align:center;animation:popIn .25s ease}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.table-modal .close-top{text-align:right;margin-bottom:5px}.table-modal .close-top button{background:none;border:none;font-size:24px;color:#999;cursor:pointer}.table-modal h4{font-size:18px;color:#333;margin:0 0 6px}.table-modal .subtitle{color:#ff4b33;font-size:17px;font-weight:600;margin-bottom:6px}.table-modal .hint{font-size:12px;color:#999;margin-bottom:18px}.table-input{width:100%;padding:16px;border:2.5px solid #28a745;border-radius:12px;font-size:28px;text-align:center;font-weight:700;color:#333;margin-bottom:18px}.table-input:focus{outline:none;border-color:#28a745}.btn-confirm-table{width:100%;padding:14px;background:linear-gradient(135deg,#4caf50,#28a745);color:#fff;border:none;border-radius:25px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #28a7454d}.btn-confirm-table:active{transform:scale(.98)}.delivery-info-box{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:14px;margin:16px 16px 14px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:14px;color:#666}.info-row.info-total{margin-top:8px;padding-top:10px;border-top:1px dashed #ddd;font-weight:600}.total-price{font-size:17px;color:#007bff;font-weight:700}.free-tag{color:#28a745;font-weight:600}.free-shipping-banner{background:#e8f5e9;border:1px solid #4caf50;color:#2e7d32;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:600;text-align:center;margin-top:10px}.free-shipping-banner:before{content:"✅ "}.delivery-form{padding:0 16px 20px}.field-label{font-size:13px;font-weight:600;color:#444;margin-bottom:6px;margin-top:12px}.form-field{width:100%;padding:12px 14px;border:1.5px solid #e0e0e0;border-radius:10px;font-size:15px;background:#fafafa;font-family:inherit}.form-field:focus{outline:none;border-color:#007bff;background:#fff}.form-textarea{resize:vertical;min-height:60px}.addr-history,.zone-select{margin-top:12px}.addr-chips,.zone-btns{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.addr-chip,.zone-chip{padding:10px 14px;background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;font-size:13px;color:#333;cursor:pointer;white-space:nowrap}.addr-chip:active,.zone-chip:active{background:#007bff;color:#fff;border-color:#007bff}.zone-chip{flex:1;min-width:80px;text-align:center;padding:12px 16px;font-size:14px;font-weight:600;border-radius:10px}.zone-chip:active{background:#333;color:#fff;border-color:#333}.divider-or{text-align:center;color:#ccc;font-size:12px;margin:16px 0;position:relative}.divider-or:before,.divider-or:after{content:"";position:absolute;top:50%;width:35%;height:1px;background:#e0e0e0}.divider-or:before{left:0}.divider-or:after{right:0}.submit-btns{display:flex;gap:12px;margin-top:18px}.submit-cash{flex:1;padding:14px;background:#fff;border:1.5px solid #ddd;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}.submit-cash .icon{font-size:24px}.submit-cash .label-main{font-size:14px;font-weight:600;color:#333}.submit-cash .label-sub{font-size:11px;color:#999}.submit-cash:active{background:#f5f5f5;border-color:#999}.submit-wechat{flex:1;padding:14px;background:#e8f5e9;border:1.5px solid #4caf50;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;color:#2e7d32}.submit-wechat .icon{width:24px;height:24px;background:#4caf50;border-radius:50%}.submit-wechat .label-main{font-size:14px;font-weight:600}.submit-wechat .label-sub{font-size:11px;opacity:.7}.submit-wechat:active{background:#c8e6c9}.back-btn{width:100%;padding:12px;background:none;border:none;color:#007bff;font-size:14px;cursor:pointer;margin-top:14px}.wechat-pay-modal{background:#fff;width:90%;max-width:340px;border-radius:18px;padding:28px 22px;text-align:center;animation:popIn .25s ease}.wechat-icon-circle{width:56px;height:56px;background:#4caf50;border-radius:50%;margin:0 auto 18px}.wechat-title{font-size:19px;font-weight:700;color:#333;margin-bottom:4px}.wechat-subtitle{font-size:15px;color:#666;margin-bottom:14px}.wechat-amount{font-size:24px;font-weight:800;color:#4caf50;margin-bottom:18px}.wechat-hint{background:#f5f5f5;border-radius:18px;padding:10px 18px;font-size:12px;color:#999;margin-bottom:18px}.btn-wechat-confirm{width:100%;padding:14px;background:linear-gradient(135deg,#4caf50,#28a745);color:#fff;border:none;border-radius:25px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #28a7454d;margin-bottom:14px}.btn-wechat-confirm:active{transform:scale(.98)}.wechat-note{font-size:12px;color:#999;line-height:1.6;margin-bottom:18px}.btn-wechat-close{width:100%;padding:12px;background:#fff;border:1.5px solid #ddd;border-radius:25px;font-size:14px;font-weight:600;color:#333;cursor:pointer}.btn-wechat-close:active{background:#f5f5f5}.user-modal{background:#f7f8fa}.user-hint-bar{background:#fff8e1;padding:10px 14px;font-size:12px;color:#666;text-align:center;border-bottom:1px solid #f0f0f0}.user-login-box{padding:40px 24px;text-align:center;background:#fff}.login-hint{color:#666;font-size:14px;margin-bottom:20px;line-height:1.5}.user-info-bar{background:#fff;padding:14px 16px;margin:14px 14px 0;border-radius:12px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000a}.user-phone-num{font-size:16px;font-weight:700;color:#333}.user-subtitle{font-size:12px;color:#999;margin-top:2px}.btn-logout-simple{padding:8px 14px;background:#fff;color:#ff4b33;border:1px solid #ff4b33;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer}.orders-tip{font-size:13px;color:#666;font-weight:600;margin:16px 14px 10px;padding-bottom:8px}.history-order-card{background:#fff;margin:0 14px 12px;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.order-top{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid #f0f0f0}.order-num{font-size:15px;font-weight:700;color:#333}.order-price{font-size:16px;font-weight:800;color:#ff4b33}.order-content{font-size:13px;color:#666;line-height:1.6;padding:12px 14px}.order-bottom{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#fafafa}.order-time{font-size:12px;color:#999}.order-qty-ctrl{display:flex;align-items:center;gap:8px}.order-qty-btn{width:28px;height:28px;border:1.5px solid #ff6b4a;border-radius:6px;background:#fff;color:#ff6b4a;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.order-qty-btn:active{background:#ff6b4a;color:#fff}.order-qty-num{font-weight:600;font-size:14px;color:#333;min-width:20px;text-align:center}.order-add-btn{width:32px;height:32px;background:linear-gradient(135deg,#4facfe,#007bff);border:none;border-radius:50%;color:#fff;font-size:20px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px #007bff4d}.order-add-btn:active{transform:scale(.95)}.orders-footer-bar{background:#fff;padding:14px 18px 24px;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.footer-left{display:flex;align-items:center;gap:10px}.footer-badge{background:#ff6b4a;color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:10px}.footer-total{font-size:17px;font-weight:800;color:#333}.footer-total small{font-size:12px;font-weight:500}.btn-goto-cart{background:#333;color:#fff;border:none;padding:10px 18px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px}.btn-goto-cart:active{background:#555}.logout-link{text-align:center;color:#ff4b33;font-size:14px;padding:16px;cursor:pointer}.input-box{width:100%;padding:14px 16px;border:1.5px solid #e0e0e0;border-radius:10px;font-size:15px;background:#fafafa;margin-bottom:12px}.input-box:focus{outline:none;border-color:#007bff;background:#fff}.btn-full-green{width:100%;padding:14px;background:linear-gradient(135deg,#4caf50,#28a745);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #28a7454d}.btn-full-green:disabled{background:#ccc;box-shadow:none}.no-orders{padding:50px 20px;text-align:center}.no-orders p{color:#999;font-size:14px;line-height:1.6}.my-footer{text-align:center;padding:30px 0 100px;color:#bbb;font-size:12px}.bottom-nav-bar{position:fixed;bottom:0;left:0;width:100%;height:60px;background:#fff;box-shadow:0 -2px 10px #00000014;display:flex;justify-content:space-between;align-items:center;padding:0 15px;z-index:999}.nav-right-group{display:flex;align-items:center;gap:8px}.nav-btn{background:none;border:none;padding:8px;cursor:pointer;color:#888;display:flex;align-items:center;justify-content:center}.nav-btn.nav-user{width:40px;height:40px;background:#f5f5f5;border-radius:50%}.nav-price-display{display:flex;align-items:baseline;cursor:pointer;padding:0 6px}.price-num{font-size:20px;font-weight:800;color:#333}.price-unit{font-size:12px;font-weight:500;color:#888;margin-left:3px}.nav-cart{position:relative;width:48px;height:48px;background:linear-gradient(135deg,#4facfe,#007bff);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #007bff59}.nav-cart svg{stroke:#fff}.nav-cart-badge{position:absolute;top:-5px;right:-5px;background:#ff4b33;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;padding:0 5px;border-radius:10px;border:2px solid #fff;display:flex;align-items:center;justify-content:center}.shop-closed-banner{background:linear-gradient(135deg,#ff4b33,#e53e3e);color:#fff;padding:12px 16px;border-radius:10px;text-align:center;font-weight:700;font-size:15px;margin-bottom:12px;animation:pulse-red 2s infinite}.shop-closed-banner span{font-size:12px;font-weight:400;opacity:.9}@keyframes pulse-red{0%,to{box-shadow:0 0 #ff4b3366}50%{box-shadow:0 0 0 8px #ff4b3300}}@media (min-width: 768px){.app-container{max-width:1200px;margin:0 auto}.menu-container{padding:20px}.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.product-item{border:1px solid #f0f0f0;border-radius:12px;margin:0}.category-section>.category-header{grid-column:1 / -1}.bottom-nav-bar{max-width:1200px;left:50%;transform:translate(-50%);border-radius:20px 20px 0 0}.modal-container{max-width:500px}.app-sidebar{width:140px}}.qty-ctrl{display:flex;align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:50px;height:32px;box-shadow:0 1px 3px #0000000d;overflow:hidden;width:fit-content}.qty-btn{width:32px;height:100%;border:none;background:transparent;color:#ff4b33;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding-bottom:2px;transition:background .2s}.qty-btn:active{background:#fff5f5}.qty-num{min-width:24px;text-align:center;font-weight:700;font-size:16px;color:#2d3748;border:none;background:transparent;padding:0 2px}.cart-item-right .qty-ctrl{height:28px}.cart-item-right .qty-btn{width:28px;font-size:18px}.cart-item-right .qty-num{font-size:15px}.prod-title{font-size:16px;font-weight:700;color:#1a202c;margin-bottom:4px;line-height:1.3}.prod-sub{font-size:13px;color:#718096;margin-bottom:6px}.prod-price{font-size:16px;font-weight:800;color:#e53e3e}
