/* ═══════════════════════════════════════════
   MENU PAGE
═══════════════════════════════════════════ */
.menu-pg{padding-top:var(--nav);min-height:100vh;background:#e9f5f0;}
.menu-pg.bakery-mode{
  --p:#b91c1c;
  --p2:#7f1d1d;
  --a:#ef4444;
  --accent-rgb:239,68,68;
  --sh-g:0 8px 24px rgba(239,68,68,.3);
  background:#fff1f1;
}
.menu-pg.bakery-mode .m-banner::after{background:#fff1f1;}

.m-banner{
  background:linear-gradient(135deg,#0a3d2c 0%,var(--p) 55%,var(--a) 100%);
  padding:52px 24px 110px;position:relative;overflow:hidden;
}
.m-banner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 80% 30%,rgba(var(--accent-rgb),.2) 0%,transparent 55%);
}
.m-banner::after{
  content:'';position:absolute;
  bottom:-66px;left:50%;transform:translateX(-50%);
  width:130%;height:132px;background:#e9f5f0;
  border-radius:50% 50% 0 0/100% 100% 0 0;
}
.m-banner-in{position:relative;z-index:1;max-width:600px;margin:0 auto;text-align:center;}
.m-banner h2{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,5vw,52px);font-weight:700;color:#fff;margin-bottom:8px;}
.m-banner h2 em{font-style:italic;opacity:.68;}
.m-banner p{color:rgba(255,255,255,.62);font-size:14px;margin-bottom:28px;}
.menu-toggle{
  display:inline-flex;align-items:center;gap:4px;
  padding:5px;margin:0 auto 20px;
  background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);
  border-radius:999px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.menu-toggle-btn{
  min-width:118px;border:0;border-radius:999px;background:transparent;color:rgba(255,255,255,.76);
  padding:10px 16px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:800;
  transition:background .22s var(--ease),color .22s var(--ease),box-shadow .22s var(--ease);
}
.menu-toggle-btn.on{background:#fff;color:var(--p);box-shadow:0 8px 22px rgba(0,0,0,.18);}
@media(max-width:480px){
  .menu-toggle{display:flex;width:100%;}
  .menu-toggle-btn{flex:1;min-width:0;padding:10px 12px;}
}

/* Search */
.s-wrap{position:relative;max-width:440px;margin:0 auto;}
.s-ico{position:absolute;left:16px;top:50%;transform:translateY(-50%);pointer-events:none;}
.s-ico svg{width:15px;height:15px;stroke:var(--p);fill:none;stroke-width:2;}
.s-input{
  width:100%;padding:13px 18px 13px 44px;
  border-radius:50px;border:none;
  font-family:'DM Sans',sans-serif;font-size:14px;
  background:rgba(255,255,255,.95);color:var(--ink);
  box-shadow:0 8px 32px rgba(0,0,0,.2);outline:none;
  transition:background .2s,box-shadow .2s;
}
.s-input::placeholder{color:#a09a92;}
.s-input:focus{background:#fff;box-shadow:0 12px 40px rgba(0,0,0,.26);}

/* layout */
.m-layout{max-width:1480px;margin:0 auto;padding:32px 24px 120px;}
.m-layout > .m-side{display:none!important;}

/* sidebar */
.m-side{
  width:220px;flex-shrink:0;align-self:flex-start;
  height:min(640px, calc(100vh - var(--nav) - 42px));overflow:hidden;overscroll-behavior:contain;
  scrollbar-width:thin;scrollbar-color:rgba(var(--accent-rgb),.22) transparent;
  background:var(--card);border-radius:var(--r);padding:8px;box-shadow:var(--sh-sm);
  border:1px solid rgba(0,0,0,.04);display:none;
}
.m-side-menu{flex:1;min-height:0;overflow-y:auto;padding:0 4px 4px 0;scrollbar-width:thin;scrollbar-color:rgba(var(--accent-rgb),.22) transparent;}
.m-side-menu::-webkit-scrollbar{width:4px;}
.m-side-menu::-webkit-scrollbar-track{background:transparent;}
.m-side-menu::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),.22);border-radius:4px;}
@media(min-width:1024px){.m-side-inline{display:flex;flex-direction:column;position:sticky;top:calc(var(--nav) + 18px);}}
.sb-head{flex-shrink:0;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);padding:10px 12px 8px;}
.sb-btn{
  width:100%;text-align:left;padding:9px 13px;border-radius:10px;border:1px solid rgba(0,0,0,.035);background:var(--cream);
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--muted);
  cursor:pointer;display:flex;align-items:center;justify-content:space-between;position:relative;
  transition:all .18s var(--ease);box-shadow:0 1px 0 rgba(255,255,255,.74) inset;
}
.sb-btn + .sb-btn{margin-top:4px;}
.sb-btn:hover{background:#fff;color:var(--p);border-color:rgba(var(--accent-rgb),.12);}
.sb-btn.on{background:linear-gradient(135deg,rgba(var(--accent-rgb),.11),rgba(var(--accent-rgb),.08));color:var(--p);font-weight:600;border-color:rgba(var(--accent-rgb),.15);}
.sb-btn.on::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:58%;background:linear-gradient(var(--p),var(--a));border-radius:0 2px 2px 0;}
.sb-ct{font-size:10px;font-weight:600;color:var(--muted);background:var(--cream);border-radius:50px;padding:1px 7px;}
.sb-btn.on .sb-ct{background:rgba(var(--accent-rgb),.1);color:var(--p);}

