.wbop-order-app { --wbop-dark:#14110d; --wbop-gold:#d99a28; --wbop-gold-2:#f3c15f; --wbop-cream:#fffaf2; --wbop-line:#eadfce; --wbop-muted:#716558; font-family:inherit; max-width:1320px; margin:0 auto; padding:clamp(14px,3vw,32px); color:var(--wbop-dark); }
.wbop-order-app * { box-sizing:border-box; }
.wbop-order-hero { background:linear-gradient(135deg,#17130f,#342415); color:#fff; border-radius:28px; padding:clamp(22px,5vw,44px); display:grid; grid-template-columns:1fr auto; gap:20px; align-items:end; box-shadow:0 22px 48px rgba(0,0,0,.14); }
.wbop-kicker { color:var(--wbop-gold-2)!important; text-transform:uppercase; letter-spacing:.14em; font-weight:800; font-size:12px; margin:0 0 8px!important; }
.wbop-order-hero h2 { color:#fff; font-size:clamp(34px,7vw,62px); line-height:1; margin:0 0 10px; font-weight:900; }
.wbop-order-hero p { color:#f7efe3; max-width:720px; margin:0; font-size:16px; }
.wbop-service-toggle,.wbop-time-toggle { display:flex; background:rgba(255,255,255,.12); padding:6px; border-radius:999px; gap:6px; }
.wbop-service-toggle button,.wbop-time-toggle button,.wbop-category-strip button,.wbop-mobile-cart-bar button,.wbop-tip-buttons button,.wbop-add-cart,.wbop-checkout-button,.wbop-qty button,.wbop-modal-close { min-height:44px; border:0; border-radius:999px; font-weight:800; cursor:pointer; font-family:inherit; }
.wbop-service-toggle button { color:#fff; background:transparent; padding:0 18px; }
.wbop-service-toggle button.is-active,.wbop-time-toggle button.is-active { color:#111; background:var(--wbop-gold-2); }
.wbop-schedule-card { margin:18px 0 8px; background:#fff; border:1px solid var(--wbop-line); border-radius:22px; padding:14px; display:grid; grid-template-columns:auto auto 1fr; align-items:center; gap:14px; box-shadow:0 12px 28px rgba(60,42,22,.06); }
.wbop-schedule-card strong { display:block; font-size:18px; }
.wbop-pill { display:inline-flex; align-items:center; border-radius:999px; padding:5px 10px; background:#fff5e5; color:#7b4c09; font-size:12px; font-weight:900; text-transform:uppercase; letter-spacing:.08em; }
.wbop-time-toggle { background:#f5ead9; justify-self:start; }
.wbop-time-toggle button { background:transparent; color:#231a13; padding:0 16px; }
.wbop-schedule-fields { display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap; }
.wbop-schedule-fields label { font-size:12px; font-weight:800; color:var(--wbop-muted); display:grid; gap:4px; }
.wbop-schedule-fields select,.wbop-search-row input,.wbop-custom-tip input,.wbop-item-notes textarea { border:1px solid var(--wbop-line); border-radius:16px; padding:10px 12px; font-size:16px; background:#fff; color:var(--wbop-dark); font-family:inherit; }
.wbop-category-strip { position:sticky; top:0; z-index:5; display:flex; gap:10px; overflow:auto; padding:14px 0; background:#fff; scrollbar-width:none; }
.wbop-category-strip::-webkit-scrollbar { display:none; }
.wbop-category-strip button { background:#fff8ed; border:1px solid var(--wbop-line); padding:0 18px; white-space:nowrap; color:#231a13; }
.wbop-category-strip button.is-active { background:#111; color:#fff; border-color:#111; }
.wbop-search-row { display:flex; align-items:center; gap:12px; margin:10px 0 18px; }
.wbop-search-row input { width:100%; min-height:50px; }
.wbop-search-row span { background:#f3eadc; color:#6a5540; border-radius:999px; padding:8px 12px; font-size:12px; font-weight:800; white-space:nowrap; }
.wbop-menu-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; padding-bottom:108px; }
.wbop-menu-card,.wbop-loading-card { background:#fff; border:1px solid var(--wbop-line); border-radius:24px; overflow:hidden; box-shadow:0 16px 35px rgba(60,42,22,.07); }
.wbop-card-button { all:unset; display:block; width:100%; height:100%; cursor:pointer; }
.wbop-menu-card-image { height:154px; background:radial-gradient(circle at 30% 30%,#f8ddb0,#b87523); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.wbop-menu-card-image img { width:100%; height:100%; object-fit:cover; }
.wbop-menu-card-content { padding:18px; }
.wbop-menu-card-content > span { display:inline-block; font-size:11px; text-transform:uppercase; letter-spacing:.08em; font-weight:900; color:#97630f; margin-bottom:7px; }
.wbop-menu-card h3 { margin:0 0 8px; font-size:20px; line-height:1.2; }
.wbop-menu-card p,.wbop-loading-card p { color:var(--wbop-muted); font-size:14px; margin:0 0 16px; }
.wbop-card-foot { display:flex; justify-content:space-between; align-items:center; gap:12px; }
.wbop-card-foot strong { font-size:18px; }
.wbop-card-foot em { background:#111; color:#fff; padding:12px 16px; border-radius:999px; font-style:normal; font-weight:900; }
.wbop-loading-card { grid-column:1/-1; padding:24px; }
.wbop-mobile-cart-bar { position:sticky; bottom:14px; z-index:10; margin:20px auto 0; max-width:820px; background:#111; color:#fff; border-radius:22px; padding:12px; display:flex; justify-content:space-between; align-items:center; gap:14px; box-shadow:0 20px 48px rgba(0,0,0,.25); }
.wbop-mobile-cart-bar span { display:block; color:#ddd; font-size:12px; margin-top:2px; }
.wbop-mobile-cart-bar button { background:var(--wbop-gold-2); color:#111; padding:0 20px; }
.wbop-mobile-cart-bar button:disabled { opacity:.55; cursor:not-allowed; }
.wbop-modal { position:fixed; inset:0; z-index:99999; display:none; }
.wbop-modal.is-open { display:block; }
.wbop-modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.52); }
.wbop-modal-sheet { position:absolute; left:50%; bottom:18px; transform:translateX(-50%); width:min(720px,calc(100vw - 24px)); max-height:calc(100vh - 40px); overflow:auto; background:#fff; border-radius:28px; box-shadow:0 30px 80px rgba(0,0,0,.35); padding:22px; }
.wbop-cart-sheet { width:min(680px,calc(100vw - 24px)); }
.wbop-modal-close { position:sticky; top:0; float:right; width:44px; background:#f3eadc; color:#111; font-size:26px; line-height:1; z-index:2; }
.wbop-modal-body h3,.wbop-cart-panel h3 { font-size:clamp(26px,5vw,38px); line-height:1.05; margin:4px 50px 8px 0; }
.wbop-modal-desc { color:var(--wbop-muted); margin:0 0 14px; }
.wbop-modal-price,.wbop-total-box div,.wbop-cart-line { display:flex; justify-content:space-between; align-items:flex-start; gap:14px; }
.wbop-modal-price { background:#fff7eb; border:1px solid var(--wbop-line); border-radius:18px; padding:12px 14px; margin:14px 0; }
.wbop-modal-price span,.wbop-total-box span { color:var(--wbop-muted); }
.wbop-modifier-group { border-top:1px solid var(--wbop-line); padding:16px 0; }
.wbop-modifier-group h4 { margin:0 0 4px; font-size:18px; }
.wbop-modifier-group p { margin:0 0 10px; color:var(--wbop-muted); font-size:13px; }
.wbop-modifier-row { min-height:50px; display:grid; grid-template-columns:28px 1fr auto; align-items:center; gap:10px; border:1px solid var(--wbop-line); border-radius:16px; padding:10px 12px; margin:8px 0; font-weight:700; }
.wbop-modifier-row input { width:22px; height:22px; }
.wbop-modifier-row strong { font-size:13px; color:#6b4d18; }
.wbop-no-mods,.wbop-checkout-note { background:#fff8ed; border:1px solid var(--wbop-line); border-radius:18px; padding:14px; margin:14px 0; color:#5f4c35; }
.wbop-no-mods p,.wbop-checkout-note p { margin:6px 0 0; }
.wbop-item-notes { display:grid; gap:6px; margin:12px 0; color:var(--wbop-muted); font-weight:800; }
.wbop-item-notes textarea { width:100%; resize:vertical; }
.wbop-add-row { position:sticky; bottom:0; background:#fff; padding-top:12px; display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:center; }
.wbop-qty { display:flex; align-items:center; gap:10px; background:#f3eadc; border-radius:999px; padding:6px; }
.wbop-qty button { width:44px; background:#fff; font-size:20px; }
.wbop-qty strong { min-width:22px; text-align:center; }
.wbop-add-cart,.wbop-checkout-button { background:#111; color:#fff; padding:0 20px; width:100%; }
.wbop-item-errors { color:#a40000; font-weight:800; margin-top:10px; }
.wbop-cart-items { display:grid; gap:10px; margin:12px 0; }
.wbop-cart-line { border:1px solid var(--wbop-line); border-radius:18px; padding:12px; }
.wbop-cart-line span { display:block; color:var(--wbop-muted); font-size:13px; margin-top:2px; }
.wbop-cart-line ul { margin:8px 0 0 18px; color:#5f4c35; font-size:13px; }
.wbop-cart-line p { margin:8px 0 0; color:#5f4c35; font-size:13px; }
.wbop-cart-line button { border:0; background:#f3eadc; border-radius:999px; padding:8px 10px; font-weight:800; margin-top:8px; }
.wbop-tip-box { border:1px solid var(--wbop-line); border-radius:20px; padding:14px; margin:14px 0; }
.wbop-tip-buttons { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; margin-top:10px; }
.wbop-tip-buttons button { background:#fff8ed; border:1px solid var(--wbop-line); color:#231a13; min-height:42px; }
.wbop-tip-buttons button.is-active { background:#111; color:#fff; border-color:#111; }
.wbop-custom-tip { display:grid; gap:6px; margin-top:10px; color:var(--wbop-muted); font-weight:800; }
.wbop-total-box { display:grid; gap:8px; border-top:1px solid var(--wbop-line); padding-top:14px; }
.wbop-total-box div { align-items:center; }
.wbop-grand-total { font-size:20px; border-top:1px solid var(--wbop-line); padding-top:10px; margin-top:4px; }
.wbop-empty-cart { color:var(--wbop-muted); }
@media (max-width: 980px) { .wbop-order-hero { grid-template-columns:1fr; } .wbop-menu-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } .wbop-schedule-card { grid-template-columns:1fr; align-items:stretch; } .wbop-schedule-fields { justify-content:stretch; } .wbop-schedule-fields label { flex:1; } }
@media (max-width: 640px) { .wbop-order-app { padding:12px 10px; } .wbop-order-hero { border-radius:22px; padding:24px 18px; } .wbop-service-toggle,.wbop-time-toggle { width:100%; } .wbop-service-toggle button,.wbop-time-toggle button { flex:1; } .wbop-menu-grid { grid-template-columns:1fr; gap:12px; } .wbop-menu-card { border-radius:18px; } .wbop-card-button { display:grid; grid-template-columns:104px 1fr; } .wbop-menu-card-image { height:100%; min-height:132px; } .wbop-menu-card-content { padding:14px; } .wbop-menu-card h3 { font-size:17px; } .wbop-card-foot em { padding:10px 12px; } .wbop-search-row { align-items:stretch; flex-direction:column; } .wbop-search-row span { align-self:flex-start; } .wbop-mobile-cart-bar { bottom:10px; border-radius:18px; } .wbop-modal-sheet { bottom:0; width:100%; max-height:92vh; border-radius:24px 24px 0 0; padding:18px; } .wbop-add-row { grid-template-columns:1fr; } .wbop-tip-buttons { grid-template-columns:repeat(3,1fr); } .wbop-cart-line { display:grid; grid-template-columns:1fr; } }

.wbop-required-badge,
.wbop-optional-badge {
  display: inline-flex;
  align-items: center;
  margin-left: .4rem;
  padding: .15rem .45rem;
  border-radius: 999px;
  font-size: .7rem;
  font-weight: 800;
  vertical-align: middle;
}
.wbop-required-badge { background: #111; color: #fff; }
.wbop-optional-badge { background: #f1f1f1; color: #555; }

/* v0.3.6 customer-facing layout polish */
.wbop-order-app {
  max-width: 1240px;
}

.wbop-category-strip {
  flex-wrap: wrap;
  overflow: visible;
  row-gap: 10px;
  padding: 12px 0 14px;
  top: 72px;
}

.wbop-category-strip button {
  min-height: 40px;
  padding: 0 15px;
  font-size: 14px;
}

.wbop-menu-grid {
  grid-template-columns: repeat(3, minmax(240px, 1fr));
  gap: 16px;
}

.wbop-menu-card-image {
  height: 128px;
}

.wbop-menu-card-content {
  padding: 15px;
}

.wbop-menu-card h3 {
  font-size: 18px;
}

.wbop-menu-card p {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 40px;
}

.wbop-card-foot em {
  padding: 10px 13px;
  font-size: 13px;
}

.wbop-modal-backdrop {
  backdrop-filter: blur(2px);
}

.wbop-modal-sheet {
  top: 50%;
  bottom: auto;
  transform: translate(-50%, -50%);
  width: min(580px, calc(100vw - 32px));
  max-height: min(84vh, 760px);
  padding: 18px;
  border-radius: 24px;
}

.wbop-cart-sheet {
  width: min(640px, calc(100vw - 32px));
}

.wbop-modal-close {
  width: 40px;
  min-height: 40px;
  font-size: 24px;
}

.wbop-modal-body h3,
.wbop-cart-panel h3 {
  font-size: clamp(24px, 3vw, 32px);
  margin-top: 0;
}

.wbop-modal-desc {
  font-size: 14px;
  line-height: 1.45;
}

.wbop-modal-price {
  margin: 10px 0;
  padding: 10px 12px;
}

.wbop-modifier-group {
  padding: 12px 0;
}

.wbop-modifier-group h4 {
  font-size: 16px;
}

.wbop-modifier-row {
  min-height: 44px;
  border-radius: 14px;
  padding: 8px 10px;
  margin: 6px 0;
}

.wbop-item-notes textarea {
  min-height: 76px;
}

.wbop-add-row {
  margin: 8px -18px -18px;
  padding: 12px 18px 18px;
  border-top: 1px solid var(--wbop-line);
  box-shadow: 0 -10px 24px rgba(255,255,255,.95);
}

@media (min-width: 981px) {
  .wbop-order-hero {
    padding-top: 36px;
    padding-bottom: 36px;
  }
}

@media (max-width: 980px) {
  .wbop-category-strip {
    top: 0;
  }
  .wbop-menu-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .wbop-category-strip {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    margin-left: -10px;
    margin-right: -10px;
    padding: 12px 10px;
    background: rgba(255,255,255,.97);
    box-shadow: 0 8px 18px rgba(60,42,22,.08);
  }
  .wbop-category-strip button {
    flex: 0 0 auto;
  }
  .wbop-menu-card p {
    min-height: 0;
  }
  .wbop-modal-sheet {
    top: auto;
    bottom: 0;
    transform: translateX(-50%);
    width: 100%;
    max-height: 88vh;
    border-radius: 22px 22px 0 0;
    padding: 16px;
  }
  .wbop-add-row {
    margin: 8px -16px -16px;
    padding: 12px 16px 16px;
  }
}

/* v0.3.7 collapsible modifier modal */
.wbop-accordion-group {
  border: 1px solid var(--wbop-line);
  border-radius: 18px;
  padding: 0;
  margin: 10px 0;
  overflow: hidden;
  background: #fff;
}
.wbop-accordion-group + .wbop-accordion-group {
  border-top: 1px solid var(--wbop-line);
}
.wbop-modifier-head {
  width: 100%;
  min-height: 58px;
  border: 0;
  background: #fff8ed;
  color: var(--wbop-dark);
  display: grid;
  grid-template-columns: 34px 1fr 32px;
  align-items: center;
  gap: 10px;
  padding: 12px;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
}
.wbop-accordion-group.is-complete .wbop-modifier-head {
  background: #f8f1e7;
}
.wbop-step-dot {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 13px;
}
.wbop-accordion-group.is-complete .wbop-step-dot {
  background: var(--wbop-gold-2);
  color: #111;
}
.wbop-head-text {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.wbop-head-text strong {
  font-size: 15px;
  line-height: 1.2;
}
.wbop-head-text em {
  color: var(--wbop-muted);
  font-style: normal;
  font-size: 11px;
  font-weight: 700;
}
.wbop-head-text small {
  color: #3f3328;
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wbop-collapse-icon {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 900;
}
.wbop-modifier-options {
  padding: 10px 12px 12px;
}
.wbop-accordion-group.is-collapsed .wbop-modifier-options {
  display: none;
}
.wbop-accordion-group.is-incomplete {
  box-shadow: inset 0 0 0 1px rgba(164,0,0,.08);
}
@media (max-width: 640px) {
  .wbop-modifier-head {
    grid-template-columns: 30px 1fr 28px;
    padding: 10px;
  }
  .wbop-step-dot,
  .wbop-collapse-icon {
    width: 28px;
    height: 28px;
  }
  .wbop-head-text strong { font-size: 14px; }
}


/* v0.3.8 customer cart behavior polish */
.wbop-added-toast {
  position: fixed;
  left: 50%;
  bottom: 98px;
  transform: translate(-50%, 18px);
  z-index: 100000;
  width: min(420px, calc(100vw - 28px));
  background: #111;
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 12px 14px;
  box-shadow: 0 18px 42px rgba(0,0,0,.28);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
.wbop-added-toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}
.wbop-added-toast strong {
  display: block;
  color: var(--wbop-gold-2);
  font-size: 14px;
  line-height: 1.2;
}
.wbop-added-toast span {
  display: block;
  color: #f7efe3;
  font-size: 13px;
  margin-top: 3px;
}
.wbop-mobile-cart-bar {
  transition: transform .18s ease, box-shadow .18s ease;
}
.wbop-mobile-cart-bar button:not(:disabled) {
  box-shadow: 0 8px 18px rgba(243,193,95,.25);
}
@media (max-width: 640px) {
  .wbop-added-toast {
    bottom: 92px;
    border-radius: 16px;
  }
  .wbop-mobile-cart-bar {
    align-items: center;
  }
  .wbop-mobile-cart-bar button {
    padding: 0 14px;
    white-space: nowrap;
  }
}

/* v0.3.9 Clover item photo polish */
.wbop-menu-card-image {
  height: 82px;
  background: #f8f1e7;
}
.wbop-menu-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.wbop-photo-placeholder {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #111;
  color: var(--wbop-gold-2);
  font-weight: 900;
  letter-spacing: .04em;
  font-size: 13px;
}
.wbop-modal-photo {
  height: 188px;
  border-radius: 20px;
  overflow: hidden;
  background: #f8f1e7;
  margin: 0 0 14px;
  border: 1px solid var(--wbop-line);
}
.wbop-modal-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (min-width: 641px) {
  .wbop-card-button {
    display: grid;
    grid-template-columns: 96px 1fr;
    min-height: 154px;
  }
  .wbop-menu-card-image {
    height: 100%;
    min-height: 154px;
  }
}
@media (max-width: 640px) {
  .wbop-card-button {
    grid-template-columns: 88px 1fr;
  }
  .wbop-menu-card-image {
    min-height: 118px;
    height: 100%;
  }
  .wbop-modal-photo {
    height: 150px;
    border-radius: 18px;
  }
}

/* v0.4.0 checkout/test order fields */
.wbop-checkout-form{margin-top:16px;border-top:1px solid rgba(0,0,0,.08);padding-top:16px;display:grid;gap:14px}.wbop-checkout-form h4{margin:0;font-size:15px}.wbop-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.wbop-form-grid label,.wbop-checkout-form label{display:grid;gap:5px;font-size:12px;font-weight:800;color:#30261f}.wbop-form-grid input,.wbop-form-grid select,.wbop-form-grid textarea,.wbop-checkout-form textarea{width:100%;border:1px solid rgba(0,0,0,.14);border-radius:12px;padding:10px 11px;font:inherit;background:#fff}.wbop-wide{grid-column:1/-1}.wbop-delivery-fields{background:#fff8ef;border:1px solid rgba(111,74,42,.14);border-radius:16px;padding:12px;display:grid;gap:12px}.wbop-delivery-fields[hidden]{display:none}.wbop-order-notes textarea{width:100%;border:1px solid rgba(0,0,0,.14);border-radius:12px;padding:10px 11px}.wbop-submit-result{display:none;border-radius:12px;padding:10px 12px;font-weight:800;font-size:13px}.wbop-submit-result.is-error{display:block;background:#fff1f0;color:#8a1f11;border:1px solid #f3b3aa}.wbop-submit-result.is-success{display:block;background:#effaf2;color:#12612b;border:1px solid #aee0bd}.wbop-submit-result.is-info{display:block;background:#f4f6fb;color:#20324d;border:1px solid #cdd7ec}.wbop-checkout-button:disabled{opacity:.58;cursor:not-allowed}
@media(max-width:640px){.wbop-form-grid{grid-template-columns:1fr}.wbop-cart-sheet{max-height:92vh}.wbop-checkout-form{padding-bottom:18px}}

/* v0.4.1 mobile app layout pass */
.wbop-mobile-home,
.wbop-mobile-bottom-nav {
  display: none;
}

@media (max-width: 720px) {
  .wbop-order-app {
    --wbop-app-green: #06a64f;
    --wbop-app-soft: #f7f7f4;
    max-width: none;
    margin: 0;
    padding: 0 0 140px;
    background: #fff;
    min-height: 100vh;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  }

  .wbop-mobile-home {
    display: block;
    background: #fff;
    padding-bottom: 14px;
  }

  .wbop-order-hero {
    display: none;
  }

  .wbop-mobile-hero {
    position: relative;
    min-height: 258px;
    padding: 54px 24px 18px;
    background:
      linear-gradient(to bottom, rgba(255,255,255,.05), rgba(255,255,255,.90) 72%, #fff),
      radial-gradient(circle at 16% 0%, rgba(0,0,0,.10), transparent 45%),
      linear-gradient(135deg, #221914, #5b3b22);
    background-size: cover;
    background-position: center;
    text-align: center;
  }

  .wbop-mobile-icon {
    position: absolute;
    top: 52px;
    width: 52px;
    height: 52px;
    min-height: 52px;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,.95);
    box-shadow: 0 8px 22px rgba(0,0,0,.10);
    font-size: 0;
    cursor: pointer;
  }
  .wbop-mobile-icon::before {
    display: block;
    font-size: 24px;
    line-height: 52px;
    color: #111;
  }
  .wbop-mobile-icon[data-mobile-profile] { left: 24px; }
  .wbop-mobile-icon[data-mobile-profile]::before { content: '●'; font-size: 28px; transform: translateY(-1px); }
  .wbop-mobile-icon[data-mobile-location] { right: 24px; }
  .wbop-mobile-icon[data-mobile-location]::before { content: '⌖'; }

  .wbop-mobile-location-copy {
    padding-top: 84px;
  }
  .wbop-mobile-location-copy span {
    display: block;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(0,0,0,.56);
  }
  .wbop-mobile-location-copy strong {
    display: block;
    margin-top: 8px;
    font-size: 42px;
    line-height: 1;
    letter-spacing: -.04em;
  }
  .wbop-mobile-location-copy em {
    display: block;
    margin: 10px auto 0;
    max-width: 320px;
    color: rgba(0,0,0,.70);
    font-style: normal;
    font-size: 17px;
    line-height: 1.25;
  }

  .wbop-mobile-controls {
    margin: -10px 16px 0;
    position: relative;
    z-index: 3;
  }

  .wbop-mobile-service,
  .wbop-time-toggle {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    min-height: 64px;
    background: #f3f3f0;
    border-radius: 999px;
    padding: 6px;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.04);
  }
  .wbop-mobile-service button,
  .wbop-time-toggle button {
    min-height: 52px;
    border-radius: 999px;
    background: transparent;
    color: #111;
    font-size: 22px;
    font-weight: 800;
  }
  .wbop-mobile-service button.is-active,
  .wbop-time-toggle button.is-active {
    background: #fff;
    box-shadow: 0 2px 10px rgba(0,0,0,.14);
    color: #111;
  }

  .wbop-mobile-quick-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 10px;
  }
  .wbop-mobile-quick-row button {
    min-height: 58px;
    border: 0;
    border-radius: 17px;
    background: #f7f7f4;
    color: #111;
    font-size: 19px;
    font-weight: 800;
  }

  .wbop-schedule-card {
    margin: 0 16px 12px;
    padding: 16px;
    border: 0;
    border-radius: 22px;
    background: #fff;
    box-shadow: none;
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .wbop-schedule-card > div:first-child {
    display: none;
  }
  .wbop-schedule-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .wbop-schedule-fields[hidden] {
    display: none;
  }
  .wbop-schedule-fields label {
    display: grid;
    gap: 6px;
    font-size: 12px;
    font-weight: 800;
    color: rgba(0,0,0,.62);
  }
  .wbop-schedule-fields select {
    width: 100%;
    min-height: 50px;
    border-radius: 14px;
    border: 1px solid rgba(0,0,0,.12);
    padding: 0 13px;
    background: #fff;
    font-size: 16px;
  }

  .wbop-mobile-featured {
    display: block;
    padding: 6px 0 10px;
  }
  .wbop-feature-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 24px 6px;
  }
  .wbop-feature-head h3 {
    margin: 0;
    font-size: 28px;
    letter-spacing: -.04em;
  }
  .wbop-feature-head button {
    border: 0;
    background: transparent;
    color: rgba(0,0,0,.68);
    font-size: 18px;
    font-weight: 700;
  }
  .wbop-feature-second {
    margin-top: 14px;
  }
  .wbop-feature-scroll {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 38%;
    gap: 14px;
    overflow-x: auto;
    padding: 8px 24px 14px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }
  .wbop-feature-scroll::-webkit-scrollbar,
  .wbop-category-strip::-webkit-scrollbar { display: none; }
  .wbop-feature-mini {
    position: relative;
    scroll-snap-align: start;
    border: 0;
    background: transparent;
    text-align: left;
    padding: 0;
    color: #111;
    font-family: inherit;
  }
  .wbop-feature-mini span {
    position: relative;
    display: block;
    height: 122px;
    overflow: hidden;
    border-radius: 18px;
    background: #f4f4f1;
  }
  .wbop-feature-mini img,
  .wbop-feature-row img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .wbop-feature-mini em,
  .wbop-feature-row em {
    position: absolute;
    right: 8px;
    bottom: 8px;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: rgba(255,255,255,.96);
    color: #111;
    box-shadow: 0 3px 9px rgba(0,0,0,.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-style: normal;
    font-size: 27px;
    line-height: 1;
  }
  .wbop-feature-mini strong,
  .wbop-feature-mini small {
    display: block;
  }
  .wbop-feature-mini strong {
    margin-top: 8px;
    font-size: 17px;
    line-height: 1.15;
    font-weight: 800;
  }
  .wbop-feature-mini small {
    margin-top: 4px;
    font-size: 16px;
    color: rgba(0,0,0,.68);
  }
  .wbop-feature-list {
    display: grid;
    gap: 0;
    padding: 2px 24px 10px;
  }
  .wbop-feature-row {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 96px;
    gap: 16px;
    text-align: left;
    border: 0;
    border-bottom: 1px dashed rgba(0,0,0,.11);
    background: transparent;
    padding: 15px 0;
    min-height: 126px;
    color: #111;
    font-family: inherit;
  }
  .wbop-feature-row span {
    grid-column: 2;
    grid-row: 1 / span 3;
    overflow: hidden;
    border-radius: 16px;
    background: #f4f4f1;
    height: 96px;
  }
  .wbop-feature-row b {
    grid-column: 1;
    grid-row: 1;
    font-size: 22px;
    line-height: 1.12;
  }
  .wbop-feature-row small {
    grid-column: 1;
    grid-row: 2;
    font-size: 19px;
    color: rgba(0,0,0,.66);
  }

  .wbop-category-strip {
    position: sticky;
    top: 0;
    z-index: 15;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 28px;
    margin: 0;
    padding: 18px 24px 10px;
    background: rgba(255,255,255,.98);
    border-bottom: 1px solid rgba(0,0,0,.07);
    box-shadow: 0 5px 13px rgba(0,0,0,.05);
  }
  .wbop-category-strip button {
    position: relative;
    flex: 0 0 auto;
    min-height: 42px;
    padding: 0 0 7px;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #111;
    font-size: 20px;
    font-weight: 800;
  }
  .wbop-category-strip button.is-active {
    background: transparent;
    color: #111;
  }
  .wbop-category-strip button.is-active::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 4px;
    background: #111;
    border-radius: 999px;
  }

  .wbop-search-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
    margin: 14px 24px 8px;
  }
  .wbop-search-row input {
    min-height: 62px;
    border: 1.5px solid rgba(0,0,0,.18);
    border-radius: 22px;
    padding: 0 18px;
    font-size: 18px;
    background: #fff;
  }
  .wbop-search-row span {
    background: #f3f3f0;
    color: rgba(0,0,0,.58);
    padding: 12px 13px;
    border-radius: 999px;
    font-size: 12px;
  }

  .wbop-menu-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    padding: 8px 24px 150px;
  }
  .wbop-menu-card,
  .wbop-loading-card {
    border: 0;
    border-bottom: 1px dashed rgba(0,0,0,.11);
    border-radius: 0;
    box-shadow: none;
    background: transparent;
    overflow: visible;
  }
  .wbop-card-button {
    display: grid;
    grid-template-columns: 1fr 104px;
    gap: 16px;
    min-height: 130px;
    padding: 18px 0;
  }
  .wbop-menu-card-image {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    min-height: 104px;
    height: 104px;
    border-radius: 18px;
    overflow: hidden;
    background: #f4f4f1;
    position: relative;
  }
  .wbop-menu-card-image::after {
    content: '+';
    position: absolute;
    right: -1px;
    bottom: -1px;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: rgba(255,255,255,.96);
    box-shadow: 0 3px 9px rgba(0,0,0,.18);
    color: #111;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    line-height: 1;
  }
  .wbop-menu-card-content {
    grid-column: 1;
    grid-row: 1;
    padding: 0;
    min-width: 0;
  }
  .wbop-menu-card-content > span {
    display: none;
  }
  .wbop-menu-card h3 {
    font-size: 22px;
    line-height: 1.12;
    margin: 0 0 8px;
    letter-spacing: -.025em;
  }
  .wbop-menu-card p {
    font-size: 19px;
    line-height: 1.28;
    color: rgba(0,0,0,.68);
    -webkit-line-clamp: 2;
    margin: 6px 0 0;
    min-height: 0;
  }
  .wbop-card-foot {
    display: block;
    margin-top: 6px;
  }
  .wbop-card-foot strong {
    display: block;
    font-size: 20px;
    color: rgba(0,0,0,.72);
    font-weight: 500;
  }
  .wbop-card-foot em {
    display: none;
  }

  .wbop-mobile-cart-bar {
    position: fixed;
    left: 22px;
    right: 22px;
    bottom: 82px;
    z-index: 50;
    max-width: none;
    margin: 0;
    min-height: 66px;
    border-radius: 999px;
    padding: 8px 14px 8px 60px;
    background: var(--wbop-app-green);
    color: #061b0d;
    box-shadow: 0 16px 34px rgba(0,0,0,.18);
  }
  .wbop-mobile-cart-bar::before {
    content: '🛒';
    position: absolute;
    left: 22px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 24px;
    opacity: .55;
  }
  .wbop-mobile-cart-bar strong {
    display: block;
    font-size: 20px;
    line-height: 1;
    color: #041609;
  }
  .wbop-mobile-cart-bar span {
    color: rgba(0,0,0,.70);
    font-size: 13px;
  }
  .wbop-mobile-cart-bar button {
    background: transparent;
    box-shadow: none !important;
    color: #041609;
    min-height: 50px;
    padding: 0 6px;
    font-size: 0;
  }
  .wbop-mobile-cart-bar button::after {
    content: '›';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    background: rgba(0,91,36,.45);
    color: #fff;
    border-radius: 999px;
    font-size: 24px;
    font-weight: 800;
  }
  .wbop-mobile-cart-bar button:disabled::after {
    background: rgba(0,0,0,.13);
  }

  .wbop-mobile-bottom-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 45;
    min-height: 86px;
    padding: 9px 14px 15px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 6px;
    background: rgba(255,255,255,.92);
    border-top: 1px solid rgba(0,0,0,.08);
    backdrop-filter: blur(12px);
  }
  .wbop-mobile-bottom-nav button {
    border: 0;
    background: transparent;
    border-radius: 24px;
    color: rgba(0,0,0,.70);
    font-size: 12px;
    font-weight: 800;
    display: grid;
    place-items: center;
    gap: 3px;
    min-height: 58px;
  }
  .wbop-mobile-bottom-nav button span {
    font-size: 22px;
    line-height: 1;
  }
  .wbop-mobile-bottom-nav button.is-active {
    background: #fff;
    color: var(--wbop-app-green);
    box-shadow: 0 7px 18px rgba(0,0,0,.09);
  }

  .wbop-modal-sheet {
    bottom: 0;
    top: auto;
    transform: translateX(-50%);
    width: 100%;
    max-height: 94vh;
    border-radius: 28px 28px 0 0;
    padding: 0 0 22px;
    overflow: auto;
  }
  .wbop-modal-close {
    position: sticky;
    top: 14px;
    float: right;
    margin-right: 16px;
    width: 52px;
    min-height: 52px;
    border-radius: 999px;
    background: rgba(255,255,255,.92);
    box-shadow: 0 4px 14px rgba(0,0,0,.12);
    z-index: 5;
  }
  .wbop-modal-photo {
    height: min(42vh, 330px);
    margin: 0 0 22px;
    border: 0;
    border-radius: 0;
  }
  .wbop-modal-body > h3,
  .wbop-modal-body > .wbop-modal-desc,
  .wbop-modal-body > .wbop-modal-price,
  .wbop-modal-body > .wbop-modifier-group,
  .wbop-modal-body > .wbop-item-notes,
  .wbop-modal-body > .wbop-no-mods,
  .wbop-modal-body > .wbop-item-errors {
    margin-left: 24px;
    margin-right: 24px;
  }
  .wbop-modal-body h3 {
    font-size: 32px;
    line-height: 1.08;
    margin-top: 4px;
    margin-bottom: 12px;
  }
  .wbop-modal-desc {
    font-size: 21px;
    color: rgba(0,0,0,.72);
    line-height: 1.32;
  }
  .wbop-modal-price {
    display: none;
  }
  .wbop-accordion-group {
    border-left: 0;
    border-right: 0;
    border-radius: 0;
    margin-top: 14px;
  }
  .wbop-modifier-head {
    min-height: 68px;
    background: #fff;
    grid-template-columns: 34px 1fr 34px;
  }
  .wbop-head-text strong {
    font-size: 20px;
  }
  .wbop-head-text em,
  .wbop-head-text small {
    font-size: 14px;
  }
  .wbop-modifier-row {
    border: 0;
    border-radius: 0;
    padding: 12px 2px;
    margin: 0;
    min-height: 58px;
    grid-template-columns: 36px 1fr auto;
    font-size: 20px;
  }
  .wbop-modifier-row input {
    width: 28px;
    height: 28px;
  }
  .wbop-add-row {
    position: sticky;
    bottom: 0;
    display: grid;
    grid-template-columns: 116px 1fr;
    margin: 14px 0 -22px;
    padding: 16px 24px 22px;
    background: rgba(255,255,255,.96);
    box-shadow: 0 -16px 26px rgba(255,255,255,.94);
  }
  .wbop-add-cart,
  .wbop-checkout-button {
    min-height: 62px;
    border-radius: 999px;
    background: var(--wbop-app-green);
    color: #041609;
    font-size: 21px;
    font-weight: 800;
  }

  .wbop-cart-sheet {
    padding: 18px 24px 24px;
  }
  .wbop-cart-panel h3 {
    text-align: center;
    font-size: 34px;
    margin: 8px 54px 20px;
  }
  .wbop-tip-box,
  .wbop-total-box,
  .wbop-checkout-form {
    border-left: 0;
    border-right: 0;
    border-radius: 0;
  }
  .wbop-tip-buttons {
    grid-template-columns: repeat(4, 1fr);
    background: #f3f3f0;
    border-radius: 999px;
    gap: 0;
    padding: 4px;
  }
  .wbop-tip-buttons button {
    border: 0;
    background: transparent;
    font-size: 17px;
  }
  .wbop-tip-buttons button:first-child {
    display: none;
  }
  .wbop-tip-buttons button.is-active {
    background: #fff;
    color: #111;
    box-shadow: 0 2px 8px rgba(0,0,0,.16);
  }
}

/* v0.4.3 fullscreen order page mode */
body.wbop-ordering-fullscreen {
  background: #f7f4ef;
}
body.wbop-ordering-fullscreen > header,
body.wbop-ordering-fullscreen > footer,
body.wbop-ordering-fullscreen .site-header,
body.wbop-ordering-fullscreen .site-footer,
body.wbop-ordering-fullscreen header.wp-block-template-part,
body.wbop-ordering-fullscreen footer.wp-block-template-part,
body.wbop-ordering-fullscreen .wp-site-blocks > header,
body.wbop-ordering-fullscreen .wp-site-blocks > footer,
body.wbop-ordering-fullscreen .wp-site-blocks > .wp-block-template-part:first-child,
body.wbop-ordering-fullscreen .wp-site-blocks > .wp-block-template-part:last-child {
  display: none !important;
}
body.wbop-ordering-fullscreen .wp-site-blocks,
body.wbop-ordering-fullscreen main,
body.wbop-ordering-fullscreen .entry-content,
body.wbop-ordering-fullscreen .wp-block-post-content {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
body.wbop-ordering-fullscreen .entry-title,
body.wbop-ordering-fullscreen .wp-block-post-title {
  display: none !important;
}
body.wbop-ordering-fullscreen .wbop-customer-app {
  min-height: 100vh;
  min-height: 100dvh;
}
@media (max-width: 768px) {
  body.wbop-ordering-fullscreen .entry-content,
  body.wbop-ordering-fullscreen .wp-block-post-content,
  body.wbop-ordering-fullscreen .wp-block-group {
    padding-left: 0 !important;
    padding-right: 0 !important;
    max-width: none !important;
  }
}


/* v0.5.6 customer cleanup: mobile containment, safe modals, single-location header */
body.wbop-ordering-app-page,
body.wbop-ordering-app-page html {
  max-width: 100%;
  overflow-x: hidden !important;
}
body.wbop-ordering-app-page {
  overscroll-behavior-x: none;
  -webkit-text-size-adjust: 100%;
  touch-action: pan-y;
}
body.wbop-ordering-app-page .wp-site-blocks,
body.wbop-ordering-app-page .entry-content,
body.wbop-ordering-app-page .wp-block-post-content,
body.wbop-ordering-app-page .wbop-order-app {
  max-width: 100vw !important;
  overflow-x: hidden !important;
}
.wbop-order-app,
.wbop-order-app * {
  box-sizing: border-box;
}
.wbop-order-app {
  width: 100%;
  max-width: 100vw;
  overscroll-behavior-x: none;
}
.wbop-order-app img,
.wbop-order-app video {
  max-width: 100%;
}
.wbop-category-strip,
.wbop-feature-scroll,
.wbop-mobile-bottom-nav {
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
}
.wbop-mobile-icon[data-mobile-profile] {
  left: 18px;
  right: auto;
}
.wbop-mobile-icon[data-mobile-location] {
  display: none !important;
}
@media (max-width: 768px) {
  .wbop-mobile-hero {
    padding-left: 76px;
    padding-right: 20px;
  }
  .wbop-modal.is-open {
    align-items: flex-end;
    padding: max(14px, env(safe-area-inset-top)) 0 0;
  }
  .wbop-modal-sheet {
    width: 100vw !important;
    max-width: 100vw !important;
    max-height: calc(100dvh - max(22px, env(safe-area-inset-top))) !important;
    margin-top: max(18px, env(safe-area-inset-top));
    border-top-left-radius: 28px;
    border-top-right-radius: 28px;
    overflow: hidden;
  }
  .wbop-modal-body,
  .wbop-cart-panel {
    max-height: calc(100dvh - max(86px, env(safe-area-inset-top)));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-top: 48px;
  }
  .wbop-modal-close {
    position: sticky !important;
    top: max(10px, env(safe-area-inset-top));
    z-index: 50;
    margin-left: auto;
    margin-right: 12px;
    transform: none !important;
  }
  .wbop-cart-sheet .wbop-modal-close {
    position: sticky !important;
    top: max(10px, env(safe-area-inset-top));
  }
  .wbop-mobile-cart-bar,
  .wbop-mobile-bottom-nav {
    max-width: calc(100vw - 24px);
    left: 12px;
    right: 12px;
  }
}

/* v0.5.7 mobile modal containment: modal owns scroll, background stays locked */
html.wbop-modal-scroll-locked-html,
body.wbop-modal-scroll-locked {
  overflow: hidden !important;
  overscroll-behavior: none !important;
}
body.wbop-modal-scroll-locked {
  position: fixed !important;
}
body.wbop-ordering-app-page .wbop-modal {
  overflow: hidden !important;
  touch-action: none;
  overscroll-behavior: contain;
}
body.wbop-ordering-app-page .wbop-modal-backdrop {
  touch-action: none;
}
body.wbop-ordering-app-page .wbop-modal-sheet,
body.wbop-ordering-app-page .wbop-modal-body,
body.wbop-ordering-app-page .wbop-cart-panel {
  overscroll-behavior: contain;
}
@media (max-width: 768px) {
  body.wbop-ordering-app-page .wbop-modal.is-open {
    display: flex !important;
    align-items: flex-end;
    justify-content: stretch;
    width: 100vw;
    height: 100dvh;
    max-width: 100vw;
    overflow: hidden !important;
    padding: max(12px, env(safe-area-inset-top)) 0 0 !important;
  }
  body.wbop-ordering-app-page .wbop-modal-sheet {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: auto !important;
    transform: none !important;
    display: flex;
    flex-direction: column;
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    height: calc(100dvh - max(12px, env(safe-area-inset-top))) !important;
    max-height: calc(100dvh - max(12px, env(safe-area-inset-top))) !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 28px 28px 0 0;
    overflow: hidden !important;
  }
  body.wbop-ordering-app-page .wbop-modal-body,
  body.wbop-ordering-app-page .wbop-cart-panel {
    flex: 1 1 auto;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    max-height: none !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    padding-top: 58px !important;
    padding-bottom: calc(22px + env(safe-area-inset-bottom)) !important;
    touch-action: pan-y;
  }
  body.wbop-ordering-app-page .wbop-modal-photo {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    flex: 0 0 auto;
  }
  body.wbop-ordering-app-page .wbop-modal-photo img {
    width: 100% !important;
    max-width: 100% !important;
    display: block;
  }
  body.wbop-ordering-app-page .wbop-modal-close {
    position: absolute !important;
    top: max(14px, env(safe-area-inset-top)) !important;
    right: 16px !important;
    margin: 0 !important;
    z-index: 100 !important;
    flex: 0 0 auto;
  }
  body.wbop-ordering-app-page .wbop-add-row {
    bottom: 0 !important;
    padding-bottom: calc(18px + env(safe-area-inset-bottom)) !important;
  }
  body.wbop-ordering-app-page .wbop-cart-sheet .wbop-modal-close {
    top: max(14px, env(safe-area-inset-top)) !important;
    right: 16px !important;
  }
}

/* v0.5.8 cart UX upgrade - keep v0.5.7 modal containment protected */
.wbop-cart-items {
  gap: 14px;
}
.wbop-cart-card {
  display: block;
  border: 1px solid rgba(95,76,53,.22);
  border-radius: 24px;
  padding: 14px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(44,31,18,.06);
}
.wbop-cart-card-main {
  display: grid;
  grid-template-columns: 1fr 82px;
  gap: 14px;
  align-items: start;
}
.wbop-cart-title-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}
.wbop-cart-title-row h4 {
  margin: 0;
  font-size: 18px;
  line-height: 1.14;
  color: #15100b;
}
.wbop-cart-title-row strong {
  white-space: nowrap;
  font-size: 16px;
}
.wbop-cart-thumb {
  width: 82px;
  height: 82px;
  border-radius: 18px;
  overflow: hidden;
  background: #f4eadc;
  display: grid;
  place-items: center;
}
.wbop-cart-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.wbop-cart-thumb-fallback {
  font-weight: 900;
  color: #8b6b3e;
}
.wbop-cart-mods {
  margin: 10px 0 0;
  display: grid;
  gap: 8px;
  color: #5f4c35;
}
.wbop-cart-mods b {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #7d6a54;
  margin-bottom: 3px;
}
.wbop-cart-mods ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 2px;
}
.wbop-cart-mods li {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
  line-height: 1.35;
}
.wbop-cart-mods li::before {
  content: '•';
  margin-right: 4px;
  color: #b88a35;
}
.wbop-cart-mods li span {
  margin-left: auto;
  color: #7d6a54;
}
.wbop-cart-note {
  margin: 10px 0 0;
  padding: 9px 10px;
  border-radius: 14px;
  background: #fff7e9;
  color: #5f4c35;
  font-size: 13px;
}
.wbop-cart-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.wbop-cart-actions button {
  border: 0;
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 900;
  background: #f3eadc;
  color: #1a1510;
}
.wbop-cart-actions button[data-remove-line] {
  color: #9b2b20;
}
.wbop-cart-qty-row {
  margin-top: 13px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-top: 1px solid rgba(95,76,53,.12);
  padding-top: 12px;
}
.wbop-cart-qty-row button {
  width: 44px;
  height: 44px;
  border-radius: 15px;
  border: 1px solid rgba(95,76,53,.18);
  background: #f8efe1;
  color: #111;
  font-size: 20px;
  font-weight: 900;
  display: inline-grid;
  place-items: center;
}
.wbop-cart-qty-row strong {
  min-width: 28px;
  text-align: center;
  font-size: 18px;
}
.wbop-cart-qty-row span {
  margin-left: auto;
  color: #7d6a54;
  font-size: 13px;
}
.wbop-tip-box {
  border: 1px solid rgba(95,76,53,.15);
  border-radius: 24px;
  padding: 14px;
  background: #faf6ee;
}
.wbop-tip-buttons {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-top: 10px;
}
.wbop-tip-buttons button {
  background: #fff;
  color: #111;
  border: 1px solid rgba(95,76,53,.14);
}
.wbop-tip-buttons button.is-active {
  background: #111;
  color: #fff;
  box-shadow: 0 8px 18px rgba(0,0,0,.16);
}
.wbop-total-box {
  border-radius: 24px;
  background: #fff;
  border: 1px solid rgba(95,76,53,.14);
  padding: 14px;
}
.wbop-total-box div {
  padding: 8px 0;
  border-bottom: 1px dashed rgba(95,76,53,.13);
}
.wbop-total-box div:last-child {
  border-bottom: 0;
}
.wbop-grand-total strong,
.wbop-grand-total span {
  font-size: 20px;
}
@media(max-width:640px){
  .wbop-cart-panel h3 { font-size: 30px; margin-bottom: 14px; }
  .wbop-cart-card { border-radius: 22px; padding: 13px; }
  .wbop-cart-card-main { grid-template-columns: 1fr 74px; }
  .wbop-cart-thumb { width: 74px; height: 74px; border-radius: 17px; }
  .wbop-cart-title-row { display: block; }
  .wbop-cart-title-row h4 { font-size: 19px; padding-right: 4px; }
  .wbop-cart-title-row strong { display:block; margin-top: 4px; font-size: 17px; }
  .wbop-tip-buttons { grid-template-columns: repeat(4, 1fr); }
  .wbop-tip-buttons button[data-tip="0"] { grid-column: span 2; }
  .wbop-tip-buttons button[data-tip="custom"] { grid-column: span 2; }
}


/* v0.5.9 desktop persistent cart button - keep mobile modal containment protected */
@media (min-width: 769px) {
  body.wbop-ordering-app-page .wbop-order-app {
    padding-bottom: 120px;
  }
  body.wbop-ordering-app-page .wbop-mobile-cart-bar {
    position: fixed !important;
    right: 32px !important;
    bottom: 32px !important;
    left: auto !important;
    z-index: 99980 !important;
    width: min(460px, calc(100vw - 64px));
    max-width: 460px;
    margin: 0 !important;
    border-radius: 999px;
    padding: 14px 16px 14px 20px;
    background: #111;
    color: #fff;
    box-shadow: 0 22px 54px rgba(0,0,0,.28);
    border: 1px solid rgba(255,255,255,.08);
  }
  body.wbop-ordering-app-page .wbop-mobile-cart-bar strong {
    color: #fff;
    font-size: 17px;
    line-height: 1.1;
  }
  body.wbop-ordering-app-page .wbop-mobile-cart-bar span {
    color: rgba(255,255,255,.74);
    font-size: 13px;
  }
  body.wbop-ordering-app-page .wbop-mobile-cart-bar button {
    background: var(--wbop-gold-2);
    color: #111;
    min-width: 132px;
    padding: 0 20px;
    white-space: nowrap;
    box-shadow: none;
  }
  body.wbop-ordering-app-page .wbop-mobile-cart-bar button:disabled {
    opacity: .62;
  }
}
@media (min-width: 769px) and (max-width: 1060px) {
  body.wbop-ordering-app-page .wbop-mobile-cart-bar {
    right: 20px !important;
    bottom: 20px !important;
    width: min(420px, calc(100vw - 40px));
  }
}


/* v0.5.10 modal open reset hardening - keep v0.5.7 containment protected */
body.wbop-ordering-app-page .wbop-modal,
body.wbop-ordering-app-page .wbop-modal-sheet,
body.wbop-ordering-app-page .wbop-modal-body,
body.wbop-ordering-app-page .wbop-cart-panel {
  scroll-behavior: auto !important;
}
@media (max-width: 768px) {
  body.wbop-ordering-app-page .wbop-modal.is-open {
    align-items: flex-end !important;
  }
  body.wbop-ordering-app-page .wbop-modal-body,
  body.wbop-ordering-app-page .wbop-cart-panel {
    overscroll-behavior-y: contain !important;
  }
}


/* v0.5.11 required modifier inline validation */
.wbop-accordion-group.has-error .wbop-modifier-head {
  border-color: #b91c1c;
  box-shadow: 0 0 0 2px rgba(185, 28, 28, .08);
}
.wbop-inline-group-error {
  margin: 8px 0 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: #fff1f2;
  color: #9f1239;
  font-weight: 800;
  font-size: 13px;
}
.wbop-item-errors:empty { display: none; }

/* v0.5.13 sticky add-row required modifier warning */
.wbop-add-row-warning {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 12px;
  margin-bottom: 8px;
  border: 1px solid #fecdd3;
  border-radius: 14px;
  background: #fff1f2;
  color: #9f1239;
  font-size: 13px;
  line-height: 1.25;
}
.wbop-add-row-warning strong {
  font-size: 13px;
  font-weight: 900;
}
.wbop-add-row-warning span {
  font-weight: 750;
}
@media (max-width: 768px) {
  body.wbop-ordering-app-page .wbop-add-row-warning {
    margin-bottom: 10px;
  }
}


/* v0.5.14 display controls and delivery-fee visibility hardening */
.wbop-total-box [hidden],
.wbop-total-box div[hidden],
[data-delivery-total-row][hidden] { display: none !important; }
.wbop-order-hero[style*="--wbop-hero-image"] {
  position: relative;
  overflow: hidden;
  background-image: linear-gradient(135deg, rgba(23,19,15,.88), rgba(52,36,21,.78)), var(--wbop-hero-image);
  background-size: cover;
  background-position: center;
}
.wbop-mobile-hero[style*="--wbop-mobile-hero-image"] {
  position: relative;
  overflow: hidden;
  background-image: linear-gradient(135deg, rgba(23,19,15,.78), rgba(52,36,21,.62)), var(--wbop-mobile-hero-image);
  background-size: cover;
  background-position: center;
}
.wbop-media-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.wbop-media-row input { min-width: min(480px, 100%); }

/* v0.5.15 admin-controlled header design */
.wbop-order-hero,
.wbop-mobile-hero {
  --wbop-header-title-color: #ffffff;
  --wbop-header-address-color: #f7efe3;
  --wbop-header-tagline-color: #f7efe3;
  --wbop-header-overlay-dark: .74;
  --wbop-header-overlay-light: .56;
  --wbop-header-brightness: 82%;
  --wbop-header-position: center center;
}
.wbop-order-hero h2,
.wbop-mobile-location-copy span { color: var(--wbop-header-title-color) !important; }
.wbop-order-hero .wbop-kicker,
.wbop-mobile-location-copy strong { color: var(--wbop-header-address-color) !important; }
.wbop-order-hero p:not(.wbop-kicker),
.wbop-mobile-location-copy em { color: var(--wbop-header-tagline-color) !important; }
.wbop-order-hero[style*="--wbop-hero-image"] {
  background-image: linear-gradient(135deg, rgba(23,19,15,var(--wbop-header-overlay-dark)), rgba(52,36,21,var(--wbop-header-overlay-light))), var(--wbop-hero-image) !important;
  background-position: var(--wbop-header-position) !important;
  filter: none;
}
.wbop-order-hero[style*="--wbop-hero-image"]::before,
.wbop-mobile-hero[style*="--wbop-mobile-hero-image"]::before {
  content: "";
  position: absolute;
  inset: 0;
  background: inherit;
  background-image: inherit;
  background-size: cover;
  background-position: var(--wbop-header-position);
  filter: brightness(var(--wbop-header-brightness));
  z-index: 0;
  transform: scale(1.01);
}
.wbop-order-hero[style*="--wbop-hero-image"] > *,
.wbop-mobile-hero[style*="--wbop-mobile-hero-image"] > * {
  position: relative;
  z-index: 1;
}
.wbop-mobile-hero[style*="--wbop-mobile-hero-image"] {
  background-image: linear-gradient(135deg, rgba(23,19,15,var(--wbop-header-overlay-dark)), rgba(52,36,21,var(--wbop-header-overlay-light))), var(--wbop-mobile-hero-image) !important;
  background-position: var(--wbop-header-position) !important;
}

/* v0.5.17 mobile profile control: fixed app-style profile button */
.wbop-mobile-profile-fixed {
  display: none;
}
@media (max-width: 768px) {
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed {
    display: inline-flex;
    position: fixed;
    top: calc(env(safe-area-inset-top, 0px) + 14px);
    left: 18px;
    z-index: 9999;
    width: 52px;
    height: 52px;
    min-height: 52px;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,.96);
    color: #111;
    box-shadow: 0 10px 28px rgba(0,0,0,.18);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
  }
  body.admin-bar.wbop-ordering-app-page .wbop-mobile-profile-fixed {
    top: calc(46px + env(safe-area-inset-top, 0px) + 10px);
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed svg {
    width: 26px;
    height: 26px;
    display: block;
    fill: currentColor;
  }
  body.wbop-ordering-app-page .wbop-mobile-hero {
    padding-left: 20px;
    padding-right: 20px;
  }
}


/* v0.5.18 admin-controlled header font sizes */
.wbop-order-hero h2 { font-size: var(--wbop-header-title-size, clamp(34px,7vw,62px)) !important; }
.wbop-order-hero .wbop-kicker { font-size: var(--wbop-header-address-size, 14px) !important; }
.wbop-order-hero p:not(.wbop-kicker) { font-size: var(--wbop-header-tagline-size, 16px) !important; }
.wbop-mobile-location-copy span { font-size: var(--wbop-mobile-header-title-size, 22px) !important; }
.wbop-mobile-location-copy strong { font-size: var(--wbop-mobile-header-address-size, 42px) !important; }
.wbop-mobile-location-copy em { font-size: var(--wbop-mobile-header-tagline-size, 19px) !important; }
@media (max-width: 420px) {
  .wbop-mobile-location-copy strong { line-height: .98; }
}

/* v0.5.19 header overlay fix: remove hard-coded mobile/desktop overlay defaults from hero children */
.wbop-order-app .wbop-order-hero,
.wbop-order-app .wbop-mobile-hero {
  --wbop-header-title-color: inherit;
  --wbop-header-address-color: inherit;
  --wbop-header-tagline-color: inherit;
  --wbop-header-overlay-dark: inherit;
  --wbop-header-overlay-light: inherit;
  --wbop-header-brightness: inherit;
  --wbop-header-position: inherit;
}
.wbop-order-app .wbop-order-hero[style*="--wbop-hero-image"],
.wbop-order-app .wbop-mobile-hero[style*="--wbop-mobile-hero-image"] {
  background-image: none !important;
  background-color: #17130f !important;
  background-position: var(--wbop-header-position) !important;
}
.wbop-order-app .wbop-order-hero[style*="--wbop-hero-image"]::before,
.wbop-order-app .wbop-mobile-hero[style*="--wbop-mobile-hero-image"]::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--wbop-hero-image);
  background-size: cover;
  background-position: var(--wbop-header-position);
  filter: brightness(var(--wbop-header-brightness));
  z-index: 0;
  transform: scale(1.01);
}
.wbop-order-app .wbop-mobile-hero[style*="--wbop-mobile-hero-image"]::before {
  background-image: var(--wbop-mobile-hero-image);
}
.wbop-order-app .wbop-order-hero[style*="--wbop-hero-image"]::after,
.wbop-order-app .wbop-mobile-hero[style*="--wbop-mobile-hero-image"]::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(23,19,15,var(--wbop-header-overlay-dark)), rgba(52,36,21,var(--wbop-header-overlay-light)));
  z-index: 1;
  pointer-events: none;
}
.wbop-order-app .wbop-order-hero[style*="--wbop-hero-image"] > *,
.wbop-order-app .wbop-mobile-hero[style*="--wbop-mobile-hero-image"] > * {
  position: relative;
  z-index: 2;
}

/* v0.5.25 desktop start-order flow and compact mode bar */
.wbop-order-mode-bar {
  margin: 16px 0 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 16px;
  border: 1px solid var(--wbop-line);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(60,42,22,.06);
}
.wbop-order-mode-bar[hidden] { display: none !important; }
.wbop-order-mode-bar strong {
  display: block;
  font-size: 20px;
  line-height: 1.1;
  margin-top: 3px;
}
.wbop-order-mode-bar em {
  display: block;
  margin-top: 3px;
  color: var(--wbop-muted);
  font-style: normal;
  font-size: 13px;
}
.wbop-order-mode-bar button,
.wbop-start-button {
  min-height: 46px;
  border: 0;
  border-radius: 999px;
  padding: 0 20px;
  background: var(--wbop-gold);
  color: #111;
  font-weight: 900;
  cursor: pointer;
  font-family: inherit;
}

.wbop-order-mode-bar {
  align-items: center;
}
.wbop-order-mode-copy {
  min-width: 0;
}
.wbop-order-mode-change {
  justify-self: end;
  white-space: nowrap;
}
.wbop-order-mode-availability {
  grid-column: 1 / -1;
  margin: 2px 0 0;
  box-shadow: none;
  border-radius: 16px;
}
.wbop-order-mode-availability[hidden] {
  display: none !important;
}
.wbop-start-modal .wbop-modal-backdrop { background: rgba(0,0,0,.62); }
.wbop-start-sheet {
  width: min(560px, calc(100vw - 32px));
  bottom: auto;
  top: 50%;
  transform: translate(-50%, -50%);
  max-height: calc(100vh - 50px);
  padding: 26px;
}
.wbop-start-sheet h3 {
  margin: 0 0 8px;
  font-size: 38px;
  line-height: 1.02;
}
.wbop-start-sheet p {
  margin: 0 0 18px;
  color: var(--wbop-muted);
}
.wbop-start-section {
  display: grid;
  gap: 10px;
  margin: 14px 0;
}
.wbop-start-section > span,
.wbop-start-schedule label {
  font-weight: 900;
  color: #241b15;
}
.wbop-start-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 6px;
  border-radius: 999px;
  background: #f3eadc;
}
.wbop-start-toggle button {
  min-height: 52px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #111;
  font-family: inherit;
  font-weight: 900;
  cursor: pointer;
}
.wbop-start-toggle button.is-active {
  background: var(--wbop-gold);
  box-shadow: 0 6px 14px rgba(0,0,0,.10);
}
.wbop-start-schedule {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 12px 0 18px;
}
.wbop-start-schedule[hidden] { display: none !important; }
.wbop-start-schedule label {
  display: grid;
  gap: 6px;
  font-size: 13px;
}
.wbop-start-schedule select {
  min-height: 50px;
  width: 100%;
  border: 1px solid var(--wbop-line);
  border-radius: 14px;
  background: #fff;
  padding: 0 13px;
  font: inherit;
}
.wbop-start-button {
  width: 100%;
  min-height: 56px;
  margin-top: 8px;
  font-size: 18px;
}
@media (min-width: 721px) {
  .wbop-order-hero > .wbop-service-toggle,
  .wbop-schedule-card {
    display: none !important;
  }
}
@media (min-width: 721px) and (max-width: 980px) {
  .wbop-order-mode-bar {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .wbop-order-mode-change {
    justify-self: stretch;
    width: 100%;
  }
}

@media (max-width: 720px) {
  .wbop-order-mode-bar,
  .wbop-start-modal {
    display: none !important;
  }
}

/* v0.5.30 mobile order setup: keep Pickup/Delivery and ASAP/Schedule together at top */
@media (max-width: 720px) {
  body.wbop-ordering-app-page .wbop-mobile-controls {
    gap: 12px;
  }
  body.wbop-ordering-app-page .wbop-mobile-order-setup {
    display: grid;
    gap: 10px;
    width: 100%;
    padding: 0 0 2px;
  }
  body.wbop-ordering-app-page .wbop-mobile-service,
  body.wbop-ordering-app-page .wbop-mobile-time {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border-radius: 999px;
    background: rgba(17,17,17,.06);
    padding: 6px;
    box-shadow: inset 0 0 0 1px rgba(17,17,17,.06);
  }
  body.wbop-ordering-app-page .wbop-mobile-service button,
  body.wbop-ordering-app-page .wbop-mobile-time button {
    width: 100%;
    min-height: 56px;
    border-radius: 999px;
    font-size: 20px;
    font-weight: 900;
    background: transparent;
    color: #111;
  }
  body.wbop-ordering-app-page .wbop-mobile-service button.is-active,
  body.wbop-ordering-app-page .wbop-mobile-time button.is-active {
    background: #fff;
    box-shadow: 0 6px 22px rgba(0,0,0,.12);
  }
  body.wbop-ordering-app-page .wbop-mobile-schedule-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 0 2px;
  }
  body.wbop-ordering-app-page .wbop-mobile-schedule-fields[hidden] {
    display: none !important;
  }
  body.wbop-ordering-app-page .wbop-mobile-schedule-fields label {
    font-size: 12px;
    font-weight: 900;
    color: #6b6258;
    text-transform: uppercase;
    letter-spacing: .08em;
  }
  body.wbop-ordering-app-page .wbop-mobile-schedule-fields select {
    width: 100%;
    margin-top: 5px;
    border: 1px solid rgba(17,17,17,.14);
    border-radius: 16px;
    padding: 13px 12px;
    font-size: 16px;
    background: #fff;
    color: #111;
  }
  body.wbop-ordering-app-page .wbop-schedule-card {
    display: none !important;
  }
  body.wbop-ordering-app-page .wbop-category-strip {
    margin-top: 12px;
  }
}

/* v0.5.32 service pause/customer availability notice */
.wbop-service-notice{margin:12px 0;padding:12px 14px;border:1px solid #f4c7a1;background:#fff4ea;color:#7a3414;border-radius:16px;font-weight:900;}
.wbop-service-notice[hidden]{display:none!important;}
.wbop-service-toggle button.is-disabled,.wbop-time-toggle button.is-disabled,.wbop-start-toggle button.is-disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.2);}


/* v0.5.35 mobile home/menu tab visibility fix */
@media (max-width: 720px) {
  .wbop-order-app:not(.is-mobile-menu) .wbop-order-mode-bar,
  .wbop-order-app:not(.is-mobile-menu) .wbop-schedule-card,
  .wbop-order-app:not(.is-mobile-menu) .wbop-category-strip,
  .wbop-order-app:not(.is-mobile-menu) .wbop-search-row,
  .wbop-order-app:not(.is-mobile-menu) .wbop-menu-grid {
    display: none !important;
  }

  .wbop-order-app.is-mobile-menu .wbop-mobile-home {
    display: none !important;
  }

  .wbop-order-app.is-mobile-menu .wbop-category-strip {
    display: flex !important;
  }

  .wbop-order-app.is-mobile-menu .wbop-search-row {
    display: grid !important;
  }

  .wbop-order-app.is-mobile-menu .wbop-menu-grid {
    display: grid !important;
  }

  .wbop-order-app.is-mobile-menu .wbop-order-mode-bar {
    display: flex !important;
    margin: 10px 18px 10px;
  }
}

/* v0.5.37 stronger mobile Order Now/menu switching fallback */
@media (max-width: 720px) {
  .wbop-order-app[data-mobile-view="home"] .wbop-order-mode-bar,
  .wbop-order-app[data-mobile-view="home"] .wbop-schedule-card,
  .wbop-order-app[data-mobile-view="home"] .wbop-category-strip,
  .wbop-order-app[data-mobile-view="home"] .wbop-search-row,
  .wbop-order-app[data-mobile-view="home"] .wbop-menu-grid {
    display: none !important;
  }
  .wbop-order-app[data-mobile-view="menu"] .wbop-mobile-home {
    display: none !important;
  }
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-bar {
    display: flex !important;
    margin: 10px 18px 10px;
  }
  .wbop-order-app[data-mobile-view="menu"] .wbop-category-strip {
    display: flex !important;
  }
  .wbop-order-app[data-mobile-view="menu"] .wbop-search-row,
  .wbop-order-app[data-mobile-view="menu"] .wbop-menu-grid {
    display: grid !important;
  }
}

/* v0.5.40 customer profile shell: mobile + desktop entry points */
.wbop-desktop-profile-button {
  position: absolute;
  top: 18px;
  right: 18px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.38);
  background: rgba(0,0,0,.32);
  color: #fff;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 12px 30px rgba(0,0,0,.22);
  backdrop-filter: blur(10px);
}
.wbop-desktop-profile-button svg {
  width: 19px;
  height: 19px;
  fill: currentColor;
}
.wbop-profile-sheet {
  width: min(760px, calc(100vw - 24px));
}
.wbop-profile-panel h3 {
  margin: 0 0 6px;
  font-size: 30px;
  line-height: 1.05;
}
.wbop-profile-panel p {
  color: #6d6258;
  margin: 0;
  line-height: 1.45;
}
.wbop-profile-head {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 16px;
  align-items: start;
  margin-bottom: 18px;
}
.wbop-profile-head span {
  display: inline-block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 900;
  color: #8b5d1c;
  margin-bottom: 6px;
}
.wbop-profile-avatar {
  width: 64px;
  height: 64px;
  border-radius: 22px;
  background: #111;
  display: grid;
  place-items: center;
  box-shadow: 0 14px 30px rgba(0,0,0,.18);
}
.wbop-profile-avatar svg {
  width: 34px;
  height: 34px;
  fill: #fff;
}
.wbop-profile-lookup {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 10px;
  align-items: end;
  background: #fff7ea;
  border: 1px solid rgba(132,88,28,.16);
  border-radius: 20px;
  padding: 14px;
  margin-bottom: 16px;
}
.wbop-profile-lookup label {
  display: grid;
  gap: 6px;
  font-weight: 900;
  color: #2a2119;
}
.wbop-profile-lookup input {
  border: 1px solid rgba(0,0,0,.16);
  border-radius: 14px;
  padding: 12px;
  font: inherit;
}
.wbop-profile-lookup button {
  border: 0;
  border-radius: 14px;
  padding: 13px 16px;
  background: #111;
  color: #fff;
  font-weight: 900;
  opacity: .58;
}
.wbop-profile-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
.wbop-profile-grid article {
  border: 1px solid rgba(0,0,0,.09);
  border-radius: 18px;
  background: #fff;
  padding: 14px;
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
}
.wbop-profile-grid strong {
  display: block;
  margin-bottom: 6px;
  color: #1b1713;
}
@media (max-width: 720px) {
  .wbop-desktop-profile-button { display: none !important; }
  .wbop-profile-sheet {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 70vh;
  }
  .wbop-profile-panel h3 { font-size: 24px; }
  .wbop-profile-head {
    grid-template-columns: 52px 1fr;
    gap: 12px;
  }
  .wbop-profile-avatar {
    width: 52px;
    height: 52px;
    border-radius: 18px;
  }
  .wbop-profile-avatar svg {
    width: 28px;
    height: 28px;
  }
  .wbop-profile-lookup {
    grid-template-columns: 1fr;
  }
  .wbop-profile-grid {
    grid-template-columns: 1fr;
  }
}

/* v0.6.0 customer SMS profile shell */
.wbop-profile-auth{background:#fff;border:1px solid #eadfce;border-radius:18px;padding:14px;margin:14px 0;box-shadow:0 10px 24px rgba(40,28,14,.06)}
.wbop-profile-stage{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:end}
.wbop-profile-stage[hidden]{display:none!important}
.wbop-profile-stage label{font-size:13px;font-weight:800;color:#3a2819;display:flex;flex-direction:column;gap:5px}
.wbop-profile-stage input{border:1px solid #dacdbb;border-radius:12px;padding:11px 12px;font-size:16px;background:#fff}
.wbop-profile-primary{grid-column:1/-1;border:0;border-radius:999px;background:#1f7a3a;color:#fff;font-weight:900;padding:13px 16px;font-size:15px;box-shadow:0 12px 24px rgba(31,122,58,.22)}
.wbop-profile-code-copy{grid-column:1/-1;margin:0;color:#5b4a38;font-weight:700}
.wbop-profile-code-input{grid-column:1/-1;text-align:center;letter-spacing:.45em;font-size:28px!important;font-weight:900;padding:14px!important}
.wbop-profile-message{margin-top:10px;font-size:13px;font-weight:800;min-height:18px;color:#5b4a38}
.wbop-profile-message.is-error{color:#a12618}.wbop-profile-message.is-success{color:#1f7a3a}.wbop-profile-message.is-info{color:#5b4a38}
@media(max-width:720px){.wbop-profile-stage{grid-template-columns:1fr}.wbop-profile-sheet{max-height:calc(100dvh - 24px)}}


/* v0.6.1 customer profile logout/name display + mobile scroll recovery */
body.wbop-ordering-app-page:not(.wbop-modal-scroll-locked) {
  position: static !important;
  overflow-y: auto !important;
}
body.wbop-ordering-app-page:not(.wbop-modal-scroll-locked) .wbop-order-app {
  touch-action: pan-y !important;
}
@media (max-width: 768px) {
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed {
    width: auto;
    min-width: 52px;
    max-width: 152px;
    padding: 0 12px 0 0;
    gap: 7px;
    justify-content: flex-start;
    overflow: hidden;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed .wbop-profile-icon-wrap {
    width: 52px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 52px;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed .wbop-profile-first-name {
    font-size: 13px;
    line-height: 1;
    font-weight: 900;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 84px;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed .wbop-profile-first-name[hidden] {
    display: none !important;
  }
}
.wbop-profile-logout {
  margin-top: 10px;
  width: 100%;
  border: 1px solid #d8c9b8;
  border-radius: 999px;
  background: #fff;
  color: #3a2819;
  font-weight: 900;
  padding: 12px 14px;
  cursor: pointer;
}
.wbop-profile-logout[hidden] {
  display: none !important;
}

/* v0.6.2 simplified customer login/create account tabs */
.wbop-profile-tabs{display:grid;grid-template-columns:1fr 1fr;border:1px solid #eadfce;border-radius:16px;overflow:hidden;margin-bottom:14px;background:#f7f2ea}
.wbop-profile-tabs button{border:0;background:transparent;padding:13px 10px;font-weight:900;font-size:15px;color:#5b4a38;cursor:pointer}
.wbop-profile-tabs button.is-active{background:#ffffff;color:#111827;box-shadow:inset 0 -3px 0 #1f7a3a}
.wbop-profile-stage .wbop-profile-help{grid-column:1/-1;margin:0;color:#8b7a68;font-size:13px;font-weight:700}
.wbop-profile-stage label.wbop-wide{grid-column:1/-1}
@media(max-width:720px){
  .wbop-profile-tabs button{font-size:16px;padding:14px 8px}
  .wbop-profile-primary{font-size:16px;padding:14px 16px}
}

/* v0.6.7: true logged-in profile mode */
.wbop-profile-auth[hidden], .wbop-profile-dashboard[hidden]{display:none !important;}
.wbop-profile-dashboard{background:#fff;border:1px solid #eadfce;border-radius:18px;padding:16px;margin:14px 0;box-shadow:0 10px 24px rgba(40,28,14,.06)}
.wbop-profile-welcome-card{background:#111827;color:#fff;border-radius:16px;padding:18px 20px;margin-bottom:14px;}
.wbop-profile-welcome-card strong{display:block;font-size:22px;line-height:1.15;color:#ffc857;text-transform:uppercase;letter-spacing:.05em;}
.wbop-profile-welcome-card p{margin:8px 0 0;color:#f4eadb;font-weight:700;}
.wbop-profile-dashboard-actions{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;}
.wbop-profile-secondary{border:1px solid #d9cbb7;background:#fff;border-radius:999px;padding:13px 18px;font-weight:900;cursor:pointer;color:#2b2118;}
@media(max-width:760px){.wbop-profile-dashboard-actions{grid-template-columns:1fr}.wbop-profile-welcome-card strong{font-size:18px}}

/* v0.7.2 Clover iframe payment sheet */
.wbop-payment-box{border:1px solid rgba(0,0,0,.12);background:#f8fbf8;border-radius:18px;padding:14px;display:grid;gap:10px}.wbop-payment-box[hidden]{display:none}.wbop-payment-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.wbop-payment-head strong{font-size:15px}.wbop-payment-head span{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;color:#28633b;background:#e8f6ec;border-radius:999px;padding:5px 8px}.wbop-payment-box p{margin:0;color:#4d5b50;font-size:12px;font-weight:700}.wbop-payment-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.wbop-payment-grid label{display:grid;gap:5px;font-size:12px;font-weight:900;color:#30261f}.wbop-payment-grid .wbop-wide{grid-column:1/-1}.wbop-clover-field{box-sizing:border-box;width:100%;height:40px!important;min-height:40px!important;max-height:40px!important;overflow:hidden;border:1px solid rgba(0,0,0,.16);border-radius:13px;background:#fff;padding:0 12px;box-shadow:inset 0 1px 0 rgba(0,0,0,.03);display:flex;align-items:center}.wbop-clover-field iframe{display:block!important;width:100%!important;height:38px!important;min-height:38px!important;max-height:38px!important;border:0!important;margin:0!important;padding:0!important}.wbop-payment-grid small{min-height:14px;color:#9b1c12;font-weight:800}.wbop-checkout-note[data-checkout-note]{font-size:13px}
@media(max-width:640px){.wbop-payment-grid{grid-template-columns:1fr}.wbop-payment-head{align-items:flex-start;flex-direction:column}.wbop-clover-field{height:40px!important;min-height:40px!important;max-height:40px!important}}

/* v0.7.8: desktop and mobile master online-ordering disabled state */
.wbop-order-app.is-ordering-disabled .wbop-menu-card,
.wbop-order-app.is-ordering-disabled .wbop-feature-row { opacity: .45; filter: grayscale(.15); }
.wbop-order-app.is-ordering-disabled [data-open-item],
.wbop-order-app.is-ordering-disabled [data-add-cart],
.wbop-order-app.is-ordering-disabled [data-mobile-order-now],
.wbop-order-app.is-ordering-disabled [data-open-cart],
.wbop-order-app.is-ordering-disabled [data-submit-order] { pointer-events: none; cursor: not-allowed; }
.wbop-ordering-paused-card { border: 1px solid rgba(138,31,17,.18); background: #fff8f5; }
.wbop-service-notice { margin: 14px auto; max-width: 1180px; border: 1px solid rgba(138,31,17,.18); background: #fff8f5; color: #6b2419; border-radius: 18px; padding: 14px 16px; font-weight: 800; }

/* v0.9.4 customer saved-address manager */
.wbop-profile-address-editor{margin-top:16px;background:#fff;border:1px solid #eadfce;border-radius:18px;padding:14px;box-shadow:0 10px 24px rgba(40,28,14,.05)}
.wbop-profile-address-editor-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:12px}
.wbop-profile-address-editor-head strong{font-size:16px;color:#2b2118}
.wbop-profile-address-editor-head span{font-size:13px;color:#786655;font-weight:700;text-align:right}
.wbop-profile-address-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:end}
.wbop-profile-address-form label{font-size:13px;font-weight:800;color:#3a2819;display:flex;flex-direction:column;gap:5px}
.wbop-profile-address-form input,.wbop-profile-address-form select,.wbop-profile-address-form textarea{border:1px solid #dacdbb;border-radius:12px;padding:11px 12px;font-size:16px;background:#fff;width:100%}
.wbop-profile-address-form .wbop-wide{grid-column:1/-1}
.wbop-profile-address-actions{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;margin-top:12px}
.wbop-profile-address-message{font-size:13px;font-weight:800;color:#5b4a38}
.wbop-profile-address-message.is-error{color:#a12618}.wbop-profile-address-message.is-success{color:#1f7a3a}.wbop-profile-address-message.is-info{color:#5b4a38}
@media(max-width:720px){.wbop-profile-address-form,.wbop-profile-address-actions{grid-template-columns:1fr}.wbop-profile-address-editor-head{display:block}.wbop-profile-address-editor-head span{text-align:left;display:block;margin-top:4px}}

/* v0.9.6 cash test method + Google Places dropdown inside high-z modals */
.wbop-payment-method-box{background:#f7fbf7;border:1px solid rgba(24,94,39,.18);border-radius:16px;padding:12px;display:grid;gap:10px}.wbop-payment-method-box[hidden]{display:none}.wbop-payment-method-options{display:flex;flex-wrap:wrap;gap:10px}.wbop-payment-method-options label{display:flex!important;align-items:center;gap:8px;background:#fff;border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:10px 13px;font-size:13px!important}.wbop-payment-method-help{margin:0;color:#6b4b2a;font-size:12px;font-weight:800}

/* v0.9.7 checkout address autocomplete + profile edit address affordance */
.wbop-checkout-address-message{font-size:12px;font-weight:800;color:#5b4a38;margin-top:-4px}.wbop-checkout-address-message.is-error{color:#a12618}.wbop-checkout-address-message.is-success{color:#1f7a3a}.wbop-checkout-address-message.is-info{color:#5b4a38}.wbop-profile-dashboard-actions{grid-template-columns:1fr auto auto;}@media(max-width:760px){.wbop-profile-dashboard-actions{grid-template-columns:1fr}.wbop-checkout-address-message{margin-top:0}}


/* v0.9.37: native Google pac-container is intentionally suppressed; inline suggestions are rendered by WBOP. */
/* v0.9.10 hide Google Places dropdown after address selection */
.pac-container.wbop-google-pac-hidden {
  display: none !important;
  visibility: hidden !important;
}


/* v0.9.11 order confirmation redirect + mobile profile popup scroll fix */
.wbop-profile-modal.is-open{display:block;}
.wbop-profile-modal.is-open .wbop-modal-sheet.wbop-profile-sheet{
  display:flex;
  flex-direction:column;
  max-height:calc(100dvh - 28px);
  overflow:hidden;
}
.wbop-profile-modal.is-open .wbop-profile-panel{
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  max-height:calc(100dvh - 48px);
  padding-bottom:calc(24px + env(safe-area-inset-bottom));
}
@media(max-width:720px){
  .wbop-profile-modal.is-open .wbop-modal-sheet.wbop-profile-sheet{
    inset:auto 8px 8px 8px;
    width:auto;
    max-width:none;
    height:auto;
    max-height:calc(100dvh - 16px);
    border-radius:24px 24px 18px 18px;
  }
  .wbop-profile-modal.is-open .wbop-profile-panel{
    max-height:calc(100dvh - 36px);
    overflow-y:auto!important;
    touch-action:pan-y!important;
  }
  .wbop-profile-modal.is-open .wbop-modal-close{
    position:sticky;
    top:calc(8px + env(safe-area-inset-top));
    z-index:20;
    align-self:flex-end;
  }
}

/* v0.9.12 Brunch Perks customer profile polish */
.wbop-profile-hero-card{background:linear-gradient(135deg,#12203a 0%,#1f2c48 55%,#3b2b19 100%);color:#fff;border-radius:24px;padding:22px;display:flex;justify-content:space-between;gap:18px;align-items:flex-start;border:1px solid rgba(244,198,77,.35);box-shadow:0 18px 40px rgba(18,32,58,.22);margin-bottom:16px;position:relative;overflow:hidden}
.wbop-profile-hero-card:before{content:"";position:absolute;inset:auto -60px -80px auto;width:220px;height:220px;background:radial-gradient(circle,rgba(244,198,77,.28),rgba(244,198,77,0) 70%);pointer-events:none}
.wbop-profile-eyebrow{display:block;color:#f4c64d;text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:900;margin-bottom:8px}
.wbop-profile-hero-card strong{display:block;font-size:28px;line-height:1.05;color:#fff;letter-spacing:-.03em}
.wbop-profile-hero-card p{margin:8px 0 0!important;color:#f7ead1!important;font-weight:800!important}
.wbop-profile-logout-pill{border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.09);color:#fff;border-radius:999px;padding:10px 14px;font-weight:900;cursor:pointer;position:relative;z-index:1;white-space:nowrap}
.wbop-profile-nav{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:0 0 16px}
.wbop-profile-nav button{border:1px solid #e7dccb;background:#fff;border-radius:16px;padding:13px 10px;font-weight:950;color:#172033;box-shadow:0 8px 18px rgba(35,28,20,.06);cursor:pointer}
.wbop-profile-nav button.is-active{background:#172033;color:#f4c64d;border-color:#172033}
.wbop-profile-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:0 0 16px}
.wbop-profile-stat-grid article{background:#fff;border:1px solid #eadfce;border-radius:20px;padding:18px;text-align:center;box-shadow:0 10px 24px rgba(40,28,14,.06)}
.wbop-profile-stat-grid span{display:block;font-size:24px;margin-bottom:8px}.wbop-profile-stat-grid strong{display:block;font-size:28px;line-height:1;color:#172033}.wbop-profile-stat-grid em{display:block;margin-top:6px;font-style:normal;text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:900;color:#7c6a56}
.wbop-profile-feature-card{background:linear-gradient(135deg,#fff8e6,#fff);border:1px solid #eadfce;border-radius:22px;padding:18px;display:flex;justify-content:space-between;gap:16px;align-items:center;margin:0 0 16px;box-shadow:0 10px 24px rgba(40,28,14,.06)}
.wbop-profile-feature-card span{font-size:28px}.wbop-profile-feature-card strong{display:block;font-size:22px;color:#172033}.wbop-profile-feature-card p{margin:6px 0 0!important;color:#6b5b49!important;font-weight:700!important}.wbop-profile-feature-card em{font-style:normal;background:#f4c64d;color:#172033;border-radius:999px;padding:12px 16px;font-weight:950;white-space:nowrap}
.wbop-profile-card-list{background:#fff;border:1px solid #eadfce;border-radius:22px;padding:16px;margin:0 0 16px;box-shadow:0 10px 24px rgba(40,28,14,.06)}
.wbop-profile-section-head{display:flex;justify-content:space-between;gap:10px;margin-bottom:10px}.wbop-profile-section-head strong{font-size:18px;color:#172033}.wbop-profile-section-head span{font-size:12px;color:#7c6a56;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.wbop-profile-order-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:12px 0;border-top:1px solid #f0e5d6}.wbop-profile-order-row:first-child{border-top:0}.wbop-profile-order-row strong{display:block;color:#172033}.wbop-profile-order-row span{display:block;color:#7c6a56;font-size:12px;font-weight:700;margin-top:3px}.wbop-profile-order-row em{font-style:normal;font-weight:950;color:#172033}.wbop-profile-order-row b{background:#eaf6ed;color:#1f7a3a;border-radius:999px;padding:6px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.wbop-profile-summary-grid article strong{color:#172033}.wbop-profile-dashboard-actions{margin-bottom:16px}
@media(max-width:760px){.wbop-profile-hero-card{display:block;padding:18px}.wbop-profile-logout-pill{margin-top:12px}.wbop-profile-nav{grid-template-columns:1fr 1fr}.wbop-profile-stat-grid{grid-template-columns:1fr}.wbop-profile-feature-card{display:block}.wbop-profile-feature-card em{display:inline-block;margin-top:12px}.wbop-profile-order-row{grid-template-columns:1fr auto}.wbop-profile-order-row b{grid-column:1/-1;justify-self:start}.wbop-profile-hero-card strong{font-size:23px}}

/* v0.9.13 saved address book: show list first, form only for add/edit */
.wbop-profile-address-book{
  margin-top:18px;
  padding:20px;
  border:1px solid rgba(121,91,54,.22);
  border-radius:22px;
  background:#fffaf0;
}
.wbop-profile-address-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:14px;
  margin-top:14px;
}
.wbop-profile-address-card{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:16px;
  border:1px solid rgba(31,122,58,.18);
  border-radius:18px;
  background:#fff;
  box-shadow:0 12px 28px rgba(40,28,12,.08);
}
.wbop-profile-address-card > div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color:#766650;
  font-size:.85rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.wbop-profile-address-card b{
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  border-radius:999px;
  background:#eaf6ec;
  color:#1f7a3a;
  font-size:.75rem;
}
.wbop-profile-address-card b.is-secondary{
  background:#f4ecdb;
  color:#795b36;
}
.wbop-profile-address-card strong{
  color:#24190d;
  font-size:1.02rem;
  line-height:1.25;
}
.wbop-profile-address-card p,
.wbop-profile-address-card em{
  margin:0;
  color:#6d6256;
  font-style:normal;
}
.wbop-profile-address-card .wbop-profile-secondary{
  margin-top:auto;
  width:100%;
}
.wbop-profile-address-empty{
  grid-column:1/-1;
  padding:20px;
  border:1px dashed rgba(121,91,54,.35);
  border-radius:18px;
  background:#fff;
  text-align:center;
}
.wbop-profile-address-empty p{margin:6px 0 14px;color:#766650;}
.wbop-profile-address-editor[hidden]{display:none!important;}
@media(max-width:760px){
  .wbop-profile-address-book{padding:14px;border-radius:18px;}
  .wbop-profile-address-list{grid-template-columns:1fr;}
}

/* v0.9.14 address book controls */
.wbop-profile-address-card .wbop-profile-address-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-top:auto;
}
.wbop-profile-address-card .wbop-profile-address-actions .wbop-profile-secondary,
.wbop-profile-address-card .wbop-profile-address-actions .wbop-profile-danger{
  width:auto;
  flex:1 1 auto;
  min-width:110px;
  margin-top:0;
}
.wbop-profile-danger{
  border:1px solid rgba(145,38,28,.22);
  background:#fff5f3;
  color:#9d2418;
  border-radius:999px;
  padding:10px 14px;
  font-weight:950;
  cursor:pointer;
}
.wbop-profile-danger:hover{background:#ffe7e3;}
@media(max-width:720px){
  .wbop-profile-address-card .wbop-profile-address-actions{display:grid;grid-template-columns:1fr;}
  .wbop-profile-address-card .wbop-profile-address-actions .wbop-profile-secondary,
  .wbop-profile-address-card .wbop-profile-address-actions .wbop-profile-danger{width:100%;}
}


.wbop-profile-order-row-actions{align-items:center;gap:10px;grid-template-columns:1fr auto auto auto}
.wbop-profile-order-row small{display:block;margin-top:4px;color:#7a6a57;font-size:.88rem;line-height:1.3}
.wbop-profile-order-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.wbop-profile-order-actions button{min-height:38px;padding:8px 13px;border-radius:13px;font-weight:800}
.wbop-profile-order-detail{margin:0 0 12px;padding:16px;border:1px solid rgba(56,126,58,.22);border-radius:18px;background:#fffdf7;box-shadow:0 10px 24px rgba(40,27,15,.08)}
.wbop-profile-order-detail span{display:block;color:#7a6a57;margin-top:3px}
.wbop-profile-order-detail ul{margin:12px 0 0 20px;padding:0}
.wbop-profile-order-detail li{margin:8px 0}
.wbop-profile-order-detail li ul{margin-top:4px;color:#6d6255;font-size:.9rem}
.wbop-profile-order-detail-actions{margin-top:14px;display:flex;justify-content:flex-end}
@media (max-width: 720px){
  .wbop-profile-order-row-actions{display:block}
  .wbop-profile-order-row-actions em,.wbop-profile-order-row-actions b{display:inline-block;margin-top:8px;margin-right:8px}
  .wbop-profile-order-actions{justify-content:flex-start;margin-top:10px}
  .wbop-profile-order-actions button{flex:1 1 130px}
}

/* v0.9.37 Google Places native dropdown suppression. Inline WBOP suggestions are used instead. */
.pac-container,
.pac-container.wbop-google-pac-hidden,
.pac-container.wbop-google-pac-fixed,
.pac-container.wbop-google-pac-active{display:none!important;visibility:hidden!important;pointer-events:none!important;}

/* v0.9.19 Brunch Perks earning preview */
.wbop-brunch-perks-earn{margin:10px 0 0;padding:12px 14px;border-radius:16px;background:linear-gradient(135deg,#fff8df,#f7ecd0);border:1px solid #ead7a5;color:#3b2814;display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:850;box-shadow:0 8px 22px rgba(73,45,16,.08)}
.wbop-brunch-perks-earn[hidden]{display:none!important}.wbop-brunch-perks-earn span{font-size:13px;color:#6d5538;text-align:right;font-weight:800}@media(max-width:620px){.wbop-brunch-perks-earn{display:block}.wbop-brunch-perks-earn span{display:block;text-align:left;margin-top:3px}}

/* v0.9.20 Brunch Perks profile visibility + backfill activity */
.wbop-profile-perks-activity{margin-top:12px}
.wbop-perks-activity-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid rgba(202,168,79,.35);border-radius:16px;background:linear-gradient(135deg,#fffaf0,#fff);box-shadow:0 10px 24px rgba(23,32,51,.05);margin-bottom:10px}
.wbop-perks-activity-row strong{display:block;color:#40260f;font-weight:950}
.wbop-perks-activity-row span{display:block;color:#75664f;font-size:12px;margin-top:2px}
.wbop-perks-activity-row em{font-style:normal;background:#172033;color:#fff;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:850;white-space:nowrap}
.wbop-perks-sync-note{border-radius:14px;background:#fff4d6;border:1px solid rgba(202,168,79,.45);color:#4b3518;padding:10px 12px;margin-bottom:10px;font-weight:850;font-size:12px}
.wbop-profile-empty{border:1px dashed rgba(202,168,79,.5);border-radius:16px;padding:14px;color:#75664f;background:#fffaf0;font-size:13px}
@media(max-width:620px){.wbop-perks-activity-row{align-items:flex-start;flex-direction:column}.wbop-perks-activity-row em{align-self:flex-start}}


/* v0.9.21 profile button Brunch Perks chip */
.wbop-profile-perks-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  border-radius:999px;
  background:linear-gradient(135deg,#fff3c4,#f4c64d);
  color:#172033;
  border:1px solid rgba(23,32,51,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 4px 10px rgba(0,0,0,.12);
  font-weight:950;
  font-size:12px;
  line-height:1;
  padding:6px 9px;
  white-space:nowrap;
}
.wbop-profile-perks-chip[hidden]{display:none!important;}
.wbop-desktop-profile-button .wbop-profile-perks-chip{margin-left:2px;}
@media (max-width:768px){
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed{
    width:auto;
    min-width:52px;
    max-width:calc(100vw - 32px);
    padding:0 12px;
    gap:8px;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed .wbop-profile-perks-chip{
    font-size:11px;
    padding:6px 8px;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed .wbop-profile-first-name:not([hidden]) + .wbop-profile-perks-chip{
    margin-left:0;
  }
}

/* v0.9.22 Brunch Perks customer-facing explanation */
.wbop-profile-perks-how{
  margin-top:12px;
  padding:12px 14px;
  border:1px solid rgba(244,198,77,.45);
  border-radius:16px;
  background:linear-gradient(135deg,#fffaf0,#fffdf8);
  color:#40260f;
}
.wbop-profile-perks-how > strong{
  display:block;
  font-size:14px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#172033;
  margin-bottom:7px;
}
.wbop-profile-perks-how ul{
  margin:0 0 8px 18px;
  padding:0;
  color:#6b5b49;
  font-weight:800;
  line-height:1.45;
}
.wbop-profile-perks-how li{margin:3px 0;}
.wbop-profile-perks-how p{
  margin:8px 0 0!important;
  padding-top:8px;
  border-top:1px dashed rgba(121,91,54,.28);
  color:#1f7a3a!important;
  font-weight:950!important;
}
.wbop-profile-perks-card{align-items:flex-start;}
@media(max-width:760px){
  .wbop-profile-perks-how{padding:11px 12px;}
}

.wbop-profile-order-row.is-profile-order-hidden{display:none!important}
.wbop-profile-order-detail-head{display:flex;gap:12px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}
.wbop-profile-order-detail-head .wbop-profile-secondary{order:2}
@media(max-width:640px){.wbop-profile-order-detail-head{display:block}.wbop-profile-order-detail-head .wbop-profile-secondary{width:100%;margin-bottom:10px}}

/* v0.9.37: Inline Google address suggestions for iPhone-safe modal flow. */
.wbop-address-suggest{
  position:relative!important;
  display:block;
  z-index:5!important;
  box-sizing:border-box!important;
  width:100%!important;
  max-height:238px!important;
  margin:7px 0 10px!important;
  background:#fff!important;
  border:1px solid rgba(0,0,0,.12)!important;
  border-radius:14px!important;
  box-shadow:0 10px 24px rgba(35,25,14,.13)!important;
  overflow:auto!important;
  -webkit-overflow-scrolling:touch!important;
  font-family:inherit!important;
  overscroll-behavior:contain!important;
}
.wbop-address-suggest:not(.is-open){display:none!important;}
.wbop-address-suggest-list{background:#fff!important;}
.wbop-address-suggest-item{
  width:100%!important;
  border:0!important;
  border-bottom:1px solid rgba(0,0,0,.08)!important;
  background:#fff!important;
  color:#1d2330!important;
  text-align:left!important;
  padding:12px 14px 12px 38px!important;
  min-height:50px!important;
  position:relative!important;
  display:block!important;
  cursor:pointer!important;
  font:inherit!important;
  appearance:none!important;
  -webkit-appearance:none!important;
  touch-action:manipulation!important;
}
.wbop-address-suggest-item:active,
.wbop-address-suggest-item:hover{background:#f7f4ed!important;}
.wbop-address-suggest-item:last-of-type{border-bottom:0!important;}
.wbop-address-pin{
  position:absolute!important;
  left:14px!important;
  top:16px!important;
  width:12px!important;
  height:12px!important;
  border-radius:999px!important;
  background:#b8b8b8!important;
  color:transparent!important;
}
.wbop-address-main{display:inline!important;font-weight:900!important;color:#111827!important;font-size:16px!important;line-height:1.25!important;}
.wbop-address-secondary{display:inline!important;margin-left:6px!important;color:#6b7280!important;font-size:15px!important;line-height:1.25!important;}
.wbop-address-google-brand{
  position:sticky!important;
  bottom:0!important;
  text-align:right!important;
  padding:8px 12px 9px!important;
  color:#8a8a8a!important;
  font-size:12px!important;
  line-height:1!important;
  background:#fff!important;
  border-top:1px solid rgba(0,0,0,.06)!important;
}
.wbop-address-google-brand span{font-weight:900!important;color:#4285f4!important;letter-spacing:.01em!important;}
body .pac-container.wbop-google-pac-hidden,
body .pac-container{display:none!important;visibility:hidden!important;pointer-events:none!important;}
@media (max-width:720px){
  .wbop-address-suggest{max-height:184px!important;border-radius:16px!important;margin-top:6px!important;margin-bottom:12px!important;}
  .wbop-address-main{font-size:15px!important;}
  .wbop-address-secondary{display:block!important;margin-left:0!important;margin-top:2px!important;font-size:13px!important;}
  .wbop-address-suggest-item{padding-top:11px!important;padding-bottom:11px!important;min-height:54px!important;}
}


/* v0.9.40 mobile category navigation polish */
.wbop-category-strip {
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scroll-snap-type: x proximity;
}
.wbop-category-strip .wbop-cat-pill {
  scroll-snap-align: center;
}
.wbop-category-strip .wbop-cat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 6px;
  font-size: .98em;
  line-height: 1;
}
.wbop-category-strip .wbop-cat-label {
  display: inline-block;
  max-width: 156px;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}

@media (max-width: 720px) {
  body.wbop-ordering-app-page .wbop-category-strip,
  .wbop-order-app.is-mobile-menu .wbop-category-strip,
  .wbop-category-strip {
    position: sticky;
    top: max(0px, env(safe-area-inset-top));
    z-index: 28;
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 8px;
    margin: 0 -2px 8px;
    padding: 10px 12px 9px;
    overflow-x: auto;
    overflow-y: hidden;
    background: rgba(255,255,255,.97);
    border-bottom: 1px solid rgba(0,0,0,.06);
    box-shadow: 0 8px 18px rgba(60,42,22,.08);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    position: relative;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    max-width: 180px;
    padding: 0 13px;
    border: 1px solid rgba(35,26,19,.12);
    border-radius: 999px;
    background: #fff8ed;
    color: #231a13;
    box-shadow: none;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .01em;
    line-height: 1;
    white-space: nowrap;
  }
  .wbop-category-strip button.is-active,
  .wbop-category-strip .wbop-cat-pill.is-active {
    background: #111 !important;
    border-color: #111 !important;
    color: #fff !important;
    box-shadow: 0 8px 18px rgba(0,0,0,.14);
  }
  .wbop-category-strip button.is-active::after,
  .wbop-category-strip .wbop-cat-pill.is-active::after {
    display: none !important;
    content: none !important;
  }
  .wbop-category-strip .wbop-cat-label {
    max-width: 128px;
  }
  .wbop-category-strip::after {
    content: '';
    flex: 0 0 8px;
    width: 8px;
  }
}

@media (max-width: 390px) {
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    min-height: 34px;
    padding: 0 11px;
    font-size: 12px;
  }
  .wbop-category-strip .wbop-cat-label {
    max-width: 104px;
  }
}


/* v0.9.41 mobile category navigation refinement */
@media (max-width: 720px) {
  .wbop-order-app.is-mobile-menu .wbop-category-strip,
  body.wbop-ordering-app-page .wbop-category-strip,
  .wbop-category-strip {
    min-height: 46px !important;
    gap: 6px !important;
    margin: 0 -4px 6px !important;
    padding: 7px 10px 7px !important;
    box-shadow: 0 5px 14px rgba(60,42,22,.06) !important;
    border-top: 1px solid rgba(0,0,0,.025) !important;
  }
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    min-height: 32px !important;
    max-width: 142px !important;
    padding: 0 11px !important;
    font-size: 12px !important;
    border-color: rgba(35,26,19,.10) !important;
    background: rgba(255,248,237,.86) !important;
    box-shadow: none !important;
  }
  .wbop-category-strip button.is-active,
  .wbop-category-strip .wbop-cat-pill.is-active {
    background: #fff1d2 !important;
    border-color: #e0a428 !important;
    color: #231a13 !important;
    box-shadow: inset 0 -3px 0 #e0a428, 0 5px 14px rgba(224,164,40,.13) !important;
  }
  .wbop-category-strip .wbop-cat-icon {
    margin-right: 4px !important;
    font-size: .95em !important;
  }
  .wbop-category-strip .wbop-cat-label {
    max-width: 92px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  .wbop-search-row {
    margin: 8px 0 14px !important;
    gap: 0 !important;
  }
  .wbop-search-row input {
    min-height: 46px !important;
    border-radius: 19px !important;
  }
  .wbop-search-row span[data-menu-count] {
    display: none !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-search-row {
    display: block !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-customer-chip,
  .wbop-customer-chip {
    transform: scale(.94);
    transform-origin: left top;
  }
  .wbop-order-app.is-mobile-menu .wbop-menu-stage,
  .wbop-menu-stage {
    overflow: visible !important;
  }
  .wbop-category-strip:before,
  .wbop-category-strip:after {
    content: '' !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 2 !important;
    flex: 0 0 15px !important;
    width: 15px !important;
    min-height: 32px !important;
    pointer-events: none !important;
  }
  .wbop-category-strip:before {
    left: 0 !important;
    margin-left: -10px !important;
    background: linear-gradient(90deg, rgba(255,255,255,.98), rgba(255,255,255,0)) !important;
  }
  .wbop-category-strip:after {
    right: 0 !important;
    margin-right: -10px !important;
    background: linear-gradient(270deg, rgba(255,255,255,.98), rgba(255,255,255,0)) !important;
  }
}
@media (max-width: 390px) {
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    max-width: 126px !important;
    min-height: 31px !important;
    padding: 0 10px !important;
    font-size: 11.5px !important;
  }
  .wbop-category-strip .wbop-cat-label { max-width: 78px !important; }
}


/* v0.9.42 mobile category two-line pill refinement */
@media (max-width: 720px) {
  .wbop-order-app.is-mobile-menu .wbop-category-strip,
  body.wbop-ordering-app-page .wbop-category-strip,
  .wbop-category-strip {
    min-height: 58px !important;
    padding: 8px 18px 8px 18px !important;
    gap: 8px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    scroll-padding-left: 20px !important;
    scroll-padding-right: 20px !important;
  }
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    min-height: 42px !important;
    max-width: 154px !important;
    min-width: 74px !important;
    padding: 5px 12px !important;
    white-space: normal !important;
    line-height: 1.05 !important;
    text-align: center !important;
    align-items: center !important;
    gap: 4px !important;
  }
  .wbop-category-strip .wbop-cat-icon {
    flex: 0 0 auto !important;
    margin-right: 2px !important;
  }
  .wbop-category-strip .wbop-cat-label {
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    max-width: 106px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: normal !important;
    line-height: 1.05 !important;
  }
  .wbop-category-strip:before,
  .wbop-category-strip:after {
    flex-basis: 10px !important;
    width: 10px !important;
    min-height: 42px !important;
  }
  .wbop-category-strip:before { margin-left: -18px !important; }
  .wbop-category-strip:after { margin-right: -18px !important; }
}
@media (max-width: 390px) {
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    min-height: 42px !important;
    max-width: 146px !important;
    min-width: 70px !important;
    padding: 5px 10px !important;
    font-size: 11.5px !important;
  }
  .wbop-category-strip .wbop-cat-label {
    max-width: 98px !important;
  }
}


/* v0.9.43 mobile category color restoration */
@media (max-width: 720px) {
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    box-shadow: 0 2px 8px rgba(34, 24, 14, .05) !important;
    transition: transform .16s ease, box-shadow .16s ease, background-color .16s ease, border-color .16s ease !important;
  }
  .wbop-category-strip button.is-active,
  .wbop-category-strip .wbop-cat-pill.is-active {
    box-shadow: 0 5px 14px rgba(80, 52, 16, .16) !important;
    transform: translateY(-1px) !important;
  }
  .wbop-category-strip .wbop-cat-icon {
    opacity: .95 !important;
  }
}


/* v0.9.44 mobile category color enforcement + contextual cart CTA */
@media (max-width: 720px) {
  .wbop-category-strip button,
  .wbop-category-strip .wbop-cat-pill {
    background-color: var(--wbop-cat-bg, #fff8ed) !important;
    color: var(--wbop-cat-text, #231a13) !important;
    border-color: var(--wbop-cat-border, #eadcc8) !important;
  }
  .wbop-category-strip button.is-active,
  .wbop-category-strip .wbop-cat-pill.is-active {
    background-color: var(--wbop-cat-bg, #e7b041) !important;
    color: var(--wbop-cat-text, #1f1400) !important;
    border-color: var(--wbop-cat-border, #e7b041) !important;
  }
  .wbop-mobile-bottom-nav [data-mobile-open-cart] {
    min-width: 64px;
  }
  .wbop-order-app[data-mobile-view="home"] .wbop-mobile-cart-bar button[data-open-cart] {
    min-width: 116px;
  }
}


/* v0.9.45 mobile CTA correction + stronger category color cascade */
@media (max-width: 720px) {
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip button.wbop-cat-pill,
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip .wbop-cat-pill {
    background: var(--wbop-cat-bg, #fff8ed) !important;
    background-color: var(--wbop-cat-bg, #fff8ed) !important;
    color: var(--wbop-cat-text, #231a13) !important;
    border-color: var(--wbop-cat-border, #eadcc8) !important;
  }
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip button.wbop-cat-pill.is-active,
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip .wbop-cat-pill.is-active {
    background: var(--wbop-cat-bg, #e7b041) !important;
    background-color: var(--wbop-cat-bg, #e7b041) !important;
    color: var(--wbop-cat-text, #1f1400) !important;
    border-color: var(--wbop-cat-border, #e7b041) !important;
  }
  .wbop-order-app[data-mobile-view="home"] .wbop-mobile-cart-bar strong {
    font-size: 22px !important;
  }
  .wbop-order-app[data-mobile-view="home"] .wbop-mobile-cart-bar button[data-open-cart] {
    min-width: 112px !important;
    font-weight: 950 !important;
  }
}


/* v0.9.46 checkout CTA + category color hardening */
@media (max-width: 720px) {
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip button.wbop-cat-pill[style],
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip .wbop-cat-pill[style] {
    background: var(--wbop-cat-bg, #fff8ed) !important;
    background-color: var(--wbop-cat-bg, #fff8ed) !important;
    color: var(--wbop-cat-text, #231a13) !important;
    border-color: var(--wbop-cat-border, #eadcc8) !important;
  }
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip button.wbop-cat-pill.is-active[style],
  body.wbop-ordering-app-page .wbop-order-app .wbop-category-strip .wbop-cat-pill.is-active[style] {
    background: var(--wbop-cat-bg, #e7b041) !important;
    background-color: var(--wbop-cat-bg, #e7b041) !important;
    color: var(--wbop-cat-text, #1f1400) !important;
    border-color: var(--wbop-cat-border, #e7b041) !important;
  }
  .wbop-mobile-cart-bar button[data-open-cart].is-start-order strong,
  .wbop-mobile-cart-bar button[data-open-cart].is-start-order [data-cart-count] {
    font-size: 22px !important;
    letter-spacing: -.02em;
  }
  .wbop-mobile-cart-bar button[data-open-cart].is-start-order [data-cart-summary] {
    opacity: .88;
  }
  .wbop-modal.is-open .wbop-modal-sheet,
  .wbop-cart-modal.is-open .wbop-cart-panel {
    max-height: calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 20px);
  }
  .wbop-cart-panel .wbop-checkout-button[disabled] {
    opacity: .58;
    cursor: not-allowed;
  }
}

/* v0.9.49 compact scheduling availability notices */
.wbop-availability-card {
  max-width: 1180px;
  margin: 6px auto 8px;
  padding: 9px 12px;
  border-radius: 16px;
  border: 1px solid rgba(217, 197, 164, .72);
  background: #fffaf1;
  color: #22170d;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  box-shadow: 0 8px 18px rgba(54, 38, 18, .045);
}
.wbop-availability-card[hidden],
.wbop-availability-card.is-ok { display: none !important; }
.wbop-availability-card > div {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  column-gap: 10px;
  row-gap: 1px;
}
.wbop-availability-card span[data-availability-badge] {
  grid-row: 1 / span 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(28, 125, 61, .12);
  color: #17642f;
  font-size: 11px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.wbop-availability-card strong {
  display: block;
  margin: 0;
  color: #111;
  font-size: 15px;
  line-height: 1.08;
  letter-spacing: -.02em;
}
.wbop-availability-card p {
  margin: 2px 0 0;
  color: rgba(0,0,0,.66);
  font-size: 12.5px;
  line-height: 1.24;
  font-weight: 700;
}
.wbop-availability-card button {
  flex: 0 0 auto;
  min-height: 34px;
  border: 0;
  border-radius: 999px;
  padding: 0 12px;
  background: #111;
  color: #fff;
  font-size: 12.5px;
  font-weight: 900;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
}
.wbop-availability-card button[hidden] { display: none !important; }
.wbop-availability-card.is-warning {
  border-color: rgba(224, 162, 41, .45);
  background: #fff7df;
}
.wbop-availability-card.is-warning span[data-availability-badge] {
  background: rgba(224, 162, 41, .18);
  color: #7b4d05;
}
.wbop-availability-card.is-closed,
.wbop-availability-card.is-paused {
  border-color: rgba(138, 31, 17, .22);
  background: #fff7f4;
}
.wbop-availability-card.is-closed span[data-availability-badge],
.wbop-availability-card.is-paused span[data-availability-badge] {
  background: rgba(138, 31, 17, .12);
  color: #7a2417;
}
.wbop-service-notice.is-warning { border-color: rgba(224,162,41,.45); background:#fff8e4; color:#704c05; }
.wbop-service-notice.is-closed,
.wbop-service-notice.is-paused { border-color: rgba(138,31,17,.18); background:#fff8f5; color:#6b2419; }
.wbop-service-notice.is-ok { display:none!important; }
@media (max-width: 720px) {
  .wbop-availability-card {
    margin: 6px 16px 0;
    padding: 8px 10px;
    border-radius: 15px;
    gap: 8px;
  }
  .wbop-availability-card-home {
    margin-left: 0;
    margin-right: 0;
  }
  .wbop-availability-card-menu {
    margin: 5px 18px 7px;
  }
  .wbop-availability-card > div {
    column-gap: 8px;
  }
  .wbop-availability-card span[data-availability-badge] {
    min-height: 20px;
    padding: 0 7px;
    font-size: 10px;
  }
  .wbop-availability-card strong { font-size: 13px; }
  .wbop-availability-card p { font-size: 11.5px; line-height: 1.18; }
  .wbop-availability-card button {
    align-self: center;
    min-height: 32px;
    padding: 0 10px;
    font-size: 11.5px;
  }
  .wbop-order-app[data-mobile-view="home"] .wbop-availability-card-menu,
  .wbop-order-app[data-mobile-view="menu"] .wbop-availability-card-home {
    display: none !important;
  }
}

/* v0.9.50 Brunch Perks checkout redemption */
.wbop-brunch-perks-redeem {
  margin: 12px 0;
  padding: 13px 14px;
  border-radius: 16px;
  background: linear-gradient(135deg, #fffaf0, #fff);
  border: 1px solid rgba(202, 168, 79, .42);
  box-shadow: 0 8px 22px rgba(73, 45, 16, .07);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.wbop-brunch-perks-redeem[hidden] { display: none !important; }
.wbop-perks-redeem-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.wbop-perks-redeem-copy strong {
  color: #3b2814;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.15;
}
.wbop-perks-redeem-copy span {
  color: #6d5538;
  font-size: 13px;
  font-weight: 750;
  line-height: 1.35;
}
.wbop-brunch-perks-redeem button {
  border: 0;
  border-radius: 999px;
  background: #0aa84f;
  color: #fff;
  font-family: inherit;
  font-size: 13px;
  font-weight: 950;
  min-height: 36px;
  padding: 0 14px;
  white-space: nowrap;
  cursor: pointer;
}
.wbop-total-box [data-reward-discount-row] strong { color: #087d3b; }
.wbop-perks-activity-row.is-redeemed {
  background: linear-gradient(135deg, #f5fbf7, #fff);
  border-color: rgba(47, 111, 62, .25);
}
.wbop-perks-activity-row.is-redeemed strong { color: #0b6a36; }

/* v0.9.152 saved-card diagnostics */
.wbop-profile-payment-methods{border:1px solid rgba(18,63,43,.12);border-radius:18px;padding:16px;background:#fffaf2;margin:14px 0;}
.wbop-profile-add-card{border:1px dashed rgba(18,63,43,.28);border-radius:16px;padding:14px;margin-top:12px;background:#fff;}
.wbop-profile-card-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px;}
.wbop-profile-card-fields .wbop-wide{grid-column:1/-1;}
.wbop-profile-consent{display:flex!important;gap:9px;align-items:flex-start;margin:12px 0;font-weight:700;color:#4b3a29;}
.wbop-profile-consent input{width:auto!important;margin-top:3px;}
.wbop-profile-payment-card{display:flex;justify-content:space-between;gap:12px;border:1px solid rgba(18,63,43,.12);border-radius:14px;background:#fff;padding:12px;margin:8px 0;}
.wbop-profile-payment-card strong{display:block;font-weight:900;color:#123f2b;}
.wbop-profile-payment-card span,.wbop-profile-payment-card em,.wbop-profile-payment-card small{display:block;color:#6b5c4a;font-size:12px;margin-top:2px;}
.wbop-profile-card-message{font-weight:800;font-size:13px;align-self:center;}
.wbop-profile-card-message.is-success{color:#047857;}.wbop-profile-card-message.is-error{color:#b91c1c;}.wbop-profile-card-message.is-info{color:#475569;}
@media(max-width:680px){.wbop-profile-card-fields{grid-template-columns:1fr}.wbop-profile-payment-card{display:block}.wbop-profile-payment-card .wbop-profile-address-actions{margin-top:10px}}
/* v0.9.165 saved-card verification status */
.wbop-profile-payment-card .wbop-profile-card-steps{line-height:1.45;color:#365244;}

/* v0.9.169: saved-card checkout selector */
.wbop-saved-card-checkout{border:1px solid rgba(40,99,59,.18);border-radius:14px;background:#fff;padding:12px;display:grid;gap:8px}.wbop-saved-card-checkout[hidden],.wbop-payment-grid[hidden]{display:none!important}.wbop-saved-card-checkout strong{font-size:13px;font-weight:900;color:#123f2b}.wbop-saved-card-checkout p{font-size:12px;color:#4d5b50;margin:0}.wbop-saved-card-choice{display:grid;gap:8px}.wbop-saved-card-choice label{display:flex;gap:8px;align-items:center;font-size:13px;font-weight:900}.wbop-saved-card-choice select{width:100%;border:1px solid rgba(0,0,0,.16);border-radius:12px;padding:9px 10px;background:#fff;font-weight:800}

.wbop-profile-card-action{margin-top:10px;}
.wbop-profile-account-editor{margin:18px 0;padding:18px;border:1px solid rgba(154,103,33,.25);border-radius:18px;background:#fff;}


/* v0.9.237 customer profile active order card */
.wbop-profile-active-order-card{
  margin:18px 0 20px;
  padding:18px 20px;
  border-radius:18px;
  background:#0b5c2a;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  box-shadow:0 16px 34px rgba(11,92,42,.18);
}
.wbop-profile-active-order-main{display:flex;align-items:center;gap:14px;min-width:0;}
.wbop-profile-live-dot{width:14px;height:14px;border-radius:50%;background:#36d978;box-shadow:0 0 0 0 rgba(54,217,120,.72);animation:wbopPulseDot 1.35s infinite;flex:0 0 auto;}
.wbop-profile-active-order-main strong{display:block;font-weight:900;text-transform:uppercase;letter-spacing:.04em;font-size:1.02rem;color:#fff;}
.wbop-profile-active-order-main p{margin:4px 0 0;color:rgba(255,255,255,.78);font-weight:700;line-height:1.35;}
.wbop-profile-active-order-link{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;border-radius:14px;background:#32d17b;color:#073719 !important;text-decoration:none;font-weight:900;padding:14px 20px;box-shadow:0 10px 22px rgba(0,0,0,.14);}
.wbop-profile-active-order-link:hover{transform:translateY(-1px);filter:brightness(1.04);}
@keyframes wbopPulseDot{0%{box-shadow:0 0 0 0 rgba(54,217,120,.72);}70%{box-shadow:0 0 0 10px rgba(54,217,120,0);}100%{box-shadow:0 0 0 0 rgba(54,217,120,0);}}
@media (max-width:640px){.wbop-profile-active-order-card{align-items:flex-start;flex-direction:column;padding:16px;}.wbop-profile-active-order-link{width:100%;}}

/* v0.9.259 mobile rollback for compact Order Setup: keep desktop compact block, restore mobile-safe single-row summary */
@media (max-width: 720px) {
  .wbop-order-app.is-mobile-menu .wbop-order-mode-bar,
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-bar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    margin: 8px 12px 8px !important;
    padding: 10px 12px !important;
    border-radius: 16px !important;
    min-height: 0 !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-order-mode-copy,
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-copy {
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-order-mode-bar .wbop-pill,
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-bar .wbop-pill {
    font-size: 10px !important;
    line-height: 1 !important;
    padding: 6px 9px !important;
    margin: 0 0 4px !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-order-mode-bar strong,
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-bar strong {
    font-size: 15px !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    white-space: normal !important;
    word-break: normal !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-order-mode-bar em,
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-bar em {
    display: none !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-order-mode-change,
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-change {
    flex: 0 0 auto !important;
    width: auto !important;
    min-height: 40px !important;
    padding: 0 14px !important;
    font-size: 13px !important;
    white-space: nowrap !important;
  }
  .wbop-order-app.is-mobile-menu .wbop-order-mode-availability,
  .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-availability {
    display: none !important;
  }
}


/* v0.9.260 hard mobile Order Setup repair: hide desktop availability card on phones and force one clean compact row */
@media (max-width: 720px) {
  body.wbop-ordering-app-page .wbop-order-mode-bar .wbop-order-mode-availability,
  body.wbop-ordering-app-page .wbop-order-mode-availability,
  body.wbop-ordering-app-page .wbop-availability-card-menu.wbop-order-mode-availability {
    display: none !important;
    visibility: hidden !important;
    max-height: 0 !important;
    max-width: 0 !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
  }

  body.wbop-ordering-app-page .wbop-order-app.is-mobile-menu .wbop-order-mode-bar,
  body.wbop-ordering-app-page .wbop-order-app[data-mobile-view="menu"] .wbop-order-mode-bar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 12px !important;
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
    margin: 8px 12px 8px !important;
    padding: 12px 12px !important;
    border-radius: 18px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  body.wbop-ordering-app-page .wbop-order-mode-copy {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  body.wbop-ordering-app-page .wbop-order-mode-copy .wbop-pill {
    display: inline-flex !important;
    width: auto !important;
    max-width: 100% !important;
    margin: 0 0 4px !important;
    padding: 6px 9px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  body.wbop-ordering-app-page .wbop-order-mode-copy strong {
    display: block !important;
    margin: 0 !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 100% !important;
  }

  body.wbop-ordering-app-page .wbop-order-mode-copy em {
    display: block !important;
    margin: 2px 0 0 !important;
    font-size: 11px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  body.wbop-ordering-app-page .wbop-order-mode-change {
    min-width: 82px !important;
    min-height: 42px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    white-space: nowrap !important;
    justify-self: end !important;
  }
}

/* v0.9.261 mobile profile pill: keep it in normal flow so it cannot cover Order Setup */
@media (max-width: 720px) {
  body.wbop-ordering-app-page .wbop-order-app {
    position: relative;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed {
    position: sticky !important;
    top: calc(env(safe-area-inset-top, 0px) + 8px) !important;
    left: auto !important;
    right: auto !important;
    margin: 8px 16px 6px auto !important;
    width: fit-content !important;
    min-width: 48px !important;
    max-width: calc(100vw - 32px) !important;
    height: 48px !important;
    min-height: 48px !important;
    padding: 0 10px 0 0 !important;
    z-index: 60 !important;
    transform: none !important;
  }
  body.admin-bar.wbop-ordering-app-page .wbop-mobile-profile-fixed {
    top: calc(46px + env(safe-area-inset-top, 0px) + 8px) !important;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed .wbop-profile-icon-wrap {
    width: 48px !important;
    height: 48px !important;
    flex: 0 0 48px !important;
  }
  body.wbop-ordering-app-page .wbop-mobile-profile-fixed svg {
    width: 23px !important;
    height: 23px !important;
  }
}

/* v0.9.272 ASAP timing badge: show the customer-facing estimate in the ASAP choice */
.wbop-asap-minutes-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 26px;
  margin-left: 8px;
  padding: 0 7px;
  border-radius: 999px;
  background: #0b0b0b;
  color: #fff;
  font-size: 13px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0;
  vertical-align: middle;
  box-shadow: 0 3px 8px rgba(0,0,0,.18);
}
.wbop-start-toggle button,
.wbop-time-toggle button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
}
.wbop-start-toggle button.is-disabled .wbop-asap-minutes-badge,
.wbop-time-toggle button.is-disabled .wbop-asap-minutes-badge {
  opacity: .7;
}
@media (max-width: 720px) {
  .wbop-asap-minutes-badge {
    min-width: 24px;
    height: 24px;
    margin-left: 6px;
    font-size: 12px;
    padding: 0 6px;
  }
}

/* v0.9.274 Promo code v1 */
.wbop-promo-box {
  margin: 14px 0 12px;
  padding: 14px;
  border: 1px solid #eadfcd;
  border-radius: 14px;
  background: #fffaf2;
}
.wbop-promo-box h4 {
  margin: 0 0 8px;
}
.wbop-promo-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
}
.wbop-promo-row input {
  min-width: 0;
  text-transform: uppercase;
}
.wbop-promo-row button {
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
  background: #111827;
  color: #fff;
}
.wbop-promo-row [data-clear-promo] {
  background: #f3f4f6;
  color: #111827;
}
.wbop-promo-message {
  margin: 8px 0 0;
  font-size: 13px;
  font-weight: 800;
  color: #64748b;
}
.wbop-promo-message.is-success { color: #047857; }
.wbop-promo-message.is-error { color: #b91c1c; }
@media (max-width: 520px) {
  .wbop-promo-row {
    grid-template-columns: 1fr;
  }
  .wbop-promo-row button {
    width: 100%;
  }
}


/* v0.9.276 cart/customer identity banner */
.wbop-cart-customer-summary{display:inline-flex;align-items:center;gap:8px;margin:0 auto 8px auto;padding:7px 11px;border-radius:999px;background:#fff7e8;border:1px solid #eadfce;color:#111827;font-weight:900;font-size:13px;letter-spacing:.04em;text-transform:uppercase;box-shadow:0 8px 22px rgba(40,28,14,.08);}
.wbop-cart-customer-summary.is-customer{background:#f7fbf4;border-color:#d7ead8;text-transform:none;letter-spacing:0;}
.wbop-cart-customer-summary.is-guest{background:#111827;color:#fff;border-color:#111827;}
.wbop-cart-customer-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;}
.wbop-cart-customer-perks{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:28px;padding:0 9px;border-radius:999px;background:#f6c247;color:#111827;font-size:13px;font-weight:1000;box-shadow:inset 0 -2px 0 rgba(0,0,0,.12);}
@media(max-width:720px){.wbop-cart-customer-summary{display:flex;width:max-content;max-width:calc(100% - 82px);margin:0 auto 10px auto;font-size:12px;padding:7px 10px;}.wbop-cart-customer-label{max-width:130px}.wbop-cart-customer-perks{height:26px;min-width:32px;font-size:12px}}

/* v0.9.281: Start Order schedule notice and mobile sheet containment */
.wbop-start-availability{margin:12px 0 0;padding:12px 14px;border:1px solid #ead7ad;background:#fff7df;border-radius:18px;color:#6b4b20;font-weight:800;line-height:1.35}
.wbop-start-availability[hidden]{display:none!important}
@media (max-width:720px){
  .wbop-start-modal .wbop-start-sheet{width:min(94vw,560px);max-width:94vw;margin-left:auto;margin-right:auto;box-sizing:border-box}
  .wbop-start-modal .wbop-modal-sheet{left:auto;right:auto}
}


/* v0.9.282 cautious cart drawer UI polish - visual shell only */
body.wbop-ordering-app-page [data-cart-modal].is-open {
  display: block !important;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-modal-backdrop {
  background: rgba(9, 9, 11, .46);
  backdrop-filter: blur(2px);
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-modal-sheet.wbop-cart-sheet {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: auto !important;
  transform: none !important;
  width: min(760px, 56vw) !important;
  max-width: min(760px, 56vw) !important;
  height: 100dvh !important;
  max-height: 100dvh !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 30px 0 0 30px !important;
  overflow: hidden !important;
  box-shadow: -28px 0 70px rgba(15, 23, 42, .28);
  animation: wbopCartSlideIn .22s ease-out both;
}
@keyframes wbopCartSlideIn {
  from { transform: translateX(22px); opacity: .72; }
  to { transform: translateX(0); opacity: 1; }
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-cart-panel {
  height: 100% !important;
  max-height: none !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
  padding: 34px 38px calc(34px + env(safe-area-inset-bottom)) !important;
  background: #fff;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-cart-back-menu {
  appearance: none;
  border: 0;
  background: transparent;
  color: #5f4c35;
  font: inherit;
  font-weight: 800;
  padding: 0;
  margin: 0 0 18px;
  cursor: pointer;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-cart-customer-summary {
  margin-bottom: 14px;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-cart-panel h3 {
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.02;
  margin: 0 72px 24px 0;
  letter-spacing: -.04em;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-cart-items {
  margin-top: 14px;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-total-box,
body.wbop-ordering-app-page [data-cart-modal] .wbop-checkout-form,
body.wbop-ordering-app-page [data-cart-modal] .wbop-tip-box {
  border-radius: 22px;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-checkout-button {
  min-height: 58px;
  border-radius: 999px;
}
body.wbop-ordering-app-page [data-cart-modal] .wbop-modal-close {
  position: fixed !important;
  top: max(18px, env(safe-area-inset-top)) !important;
  right: 22px !important;
  z-index: 100002 !important;
  width: 52px;
  min-height: 52px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(15, 23, 42, .16);
}
@media (max-width: 980px) {
  body.wbop-ordering-app-page [data-cart-modal].is-open {
    display: flex !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    width: 100vw;
    height: 100dvh;
    padding: 0 !important;
  }
  body.wbop-ordering-app-page [data-cart-modal] .wbop-modal-sheet.wbop-cart-sheet {
    position: relative !important;
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    border-radius: 0 !important;
    box-shadow: none;
    animation: wbopCartMobileIn .18s ease-out both;
  }
  @keyframes wbopCartMobileIn {
    from { transform: translateX(18px); opacity: .8; }
    to { transform: translateX(0); opacity: 1; }
  }
  body.wbop-ordering-app-page [data-cart-modal] .wbop-cart-panel {
    padding: max(24px, env(safe-area-inset-top)) 18px calc(24px + env(safe-area-inset-bottom)) !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  body.wbop-ordering-app-page [data-cart-modal] .wbop-cart-panel h3 {
    font-size: clamp(34px, 10vw, 46px);
    margin-right: 70px;
  }
  body.wbop-ordering-app-page [data-cart-modal] .wbop-modal-close {
    top: max(18px, env(safe-area-inset-top)) !important;
    right: 16px !important;
  }
}


/* v0.9.311 checkout account prompt polish */
.wbop-checkout-account-card{
  margin:18px 0 22px;
  padding:20px;
  border:1px solid rgba(210,162,76,.38);
  border-radius:22px;
  background:linear-gradient(180deg,#fffaf1 0%,#fff 100%);
  box-shadow:0 14px 34px rgba(17,24,39,.06);
}
.wbop-checkout-account-card[hidden]{display:none!important;}
.wbop-checkout-account-copy{margin:0 0 14px;}
.wbop-checkout-account-kicker{
  display:inline-flex;align-items:center;gap:6px;
  margin:0 0 8px;padding:6px 10px;
  border-radius:999px;background:#fff3cf;color:#6b4b14;
  font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;
}
.wbop-checkout-account-kicker:before{content:'🥞';font-size:1rem;letter-spacing:0;text-transform:none;}
.wbop-checkout-account-copy h4{
  margin:0 0 7px!important;
  font-size:clamp(1.2rem,2.2vw,1.55rem)!important;
  line-height:1.12!important;
  color:#111827!important;
  background:transparent!important;
  border-radius:0!important;
}
.wbop-checkout-account-copy p{margin:0;color:#5b4b3d;line-height:1.45;font-weight:650;}
.wbop-checkout-account-main{
  display:flex!important;align-items:flex-start;gap:13px;
  padding:15px 16px;margin:14px 0 0;
  border:1px solid rgba(17,24,39,.10);
  border-radius:16px;background:#fff;
  cursor:pointer;
}
.wbop-checkout-account-main input,
.wbop-checkout-account-consent input{
  flex:0 0 auto;width:22px;height:22px;margin:2px 0 0!important;
  accent-color:#163f2a;
}
.wbop-checkout-account-main span{display:block;min-width:0;}
.wbop-checkout-account-main strong{display:block;font-size:1.02rem;line-height:1.2;color:#111827;}
.wbop-checkout-account-main small{display:block;margin-top:4px;color:#6b7280;font-weight:650;line-height:1.35;}
.wbop-checkout-account-options{
  margin:12px 0 0;padding:14px 16px;
  border-radius:16px;background:#f8faf7;border:1px solid rgba(22,63,42,.12);
}
.wbop-checkout-account-options[hidden]{display:none!important;}
.wbop-checkout-account-note{margin:0 0 12px;color:#4b5563;font-weight:650;line-height:1.4;}
.wbop-checkout-account-consent{
  display:flex!important;align-items:flex-start;gap:11px;
  margin:10px 0 0!important;color:#1f2937;line-height:1.35;font-weight:650;
}
.wbop-checkout-account-consent span{display:block;min-width:0;}
@media (max-width:640px){
  .wbop-checkout-account-card{padding:16px;border-radius:18px;margin:16px 0 20px;}
  .wbop-checkout-account-main{padding:14px;}
  .wbop-checkout-account-options{padding:13px;}
}
