:root{--bg:#f5f5f7;--card:#fff;--accent:#ff6b35;--accent-light:#ff8c5a;--accent-bg:#fff3ed;--text:#1d1d1f;--text-secondary:#86868b;--text-light:#aeaeb2;--border:#e8e8ed;--shadow:0 2px 12px #0000000f;--radius:16px;--radius-sm:10px;--safe-bottom:env(safe-area-inset-bottom)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,PingFang SC,Helvetica Neue,sans-serif}#app{min-height:100vh}.page{max-width:640px;padding:20px 16px calc(20px + var(--safe-bottom));margin:0 auto}.page-narrow{max-width:420px}.page-wide{max-width:960px}.top-banner{background:linear-gradient(135deg,#ff6b35 0%,#ff8c5a 100%);padding:36px 20px 32px;position:relative;overflow:hidden}.top-banner:after{content:"";background:#ffffff1a;border-radius:50%;width:120px;height:120px;position:absolute;bottom:-20px;right:-20px}.banner-inner{z-index:1;max-width:640px;margin:0 auto;position:relative}.banner-tag{color:#fff;background:#ffffff40;border-radius:100px;margin-bottom:10px;padding:3px 12px;font-size:12px;font-weight:500;display:inline-block}.banner-title{color:#fff;letter-spacing:-.5px;margin-bottom:4px;font-size:26px;font-weight:900}.banner-sub{color:#fffc;font-size:13px}.admin-banner{background:linear-gradient(135deg,#1d1d1f 0%,#3a3a3c 100%);padding:36px 20px 32px}.admin-banner:after{background:#ffffff0d}.admin-banner .banner-title{color:#fff}.admin-banner .banner-sub{color:#fff9}.admin-banner .banner-tag{color:#fffc;background:#ffffff26}.card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:12px;overflow:hidden}.card-body{padding:16px}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.card-title{font-size:15px;font-weight:700}.section-title{align-items:center;gap:6px;margin-bottom:12px;font-size:15px;font-weight:700;display:flex}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;height:48px;color:var(--text);background:#fff;outline:none;padding:0 14px;font-size:15px;transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);resize:vertical;background:#fff;outline:none;min-height:80px;padding:12px 14px;font-size:15px;transition:border-color .2s}.form-textarea:focus{border-color:var(--accent)}.form-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;height:48px;color:var(--text);appearance:none;background:#fff url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2386868b' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") right 14px center no-repeat;outline:none;padding:0 14px;font-size:15px}.btn{cursor:pointer;border:none;border-radius:24px;justify-content:center;align-items:center;gap:6px;height:48px;padding:0 28px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:#fff;box-shadow:0 4px 16px #ff6b354d}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;background:#d1d1d6;transform:none}.btn-secondary{background:var(--bg);color:var(--text);border:1.5px solid var(--border)}.btn-danger{color:#fff;background:#ff3b30}.btn-sm{border-radius:18px;height:36px;padding:0 16px;font-size:13px}.btn-block{width:100%}.counter{align-items:center;gap:10px;display:flex}.counter-btn{border:1.5px solid var(--accent);width:32px;height:32px;color:var(--accent);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:18px;font-weight:600;line-height:1;transition:all .12s;display:flex}.counter-btn:active{background:var(--accent);color:#fff}.counter-btn.disabled{color:#d1d1d6;pointer-events:none;border-color:#d1d1d6}.counter-btn.has-item{background:var(--accent);color:#fff}.counter-num{text-align:center;min-width:24px;font-size:16px;font-weight:700}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}th,td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 12px}th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;background:var(--bg);font-size:12px;font-weight:600;position:sticky;top:0}td{font-size:14px}.toast{z-index:10000;opacity:0;pointer-events:none;text-align:center;border:1px solid var(--border);background:#fff;border-radius:16px;max-width:260px;padding:16px 24px;font-size:15px;font-weight:600;transition:all .2s;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)scale(.85);box-shadow:0 8px 32px #00000026}.toast.show{opacity:1;transform:translate(-50%,-50%)scale(1)}.toast-icon{margin-bottom:8px;font-size:28px;display:block}.toast.success .toast-icon{color:#34c759}.toast.error .toast-icon{color:#ff3b30}.toast.warning .toast-icon{color:#ff9500}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:20px;width:100%;max-width:400px;padding:24px;box-shadow:0 16px 48px #00000026}.modal-title{text-align:center;margin-bottom:8px;font-size:17px;font-weight:700}.modal-desc{color:var(--text-secondary);text-align:center;margin-bottom:20px;font-size:13px}.modal-actions{gap:10px;display:flex}.modal-actions .btn{flex:1}.nav-tabs{border-radius:var(--radius-sm);background:#8e8e9314;gap:0;margin-bottom:16px;padding:3px;display:flex}.nav-tab{text-align:center;color:var(--text-secondary);cursor:pointer;border-radius:8px;flex:1;padding:8px 12px;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s}.nav-tab.active{color:var(--text);background:#fff;box-shadow:0 1px 4px #00000014}.bottom-bar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border);padding:10px 16px calc(10px + var(--safe-bottom));z-index:100;background:#ffffffd9;position:fixed;bottom:0;left:0;right:0}.bottom-inner{align-items:center;gap:12px;max-width:640px;margin:0 auto;display:flex}.text-center{text-align:center}.text-accent{color:var(--accent)}.text-secondary{color:var(--text-secondary)}.text-light{color:var(--text-light)}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}.gap-12{gap:12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.fade-enter-active,.fade-leave-active{transition:opacity .2s}.fade-enter-from,.fade-leave-to{opacity:0}.empty-state{text-align:center;color:var(--text-light);padding:48px 20px;font-size:14px}.empty-icon{margin-bottom:12px;font-size:40px;display:block}.dish-img{border-radius:var(--radius-sm);background:#f5f0eb;flex-shrink:0;width:76px;height:76px;overflow:hidden}.dish-img img{object-fit:cover;width:100%;height:100%}.dish-img-placeholder{color:#ccc;background:linear-gradient(135deg,#f5f0eb,#ede7df);justify-content:center;align-items:center;font-size:28px;display:flex}.checkbox-label{cursor:pointer;align-items:center;gap:10px;padding:12px 0;display:flex}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent)}a,.link{color:var(--accent);cursor:pointer;text-decoration:none}a:hover,.link:hover{text-decoration:underline}