.m-right{min-width:0;}

/* Menu skeleton */
.menu-skeleton{
  display:grid;grid-template-columns:minmax(0,1fr);gap:24px;
}
.menu-skel-label,
.menu-skel-cat,
.menu-skel-title,
.menu-skel-line,
.menu-skel-count,
.menu-skel-img,
.menu-skel-text,
.menu-skel-button,
.menu-skel-orbit div{
  position:relative;overflow:hidden;background:#dfe8e2;border-radius:12px;
}
.menu-skel-label::after,
.menu-skel-cat::after,
.menu-skel-title::after,
.menu-skel-line::after,
.menu-skel-count::after,
.menu-skel-img::after,
.menu-skel-text::after,
.menu-skel-button::after,
.menu-skel-orbit div::after{
  content:'';position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);
  animation:skeletonSweep 1.35s ease-in-out infinite;
}
.menu-skel-side{display:none;}
.menu-skel-main{background:transparent;}
.menu-skel-head{display:flex;align-items:center;gap:14px;margin-bottom:24px;}
.menu-skel-title{width:180px;height:34px;border-radius:10px;}
.menu-skel-line{flex:1;height:1px;border-radius:0;background:#d7dfd9;}
.menu-skel-count{width:86px;height:24px;border-radius:999px;background:#fff;}
.menu-skel-wheel{
  min-height:520px;border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.44),rgba(255,255,255,0));
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:38px 18px;
}
.menu-skel-orbit{
  width:min(660px,100%);height:150px;position:relative;margin-bottom:26px;
  background:transparent;
}
.menu-skel-orbit div{position:absolute;width:86px;height:86px;border-radius:50%;background:#d9e4dd;}
.menu-skel-orbit div:nth-child(1){left:4%;bottom:0;opacity:.45;}
.menu-skel-orbit div:nth-child(2){left:22%;top:18px;opacity:.7;}
.menu-skel-orbit div:nth-child(3){left:50%;top:0;transform:translateX(-50%);}
.menu-skel-orbit div:nth-child(4){right:22%;top:18px;opacity:.7;}
.menu-skel-orbit div:nth-child(5){right:4%;bottom:0;opacity:.45;}
.menu-skel-card{
  width:min(310px,100%);padding:16px;border-radius:20px;background:#fff;
  box-shadow:0 24px 64px rgba(0,0,0,.1);
}
.menu-skel-img{height:170px;border-radius:16px;margin-bottom:14px;background:#dfe5de;}
.menu-skel-text{height:14px;width:58%;border-radius:999px;margin-bottom:10px;background:#e5e0d7;}
.menu-skel-text.wide{width:86%;height:18px;}
.menu-skel-button{height:42px;border-radius:999px;margin-top:16px;background:#c7ddd4;}
@media(min-width:1024px){
  .menu-skeleton{grid-template-columns:220px minmax(0,1fr);gap:30px;}
  .menu-skel-side{display:block;background:#fff;border-radius:var(--r);padding:14px;box-shadow:var(--sh-sm);}
  .menu-skel-label{width:90px;height:10px;margin:4px 0 14px;border-radius:999px;background:#e5e0d7;}
  .menu-skel-cat{height:38px;margin-top:8px;border-radius:10px;background:#f2f0eb;}
  .menu-skel-cat.short{width:72%;}
}
@media(max-width:620px){
  .menu-skel-title{width:130px;}
  .menu-skel-count{display:none;}
  .menu-skel-wheel{min-height:440px;padding:28px 8px;}
  .menu-skel-orbit{height:112px;}
  .menu-skel-orbit div{width:62px;height:62px;}
  .menu-skel-img{height:145px;}
}
@media(prefers-reduced-motion:reduce){
  .menu-skel-label::after,
  .menu-skel-cat::after,
  .menu-skel-title::after,
  .menu-skel-line::after,
  .menu-skel-count::after,
  .menu-skel-img::after,
  .menu-skel-text::after,
  .menu-skel-button::after,
  .menu-skel-orbit div::after{animation:none;}
}

/* BOLD SLIDING TABS */
.m-tabs{position:relative;display:flex;overflow-x:auto;background:var(--card);border-radius:12px;padding:5px;gap:2px;box-shadow:var(--sh-sm);margin-bottom:28px;}
.m-tabs::-webkit-scrollbar{height:0;}
@media(min-width:1024px){.m-tabs{display:none;}}
.tabs-pill{position:absolute;top:5px;height:calc(100% - 10px);background:linear-gradient(135deg,var(--p),var(--a));border-radius:8px;transition:left .32s var(--ease),width .32s var(--ease);box-shadow:0 4px 14px rgba(var(--accent-rgb),.3);pointer-events:none;z-index:0;}
.tab-btn{position:relative;z-index:1;flex-shrink:0;padding:9px 16px;border:none;background:transparent;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;border-radius:8px;white-space:nowrap;transition:color .22s var(--ease);}
.tab-btn:hover:not(.on){color:var(--p);}
.tab-btn.on{color:#fff;}

/* no results */
.no-res{text-align:center;padding:60px 20px;color:var(--muted);}
.no-res svg{width:44px;height:44px;stroke:var(--border);fill:none;stroke-width:1.5;margin:0 auto 14px;}

/* ═══════════════════════════════════════════
   ITEM MODAL
═══════════════════════════════════════════ */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(15,20,18,.6);z-index:980;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
.modal-ov.on{display:flex;align-items:center;justify-content:center;animation:fadeIn .22s var(--ease);}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--card);border-radius:20px;width:90%;max-width:430px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.3);animation:modalIn .38s var(--spring);}
@keyframes modalIn{from{transform:scale(.82) translateY(28px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-img{width:100%;height:230px;object-fit:cover;background:#e8e4dc;display:block;}
.modal.unavailable .modal-img{filter:grayscale(.25);opacity:.82;}
.modal-body{padding:22px 24px 26px;}
.modal-unavailable{
  margin:0 0 10px;padding:9px 11px;border-radius:10px;
  background:#fff1f1;color:#b91c1c;border:1px solid rgba(185,28,28,.24);
  font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;
}
.modal-cat{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--a);margin-bottom:6px;}
.modal-name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:700;color:var(--ink);margin-bottom:6px;}
.modal-price{font-family:'DM Mono',monospace;font-size:20px;font-weight:500;color:var(--p);margin-bottom:16px;}
.modal-options{margin:0 0 18px;display:grid;gap:9px;}
.modal-options-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:1.4px;color:var(--muted);}
.modal-options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:8px;}
.modal-option{min-height:54px;border:1.5px solid var(--border);border-radius:12px;background:var(--cream);color:var(--ink);padding:9px 10px;display:grid;gap:3px;text-align:left;font-family:'DM Sans',sans-serif;cursor:pointer;transition:border-color .18s var(--ease),background .18s var(--ease),transform .18s var(--ease);}
.modal-option span{font-size:12px;font-weight:800;line-height:1.2;}
.modal-option strong{font-family:'DM Mono',monospace;font-size:13px;color:var(--p);}
.modal-option.on{border-color:var(--p);background:#edf8f4;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1);}
.modal-option:active{transform:scale(.98);}
.c-row-opt{font-size:11px;color:var(--p);font-weight:800;margin-top:2px;}
.qty-row{display:inline-flex;align-items:center;background:var(--cream);border-radius:12px;padding:5px;margin-bottom:18px;border:1px solid var(--border);}
.qty-b{width:38px;height:38px;border-radius:8px;border:none;background:var(--card);color:var(--p);font-size:20px;font-weight:600;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm);transition:all .18s var(--ease);}
.qty-b:hover{background:var(--p);color:#fff;}
.qty-b:active{transform:scale(.9);}
.qty-b.action-confirm{background:var(--p);color:#fff;}
.qty-v{width:52px;text-align:center;font-family:'DM Mono',monospace;font-size:18px;font-weight:500;}
.modal-cta{width:100%;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--p),var(--a));color:#fff;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;box-shadow:var(--sh-g);transition:transform .2s var(--spring),box-shadow .2s,filter .2s;}
.modal-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(var(--accent-rgb),.42);}
.modal-cta:active{transform:scale(.97);filter:brightness(.94);}
.modal-cta:disabled{
  cursor:not-allowed;background:#d8d1c8;color:#7a7570;box-shadow:none;transform:none;filter:none;
}

/* ═══════════════════════════════════════════
   CART POPUP (Mac-style centered modal)
═══════════════════════════════════════════ */
.cart-bd{
  position:fixed;inset:0;
  background:rgba(10,18,14,.55);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  z-index:1200;
  opacity:0;pointer-events:none;
  touch-action:none;overscroll-behavior:contain;
  transition:opacity .34s ease;
}
.cart-bd.on{opacity:1;pointer-events:auto;cursor:default;}

.cart-dr{
  position:fixed;
  top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0.82);
  width:92%;max-width:480px;
  max-height:88vh;
  background:var(--card);
  z-index:1210;
  border-radius:24px;
  display:flex;flex-direction:column;
  overflow:hidden;
  touch-action:auto;overscroll-behavior:contain;
  opacity:0;pointer-events:none;
  transition:
    opacity .4s cubic-bezier(.34,1.56,.64,1),
    transform .4s cubic-bezier(.34,1.56,.64,1);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.08),
    0 24px 60px rgba(0,0,0,.32),
    0 8px 20px rgba(0,0,0,.18);
}
.cart-dr.open{
  opacity:1;pointer-events:auto;
  transform:translate(-50%,-50%) scale(1);
}
.cart-dr.closing{
  opacity:0;
  transform:translate(-50%,-50%) scale(0.82);
  transition:
    opacity .28s cubic-bezier(.4,0,.2,1),
    transform .28s cubic-bezier(.4,0,.2,1);
}

.cart-head{
  padding:18px 22px;
  background:linear-gradient(135deg,var(--p),var(--a));
  color:#fff;
  display:flex;justify-content:space-between;align-items:center;
  flex-shrink:0;
  border-radius:24px 24px 0 0;
}
.cart-head-t{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;}
.cart-x{
  width:32px;height:32px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.12);
  color:#fff;display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.cart-x:hover{background:rgba(255,255,255,.26);transform:scale(1.08);}
.cart-x:active{transform:scale(.9);}
.cart-x svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2.5;}

.cart-body{flex:1;overflow-y:auto;padding:14px;}
.cart-body::-webkit-scrollbar{width:4px;}
.cart-body::-webkit-scrollbar-track{background:transparent;}
.cart-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}

.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--muted);text-align:center;}
.cart-empty svg{width:52px;height:52px;stroke:var(--border);fill:none;stroke-width:1.5;margin-bottom:14px;}
.cart-empty p{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:4px;}

