/* ================================================================
   点餐系统 · Mobile UI v2
   Design: Warm Ivory · Deep Charcoal · Vivid Coral accent
   精致现代，移动优先，卡片化布局
   ================================================================ */

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --pri:       #FF4438;
  --pri-d:     #e02e23;
  --pri-l:     #fff1f0;
  --pri-grd:   linear-gradient(135deg, #FF4438 0%, #FF7B54 100%);
  --acc:       #FF9000;
  --acc-l:     #fff8ee;
  --ok:        #00b69b;
  --ok-l:      #edfaf7;
  --warn:      #f59e0b;
  --warn-l:    #fffbeb;
  --err:       #ef4444;
  --ink:       #171412;
  --ink-2:     #3d3530;
  --sub:       #72665e;
  --muted:     #a89f99;
  --bd:        #ede8e4;
  --bd-l:      #f5f2ef;
  --bg:        #f8f5f2;
  --surface:   #ffffff;
  --surface-2: #fdf9f7;

  --nav-h:  52px;
  --tab-h:  64px;
  --r-xs:   6px;
  --r-s:    10px;
  --r:      16px;
  --r-l:    22px;
  --r-xl:   28px;

  --sh-xs: 0 1px 3px rgba(0,0,0,.06);
  --sh-s:  0 2px 8px rgba(0,0,0,.08);
  --sh:    0 4px 16px rgba(0,0,0,.09);
  --sh-l:  0 8px 32px rgba(0,0,0,.12);
  --sh-pri:0 4px 20px rgba(255,68,56,.28);

  --font: 'Noto Sans SC','PingFang SC','HarmonyOS Sans',sans-serif;
  --dur: .18s;
  --ease: cubic-bezier(.4,0,.2,1);
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.55;
  min-height:100dvh;padding-top:var(--nav-h);
  padding-bottom:calc(var(--tab-h) + env(safe-area-inset-bottom,0px));
  overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button,input,textarea,select{font-family:var(--font)}

/* ── Top Nav ────────────────────────────────────────────────── */
.top-nav{
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:640px;z-index:300;
  height:var(--nav-h);
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--bd);
  display:flex;align-items:center;padding:0 14px;gap:6px}
.tn-logo{display:flex;align-items:center;gap:7px;font-size:17px;font-weight:800;color:var(--pri);flex:1;letter-spacing:-.3px}
.tn-logo-icon{width:30px;height:30px;border-radius:9px;background:var(--pri-grd);
  display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:var(--sh-pri)}
.tn-title{flex:1;font-size:15px;font-weight:700;text-align:center;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;color:var(--ink)}
.tn-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;background:var(--surface-2);border:1px solid var(--bd);
  font-size:17px;cursor:pointer;color:var(--ink-2);flex-shrink:0;
  transition:background var(--dur)}
.tn-btn:active{background:var(--bd)}

/* ── Bottom Tabs ────────────────────────────────────────────── */
.bottom-tabs{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:640px;z-index:300;
  height:calc(var(--tab-h) + env(safe-area-inset-bottom,0px));
  padding-bottom:env(safe-area-inset-bottom,0px);
  background:rgba(255,255,255,.95);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-top:1px solid var(--bd);
  display:flex;align-items:stretch}
.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:3px;font-size:10px;font-weight:500;color:var(--muted);
  cursor:pointer;text-decoration:none;transition:color var(--dur);position:relative;padding-top:6px}
.tab-item .ti{font-size:22px;line-height:1;transition:transform var(--dur) var(--ease)}
.tab-item.active{color:var(--pri)}
.tab-item.active .ti{transform:translateY(-2px) scale(1.1)}
.tab-bdg{position:absolute;top:5px;right:calc(50% - 20px);background:var(--err);color:#fff;
  font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;padding:0 4px;
  display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}

/* ── Layout ─────────────────────────────────────────────────── */
.page{max-width:640px;margin:0 auto;padding:12px 14px 8px}
.page-full{max-width:640px;margin:0 auto}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mt8{margin-top:8px}
.mt12{margin-top:12px}.mt16{margin-top:16px}.ml8{margin-left:8px}
.flex{display:flex}.items-c{align-items:center}.jbetween{justify-content:space-between}
.gap8{gap:8px}.gap12{gap:12px}.font-bold{font-weight:700}
.text-pri{color:var(--pri)}.text-ok{color:var(--ok)}.text-sub{color:var(--sub)}
.text-muted{color:var(--muted)}.text-sm{font-size:12px}.text-xs{font-size:11px}
.w-full{width:100%}

/* ── Card ───────────────────────────────────────────────────── */
.card{background:var(--surface);border-radius:var(--r);box-shadow:var(--sh-s);overflow:hidden}
.card+.card{margin-top:10px}
.card-body{padding:14px 16px}
.card-hd{padding:13px 16px 12px;border-bottom:1px solid var(--bd-l);font-weight:700;
  font-size:13.5px;display:flex;align-items:center;gap:7px;color:var(--ink-2)}

/* ── Hero Banner ────────────────────────────────────────────── */
.hero{background:var(--pri-grd);padding:22px 16px 36px;color:#fff;
  position:relative;overflow:hidden;max-width:640px;margin:0 auto}
.hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 85% 15%,rgba(255,255,255,.15) 0%,transparent 55%),
             radial-gradient(ellipse at 15% 85%,rgba(0,0,0,.08) 0%,transparent 50%)}
.hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:24px;
  background:var(--bg);border-radius:24px 24px 0 0}
.hero-eyebrow{font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;
  opacity:.7;margin-bottom:6px;position:relative}
