/*
  Imbisso UX skin (TB-ultra)
  Goals:
  - no orange
  - mobile-first, fast, clean
  - categories as one horizontal row
  - products in 2-column grid (phone)
  - add button becomes + (no "Toevoegen")
  - existing bottom bar (.imb-fsbar) becomes a top sticky bar
*/

:root{
  --imb-bg: #f6f7f8;
  --imb-surface: #ffffff;
  --imb-border: rgba(17, 24, 39, 0.10);
  --imb-text: #111827;
  --imb-muted: #6b7280;

  /* Brand accent — set dynamically via PHP (IMB_Assets::inject_accent_color) */
  --imb-accent: #b11212;
  --imb-accent-2: #8a0d0f;

  --imb-radius: 16px;
  --imb-shadow: 0 10px 30px rgba(17,24,39,.10);
}

/* Page surface */
.imb-wrap{
  background: transparent;
  color: var(--imb-text);
}

/* ===== Sticky top service bar (re-uses .imb-fsbar markup) ===== */
.imb-fsbar{
  position: sticky;
  top: 10px;
  z-index: 50;

  display: flex;
  align-items: center;
  gap: 10px;

  padding: 12px;
  margin: 10px 0 14px;

  background: var(--imb-surface);
  border: 1px solid var(--imb-border);
  border-radius: calc(var(--imb-radius) + 6px);
  box-shadow: var(--imb-shadow);
}

@media (max-width: 782px){
  .imb-fsbar{ top: 6px; }
}