.c-row{
  display:flex;gap:12px;align-items:center;
  padding:12px;background:var(--cream);
  border-radius:12px;margin-bottom:10px;
  border:1px solid var(--border);
  animation:rowIn .32s cubic-bezier(.34,1.56,.64,1);
}
@keyframes rowIn{from{opacity:0;transform:scale(.9) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.c-row.row-plus{animation:rowPulseGreen .46s var(--spring);}
.c-row.row-minus{animation:rowPulseWarm .46s var(--spring);}
@keyframes rowPulseGreen{
  0%{background:rgba(var(--accent-rgb),.2);transform:scale(1);}
  55%{background:rgba(var(--accent-rgb),.12);transform:scale(1.015);}
  100%{background:var(--cream);transform:scale(1);}
}
@keyframes rowPulseWarm{
  0%{background:#fff4dd;transform:scale(1);}
  55%{background:#fff8e8;transform:scale(1.015);}
  100%{background:var(--cream);transform:scale(1);}
}

.c-row-img{width:58px;height:58px;border-radius:10px;object-fit:cover;flex-shrink:0;background:#e0dcd5;}
.c-row-info{flex:1;min-width:0;}
.c-row-nm{font-weight:600;font-size:13px;color:var(--ink);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.c-row-pr{font-size:12px;color:var(--muted);font-family:'DM Mono',monospace;}
.c-ctrl{display:flex;align-items:center;gap:5px;background:var(--card);border-radius:8px;padding:3px;border:1px solid var(--border);flex-shrink:0;}
.cc-b{width:26px;height:26px;border:none;background:transparent;color:var(--p);font-weight:700;font-size:16px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.cc-b:hover{background:var(--p);color:#fff;}
.cc-b:active{transform:scale(.88);}
.cc-n{min-width:24px;text-align:center;font-family:'DM Mono',monospace;font-size:13px;font-weight:500;}
.cc-n.count-pop,.cart-tax-row span.count-pop{animation:countPop .4s var(--spring);color:var(--p);}
@keyframes countPop{0%{transform:scale(1)}50%{transform:scale(1.28)}100%{transform:scale(1)}}

.cart-foot{padding:16px 18px;border-top:1px solid var(--border);background:var(--card);flex-shrink:0;}
.cart-tot-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;}
.cart-tot-l{font-size:13px;color:var(--muted);}
.cart-tot-v{font-family:'DM Mono',monospace;font-size:22px;font-weight:500;color:var(--p);}
.cart-tot-v.bump{animation:bump .4s var(--spring);}
@keyframes bump{0%{transform:scale(1)}50%{transform:scale(1.22)}100%{transform:scale(1)}}
.cart-cta{width:100%;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--p),var(--a));color:#fff;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;box-shadow:var(--sh-g);transition:transform .2s var(--spring),box-shadow .2s,filter .2s;}
.cart-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(var(--accent-rgb),.42);}
.cart-cta:active{transform:scale(.97);filter:brightness(.94);}

.co-view{display:none;padding:20px;overflow-y:auto;flex:1;}
.co-view.on{display:block;}
.co-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:var(--ink);margin-bottom:20px;}
.fulfillment-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;}
.fulfillment-option{border:1.5px solid var(--border);border-radius:12px;background:var(--cream);padding:11px 10px;text-align:left;color:var(--ink);font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .2s var(--ease);}
.fulfillment-option span{display:block;font-size:13px;font-weight:800;margin-bottom:3px;}
.fulfillment-option small{display:block;font-size:10px;line-height:1.35;color:var(--muted);}
.fulfillment-option.on{border-color:var(--p);background:rgba(var(--accent-rgb),.09);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.08);}
.fulfillment-option.on span{color:var(--p);}
.field{margin-bottom:15px;}
.field label{display:block;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);margin-bottom:6px;}
.field input,.field textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);background:var(--cream);transition:all .2s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--p);background:var(--card);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1);}
.field textarea{resize:vertical;min-height:78px;}
.co-btn{width:100%;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--p),var(--a));color:#fff;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;box-shadow:var(--sh-g);margin-bottom:10px;transition:transform .2s var(--spring),box-shadow .2s,filter .2s;display:flex;align-items:center;justify-content:center;}
.co-btn.is-loading{gap:10px;filter:saturate(.98);cursor:wait;box-shadow:0 14px 34px rgba(var(--accent-rgb),.34);}
.co-btn.is-loading .btn-spinner{width:17px;height:17px;border-width:2.5px;}
.co-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(var(--accent-rgb),.42);}
.co-btn:active{transform:scale(.97);filter:brightness(.94);}
.co-back{width:100%;padding:11px;border-radius:12px;border:1.5px solid var(--border);background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;transition:all .2s;}
.co-back:hover{border-color:var(--p);color:var(--p);}