.hero-title{font-size:24px;font-weight:900;margin-bottom:4px;position:relative;
  letter-spacing:-.5px;line-height:1.25}
.hero-sub{font-size:13px;opacity:.82;margin-bottom:18px;position:relative}
.hero-search{display:flex;gap:8px;position:relative}
.hero-search input{flex:1;height:46px;border-radius:14px;border:none;padding:0 18px;
  font-size:14px;font-weight:500;background:rgba(255,255,255,.97);color:var(--ink);
  outline:none;box-shadow:0 4px 16px rgba(0,0,0,.15)}
.hero-search input::placeholder{color:var(--muted)}
.hero-search button{height:46px;padding:0 20px;border-radius:14px;
  background:rgba(0,0,0,.25);color:#fff;border:none;font-size:14px;font-weight:700;
  cursor:pointer;white-space:nowrap;transition:background var(--dur)}
.hero-search button:active{background:rgba(0,0,0,.4)}

/* ── Category Chips ─────────────────────────────────────────── */
.chip-scroll{display:flex;gap:8px;overflow-x:auto;padding:14px 14px 10px;
  scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;
  max-width:640px;margin:0 auto}
.chip-scroll::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;padding:7px 16px;border-radius:100px;font-size:13px;font-weight:500;
  background:var(--surface);color:var(--sub);border:1.5px solid var(--bd);
  cursor:pointer;transition:all var(--dur);white-space:nowrap;line-height:1}
.chip.active{background:var(--pri-l);color:var(--pri);border-color:var(--pri);font-weight:600}

/* ── Section header ─────────────────────────────────────────── */
.sec-hd{font-size:16px;font-weight:800;padding:4px 14px 10px;color:var(--ink);
  letter-spacing:-.3px;max-width:640px;margin:0 auto}

/* ── Hot Products Scroll ─────────────────────────────────────── */
.hot-scroll{display:flex;gap:10px;overflow-x:auto;padding:0 14px 16px;
  scrollbar-width:none;-ms-overflow-style:none;max-width:640px;margin:0 auto}
.hot-scroll::-webkit-scrollbar{display:none}
.hot-card{flex:0 0 130px;background:var(--surface);border-radius:var(--r);
  box-shadow:var(--sh-s);overflow:hidden;text-decoration:none;color:inherit;
  display:block;transition:transform .15s}
.hot-card:active{transform:scale(.97)}
.hot-img{width:100%;height:100px;object-fit:cover;display:block}
.hot-img-ph{width:100%;height:100px;display:flex;align-items:center;
  justify-content:center;font-size:36px;background:linear-gradient(135deg,#fce4dc,#ffd6c0)}
.hot-card > div{padding:0 8px}
.hot-name{font-size:13px;font-weight:700;padding:6px 8px 2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hot-meta{display:flex;align-items:center;gap:4px;padding:0 8px 2px}
.hot-price{font-size:14px;font-weight:800;color:#FF4B2B}
.hot-sales{font-size:11px;color:var(--sub)}
.hot-shop{font-size:11px;color:var(--sub);padding:0 8px 8px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}


.mc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;
  padding:4px 14px 14px;max-width:640px;margin:0 auto}
@media(max-width:360px){.mc-grid{grid-template-columns:1fr}}
.mc{background:var(--surface);border-radius:var(--r);box-shadow:var(--sh-s);
  overflow:hidden;display:block;position:relative;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur)}
.mc:active{transform:scale(.97);box-shadow:var(--sh-xs)}
.mc-img{width:100%;height:130px;object-fit:cover}
.mc-ph{width:100%;height:130px;background:linear-gradient(135deg,#ffe5df 0%,#ffd5c5 100%);
  display:flex;align-items:center;justify-content:center;font-size:44px}
.mc-body{padding:10px 11px 12px}
.mc-name{font-size:13.5px;font-weight:700;margin-bottom:5px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink)}
.mc-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--sub);margin-bottom:5px}
.mc-stars{color:var(--acc);font-weight:700}
.mc-desc{font-size:11px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:1;
  -webkit-box-orient:vertical;overflow:hidden}
.mc-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}
.mc-tag{font-size:10px;padding:2px 7px;border-radius:100px;
  background:var(--surface-2);color:var(--sub);border:1px solid var(--bd)}
.mc-closed-badge{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.55);color:#fff;
  font-size:10px;font-weight:600;padding:2px 8px;border-radius:100px;backdrop-filter:blur(4px)}

/* ── Product Items ───────────────────────────────────────────── */
.pcat-title{padding:13px 16px 11px;font-size:13px;font-weight:700;color:var(--sub);
  border-bottom:1px solid var(--bd-l);background:var(--surface-2)}
.pitem{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--bd-l)}
.pitem:last-child{border-bottom:none}
.p-img{width:80px;height:80px;border-radius:var(--r-s);object-fit:cover;flex-shrink:0}
.p-ph{width:80px;height:80px;border-radius:var(--r-s);flex-shrink:0;
  background:linear-gradient(135deg,#ffe5df,#ffd5c5);
  display:flex;align-items:center;justify-content:center;font-size:32px}
.p-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}
.p-name{font-size:14px;font-weight:600;color:var(--ink);line-height:1.35}
.p-desc{font-size:12px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;line-height:1.4}
.p-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.p-price{font-size:16px;font-weight:800;color:var(--pri)}
.p-price small{font-size:11px;font-weight:600}
.p-ori{font-size:11px;color:var(--muted);text-decoration:line-through;margin-left:4px}