/* Service mode button (Bezorg/Afhaal trigger) */
button.imb-orderbtn{
  flex: 0 0 auto;
  height: 44px;
  padding: 0 14px;

  border-radius: 999px;
  border: 1px solid var(--imb-border);
  background: #f3f4f6;
  color: var(--imb-text);

  font-weight: 800;
  letter-spacing: .2px;
}
button.imb-orderbtn:hover{ background:#eef0f3; }

/* Checkout button */
a.imb-fsbar__checkout,
.imb-fsbar a[href*="checkout"],
.imb-fsbar a.imb-checkout{
  margin-left: auto;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  height: 44px;
  padding: 0 16px;

  border-radius: 999px;
  background: #111827;
  color: #fff !important;
  text-decoration: none;

  font-weight: 900;
}

/* ===== Categories: single horizontal row ===== */
.imb-catswrap{
  display: flex;
  align-items: center;
  gap: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 6px 2px;
  scrollbar-width: none;
}
.imb-catswrap::-webkit-scrollbar{ display:none; }

.imb-cat{
  flex: 0 0 auto;
  border-radius: 999px !important;
  border: 1px solid var(--imb-border) !important;
  background: var(--imb-surface) !important;
  color: var(--imb-text) !important;
  font-weight: 800;
  padding: 10px 14px !important;
  line-height: 1;
}

.imb-cat.is-active,
.imb-cat.active,
.imb-cat[aria-current="true"]{
  background: var(--imb-accent) !important;
  border-color: transparent !important;
  color: #fff !important;
}

/* ===== Search ===== */
.imb-search input,
.imb-search input[type="search"],
input.imb-search{
  width: 100%;
  height: 46px;
  border-radius: 999px;
  border: 1px solid var(--imb-border);
  padding: 0 16px;
  outline: none;
  background: var(--imb-surface);
}
.imb-search input:focus{
  border-color: rgba(164,15,18,.35);
  box-shadow: 0 0 0 4px rgba(164,15,18,.12);
}

/* ===== Products: 2-column grid on phone ===== */
.imb-list{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: stretch;
}
@media (max-width: 360px){
  .imb-list{ grid-template-columns: 1fr; }
}

.imb-item,
.imb-card,
.imb-product{
  background: var(--imb-surface);
  border: 1px solid var(--imb-border);
  border-radius: calc(var(--imb-radius) + 2px);
  padding: 14px;
  box-shadow: 0 6px 18px rgba(17,24,39,.06);
}

.imb-item .imb-title,
.imb-item h3{
  font-size: 16px;
  font-weight: 900;
  margin: 0 0 6px;
}

.imb-item .imb-price,
.imb-item .price{
  font-weight: 900;
}

.imb-item .imb-desc,
.imb-item p{
  color: var(--imb-muted);
}

/* ===== Add button: remove "Toevoegen" and show + ===== */
button.imb-addbtn,
button.imb-add-to-cart,
button.imb-add,
.imb-item button{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: none;
  background: var(--imb-accent);
  color: #fff;
  font-weight: 900;

  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Default: price + plus inside the button */
button.imb-add{
  width: auto;
  min-width: 88px;
  padding: 0 14px;
  gap: 10px;
  font-size: 14px;
  white-space: nowrap;
  flex-wrap: nowrap;
}
button.imb-add .imb-add__price{ font-weight: 900; }
button.imb-add .imb-add__icon{ font-size: 20px; line-height: 1; }

/* Mobile: keep price + icon on one line */
@media (max-width: 480px){
  button.imb-add{
    min-width: 84px;
    padding: 0 12px;
    gap: 8px;
    font-size: 13px;
  }
  button.imb-add .imb-add__icon{ font-size: 18px; }
}

/* Keep legacy add buttons as a simple plus */
button.imb-addbtn,
button.imb-add-to-cart{
  font-size: 0;
}
button.imb-addbtn::before,
button.imb-add-to-cart::before{
  content: "+";
  font-size: 20px;
  line-height: 1;
}

button.imb-addbtn:hover,
button.imb-add-to-cart:hover,
button.imb-add:hover{ background: var(--imb-accent-2); }

/* Floating cart button if present */
.imb-floatcart,
.imb-cart-float,
button.imb-cartfab{
  background: #111827 !important;
  color: #fff !important;
  border-radius: 999px !important;
}

/* Modal polish */
.imb-modal .imb-modal__panel,
.imb-modal .imb-panel{
  border-radius: calc(var(--imb-radius) + 10px);
  box-shadow: 0 18px 60px rgba(17,24,39,.18);
}

/* Safety: neutralize any accidental orange */
.imb-wrap .orange,
.imb-wrap [class*="orange"],
.imb-wrap [style*="#ffb"],
.imb-wrap [style*="FFB"]{
  /* Intentionally empty: we rely on our variables + overrides above */
}


/* ===== TB Pro: categories + section titles ===== */
.imb-topbar{
  position: sticky;
  top: 0;
  z-index: 60;
  background: #fff;
}
.imb-catswrap{
  position: sticky;
  top: var(--imb-topbar-h, 0px);
  z-index: 55;
  background: #fff;
  padding: 10px 0 6px;
}
.imb-cats{
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0 10px;
  scrollbar-width: none;
}
.imb-cats::-webkit-scrollbar{ display:none; }

.imb-cat-btn{
  flex: 0 0 auto;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 700;
  letter-spacing: .2px;
  color: #111;
  box-shadow: 0 6px 18px rgba(17,24,39,.06);
}
.imb-cat-btn.is-active{
  background: var(--imb-accent, #b11212);
  color: #fff;
  border-color: rgba(0,0,0,.0);
}
.imb-cat-btn:active{ transform: translateY(1px); }

.imb-catsec{
  padding-top: 6px;
}
.imb-cat-title{
  margin: 14px 4px 10px;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 900;
  color: #111;
}


/* === TB ULTRA: compact top bar (only Bezorg/Afhalen) === */
.imb-topbar{
  box-shadow:none !important;
  padding:10px 12px !important;
  margin:16px 0 10px !important;
}
.imb-topbar__actions.imb-modebar{
  width:100%;
  display:flex;
  gap:10px;
  background:#f4f5f7;
  border:1px solid #e6e8ee;
  border-radius:999px;
  padding:6px;
  box-shadow:none !important;
}
.imb-topbar__actions.imb-modebar .imb-modebtn{
  flex:1 1 0;
  border:0;
  border-radius:999px;
  padding:12px 10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.02em;
  background:transparent;
}
.imb-topbar__actions.imb-modebar .imb-modebtn.is-active,
.imb-topbar__actions.imb-modebar .imb-modebtn[aria-selected="true"]{
  background:var(--imb-red,#b10f14);
  color:#fff;
}


/* Foodstore layout: menu + cart sidebar */
.imb-foodstore-layout{display:block;}
.imb-foodstore-main{min-width:0;}
/* Mobile/tablet: hide sidebar cart, show floating cart button */
@media (max-width:1023px){
  .imb-cart-aside{display:none;}
  .imb-fabcart{display:flex; position:fixed; right:16px; bottom:16px; z-index:9999;}
}
/* Desktop: 2-column layout with sticky cart on the right */
@media (min-width:1024px){
  .imb-foodstore-layout{display:flex; align-items:flex-start; gap:24px;}
  .imb-foodstore-main{flex:1 1 auto;}
  .imb-cart-aside{flex:0 0 360px; width:360px; position:sticky; top:16px; align-self:flex-start;}
  .imb-fabcart{display:none;}
}

.imb-item{display:flex; gap:14px; align-items:center;}
.imb-item__img{flex:0 0 76px; width:76px; height:76px; border-radius:16px; overflow:hidden; background:rgba(0,0,0,.03);}
.imb-item__img img{width:100%; height:100%; object-fit:cover; display:block;}


/* ------------------------------------------------------------
   Mobile cart bar + cart modal (Thuisbezorgd-style)
------------------------------------------------------------ */

.imb-mobilebar{
  display:none;
  position:fixed;
  left:12px;
  right:12px;
  bottom:12px;
  z-index:99998;
  padding:14px 16px;
  border-radius:14px;
  background:#2b2b2b;
  color:#fff;
  text-decoration:none;
  font-weight:700;
  box-shadow:0 10px 28px rgba(0,0,0,.25);
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.imb-mobilebar__label{ white-space:nowrap; }
.imb-mobilebar__count{ opacity:.9; }
.imb-mobilebar__total{ margin-left:auto; font-weight:800; }

@media (max-width: 1023px){
  .imb-mobilebar{ display:flex; }
  .imb-cart{ padding-bottom:78px; }
  /* hide floating cart button when the bar exists */
  .imb-fabcart, .imb-cartbtn{ display:none; }
}

.imb-cartmodal{ display:none; }
.imb-cartmodal.is-open{ display:block; }
.imb-cartmodal__backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  z-index:99997;
}
.imb-cartmodal__panel{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  max-height:86vh;
  background:#fff;
  border-top-left-radius:18px;
  border-top-right-radius:18px;
  z-index:99998;
  overflow:auto;
}
/* ── Cart Modal fixes ── */
.imb-cartmodal__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid #eee;
  position:sticky;
  top:0;
  background:#fff;
  z-index:1;
}
.imb-cartmodal__close{
  background:#111 !important;
  border:0 !important;
  padding:9px 18px !important;
  border-radius:8px !important;
  cursor:pointer !important;
  font-size:14px !important;
  font-weight:700 !important;
  color:#fff !important;
  line-height:1 !important;
}
.imb-cartmodal__close:hover{ background:#333 !important; }
.imb-cartmodal__body{ padding:12px 16px 100px; }

/* WC mini cart list reset */
.imb-cartmodal .woocommerce-mini-cart,
.imb-cartmodal .cart_list{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}

/* Elk cart item — flex rij */
.imb-cartmodal .mini_cart_item{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  padding:12px 0 !important;
  border-bottom:1px solid #f3f4f6 !important;
  list-style:none !important;
  background:transparent !important;
}

/* WC afbeelding verbergen */
.imb-cartmodal .mini_cart_item img{ display:none !important; }

/* × remove knop — toon links, maak groot */
.imb-cartmodal .mini_cart_item a.remove_from_cart_button{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  order:-1 !important;
  flex-shrink:0 !important;
  width:34px !important;
  height:34px !important;
  border-radius:50% !important;
  background:#f3f4f6 !important;
  font-size:20px !important;
  font-weight:700 !important;
  color:#555 !important;
  text-decoration:none !important;
  line-height:1 !important;
}
.imb-cartmodal .mini_cart_item a.remove_from_cart_button:hover{
  background:#fee2e2 !important;
  color:#b91c1c !important;
}

/* Productnaam — rood, geen link gedrag */
.imb-cartmodal .mini_cart_item a:not(.remove_from_cart_button){
  color:#b11212 !important;
  text-decoration:none !important;
  pointer-events:none !important;
  font-weight:700 !important;
  font-size:15px !important;
  flex:1 !important;
}

/* Quantity tekst */
.imb-cartmodal .mini_cart_item .quantity{
  font-size:13px !important;
  color:#666 !important;
  white-space:nowrap !important;
}

/* Checkout knop */
.imb-cartmodal .woocommerce-mini-cart__buttons{ padding:12px 0 0; }
.imb-cartmodal .woocommerce-mini-cart__buttons a.checkout{
  display:block !important;
  width:100% !important;
  text-align:center !important;
  padding:15px !important;
  border-radius:10px !important;
  font-weight:800 !important;
  font-size:16px !important;
  background:#b11212 !important;
  color:#fff !important;
  text-decoration:none !important;
  box-sizing:border-box !important;
  border:none !important;
  margin-top:4px !important;
}
/* View cart verbergen */
.imb-cartmodal .woocommerce-mini-cart__buttons a:not(.checkout){
  display:none !important;
}

/* Afrekenen button in modal — volledig en duidelijk */
.imb-cartmodal .woocommerce-mini-cart__buttons,
.imb-cartmodal .wc-proceed-to-checkout{
  padding:12px 0 0;
  display:block !important;
}
.imb-cartmodal .woocommerce-mini-cart__buttons a,
.imb-cartmodal .wc-proceed-to-checkout a{
  display:block !important;
  width:100% !important;
  text-align:center !important;
  padding:15px !important;
  border-radius:10px !important;
  font-weight:800 !important;
  font-size:16px !important;
  margin-bottom:8px !important;
  text-decoration:none !important;
  box-sizing:border-box !important;
}
/* Checkout knop = donker */
.imb-cartmodal .woocommerce-mini-cart__buttons a.checkout,
.imb-cartmodal .wc-proceed-to-checkout a.checkout{
  background:var(--imb-accent, #b11212) !important;
  color:#fff !important;
  border:none !important;
}
/* View cart = verbergen */
.imb-cartmodal .woocommerce-mini-cart__buttons a:not(.checkout),
.imb-cartmodal .wc-proceed-to-checkout a:not(.checkout){
  display:none !important;
}

@media (min-width: 1024px){
  .imb-cartmodal, .imb-mobilebar{ display:none !important; }
}

/* v0.4.0 — open/closed banner */
.imb-status-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 12px;
  margin-bottom: 14px;
  font-weight: 700;
  font-size: 14px;
}
.imb-status-banner--open {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: #166534;
}
.imb-status-banner--closed {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}

/* 1.2.7b title color hotfix */
.imb-item__title,
.imb-item__title a,
.imb-item .imb-title,
.imb-item h3,
.imb-item h3 a,
.imb-product-title,
.woocommerce-loop-product__title{
  color:#111 !important;
}


/* Imbisso language switcher shortcode */
.imb-langswitch--shortcode{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:12px 0 16px;}
.imb-langswitch__option{position:relative;display:inline-flex;cursor:pointer;}
.imb-langswitch__radio{position:absolute;opacity:0;pointer-events:none;}
.imb-langswitch__chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:2px solid #e6e6e6;border-radius:999px;background:#fff;color:#222;font-weight:700;line-height:1;transition:.15s ease;box-shadow:0 1px 3px rgba(0,0,0,.05);}
.imb-langswitch__flag{font-size:18px;line-height:1;}
.imb-langswitch__option.is-active .imb-langswitch__chip,
.imb-langswitch__radio:checked + .imb-langswitch__chip{background:#fbbf24;border-color:#fbbf24;color:#fff;box-shadow:none;}
.imb-langswitch--inline .imb-langswitch__chip{border-radius:10px;}
.imb-langswitch--pills .imb-langswitch__chip{border-radius:999px;}
html[dir="rtl"] .imb-langswitch--shortcode{justify-content:flex-start;}


.imb-langswitch--dropdown{display:inline-flex;align-items:center;gap:0;max-width:100%;margin:0;}
.imb-langswitch__details{position:relative;display:inline-block;max-width:100%;}
.imb-langswitch__summary{list-style:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:42px;padding:0 36px 0 16px;border-radius:999px;background:var(--imb-primary, var(--imb-accent, #b11212));color:#fff;font-weight:900;font-size:14px;line-height:1;box-shadow:0 8px 24px rgba(0,0,0,.12);cursor:pointer;user-select:none;white-space:nowrap;max-width:100%;}
.imb-langswitch__summary::-webkit-details-marker{display:none;}
.imb-langswitch__details--flag .imb-langswitch__summary{min-width:44px;padding:0 28px 0 14px;font-size:18px;}
.imb-langswitch__details--code_flag .imb-langswitch__summary{min-width:78px;}
.imb-langswitch__details--native_flag .imb-langswitch__summary{min-width:112px;}
.imb-langswitch__summarytext{display:inline-flex;align-items:center;gap:8px;}
.imb-langswitch__menu{position:absolute;top:calc(100% + 8px);left:0;right:auto;min-width:100%;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:8px;box-shadow:0 16px 40px rgba(0,0,0,.16);z-index:999;}
.imb-langswitch__menuitem{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:#111827;text-decoration:none;font-weight:800;white-space:nowrap;}
.imb-langswitch__menuitem:hover,.imb-langswitch__menuitem.is-active{background:rgba(0,0,0,.05);}
.imb-langswitch__caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:10px;color:rgba(255,255,255,.88);pointer-events:none;}
html[dir="rtl"] .imb-langswitch__menu{left:auto;right:0;}
html[dir="rtl"] .imb-langswitch__caret{right:auto;left:12px;}

/* 1.5.1 lang switcher polish */
.imb-langswitch__menuitem,.imb-langswitch__menuitemtext{ text-decoration:none !important; }
.imb-langswitch__menuitem.is-active,.imb-langswitch__menuitem.is-active .imb-langswitch__menuitemtext{ color:var(--imb-primary, #d4a017); }


.imb-langswitch__summarytext,.imb-langswitch__menuitemtext,.imb-langswitch__text{display:inline-flex;align-items:center;gap:8px;}
.imb-langswitch__part--native,.imb-langswitch__part--code{font-weight:800;}
.imb-langswitch--desktop-code_flag .imb-langswitch__part--native{display:none;}
.imb-langswitch--desktop-flag .imb-langswitch__part--code,.imb-langswitch--desktop-flag .imb-langswitch__part--native{display:none;}
.imb-langswitch--desktop-native_flag .imb-langswitch__part--code{display:none;}
@media (max-width: 767px){
  .imb-langswitch--mobile-code_flag .imb-langswitch__part--native{display:none;}
  .imb-langswitch--mobile-flag .imb-langswitch__part--code,.imb-langswitch--mobile-flag .imb-langswitch__part--native{display:none;}
  .imb-langswitch--mobile-native_flag .imb-langswitch__part--code{display:none;}
  .imb-langswitch--dropdown.imb-langswitch--mobile-flag .imb-langswitch__summary{min-width:44px;padding:0 28px 0 14px;}
  .imb-langswitch--dropdown.imb-langswitch--mobile-code_flag .imb-langswitch__summary{min-width:78px;}
  .imb-langswitch--dropdown.imb-langswitch--mobile-native_flag .imb-langswitch__summary{min-width:112px;}
}