.delivery-location{display:grid;gap:10px;margin-bottom:12px;}
.saved-addresses{display:none;gap:8px;overflow-x:auto;padding-bottom:2px;}
.saved-addresses.has-items{display:flex;}
.saved-address-card{
  min-width:170px;max-width:240px;border:1.5px solid var(--border);border-radius:12px;
  background:var(--cream);padding:9px 10px;text-align:left;color:var(--ink);
  font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .2s var(--ease);
}
.saved-address-card:hover{border-color:var(--p);background:rgba(var(--accent-rgb),.08);}
.saved-address-card strong{display:block;font-size:12px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.saved-address-card span{display:block;font-size:10px;color:var(--muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.address-search-wrap{position:relative;}
.address-suggestions{
  display:none;position:absolute;z-index:50;top:calc(100% + 4px);left:0;right:0;
  max-height:230px;overflow:auto;background:var(--card);border:1.5px solid var(--border);
  border-radius:12px;box-shadow:0 16px 42px rgba(0,0,0,.16);
}
.address-suggestions.on{display:block;}
.address-suggestion{
  width:100%;border:0;background:transparent;text-align:left;padding:10px 12px;
  font-family:'DM Sans',sans-serif;color:var(--ink);cursor:pointer;
}
.address-suggestion:hover{background:rgba(var(--accent-rgb),.08);}
.address-suggestion strong{display:block;font-size:12px;margin-bottom:2px;}
.address-suggestion span{display:block;font-size:10px;color:var(--muted);line-height:1.35;}
.location-tools{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.loc-btn,.map-manual{
  width:100%;padding:11px 12px;border-radius:12px;margin-bottom:0;
  border:1.5px solid rgba(37,211,102,.4);background:rgba(37,211,102,.08);
  color:#1a8c45;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:800;
  display:flex;align-items:center;gap:8px;justify-content:center;
  transition:all .22s var(--ease);cursor:pointer;
}
.map-manual{
  border-color:rgba(var(--accent-rgb),.4);
  background:linear-gradient(135deg,rgba(var(--accent-rgb),.14),rgba(255,255,255,.92));
  color:var(--p);box-shadow:0 8px 18px rgba(var(--accent-rgb),.12);
}
.map-manual svg{stroke-width:2.6;}
.loc-btn:hover{background:rgba(37,211,102,.16);border-color:rgba(37,211,102,.65);}
.map-manual:hover{border-color:var(--p);background:rgba(var(--accent-rgb),.18);transform:translateY(-1px);}
.loc-btn:focus-visible,.map-manual:focus-visible,.map-ok:focus-visible,.map-clear:focus-visible{outline:3px solid rgba(var(--accent-rgb),.24);outline-offset:2px;}
.loc-btn.loading{cursor:progress;}
.loc-btn.loading::after{
  content:'';width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(26,140,69,.25);border-top-color:#1a8c45;
  animation:spin .75s linear infinite;
}
.loc-btn.got{background:rgba(37,211,102,.15);border-color:#25d366;color:#166534;}
.loc-btn.err{border-color:rgba(220,38,38,.4);background:rgba(220,38,38,.06);color:#991b1b;}
.map-picker{display:none;border:1.5px solid var(--border);border-radius:14px;overflow:hidden;background:var(--cream);}
.map-picker.on{display:block;}
.map-frame{height:92px;display:flex;align-items:center;justify-content:center;background:#e8e4dc;transition:height .24s var(--ease);}
.map-picker.expanded .map-frame{height:240px;}
.map-frame iframe{width:100%;height:100%;border:0;display:block;}
.map-frame #deliveryMap{width:100%;height:100%;}
.map-frame .leaflet-container{width:100%;height:100%;font-family:'DM Sans',sans-serif;}
.map-placeholder{font-size:12px;font-weight:700;color:var(--muted);}
.pin-help{display:none;padding:8px 10px;border-top:1px solid var(--border);background:rgba(var(--accent-rgb),.06);color:var(--muted);font-size:11px;line-height:1.35;}
.map-picker.ready .pin-help{display:block;}
.map-actions{display:none;gap:8px;padding:10px;background:var(--card);border-top:1px solid var(--border);}
.map-picker.ready .map-actions{display:flex;}
.map-ok,.map-clear{border:0;border-radius:10px;padding:10px 12px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:800;cursor:pointer;}
.map-ok{background:var(--p);color:#fff;flex:1;}
.map-clear{background:var(--cream);color:var(--muted);}
.map-ok.is-loading{cursor:wait;filter:saturate(.9);opacity:.82;}
.loc-status{
  display:none;font-size:11px;color:var(--muted);line-height:1.45;
  padding:9px 11px;border:1px solid var(--border);border-radius:12px;background:var(--cream);
}
.loc-status.on{display:block;}
.loc-status.ok{color:#166534;border-color:rgba(22,101,52,.22);background:rgba(22,101,52,.07);}
.loc-status.err{color:#991b1b;border-color:rgba(153,27,27,.22);background:rgba(153,27,27,.06);}
.delivery-location.location-confirmed .saved-addresses,
.delivery-location.location-confirmed .delivery-search-field,
.delivery-location.location-confirmed .location-tools,
.delivery-location.location-confirmed .map-picker{display:none!important;}
.delivery-location.location-confirmed #addressField textarea{
  border-color:rgba(22,101,52,.34);background:rgba(22,101,52,.045);
}
.location-change{
  display:none;justify-self:start;border:1.5px solid rgba(22,101,52,.22);
  background:#fff;color:#166534;border-radius:999px;padding:8px 12px;
  font-family:'DM Sans',sans-serif;font-size:12px;font-weight:800;cursor:pointer;
  transition:all .2s var(--ease);
}
.location-change:hover{border-color:#166534;background:rgba(22,101,52,.08);}
.delivery-location.location-confirmed .location-change{display:inline-flex;}
.payment-ready{
  display:none;margin:-2px 0 10px;padding:9px 12px;border-radius:12px;
  background:linear-gradient(135deg,rgba(22,101,52,.11),rgba(var(--accent-rgb),.08));
  border:1px solid rgba(22,101,52,.22);color:#166534;
  font-size:12px;font-weight:900;text-align:center;
}
.payment-ready.on{display:block;animation:readySlide .32s var(--spring);}
.co-btn.ready{
  position:relative;overflow:hidden;
  box-shadow:0 14px 32px rgba(var(--accent-rgb),.46),0 0 0 4px rgba(var(--accent-rgb),.1);
}
.co-btn.ready::after{
  content:'';position:absolute;inset:0;transform:translateX(-120%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);
  animation:payShine 2.2s ease-in-out infinite;
}
.co-btn.pay-pulse{animation:payPulse .9s var(--spring);}
@keyframes readySlide{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes payShine{0%,52%{transform:translateX(-120%)}82%,100%{transform:translateX(120%)}}
@keyframes payPulse{0%{transform:scale(1)}45%{transform:scale(1.035)}100%{transform:scale(1)}}
@media(max-width:420px){
  .location-tools{grid-template-columns:1fr;}
}

@media(prefers-reduced-motion:reduce){
  .c-row.row-plus,.c-row.row-minus,.cc-n.count-pop,.cart-tax-row span.count-pop,.loc-btn.loading::after,.payment-ready.on,.co-btn.ready::after,.co-btn.pay-pulse{
    animation:none!important;
  }
}

.cart-tax-row{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:5px;}
.cart-tax-row span:last-child{font-family:'DM Mono',monospace;}
.cart-divider{border:none;border-top:1px dashed var(--border);margin:8px 0;}

body.payment-flow-lock{overflow:hidden;touch-action:none;}
.payment-flow-ov{
  position:fixed;inset:0;z-index:10020;
  display:flex;align-items:center;justify-content:center;
  padding:22px;background:rgba(9,15,13,.66);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  opacity:0;pointer-events:none;
  transition:opacity .28s var(--ease);
}
.payment-flow-ov.on{opacity:1;pointer-events:auto;}
.payment-flow-card{
  width:min(100%,430px);
  border-radius:22px;padding:26px 24px 24px;
  background:linear-gradient(180deg,#fff 0%,var(--card) 54%,var(--cream) 100%);
  border:1px solid rgba(255,255,255,.78);
  color:var(--ink);text-align:center;
  box-shadow:0 30px 90px rgba(0,0,0,.32),0 0 0 1px rgba(37,62,53,.06);
  transform:translateY(18px) scale(.96);
  opacity:0;
  transition:transform .38s var(--spring),opacity .28s var(--ease);
}
.payment-flow-ov.on .payment-flow-card{transform:translateY(0) scale(1);opacity:1;}
.payment-loader{
  position:relative;display:grid;place-items:center;
  width:92px;height:92px;margin:0 auto 16px;
}
.payment-loader::before{
  content:'';position:absolute;inset:9px;border-radius:50%;
  background:rgba(var(--accent-rgb),.08);
  box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.08);
}
.payment-loader-ring{
  position:absolute;inset:0;border-radius:50%;
  border:4px solid rgba(var(--accent-rgb),.15);
  border-top-color:var(--p);
  border-right-color:var(--a);
  animation:paymentSpin .82s linear infinite;
}
.payment-loader-core{
  position:relative;z-index:1;width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--ink);color:#fff;
  font-family:'DM Mono',monospace;font-size:15px;font-weight:600;
  box-shadow:0 12px 24px rgba(0,0,0,.18);
}
.payment-flow-kicker{
  margin-bottom:8px;color:var(--p);
  font-size:11px;font-weight:900;letter-spacing:1.4px;text-transform:uppercase;
}
.payment-flow-title{
  margin:0 0 8px;font-family:'Cormorant Garamond',serif;
  font-size:30px;line-height:1.08;font-weight:700;color:var(--ink);
}
.payment-flow-copy{
  max-width:330px;margin:0 auto 18px;
  color:var(--muted);font-size:14px;line-height:1.55;
}
.payment-flow-steps{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  gap:7px;padding:8px;border-radius:14px;
  background:rgba(37,62,53,.05);
  border:1px solid rgba(37,62,53,.08);
}
.payment-flow-steps span{
  min-width:0;border-radius:10px;padding:8px 4px;
  color:var(--muted);background:transparent;
  font-size:10px;font-weight:900;text-transform:uppercase;
  letter-spacing:.4px;white-space:nowrap;
  transition:background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease);
}
.payment-flow-steps span.done{
  color:var(--p);background:rgba(var(--accent-rgb),.09);
}
.payment-flow-steps span.active{
  color:#fff;background:linear-gradient(135deg,var(--p),var(--a));
  box-shadow:0 8px 18px rgba(var(--accent-rgb),.22);
}
@keyframes paymentSpin{to{transform:rotate(360deg);}}

.order-success-ov{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:flex-end;justify-content:center;
  padding:18px;background:rgba(10,18,14,.54);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  opacity:0;pointer-events:none;
  transition:opacity .34s var(--ease);
}
.order-success-ov.on{opacity:1;pointer-events:auto;}
.order-success-card{
  width:100%;max-width:470px;
  background:var(--card);color:var(--ink);
  border-radius:22px;padding:24px;
  box-shadow:0 28px 90px rgba(0,0,0,.34),0 0 0 1px rgba(255,255,255,.45) inset;
  transform:translateY(34px) scale(.96);
  opacity:0;
  transition:transform .48s var(--spring),opacity .34s var(--ease);
}
.order-success-ov.on .order-success-card{transform:translateY(0) scale(1);opacity:1;}
.order-success-kicker{
  font-size:13px;font-weight:800;color:var(--p);
  text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;
}
.order-success-title{
  font-family:'Cormorant Garamond',serif;font-size:30px;
  line-height:1.05;font-weight:700;margin-bottom:10px;
}
.order-success-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.order-success-pill{
  border-radius:999px;background:rgba(var(--accent-rgb),.11);color:var(--p);
  padding:6px 10px;font-size:12px;font-weight:800;
}
.order-success-pill.neutral{background:var(--cream);color:var(--ink);}
.order-success-copy{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:18px;}
.tracking-preview{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
  margin:0 0 18px;padding:12px;border-radius:16px;
  background:linear-gradient(135deg,rgba(var(--accent-rgb),.1),rgba(var(--accent-rgb),.035));
  border:1px solid rgba(var(--accent-rgb),.16);
}
.track-dot{
  position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;
  color:var(--muted);font-size:9px;font-weight:800;text-align:center;text-transform:uppercase;letter-spacing:.5px;
}
.track-dot::before{
  content:'';width:12px;height:12px;border-radius:50%;
  background:var(--card);border:2px solid rgba(var(--accent-rgb),.32);
  box-shadow:0 0 0 0 rgba(var(--accent-rgb),.2);
  animation:trackPulse 1.8s ease-in-out infinite;
}
.track-dot.done{color:var(--p);}
.track-dot.done::before{background:var(--p);border-color:var(--p);}
.track-dot:nth-child(2)::before{animation-delay:.18s;}
.track-dot:nth-child(3)::before{animation-delay:.36s;}
.track-dot:nth-child(4)::before{animation-delay:.54s;}
@keyframes trackPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(var(--accent-rgb),.22)}
  50%{box-shadow:0 0 0 7px rgba(var(--accent-rgb),0)}
}
.order-success-track{
  display:block;text-align:center;background:linear-gradient(135deg,var(--p),var(--a));
  color:#fff;text-decoration:none;border-radius:12px;padding:13px 16px;
  font-weight:800;margin-bottom:10px;box-shadow:var(--sh-g);
  transition:transform .22s var(--spring),box-shadow .22s var(--ease),filter .2s;
}
.order-success-track:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(var(--accent-rgb),.34);}
.order-success-track:active{transform:scale(.97);filter:brightness(.94);}
.order-success-close{
  width:100%;border:1px solid var(--border);background:var(--card);
  border-radius:12px;padding:12px 16px;font-weight:700;color:var(--ink);
  transition:background .2s var(--ease),transform .2s var(--ease),border-color .2s var(--ease);
}
.order-success-close:hover{background:var(--cream);border-color:rgba(var(--accent-rgb),.32);}
.order-success-close:active{transform:scale(.98);}

@media(max-width:480px){
  .payment-flow-ov{align-items:flex-end;padding:14px;}
  .payment-flow-card{border-radius:20px;padding:22px 18px 18px;}
  .payment-loader{width:82px;height:82px;margin-bottom:14px;}
  .payment-loader-core{width:48px;height:48px;font-size:14px;}
  .payment-flow-title{font-size:27px;}
  .payment-flow-copy{font-size:13px;}
  .payment-flow-steps{gap:5px;padding:6px;}
  .payment-flow-steps span{font-size:9px;padding:7px 2px;letter-spacing:.2px;}
  .tracking-preview{grid-template-columns:repeat(2,1fr);}
}

@media(prefers-reduced-motion:reduce){
  .payment-flow-ov,.payment-flow-card,.payment-flow-steps span{transition:none!important;}
  .payment-loader-ring{animation:none!important;}
}