/* ── Add to Cart Controls ───────────────────────────────────── */
.add-btn{width:30px;height:30px;border-radius:50%;background:var(--pri);color:#fff;
  border:none;font-size:20px;font-weight:300;display:flex;align-items:center;
  justify-content:center;cursor:pointer;box-shadow:var(--sh-pri);
  transition:transform var(--dur);line-height:1}
.add-btn:active{transform:scale(.9)}
.qty-ctrl{display:flex;align-items:center;gap:10px}
.q-btn{width:28px;height:28px;border-radius:50%;border:2px solid var(--bd);
  background:var(--surface);color:var(--ink-2);font-size:18px;font-weight:300;
  display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;
  transition:all var(--dur)}
.q-btn.plus{border-color:var(--pri);background:var(--pri);color:#fff;box-shadow:var(--sh-pri)}
.q-btn:active{transform:scale(.88)}
.q-num{font-size:15px;font-weight:700;min-width:18px;text-align:center}

/* ── Cart Sticky Bar ─────────────────────────────────────────── */
/* Extra bottom padding when cart bar is visible */
body.has-cart-bar #spa-main { padding-bottom: 80px; }

/* Product detail add-to-cart footer bar — sits above bottom tabs */
.pd-footer {
  position: fixed;
  bottom: calc(var(--tab-h) + env(safe-area-inset-bottom, 0px));
  left: 50%; transform: translateX(-50%);
  width: 100%; max-width: 640px;
  padding: 10px 16px;
  background: #fff;
  border-top: 1px solid var(--bd);
  display: flex; gap: 10px; align-items: center;
  z-index: 250;
  box-sizing: border-box;
}

#cart-bar{position:fixed;
  bottom:calc(var(--tab-h) + env(safe-area-inset-bottom,0px) + 10px);
  left:50%;transform:translateX(-50%);
  width:calc(100% - 28px);max-width:600px;z-index:200;display:none}
.cart-bar-inner{background:var(--ink);color:#fff;border-radius:var(--r-l);
  padding:10px 10px 10px 16px;display:flex;align-items:center;gap:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.25)}
.cb-icon{font-size:20px;position:relative}
.cb-badge{position:absolute;top:-6px;right:-8px;background:var(--pri);color:#fff;
  font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;
  padding:0 3px;display:flex;align-items:center;justify-content:center}
.cb-price{flex:1;font-size:16px;font-weight:800}
.cb-price small{font-size:11px;font-weight:400;color:rgba(255,255,255,.65);margin-left:5px}
.cb-btn{background:var(--pri);color:#fff;border:none;border-radius:var(--r-l);
  padding:10px 20px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:var(--sh-pri);
  transition:background var(--dur);white-space:nowrap}
.cb-btn:active{background:var(--pri-d)}

/* ── Cart Page Items ─────────────────────────────────────────── */
.ci-card{background:var(--surface);border-radius:var(--r);box-shadow:var(--sh-s);
  overflow:hidden;margin-bottom:10px}
.ci-header{padding:13px 16px;border-bottom:1px solid var(--bd-l);
  display:flex;align-items:center;gap:8px}
.ci-merchant{font-size:14px;font-weight:700;flex:1}
.ci-clear{font-size:12px;color:var(--muted);cursor:pointer}
.ci{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--bd-l)}
.ci:last-child{border-bottom:none}
.ci-img{width:60px;height:60px;border-radius:var(--r-s);object-fit:cover;flex-shrink:0}
.ci-ph{width:60px;height:60px;border-radius:var(--r-s);
  background:linear-gradient(135deg,#ffe5df,#ffd5c5);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:24px}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:13.5px;font-weight:600;margin-bottom:2px}
.ci-spec{font-size:11px;color:var(--muted)}
.ci-price{font-size:15px;font-weight:800;color:var(--pri);margin-top:4px}

/* ── Checkout ────────────────────────────────────────────────── */
.ot-tabs{display:flex;gap:8px;flex-wrap:wrap}
.ot-tab{flex:1;min-width:80px;padding:12px 10px;border-radius:var(--r-s);
  background:var(--surface-2);border:2px solid var(--bd);
  text-align:center;font-size:13px;font-weight:600;cursor:pointer;
  transition:all var(--dur);color:var(--sub)}
.ot-tab .ot-ic{display:block;font-size:22px;margin-bottom:4px}
.ot-tab.active{background:var(--pri-l);border-color:var(--pri);color:var(--pri)}

/* ── Pay Options ─────────────────────────────────────────────── */
.pay-opt{display:flex;align-items:center;gap:12px;width:100%;padding:14px;
  background:var(--surface-2);border:2px solid var(--bd);border-radius:var(--r-s);
  cursor:pointer;margin-bottom:8px;transition:all var(--dur);text-align:left}
.pay-opt:last-child{margin-bottom:0}
.pay-opt.sel{background:var(--pri-l);border-color:var(--pri)}
.po-ic{font-size:22px}
.po-txt{flex:1}
.po-title{font-size:14px;font-weight:600;color:var(--ink);display:block}
.po-sub{font-size:12px;color:var(--sub)}

/* ── Price Summary ───────────────────────────────────────────── */
.ir{display:flex;align-items:center;justify-content:space-between;padding:7px 0;
  font-size:13px;color:var(--ink-2)}
.ir+.ir{border-top:1px solid var(--bd-l)}
.ir-l{color:var(--sub)}
.ir-r{font-weight:500}
.sum-row{display:flex;align-items:baseline;justify-content:space-between;
  padding:12px 0 4px;margin-top:6px;border-top:2px solid var(--bd);
  font-size:13px;font-weight:700;color:var(--ink)}
.sum-price{font-size:22px;font-weight:900;color:var(--pri);letter-spacing:-.5px}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 20px;
  border-radius:var(--r-s);font-size:14px;font-weight:600;border:none;cursor:pointer;
  transition:all var(--dur) var(--ease);line-height:1;gap:6px;text-decoration:none}
.btn:active{transform:scale(.97)}
.btn-pri{background:var(--pri-grd);color:#fff;box-shadow:var(--sh-pri)}
.btn-pri:active{box-shadow:none}
.btn-gray{background:var(--surface-2);color:var(--ink-2);border:1.5px solid var(--bd)}
.btn-out{background:transparent;color:var(--pri);border:1.5px solid var(--pri)}
.btn-danger{background:#fff1f0;color:var(--err);border:1.5px solid #fecaca}
.btn-full{width:100%}
.btn-lg{padding:14px 24px;font-size:15px;border-radius:var(--r)}
.btn-sm{padding:7px 14px;font-size:12px;border-radius:var(--r-xs)}
.btn[disabled]{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}

/* ── Form Fields ─────────────────────────────────────────────── */
.fg{margin-bottom:14px}
.fg:last-child{margin-bottom:0}
.flabel{display:block;font-size:12px;font-weight:600;color:var(--sub);
  margin-bottom:6px;letter-spacing:.2px}
.finput{width:100%;padding:12px 14px;border:1.5px solid var(--bd);
  border-radius:var(--r-s);background:var(--surface-2);font-size:14px;color:var(--ink);
  outline:none;transition:border-color var(--dur),box-shadow var(--dur);
  line-height:1.4;resize:none}
.finput:focus{border-color:var(--pri);box-shadow:0 0 0 3px rgba(255,68,56,.12);background:var(--surface)}
.finput::placeholder{color:var(--muted)}

/* ── Order Cards ─────────────────────────────────────────────── */
.order-card{background:var(--surface);border-radius:var(--r);box-shadow:var(--sh-s);
  overflow:hidden;display:block;margin-bottom:10px;transition:transform var(--dur)}
.order-card:active{transform:scale(.99)}
.order-card-hd{padding:13px 16px 10px;display:flex;align-items:center;
  justify-content:space-between;border-bottom:1px solid var(--bd-l)}
.order-card-name{font-size:14px;font-weight:700;margin-bottom:2px}
.order-card-no{font-size:11px;color:var(--muted)}
.order-item-row{padding:9px 16px;font-size:12.5px;color:var(--sub);
  border-bottom:1px solid var(--bd-l);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.order-card-ft{padding:10px 16px;display:flex;align-items:center;justify-content:space-between}
.order-total{font-size:13px;color:var(--sub)}
.order-total .am{font-size:16px;font-weight:800;color:var(--pri);margin-left:4px}

/* ── Order Detail Header ─────────────────────────────────────── */
.od-header{background:var(--pri-grd);padding:28px 20px 40px;text-align:center;
  color:#fff;position:relative;overflow:hidden;max-width:640px;margin:0 auto}
.od-header::before{content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 70% 20%,rgba(255,255,255,.12),transparent 60%)}
.od-header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:28px;
  background:var(--bg);border-radius:28px 28px 0 0}
.od-status{font-size:28px;font-weight:900;letter-spacing:-.8px;position:relative}
.od-no{font-size:12px;opacity:.7;margin-top:5px;position:relative}
.od-amount{font-size:40px;font-weight:900;margin-top:10px;letter-spacing:-2px;position:relative}
.od-amount small{font-size:20px;letter-spacing:0}

/* ── Pickup Number ───────────────────────────────────────────── */
.pickup-block{background:var(--acc-l);border:2px dashed var(--acc);
  border-radius:var(--r);padding:20px;text-align:center;margin:0 14px 12px}
.pickup-num{font-size:52px;font-weight:900;color:var(--acc);letter-spacing:-2px;line-height:1}

/* ── Status Pills ────────────────────────────────────────────── */
.status-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:100px;
  font-size:11px;font-weight:700;letter-spacing:.3px;white-space:nowrap}
.s-pending{background:#fef3c7;color:#92400e}
.s-confirmed{background:#dbeafe;color:#1e40af}
.s-preparing{background:#ede9fe;color:#5b21b6}
.s-ready{background:var(--ok-l);color:#065f46}
.s-completed{background:#f0fdf4;color:#166534}
.s-cancelled{background:#f8fafc;color:var(--sub)}
.s-paid{background:var(--ok-l);color:#065f46}
.s-unpaid{background:var(--pri-l);color:var(--pri-d)}

/* ── Overlays & Sheets ───────────────────────────────────────── */
/* ── Overlay / Modal ──────────────────────────────────────────── */


.overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.0);
  display:none;align-items:center;justify-content:center;
  padding:20px;box-sizing:border-box}
.overlay.show{display:flex;background:rgba(0,0,0,.5);animation:fadeIn .2s ease}

.overlay-backdrop{position:absolute;inset:0;z-index:0}
.overlay .sheet{position:relative;z-index:1}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.sheet{background:var(--surface);border-radius:var(--r-xl);
  width:100%;max-width:420px;max-height:85vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.25);
  animation:scaleIn .2s var(--ease)}
@keyframes scaleIn{from{transform:scale(.95);opacity:.6}to{transform:none;opacity:1}}
.sheet-handle{display:none}
.sheet-title{display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;font-size:16px;font-weight:800;
  border-bottom:1px solid var(--bd-l);color:var(--ink)}

/* ── Notices ─────────────────────────────────────────────────── */
.notice{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;
  border-radius:var(--r-s);font-size:13px;line-height:1.5}
.n-ok{background:var(--ok-l);color:#065f46}
.n-warn{background:var(--warn-l);color:#92400e}
.n-err{background:#fef2f2;color:#991b1b}
.n-info{background:#eff6ff;color:#1e40af}

/* ── Toast ───────────────────────────────────────────────────── */
#toast-wrap{position:fixed;top:calc(var(--nav-h) + 10px);left:50%;transform:translateX(-50%);
  z-index:9999;width:calc(100% - 40px);max-width:360px;pointer-events:none;
  display:flex;flex-direction:column;gap:8px}
.toast{background:rgba(23,20,18,.88);backdrop-filter:blur(12px);color:#fff;
  padding:12px 18px;border-radius:var(--r);font-size:13.5px;font-weight:500;
  text-align:center;box-shadow:var(--sh-l);animation:toastIn .25s var(--ease)}
@keyframes toastIn{from{transform:translateY(-10px);opacity:0}to{transform:none;opacity:1}}
.toast.ok{background:rgba(0,182,155,.9)}
.toast.err{background:rgba(239,68,68,.9)}

/* ── Loading ─────────────────────────────────────────────────── */
.loading-page{display:flex;flex-direction:column;align-items:center;
  justify-content:center;min-height:40vh;gap:14px;color:var(--muted);font-size:13px}
.loader{width:28px;height:28px;border-radius:50%;border:3px solid var(--bd-l);
  border-top-color:var(--pri);animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Empty State ─────────────────────────────────────────────── */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:45vh;gap:10px;padding:40px 20px;text-align:center}
.ei{font-size:52px}
.et{font-size:16px;font-weight:700;color:var(--ink-2)}
.es{font-size:13px;color:var(--muted)}

/* ── Auth ────────────────────────────────────────────────────── */
.auth-page{min-height:calc(100dvh - var(--nav-h));display:flex;flex-direction:column;
  align-items:center;padding:40px 20px 30px;max-width:480px;margin:0 auto}
.auth-logo{width:72px;height:72px;border-radius:22px;background:var(--pri-grd);
  display:flex;align-items:center;justify-content:center;font-size:38px;
  box-shadow:var(--sh-pri);margin-bottom:18px}
.auth-title{font-size:24px;font-weight:900;letter-spacing:-.5px;margin-bottom:5px}
.auth-sub{font-size:14px;color:var(--sub);margin-bottom:32px}
.auth-box{width:100%;background:var(--surface);border-radius:var(--r-l);
  box-shadow:var(--sh);padding:24px 22px;margin-bottom:16px}

/* ── Coupon Card ─────────────────────────────────────────────── */
.coupon{display:flex;gap:0;overflow:hidden;border-radius:var(--r);
  box-shadow:var(--sh-s);margin-bottom:10px;position:relative}
.coupon-l{background:var(--pri-grd);color:#fff;padding:20px 16px;min-width:88px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.coupon-amt{font-size:26px;font-weight:900;letter-spacing:-1px;line-height:1}
.coupon-unit{font-size:11px;font-weight:600;opacity:.85;margin-top:3px}
.coupon-r{background:var(--surface);flex:1;padding:16px 14px;
  border-top:1px solid var(--bd-l);border-right:1px solid var(--bd-l);
  border-bottom:1px solid var(--bd-l);border-radius:0 var(--r) var(--r) 0}
.coupon-name{font-size:14px;font-weight:700;margin-bottom:4px}
.coupon-cond{font-size:12px;color:var(--sub);margin-bottom:3px}
.coupon-exp{font-size:11px;color:var(--muted)}

/* ── Balance / Points Card ───────────────────────────────────── */
.bal-card{background:var(--pri-grd);color:#fff;padding:28px 20px 24px;
  text-align:center;position:relative;overflow:hidden;max-width:640px;margin:0 auto}
.bal-card::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:22px;
  background:var(--bg);border-radius:22px 22px 0 0}
.bal-label{font-size:13px;opacity:.8;margin-bottom:6px}
.bal-amt{font-size:44px;font-weight:900;letter-spacing:-2px;line-height:1}
.bal-sub{font-size:12px;opacity:.75;margin-top:6px}

/* ── History rows ────────────────────────────────────────────── */
.hist-row{display:flex;align-items:center;gap:12px;padding:12px 16px;
  border-bottom:1px solid var(--bd-l)}
.hist-row:last-child{border-bottom:none}
.hist-ic{width:36px;height:36px;border-radius:50%;background:var(--surface-2);
  border:1.5px solid var(--bd);display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0}
.hist-ic.in{background:var(--ok-l);border-color:rgba(0,182,155,.3)}
.hist-ic.out{background:var(--pri-l);border-color:rgba(255,68,56,.2)}
.hist-info{flex:1;min-width:0}
.hist-title{font-size:13px;font-weight:600}
.hist-date{font-size:11px;color:var(--muted);margin-top:2px}
.hist-amt{font-size:15px;font-weight:700}
.hist-amt.in{color:var(--ok)}
.hist-amt.out{color:var(--pri)}

/* ── Checkin ─────────────────────────────────────────────────── */
.streak-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.sd{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;background:var(--surface-2);color:var(--muted);
  border:1.5px solid var(--bd)}
.sd.done{background:var(--pri-l);color:var(--pri);border-color:rgba(255,68,56,.3)}
.sd.today{background:var(--pri-grd);color:#fff;border-color:transparent;
  box-shadow:var(--sh-pri);font-weight:800}

/* ── Star Rating ─────────────────────────────────────────────── */
.star-rate{display:flex;gap:6px}
.star-rate span{font-size:28px;cursor:pointer;transition:transform var(--dur);
  filter:grayscale(1) opacity(.4)}
.star-rate span.lit{filter:none;transform:scale(1.1)}

/* ── Mall ────────────────────────────────────────────────────── */
.mall-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mall-card{background:var(--surface);border-radius:var(--r);box-shadow:var(--sh-s);
  overflow:hidden;display:block;transition:transform var(--dur)}
.mall-card:active{transform:scale(.97)}
.mall-img{width:100%;height:120px;object-fit:cover}
.mall-body{padding:10px 12px 12px}
.mall-name{font-size:13px;font-weight:700;margin-bottom:5px;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mall-pts{font-size:16px;font-weight:800;color:var(--pri)}
.mall-stock{font-size:11px;color:var(--muted);margin-top:3px}

/* ── QR Block ────────────────────────────────────────────────── */
.qr-block{padding:20px 20px 8px;display:flex;flex-direction:column;align-items:center;gap:12px}
#qr-img{width:200px;height:200px;border-radius:var(--r);box-shadow:var(--sh)}
.qr-hint{font-size:13px;color:var(--sub);text-align:center}

/* ── Level Cards ─────────────────────────────────────────────── */
.opt-card{display:flex;align-items:center;gap:12px;padding:14px 0;
  border-bottom:1px solid var(--bd-l)}
.opt-card:last-child{border-bottom:none}
.opt-card.sel{color:var(--pri)}

/* ── Cat sticky nav ──────────────────────────────────────────── */
.cat-sticky{position:sticky;top:var(--nav-h);z-index:100;
  background:rgba(248,245,242,.92);backdrop-filter:blur(10px)}
[id^="cat-"]{scroll-margin-top:calc(var(--nav-h) + 56px)}

/* ── Misc ────────────────────────────────────────────────────── */
.divider{height:1px;background:var(--bd-l);margin:4px 0}
.page-end-pad{height:24px}
.ir-row-item{display:flex;align-items:center;justify-content:space-between;
  padding:11px 0;border-bottom:1px solid var(--bd-l);font-size:13px}
.ir-row-item:last-child{border-bottom:none}

/* ===== 红包页面样式 ===== */
.bonus-page {
    max-width: 640px;
    margin: 0 auto;
    padding: 12px 14px 20px;
}

/* 红包余额卡片 */
.bonus-card {
    position: relative;
    background: linear-gradient(135deg, #f43f5e 0%, #e11d48 100%);
    border-radius: 24px;
    margin-bottom: 16px;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s ease;
    box-shadow: 0 8px 24px rgba(244, 63, 94, 0.25);
}

.bonus-card:active {
    transform: scale(0.98);
}

.bonus-card-bg {
    position: absolute;
    top: -30%;
    right: -20%;
    width: 150px;
    height: 150px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
}

.bonus-card-bg::before {
    content: '';
    position: absolute;
    top: 20px;
    left: 20px;
    width: 100px;
    height: 100px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 50%;
}

.bonus-card-content {
    position: relative;
    padding: 24px 20px;
    color: #fff;
}

.bonus-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    opacity: 0.9;
    margin-bottom: 12px;
}

.bonus-icon {
    font-size: 20px;
}

.bonus-amount {
    font-size: 48px;
    font-weight: 800;
    letter-spacing: -1px;
    margin-bottom: 20px;
    line-height: 1;
}

.bonus-stats {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.stat-item {
    flex: 1;
    text-align: center;
}

.stat-value {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 4px;
}

.stat-label {
    font-size: 11px;
    opacity: 0.7;
}

.stat-divider {
    width: 1px;
    height: 30px;
    background: rgba(255, 255, 255, 0.2);
}

/* 使用说明卡片 */
.bonus-rules-card {
    background: #fff;
    border-radius: 20px;
    padding: 18px 20px;
    margin-bottom: 16px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

.rules-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
    font-weight: 600;
    font-size: 15px;
    color: #1f2937;
}

.rules-tip {
    font-size: 11px;
    font-weight: 400;
    color: #f59e0b;
    background: #fffbeb;
    padding: 4px 10px;
    border-radius: 20px;
}

.rules-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.rule-item {
    font-size: 13px;
    color: #6b7280;
    line-height: 1.5;
}

.estimate-box {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid #f3f4f6;
}

.estimate-title {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    margin-bottom: 10px;
}

.estimate-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #f9fafb;
    padding: 10px 14px;
    border-radius: 12px;
    font-size: 14px;
}

.estimate-arrow {
    color: #9ca3af;
}

.estimate-amount {
    font-weight: 700;
    color: #f43f5e;
}

.estimate-desc {
    font-size: 11px;
    color: #9ca3af;
    margin-top: 8px;
    text-align: center;
}

/* 红包流水卡片 */
.bonus-logs-card {
    background: #fff;
    border-radius: 20px;
    margin-bottom: 16px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

.logs-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid #f3f4f6;
    font-weight: 600;
    font-size: 15px;
    color: #1f2937;
}

.logs-count {
    font-size: 12px;
    font-weight: 400;
    color: #9ca3af;
}

.logs-list {
    max-height: 500px;
    overflow-y: auto;
}

.bonus-log-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 20px;
    border-bottom: 1px solid #f9fafb;
    cursor: pointer;
    transition: background 0.2s;
}

.bonus-log-item:hover {
    background: #fafafa;
}

.bonus-log-item:active {
    background: #f5f5f5;
}

.log-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}

.log-info {
    flex: 1;
    min-width: 0;
}

.log-title {
    font-size: 14px;
    font-weight: 600;
    color: #1f2937;
    margin-bottom: 4px;
}

.log-source {
    font-size: 11px;
    color: #9ca3af;
    margin-bottom: 2px;
}

.log-expire {
    font-size: 10px;
    margin-bottom: 2px;
}

.log-expire:not(.expired) {
    color: #f59e0b;
}

.log-expire.expired {
    color: #ef4444;
}

.log-time {
    font-size: 11px;
    color: #cbd5e1;
}

.log-amount {
    font-size: 15px;
    font-weight: 700;
    flex-shrink: 0;
}

.empty-logs {
    text-align: center;
    padding: 40px 20px;
    color: #9ca3af;
    font-size: 14px;
}

/* 常见问题卡片 */
.bonus-faq-card {
    background: #fff;
    border-radius: 20px;
    padding: 18px 20px;
    margin-bottom: 20px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

.faq-header {
    font-weight: 600;
    font-size: 15px;
    color: #1f2937;
    margin-bottom: 14px;
}

.faq-item {
    margin-bottom: 14px;
}

.faq-item:last-child {
    margin-bottom: 0;
}

.faq-question {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    margin-bottom: 6px;
}

.faq-answer {
    font-size: 12px;
    color: #6b7280;
    line-height: 1.5;
    padding-left: 8px;
    border-left: 2px solid #fee2e2;
}

/* 红包卡片动画 */
@keyframes bonusShine {
    0% { transform: translateX(-100%) rotate(45deg); }
    100% { transform: translateX(200%) rotate(45deg); }
}

.bonus-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 50%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transform: rotate(45deg);
    pointer-events: none;
}

.bonus-card:active::after {
    animation: bonusShine 0.5s ease-out;
}


/* 2026年4月3日00:19:21 */

/* 商家页面 - 不限制整体高度 */
.merchant-page {
    display: block;
    /* 删除 height 和 overflow */
}

/* 左右布局 - 使用 flex 对齐，但不限制高度 */
.merchant-layout {
    display: flex;
    align-items: flex-start;  /* 顶部对齐，不拉伸高度 */
    gap: 0;
    min-height: auto;  /* 不限制高度 */
}

/* 左侧菜单 - 粘性定位 + 独立滚动 */
.merchant-sidebar {
    position: sticky;
    top: calc(var(--nav-h) + 10px);  /* 距离顶部导航栏的位置 */
    width: 110px;
    flex-shrink: 0;
    background: var(--surface);
    border-right: 1px solid var(--bd);
    border-radius: 12px;
    max-height: calc(100vh - var(--nav-h) - 80px);  /* 限制最大高度 */
    overflow-y: auto;  /* 分类太多时内部滚动 */
    align-self: flex-start;
}

/* 右侧商品 - 正常滚动，无高度限制 */
.merchant-products {
    flex: 1;
    /* 不设置 overflow，让内容自然撑开 */
    padding-bottom: 20px;
}

/* 隐藏右侧商品区域自己的滚动条 */
.merchant-products::-webkit-scrollbar {
    display: none;
}

/* 商品分类标题 - 滚动时粘在右侧区域顶部 */
.product-section-cat {
    scroll-margin-top: 80px;  /* 滚动时留出空间给粘性元素 */
}

.cat-sidebar-list {
    padding: 8px 0;
}

.cat-sidebar-item {
    padding: 14px 12px;
    font-size: 13px;
    font-weight: 500;
    color: var(--sub);
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
    border-left: 3px solid transparent;
    word-break: break-word;
    line-height: 1.3;
}

.cat-sidebar-item.active {
    color: var(--pri);
    background: var(--pri-l);
    border-left-color: var(--pri);
    font-weight: 600;
}

/* 右侧商品区域 */
.merchant-products {
    flex: 1;
    background: var(--bg);
    overflow-y: auto;
    height: 100%;
}


.pcat-title {
    padding: 13px 16px 11px;
    font-size: 13px;
    font-weight: 700;
    color: var(--sub);
    background: var(--surface-2);
    position: sticky;
    top: 0;
    z-index: 10;
}

/* 响应式 */
@media (max-width: 480px) {
    .merchant-sidebar {
        width: 85px;
    }
    .cat-sidebar-item {
        font-size: 12px;
        padding: 12px 8px;
    }
}

/* ===== 商家店铺优惠券样式 ===== */
.merchant-coupons-section {
    background: var(--bg);
}

.coupon-scroll {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}

.coupon-scroll::-webkit-scrollbar {
    height: 3px;
}

.coupon-scroll::-webkit-scrollbar-track {
    background: var(--bd);
    border-radius: 3px;
}

.coupon-scroll::-webkit-scrollbar-thumb {
    background: var(--pri);
    border-radius: 3px;
}

.coupon-card-mini {
    flex-shrink: 0;
    width: 220px;
    background: var(--surface);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    transition: transform 0.2s, box-shadow 0.2s;
}

.coupon-card-mini:active {
    transform: scale(0.98);
}

.coupon-card-mini.disabled {
    opacity: 0.6;
}

.coupon-card-mini .coupon-left.amount {
    background: linear-gradient(135deg, #FF4B2B, #FF9E00);
}

.coupon-card-mini .coupon-left.percent {
    background: linear-gradient(135deg, #667eea, #764ba2);
}

.coupon-card-mini .coupon-left.shipping {
    background: linear-gradient(135deg, #11998e, #38ef7d);
}

.coupon-card-mini .claim-coupon-btn {
    transition: background 0.2s;
}

.coupon-card-mini .claim-coupon-btn:active {
    opacity: 0.8;
}

/* 优惠券适用范围标签 */
.coupon-scope-tag {
    display: inline-block;
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: 6px;
    white-space: nowrap;
}

.coupon-scope-tag.universal {
    background: #d1fae5;
    color: #065f46;
}

.coupon-scope-tag.specific {
    background: #fef3c7;
    color: #d97706;
}

/* 优惠券适用范围标签 */
.coupon-scope-tag {
    display: inline-block;
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: 6px;
    white-space: nowrap;
}

.coupon-scope-tag.universal {
    background: #d1fae5;
    color: #065f46;
}

.coupon-scope-tag.specific {
    background: #fef3c7;
    color: #d97706;
    cursor: pointer;
    transition: all 0.2s;
}

.coupon-scope-tag.specific:active {
    transform: scale(0.95);
}

/* 弹窗中的商品列表 */
#productListModal .sheet {
    animation: slideUp 0.3s ease;
}

@keyframes slideUp {
    from {
        transform: translateY(100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* 优惠券区域 */
.merchant-coupons-section {
    margin: 12px 16px;
}

/* 优惠券滚动容器 */
.coupon-scroll {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 8px;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}

.coupon-scroll::-webkit-scrollbar {
    height: 4px;
}

.coupon-scroll::-webkit-scrollbar-track {
    background: #f0f0f0;
    border-radius: 4px;
}

.coupon-scroll::-webkit-scrollbar-thumb {
    background: #ccc;
    border-radius: 4px;
}

/* 优惠券卡片 - 统一宽度 */
.coupon-card-mini {
    flex-shrink: 0;
    width: 280px;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    transition: transform 0.2s, box-shadow 0.2s;
    display: flex;
    flex-direction: column;
}

.coupon-card-mini:active {
    transform: scale(0.98);
}

.coupon-card-mini.disabled {
    opacity: 0.65;
}

/* 优惠券左侧颜色区域 */
.coupon-card-mini .coupon-left {
    width: 80px;
    padding: 14px 8px;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.coupon-card-mini.amount .coupon-left {
    background: linear-gradient(135deg, #FF4B2B, #FF9E00);
}

.coupon-card-mini.percent .coupon-left {
    background: linear-gradient(135deg, #667eea, #764ba2);
}

.coupon-card-mini.shipping .coupon-left {
    background: linear-gradient(135deg, #11998e, #38ef7d);
}

/* 适用范围标签 */
.coupon-scope-tag {
    display: inline-block;
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 10px;
    white-space: nowrap;
}

.coupon-scope-tag.universal {
    background: #d1fae5;
    color: #065f46;
}

.coupon-scope-tag.specific {
    background: #fef3c7;
    color: #d97706;
    cursor: pointer;
    transition: all 0.2s;
}

.coupon-scope-tag.specific:active {
    transform: scale(0.95);
}

/* 领取按钮 */
.claim-coupon-btn {
    transition: all 0.2s;
}

.claim-coupon-btn:active {
    opacity: 0.8;
}

.claim-coupon-btn:not(:disabled):active {
    transform: scale(0.98);
}

/* 商品列表弹窗 */
#productListModal .sheet {
    animation: slideUp 0.3s ease;
}

@keyframes slideUp {
    from {
        transform: translateY(100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* 弹窗内商品列表样式 */
#modalProductList .product-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid #f0f0f0;
}

#modalProductList .product-item:last-child {
    border-bottom: none;
}

#modalProductList .product-icon {
    font-size: 18px;
    width: 32px;
    text-align: center;
}

#modalProductList .product-name {
    font-size: 13px;
    color: #333;
    flex: 1;
}

/* ===== 地址管理页面样式 ===== */
.address-page {
    min-height: 100vh;
    background: var(--bg);
}

.address-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.address-card {
    background: var(--surface);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    transition: all 0.2s;
    border: 1px solid var(--bd);
}

.address-card.default {
    border-color: var(--pri);
    background: var(--pri-l);
}

.address-card-info {
    padding: 14px 16px;
    cursor: pointer;
}

.address-card-header {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
}

.address-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--ink);
}

.address-phone {
    font-size: 13px;
    color: var(--sub);
}

.address-tag {
    font-size: 10px;
    padding: 2px 8px;
    background: #f3f4f6;
    border-radius: 12px;
    color: #6b7280;
}

.address-default-badge {
    font-size: 10px;
    padding: 2px 8px;
    background: var(--pri);
    border-radius: 12px;
    color: #fff;
}

.address-detail {
    font-size: 13px;
    color: var(--ink-2);
    line-height: 1.5;
}

.address-warning {
    font-size: 11px;
    color: #f59e0b;
    margin-top: 6px;
}

.address-card-actions {
    display: flex;
    gap: 12px;
    padding: 10px 16px;
    border-top: 1px solid var(--bd);
    background: var(--surface-2);
}

.btn-icon {
    background: none;
    border: none;
    font-size: 14px;
    cursor: pointer;
    color: var(--sub);
    padding: 4px 8px;
    border-radius: 6px;
    transition: all 0.2s;
}

.btn-icon:hover {
    background: var(--bd);
}

#map-container {
    width: 100%;
    height: 100%;
    min-height: 300px;
}
