/*
 Theme Name: Storefront Child — Bacha Planet
 Theme URI: https://bachaplanet.pk
 Description: Custom child theme for Bacha Planet kids toy store. Pink + blue brand palette with playful, colorful design optimized for ecommerce conversion.
 Author: Bacha Planet
 Template: storefront
 Version: 2.1
 Text Domain: storefront-bachaplanet
*/

/* ───────────────────────────────────────────────────────────
   1. BRAND PALETTE
   ─────────────────────────────────────────────────────────── */
:root {
  --bp-pink:        #EC4899;
  --bp-pink-light:  #F472B6;
  --bp-pink-50:     #FDF2F8;
  --bp-pink-100:    #FCE7F3;
  --bp-pink-deep:   #BE185D;
  --bp-blue:        #0EA5E9;
  --bp-blue-light:  #38BDF8;
  --bp-blue-50:     #F0F9FF;
  --bp-blue-100:    #E0F2FE;
  --bp-yellow:      #FCD34D;
  --bp-yellow-light:#FEF3C7;
  --bp-orange:      #FB923C;
  --bp-mint:        #A7F3D0;
  --bp-purple:      #C4B5FD;
  --bp-dark:        #1E293B;
  --bp-body:        #475569;
  --bp-muted:       #94A3B8;
  --bp-border:      #E2E8F0;
  --bp-bg:          #FFF7FB;
  --bp-radius:      12px;
  --bp-radius-lg:   20px;
  --bp-shadow-sm:   0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --bp-shadow:      0 4px 12px rgba(15,23,42,.08), 0 2px 4px rgba(15,23,42,.04);
  --bp-shadow-lg:   0 10px 30px rgba(236,72,153,.15), 0 4px 8px rgba(15,23,42,.05);
  --bp-font:        'Nunito', 'Segoe UI', sans-serif;
  --bp-trans:       all .25s ease;
}

/* ───────────────────────────────────────────────────────────
   2. GLOBAL
   ─────────────────────────────────────────────────────────── */
body, .site, button, input, select, textarea, .button {
  font-family: var(--bp-font) !important;
}
body {
  font-size: 16px;
  line-height: 1.6;
  color: var(--bp-body);
  background-color: var(--bp-bg);
  background-image:
    radial-gradient(circle at 12% 18%, rgba(236,72,153,0.08) 0, transparent 28%),
    radial-gradient(circle at 88% 78%, rgba(14,165,233,0.07) 0, transparent 28%),
    radial-gradient(circle at 50% 50%, rgba(252,211,77,0.05) 0, transparent 35%);
  background-attachment: fixed;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--bp-font) !important;
  color: var(--bp-dark) !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em;
}
a { color: var(--bp-pink); transition: var(--bp-trans); }
a:hover { color: var(--bp-pink-light); }

.site-content { background: transparent; padding-top: 1em; }
.col-full { max-width: 1200px; }

/* ───────────────────────────────────────────────────────────
   3. HEADER — single row, logo left, cart right
   ─────────────────────────────────────────────────────────── */
.site-header {
  background: linear-gradient(110deg, #FFD8E8 0%, #FFE6F0 25%, #FFF4D6 55%, #D6F0FF 80%, #C8E6FF 100%) !important;
  border-bottom: 5px solid var(--bp-pink);
  padding: 0 !important;
  box-shadow: 0 4px 12px rgba(236,72,153,.08);
  position: relative;
  overflow: hidden;
}
.site-header::before, .site-header::after { display: none !important; }

.site-header .col-full {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  gap: 1.25em;
  padding: 0.6em 1em !important;
}

/* Logo (wordmark "Bacha planet") — sized to give the colorful wordmark room to breathe */
.site-branding,
.site-header .site-branding {
  flex: 0 0 auto !important;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  text-align: left !important;
}
.custom-logo-link {
  display: inline-block !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
}
.custom-logo,
.site-header .custom-logo,
.site-branding .custom-logo {
  max-height: 64px !important;
  max-width: 200px !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  display: block !important;
  object-fit: contain !important;
}
.site-title, .site-description { display: none !important; }

/* ─── Search — wipe Storefront defaults, rebuild cleanly ─── */
.site-header .site-search,
.site-search {
  flex: 0 1 360px !important;
  max-width: 360px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  position: relative;
}
.site-search .widget,
.site-search .widget_product_search,
.site-search .widget_search,
.site-header .site-search .widget {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
.site-search form,
.site-search .woocommerce-product-search,
.site-search form.search-form {
  margin: 0 !important;
  padding: 0 !important;
  position: relative;
  display: block;
  width: 100%;
}

/* Hide labels and submit buttons — pressing Enter submits */
.site-search label,
.site-search .screen-reader-text,
.site-search .woocommerce-product-search label,
.site-search button,
.site-search button[type="submit"],
.site-search input[type="submit"],
.site-search .search-submit,
.site-search .woocommerce-product-search button {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  position: absolute !important;
  left: -9999px !important;
}

/* The actual search input — strip browser default search styling, only one icon (background SVG) */
.site-search input[type="search"],
.site-search input.search-field,
.site-search .woocommerce-product-search input.search-field {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  background-color: #fff !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%23EC4899' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><circle cx='8' cy='8' r='6'/><path d='m16 16-4-4'/></svg>") !important;
  background-position: 16px center !important;
  background-repeat: no-repeat !important;
  background-size: 16px 16px !important;
  border: 2px solid var(--bp-pink-100) !important;
  border-radius: 999px !important;
  padding: 10px 18px 10px 42px !important;
  font-family: var(--bp-font) !important;
  font-size: 0.92em !important;
  width: 100% !important;
  height: auto !important;
  line-height: 1.4 !important;
  transition: var(--bp-trans) !important;
  box-shadow: 0 2px 6px rgba(236,72,153,.08) inset !important;
  box-sizing: border-box !important;
  display: block !important;
  color: var(--bp-dark) !important;
}
/* Kill the native browser search-cancel/decoration icons (Safari/iOS) */
.site-search input[type="search"]::-webkit-search-decoration,
.site-search input[type="search"]::-webkit-search-cancel-button,
.site-search input[type="search"]::-webkit-search-results-button,
.site-search input[type="search"]::-webkit-search-results-decoration {
  -webkit-appearance: none !important;
  display: none !important;
}
/* Nuke every icon/pseudo inside the search container — leave ONLY the input's bg SVG */
.site-search svg,
.site-search img,
.site-search i,
.site-search .dashicons,
.site-search .wp-block-search__button,
.site-search .wp-block-search__button.has-icon,
.site-search .wc-block-product-search__button,
.site-search .icon-search { display: none !important; }
.site-search form::before,
.site-search form::after,
.site-search .woocommerce-product-search::before,
.site-search .woocommerce-product-search::after,
.site-search .widget::before,
.site-search .widget::after,
.site-search label::before,
.site-search label::after { content: none !important; display: none !important; background-image: none !important; }
.site-search input[type="search"]:focus,
.site-search input.search-field:focus {
  border-color: var(--bp-pink) !important;
  box-shadow: 0 0 0 4px rgba(236, 72, 153, 0.15), 0 2px 6px rgba(236,72,153,.08) inset !important;
  outline: none !important;
  background-color: #fff !important;
}
.site-search input[type="search"]::placeholder { color: var(--bp-muted) !important; }

/* Cart — pushed to right */
.site-header-cart,
.site-header .site-header-cart {
  flex: 0 0 auto !important;
  margin: 0 0 0 auto !important;
  padding: 0 !important;
  list-style: none !important;
  width: auto !important;
}
.site-header-cart li { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.site-header-cart .cart-contents {
  background: var(--bp-pink) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 0.55em 1.1em !important;
  font-weight: 800 !important;
  display: inline-flex !important;
  align-items: center;
  gap: 0.5em;
  text-decoration: none !important;
  box-shadow: 0 3px 0 var(--bp-pink-deep);
  transition: var(--bp-trans);
  font-size: 0.92em;
  white-space: nowrap;
}
.site-header-cart .cart-contents:hover {
  background: var(--bp-pink-light) !important;
  transform: translateY(-1px);
}
.site-header-cart .amount,
.site-header-cart .woocommerce-Price-amount { color: #fff !important; font-weight: 800 !important; }
.site-header-cart .count {
  background: rgba(255,255,255,0.3);
  padding: 0.15em 0.6em;
  border-radius: 999px;
  font-size: 0.85em;
}

/* ───────────────────────────────────────────────────────────
   4. PRIMARY NAV — own row, colored bar
   ─────────────────────────────────────────────────────────── */
.storefront-primary-navigation,
.main-navigation {
  background: linear-gradient(90deg, var(--bp-pink) 0%, var(--bp-pink-light) 30%, var(--bp-blue-light) 75%, var(--bp-blue) 100%) !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  box-shadow: 0 2px 8px rgba(15,23,42,.08);
}
.storefront-primary-navigation .col-full {
  padding: 0 1em !important;
}
.main-navigation ul.menu,
.main-navigation ul.nav-menu,
.storefront-primary-navigation ul {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.25em;
  padding: 0.4em 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
}
.main-navigation ul li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}
.main-navigation ul li a {
  display: block !important;
  padding: 0.55em 1.2em !important;
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 0.95em !important;
  text-decoration: none !important;
  border-radius: 999px !important;
  transition: var(--bp-trans);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: transparent !important;
  border: none !important;
}
.main-navigation ul li a:hover,
.main-navigation ul li.current-menu-item > a {
  background: rgba(255,255,255,0.95) !important;
  color: var(--bp-pink) !important;
}

/* Hide Storefront's mobile MENU toggle on desktop */
button.menu-toggle,
.main-navigation .menu-toggle,
.menu-toggle {
  display: none !important;
}
@media (max-width: 767px) {
  button.menu-toggle, .menu-toggle { display: inline-block !important; }
}

/* Allow dropdowns to overflow the nav row */
.site-header,
.storefront-primary-navigation,
.storefront-primary-navigation .col-full,
.main-navigation,
.main-navigation ul,
.main-navigation ul.menu,
.main-navigation ul.nav-menu {
  overflow: visible !important;
}
.main-navigation { position: relative; z-index: 100; }
.main-navigation ul li { position: relative; }

/* Parent menu link with chevron — kept on one line */
.main-navigation ul li.menu-item-has-children > a {
  display: inline-flex !important;
  align-items: center;
  gap: 0.35em;
  white-space: nowrap !important;
}
.main-navigation ul li.menu-item-has-children > a::after {
  content: "▾";
  display: inline-block;
  font-size: 0.7em;
  font-weight: 800;
  vertical-align: middle;
  transition: transform .2s;
  position: static !important;
  background: transparent !important;
  height: auto !important;
  width: auto !important;
  line-height: 1;
}
.main-navigation ul li.menu-item-has-children:hover > a::after {
  transform: rotate(180deg);
}
/* Hide Storefront's own chevron/icon if the theme renders one */
.main-navigation .caret-down,
.main-navigation .menu-item-has-children > a > svg,
.main-navigation .menu-item-has-children > a > .icon,
.main-navigation .menu-item-has-children > a > .dashicons,
.main-navigation .sub-menu-toggle { display: none !important; }

/* Sub-menu dropdown — hidden by default, visible on hover */
.main-navigation ul ul.sub-menu {
  background: #fff !important;
  border-radius: var(--bp-radius) !important;
  box-shadow: var(--bp-shadow-lg) !important;
  padding: 0.5em !important;
  border: 2px solid var(--bp-pink-100) !important;
  min-width: 240px;
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  z-index: 9999 !important;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(0);
  transition: opacity .2s ease, visibility .2s ease;
  margin: 0 !important;
}
.main-navigation ul li.menu-item-has-children:hover > ul.sub-menu,
.main-navigation ul li:hover > ul.sub-menu,
.main-navigation ul li:focus-within > ul.sub-menu {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}
.main-navigation ul ul.sub-menu li { width: 100%; }
.main-navigation ul ul.sub-menu li a {
  text-transform: none !important;
  letter-spacing: normal !important;
  border-radius: 8px !important;
  color: var(--bp-dark) !important;
  font-weight: 700 !important;
  padding: 0.55em 0.85em !important;
}
.main-navigation ul ul.sub-menu li a:hover {
  background: var(--bp-pink-50) !important;
  color: var(--bp-pink) !important;
}

/* "By Type" / "By Age" — non-clickable section labels */
.main-navigation li.bp-menu-divider > a,
.main-navigation .sub-menu li.bp-menu-divider > a {
  pointer-events: none !important;
  cursor: default !important;
  color: var(--bp-muted) !important;
  font-size: 0.7em !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  font-weight: 800 !important;
  background: transparent !important;
  padding: 0.85em 0.85em 0.3em 0.85em !important;
  border-bottom: 1px solid var(--bp-border) !important;
  margin-bottom: 0.25em !important;
  border-radius: 0 !important;
}
.main-navigation li.bp-menu-divider > a:hover {
  background: transparent !important;
  color: var(--bp-muted) !important;
}

/* ───────────────────────────────────────────────────────────
   5. BUTTONS
   ─────────────────────────────────────────────────────────── */
.button,
button:not(.bp-wa-btn-skip),
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.wp-element-button,
.wp-block-button__link {
  background: var(--bp-pink) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--bp-radius) !important;
  padding: 0.7em 1.5em !important;
  font-weight: 800 !important;
  font-family: var(--bp-font) !important;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: 0.92em !important;
  box-shadow: 0 4px 0 var(--bp-pink-deep);
  transition: var(--bp-trans);
  cursor: pointer;
  text-decoration: none !important;
  display: inline-block;
}
.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.wp-element-button:hover,
.wp-block-button__link:hover {
  background: var(--bp-pink-light) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 0 var(--bp-pink-deep), var(--bp-shadow);
  color: #fff !important;
}
.button:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--bp-pink-deep); }

.button.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.added_to_cart {
  background: var(--bp-blue) !important;
  box-shadow: 0 4px 0 #075E8A !important;
}
.button.alt:hover, .added_to_cart:hover { background: var(--bp-blue-light) !important; }

.bp-wa-btn {
  background: linear-gradient(135deg, #25D366 0%, #128C7E 100%) !important;
  color: #fff !important;
  text-align: center !important;
  font-weight: 800 !important;
  border-radius: var(--bp-radius) !important;
  padding: 0.7em 1.5em !important;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  box-shadow: 0 4px 0 #075c4a !important;
  transition: var(--bp-trans);
  border: none !important;
  font-size: 0.92em !important;
  display: inline-block;
}
.bp-wa-btn::before { content: "💬 "; }
.bp-wa-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 0 #075c4a, var(--bp-shadow) !important; color: #fff !important; }
/* On single-product page only, WhatsApp button stretches under Add-to-Cart with top spacing */
.summary .bp-wa-btn,
form.cart + .bp-wa-btn,
.product .bp-wa-btn {
  display: block !important;
  margin-top: 12px !important;
  padding: 0.85em 1.5em !important;
}

/* Hero buttons — equal height, aligned */
.bp-hero .wp-block-buttons {
  align-items: center !important;
}
.bp-hero .wp-block-button { margin: 0 !important; }
.bp-hero .wp-block-button .wp-block-button__link {
  margin: 0 !important;
  height: auto !important;
  line-height: 1.4 !important;
}

/* ───────────────────────────────────────────────────────────
   6. FORMS
   ─────────────────────────────────────────────────────────── */
input[type="text"], input[type="email"], input[type="password"], input[type="tel"],
input[type="number"], input[type="search"], input[type="url"], textarea, select,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  border: 2px solid var(--bp-border) !important;
  border-radius: var(--bp-radius) !important;
  padding: 0.65em 1em !important;
  font-family: var(--bp-font) !important;
  font-size: 0.95em !important;
  background: #fff !important;
  color: var(--bp-dark);
  transition: var(--bp-trans);
}
input:focus, textarea:focus, select:focus {
  border-color: var(--bp-pink) !important;
  box-shadow: 0 0 0 4px rgba(236, 72, 153, 0.12) !important;
  outline: none !important;
}
.woocommerce .woocommerce-ordering select, select.orderby {
  border: 2px solid var(--bp-border) !important;
  border-radius: var(--bp-radius) !important;
  padding: 0.6em 2.5em 0.6em 1em !important;
  background-color: #fff !important;
  font-weight: 700;
  color: var(--bp-dark);
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23EC4899' d='M6 8L0 0h12z'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 1em center !important;
}

/* ───────────────────────────────────────────────────────────
   7. PRODUCT GRID — fixed alignment
   ─────────────────────────────────────────────────────────── */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 1.5em !important;
  padding: 0 !important;
  margin: 0 0 2em 0 !important;
  list-style: none !important;
  width: 100% !important;
  float: none !important;
  clear: both !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after { display: none !important; content: none !important; }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product.last {
  width: 100% !important;
  margin: 0 !important;
  padding: 1em !important;
  background: #fff !important;
  border-radius: var(--bp-radius-lg) !important;
  box-shadow: var(--bp-shadow-sm);
  border: 2px solid var(--bp-border);
  transition: var(--bp-trans);
  display: flex !important;
  flex-direction: column !important;
  position: relative;
  overflow: hidden;
  float: none !important;
  clear: none !important;
  grid-column: auto !important;
  grid-row: auto !important;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: var(--bp-shadow-lg);
  border-color: var(--bp-pink-light);
}

.woocommerce ul.products li.product a img {
  border-radius: var(--bp-radius) !important;
  margin: 0 0 1em 0 !important;
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  background: var(--bp-pink-50);
}

/* Sale badge — top-left, no overlap */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
  position: absolute !important;
  top: 1em !important;
  left: 1em !important;
  right: auto !important;
  margin: 0 !important;
  background: var(--bp-pink) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 0.25em 0.85em !important;
  font-weight: 800 !important;
  font-size: 0.72em !important;
  z-index: 5 !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1.5 !important;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  box-shadow: 0 2px 6px rgba(190, 24, 93, 0.3);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
  font-size: 0.95em !important;
  font-weight: 700 !important;
  color: var(--bp-dark) !important;
  margin: 0 0 0.5em 0 !important;
  padding: 0 !important;
  min-height: 2.6em;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-align: center;
}

.woocommerce ul.products li.product .price {
  color: var(--bp-pink) !important;
  font-weight: 800 !important;
  font-size: 1em !important;
  margin: 0 0 0.85em 0 !important;
  display: block;
  text-align: center;
}
.woocommerce ul.products li.product .price del { color: var(--bp-muted) !important; font-weight: 500 !important; margin-right: 0.3em; opacity: 0.7; }
.woocommerce ul.products li.product .price ins { text-decoration: none; color: var(--bp-pink) !important; font-weight: 800; }

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button.add_to_cart_button,
.woocommerce ul.products li.product a.added_to_cart {
  margin: auto 0 0 0 !important;
  width: 100% !important;
  text-align: center !important;
  padding: 0.7em 1em !important;
  font-size: 0.85em !important;
  border-radius: var(--bp-radius) !important;
  display: block !important;
}
.woocommerce ul.products li.product .star-rating { margin: 0 auto 0.5em auto !important; font-size: 0.85em !important; }

/* ───────────────────────────────────────────────────────────
   8. SHOP PAGE — pagination, sorting
   ─────────────────────────────────────────────────────────── */
.woocommerce-result-count { color: var(--bp-muted); font-weight: 700; margin-bottom: 1em !important; }
.woocommerce nav.woocommerce-pagination { margin: 2em 0 !important; text-align: center; }
.woocommerce nav.woocommerce-pagination ul {
  border: none !important;
  display: inline-flex;
  gap: 0.4em;
  flex-wrap: wrap;
  justify-content: center;
}
.woocommerce nav.woocommerce-pagination ul li { border: none !important; margin: 0 !important; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  background: #fff !important;
  border: 2px solid var(--bp-border) !important;
  border-radius: var(--bp-radius) !important;
  padding: 0.5em 1em !important;
  font-weight: 700 !important;
  color: var(--bp-dark) !important;
  min-width: 2.5em;
  display: inline-block;
  text-decoration: none;
  transition: var(--bp-trans);
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--bp-pink) !important;
  color: #fff !important;
  border-color: var(--bp-pink) !important;
}

/* Page header (term/category page) */
.woocommerce .term-description,
.term-description {
  background: linear-gradient(135deg, var(--bp-pink-50) 0%, var(--bp-blue-50) 100%);
  border-radius: var(--bp-radius);
  padding: 1em 1.5em;
  margin-bottom: 1em;
  color: var(--bp-body);
}
.woocommerce-products-header__title,
.page-title {
  color: var(--bp-dark) !important;
  font-size: 2em !important;
  margin-bottom: 0.4em !important;
}

/* Breadcrumb */
.woocommerce-breadcrumb {
  background: rgba(255,255,255,0.7);
  border-radius: var(--bp-radius);
  padding: 0.6em 1em;
  margin-bottom: 1em !important;
  color: var(--bp-muted);
  font-size: 0.9em;
}
.woocommerce-breadcrumb a { color: var(--bp-pink); font-weight: 700; }

/* ───────────────────────────────────────────────────────────
   9. SINGLE PRODUCT
   ─────────────────────────────────────────────────────────── */
.single-product div.product {
  background: #fff;
  border-radius: var(--bp-radius-lg);
  padding: 2em;
  box-shadow: var(--bp-shadow);
  border: 2px solid var(--bp-border);
}
.single-product div.product .product_title { font-size: 1.8em !important; margin-bottom: 0.4em !important; }
.single-product div.product .price { color: var(--bp-pink) !important; font-size: 1.5em !important; font-weight: 800 !important; }
.single-product div.product .price del { color: var(--bp-muted) !important; opacity: 0.7; font-size: 0.7em; margin-right: 0.5em; }
.single-product .quantity input { border: 2px solid var(--bp-border) !important; border-radius: var(--bp-radius) !important; padding: 0.5em !important; width: 80px !important; }

.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-bottom: 2px solid var(--bp-border) !important;
  padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  margin: 0 1em 0 0 !important;
  padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  padding: 0.7em 0 !important;
  font-weight: 700 !important;
  color: var(--bp-muted) !important;
  border-bottom: 3px solid transparent !important;
  margin-bottom: -2px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--bp-pink) !important; border-bottom-color: var(--bp-pink) !important; }

.related.products h2, .upsells.products h2 {
  text-align: center;
  margin: 2em 0 1em 0;
  font-size: 1.6em;
  position: relative;
}
.related.products h2::after, .upsells.products h2::after {
  content: "";
  display: block;
  width: 80px; height: 4px;
  background: linear-gradient(90deg, var(--bp-pink), var(--bp-blue));
  margin: 0.5em auto 0;
  border-radius: 999px;
}

/* ───────────────────────────────────────────────────────────
   10. CART & CHECKOUT
   ─────────────────────────────────────────────────────────── */
.woocommerce-cart .shop_table, .woocommerce-checkout .shop_table {
  border-radius: var(--bp-radius-lg);
  overflow: hidden;
  background: #fff;
  border: none !important;
  box-shadow: var(--bp-shadow-sm);
}
.woocommerce-cart .shop_table thead, .woocommerce-checkout .shop_table thead { background: var(--bp-pink-50); }
.woocommerce a.remove { color: var(--bp-pink) !important; font-weight: 800; }
.woocommerce a.remove:hover { background: var(--bp-pink) !important; color: #fff !important; }

/* ───────────────────────────────────────────────────────────
   11. HOMEPAGE — hero, sections, cards
   ─────────────────────────────────────────────────────────── */
.bp-hero {
  background:
    radial-gradient(circle at 20% 20%, rgba(252,211,77,0.4) 0, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(167,243,208,0.4) 0, transparent 50%),
    linear-gradient(135deg, var(--bp-pink-100) 0%, var(--bp-blue-100) 100%);
  border-radius: var(--bp-radius-lg);
  padding: 3em 2em;
  text-align: center;
  margin: 0 0 2em 0;
  position: relative;
  overflow: hidden;
  border: 3px solid #fff;
  box-shadow: var(--bp-shadow);
}
.bp-hero::before {
  content: "🎈";
  position: absolute;
  font-size: 8em;
  top: -20px; right: -20px;
  opacity: 0.18;
  transform: rotate(15deg);
  pointer-events: none;
}
.bp-hero::after {
  content: "🧸";
  position: absolute;
  font-size: 6em;
  bottom: -15px; left: -15px;
  opacity: 0.15;
  transform: rotate(-10deg);
  pointer-events: none;
}
.bp-hero h1 {
  font-size: 2.4em;
  margin-bottom: 0.4em;
  background: linear-gradient(135deg, var(--bp-pink) 0%, var(--bp-blue) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline-block;
  position: relative;
  line-height: 1.2;
}
.bp-hero p {
  font-size: 1.15em;
  color: var(--bp-dark);
  max-width: 640px;
  margin: 0 auto 1.5em auto;
  position: relative;
}

.bp-section-heading { text-align: center; margin: 2.5em 0 1.5em 0; position: relative; }
.bp-section-heading h2 {
  font-size: 1.8em;
  display: inline-block;
  position: relative;
  padding-bottom: 0.5em;
  margin: 0;
}
.bp-section-heading h2::after {
  content: "";
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 60px; height: 4px;
  background: linear-gradient(90deg, var(--bp-pink), var(--bp-blue));
  border-radius: 999px;
}

/* Category cards */
.bp-cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 1em;
  margin: 1em 0 2em 0;
}
.bp-cat-card {
  display: block;
  background: #fff;
  border: 3px solid transparent;
  border-radius: var(--bp-radius-lg);
  padding: 1.5em 1em;
  text-align: center;
  text-decoration: none !important;
  transition: var(--bp-trans);
  box-shadow: var(--bp-shadow-sm);
  background-image: linear-gradient(#fff, #fff), linear-gradient(135deg, var(--bp-pink-light), var(--bp-blue-light));
  background-origin: border-box;
  background-clip: padding-box, border-box;
}
.bp-cat-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--bp-shadow-lg);
}
.bp-cat-card .bp-cat-icon { font-size: 3em; display: block; margin-bottom: 0.3em; }
.bp-cat-card .bp-cat-name { font-weight: 800; color: var(--bp-dark); font-size: 0.95em; display: block; }

/* Trust badges row */
.bp-trust-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1em;
  background: linear-gradient(135deg, var(--bp-yellow-light) 0%, var(--bp-pink-100) 50%, var(--bp-blue-100) 100%);
  border-radius: var(--bp-radius-lg);
  padding: 1.5em;
  margin: 2em 0;
  border: 2px solid #fff;
  box-shadow: var(--bp-shadow-sm);
}
.bp-trust-item { text-align: center; padding: 0.5em; }
.bp-trust-item .bp-trust-icon { font-size: 2em; display: block; margin-bottom: 0.3em; }
.bp-trust-item h4 { margin: 0.3em 0 0.2em 0; font-size: 1em; color: var(--bp-dark); }
.bp-trust-item p { margin: 0; color: var(--bp-body); font-size: 0.85em; }

/* ───────────────────────────────────────────────────────────
   12. SIDEBAR / WIDGETS (sidebar + footer only — NOT header)
   ─────────────────────────────────────────────────────────── */
.widget-area .widget,
#secondary .widget,
.sidebar .widget {
  background: #fff;
  border-radius: var(--bp-radius-lg);
  padding: 1.5em;
  margin-bottom: 1.5em;
  box-shadow: var(--bp-shadow-sm);
  border: 2px solid var(--bp-border);
}
.widget-area .widget .widget-title,
.widget-area .widget h2,
.widget-area .widget h3,
#secondary .widget .widget-title,
#secondary .widget h2,
#secondary .widget h3 {
  font-size: 1.05em !important;
  font-weight: 800 !important;
  color: var(--bp-dark) !important;
  margin: 0 0 1em 0 !important;
  padding-bottom: 0.5em !important;
  border-bottom: 3px solid var(--bp-pink) !important;
  display: inline-block !important;
}
.widget-area .widget ul,
#secondary .widget ul { list-style: none; padding: 0; margin: 0; }
.widget-area .widget ul li,
#secondary .widget ul li {
  padding: 0.4em 0;
  border-bottom: 1px solid var(--bp-border);
}
.widget-area .widget ul li:last-child,
#secondary .widget ul li:last-child { border-bottom: none; }
.widget-area .widget ul li a,
#secondary .widget ul li a {
  color: var(--bp-body) !important;
  text-decoration: none;
  font-weight: 600;
  transition: var(--bp-trans);
}
.widget-area .widget ul li a:hover,
#secondary .widget ul li a:hover {
  color: var(--bp-pink) !important;
  padding-left: 4px;
}

/* ───────────────────────────────────────────────────────────
   13. BLOG / POSTS
   ─────────────────────────────────────────────────────────── */
.blog .hentry, .archive .hentry, .search .hentry {
  background: #fff;
  border-radius: var(--bp-radius-lg);
  padding: 2em;
  margin-bottom: 1.5em;
  box-shadow: var(--bp-shadow-sm);
  border: 2px solid var(--bp-border);
}
.entry-title a { color: var(--bp-dark) !important; text-decoration: none; }
.entry-title a:hover { color: var(--bp-pink) !important; }
.entry-meta { color: var(--bp-muted); font-size: 0.9em; }
.entry-meta a { color: var(--bp-pink); }

/* ───────────────────────────────────────────────────────────
   14. FOOTER
   ─────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--bp-dark) !important;
  color: #fff !important;
  border-top: 6px solid var(--bp-pink) !important;
}
.site-footer h2, .site-footer h3, .site-footer h4 { color: var(--bp-pink-light) !important; }
.site-footer a { color: var(--bp-blue-light) !important; text-decoration: none; }
.site-footer a:hover { color: var(--bp-pink-light) !important; }
.site-footer .widget { background: transparent !important; border: none !important; box-shadow: none !important; color: #cbd5e1 !important; }
.site-footer .widget ul li { border-bottom-color: rgba(255,255,255,0.1) !important; }
.site-footer .widget ul li a { color: #cbd5e1 !important; }
.site-info {
  padding: 1em !important;
  border-top: 1px solid rgba(255,255,255,0.1);
  text-align: center;
  color: var(--bp-muted) !important;
}

/* ───────────────────────────────────────────────────────────
   15. RESPONSIVE
   ─────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
  .site-header .col-full { flex-wrap: wrap !important; gap: 0.75em; }
  .site-header .site-search { flex: 1 1 100% !important; max-width: 100% !important; order: 3; }
  .site-header-cart { order: 2; }
  .site-branding { order: 1; }
}
@media (max-width: 768px) {
  .site-header { padding: 0 !important; }
  .custom-logo { max-height: 50px !important; max-width: 150px !important; }
  .main-navigation ul li a { padding: 0.4em 0.85em !important; font-size: 0.82em !important; letter-spacing: 0.02em; }
  .bp-hero { padding: 2em 1em; }
  .bp-hero h1 { font-size: 1.7em; }
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.85em !important;
  }
  .woocommerce ul.products li.product { padding: 0.7em !important; }
  .woocommerce ul.products li.product .button { font-size: 0.78em !important; padding: 0.55em 0.5em !important; }
}
@media (max-width: 480px) {
  .bp-cat-grid { grid-template-columns: repeat(2, 1fr); }
  .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 0.85em !important; }
}

/* ───────────────────────────────────────────────────────────
   16. UTILITY / MISC
   ─────────────────────────────────────────────────────────── */
.skip-link { color: var(--bp-pink) !important; }
.screen-reader-text { display: none; }

.page-header {
  background: linear-gradient(135deg, var(--bp-pink-50) 0%, var(--bp-blue-50) 100%);
  border-radius: var(--bp-radius-lg);
  padding: 2em;
  text-align: center;
  margin: 0 0 2em 0;
}
.page-header h1, .entry-header h1 { font-size: 2em; margin: 0; }

.woocommerce-message, .woocommerce-info {
  background: var(--bp-blue-50) !important;
  border-top-color: var(--bp-blue) !important;
  border-radius: var(--bp-radius);
}
.woocommerce-error {
  background: #FEF2F2 !important;
  border-top-color: #EF4444 !important;
  border-radius: var(--bp-radius);
}

/* Hide the secondary navigation row spacing if empty */
.storefront-handheld-footer-bar { display: none; }

/* ───────────────────────────────────────────────────────────
   17. SIDEBAR — only on blog index and single-post (NOT home)
   ─────────────────────────────────────────────────────────── */
body:not(.blog):not(.single-post):not(.archive.category) #secondary,
body:not(.blog):not(.single-post):not(.archive.category) .widget-area,
body:not(.blog):not(.single-post):not(.archive.category) .sidebar {
  display: none !important;
}
body:not(.blog):not(.single-post):not(.archive.category) #primary,
body:not(.blog):not(.single-post):not(.archive.category) .content-area {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin: 0 auto !important;
}

/* ───────────────────────────────────────────────────────────
   18. MOBILE MENU — clean toggle, full-width pill items
   ─────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* Force every container in the nav chain to 100% width — beats any Storefront padding/flex */
  .storefront-primary-navigation,
  .storefront-primary-navigation .col-full,
  .main-navigation {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    float: none !important;
    flex: none !important;
  }
  .storefront-primary-navigation { padding: 0.4em 0.5em !important; margin: 0 !important; }
  .storefront-primary-navigation .col-full { padding: 0 !important; margin: 0 !important; }

  .main-navigation {
    display: block !important;
    text-align: center;
    position: relative;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* Default: hide menu list, show toggle */
  .main-navigation ul.menu,
  .main-navigation ul.nav-menu,
  .main-navigation > div > ul,
  .storefront-primary-navigation ul {
    display: none !important;
  }

  /* Toggle button — clean text-only pill, NO pseudo icons, NO focus ring */
  button.menu-toggle,
  button.menu-toggle:hover,
  button.menu-toggle:active,
  button.menu-toggle:focus,
  button.menu-toggle:focus-visible,
  .main-navigation .menu-toggle,
  .main-navigation > button.menu-toggle,
  .menu-toggle {
    display: inline-block !important;
    background: #fff !important;
    background-color: #fff !important;
    background-image: none !important;
    color: var(--bp-pink) !important;
    padding: 0.55em 1.8em !important;
    margin: 0.25em auto !important;
    border-radius: 999px !important;
    font-weight: 800 !important;
    border: none !important;
    outline: none !important;
    outline-offset: 0 !important;
    box-shadow: 0 3px 0 rgba(0,0,0,.15) !important;
    font-size: 0.85em !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    width: auto !important;
    cursor: pointer;
    line-height: 1;
    font-family: var(--bp-font) !important;
    -webkit-tap-highlight-color: transparent !important;
  }
  /* Kill ANY background/focus styling on the toggle's children too */
  .menu-toggle *,
  .menu-toggle *:focus {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    outline: none !important;
    border: none !important;
    box-shadow: none !important;
  }
  /* KILL all three Storefront hamburger pseudos (the ones drawn with background-color stripes) */
  button.menu-toggle::before,
  button.menu-toggle::after,
  button.menu-toggle span::before,
  button.menu-toggle span::after,
  button.menu-toggle:before,
  button.menu-toggle:after,
  button.menu-toggle span:before,
  button.menu-toggle span:after {
    content: none !important;
    display: none !important;
    background: none !important;
    background-color: transparent !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    font-size: 0 !important;
    border: none !important;
    box-shadow: none !important;
    transform: none !important;
  }
  /* Hide any inner element (svg/img/i) the theme injects */
  .menu-toggle svg,
  .menu-toggle img,
  .menu-toggle i,
  .menu-toggle .dashicons { display: none !important; }
  /* Keep the span text visible — it contains the word "Menu" */
  .menu-toggle span {
    display: inline !important;
    background: transparent !important;
    color: var(--bp-pink) !important;
    font-weight: 800 !important;
    font-size: 1em !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
  }

  /* Storefront hides .primary-navigation on mobile — force it visible AND full-width when toggled */
  .main-navigation.toggled .primary-navigation,
  .main-navigation .menu-toggle[aria-expanded="true"] ~ .primary-navigation,
  .menu-toggle[aria-expanded="true"] + .primary-navigation {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    flex: none !important;
    float: none !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
  }

  /* Open state — UL spans full width with full-width pill items */
  .main-navigation.toggled ul.menu,
  .main-navigation.toggled ul.nav-menu,
  .main-navigation.toggled .primary-navigation > ul,
  .main-navigation.toggled > div > ul,
  .main-navigation .menu-toggle[aria-expanded="true"] ~ ul.menu,
  .main-navigation .menu-toggle[aria-expanded="true"] ~ .primary-navigation > ul,
  .main-navigation .menu-toggle[aria-expanded="true"] ~ div > ul,
  .menu-toggle[aria-expanded="true"] + ul,
  .menu-toggle[aria-expanded="true"] + div > ul {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box !important;
    gap: 0.35em !important;
    background: rgba(255,255,255,0.18) !important;
    padding: 0.6em !important;
    border-radius: 16px !important;
    margin: 0.5em 0 0 0 !important;
    list-style: none !important;
  }
  .main-navigation.toggled ul.menu li,
  .main-navigation.toggled ul.nav-menu li {
    width: 100% !important;
    list-style: none !important;
    margin: 0 !important;
  }
  .main-navigation.toggled ul.menu > li > a,
  .main-navigation.toggled ul.nav-menu > li > a {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    padding: 0.7em 1em !important;
    background: rgba(255,255,255,0.12) !important;
    color: #fff !important;
    border-radius: 999px !important;
    font-size: 0.95em !important;
    font-weight: 800 !important;
    box-sizing: border-box !important;
  }
  .main-navigation.toggled ul.menu li a:hover,
  .main-navigation.toggled ul.menu li.current-menu-item > a {
    background: #fff !important;
    color: var(--bp-pink) !important;
  }
  /* Show chevron on parent items, rotate when expanded */
  .main-navigation.toggled ul li.menu-item-has-children > a::after {
    content: "▾" !important;
    display: inline-block !important;
    margin-left: 0.4em !important;
    font-size: 0.85em !important;
    transition: transform .2s !important;
    position: static !important;
    background: transparent !important;
    color: inherit !important;
    width: auto !important;
    height: auto !important;
    line-height: 1 !important;
  }
  .main-navigation.toggled ul li.menu-item-has-children.bp-submenu-open > a::after {
    transform: rotate(180deg) !important;
  }
  /* Submenu hidden by default on mobile — expand only when parent has bp-submenu-open */
  .main-navigation.toggled ul ul.sub-menu {
    display: none !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    position: static !important;
    box-shadow: none !important;
    border: none !important;
    background: rgba(0,0,0,0.12) !important;
    margin: 0.3em 0 0 0 !important;
    padding: 0.4em !important;
    border-radius: 12px !important;
    flex-direction: column !important;
    gap: 0.2em !important;
  }
  .main-navigation.toggled ul li.menu-item-has-children.bp-submenu-open > ul.sub-menu {
    display: flex !important;
  }
  .main-navigation.toggled ul ul.sub-menu li a {
    color: #fff !important;
    background: transparent !important;
    font-size: 0.85em !important;
    padding: 0.45em 0.8em !important;
    text-align: center !important;
  }
  .main-navigation.toggled ul ul.sub-menu li.bp-menu-divider > a {
    color: rgba(255,255,255,0.55) !important;
    font-size: 0.7em !important;
    text-transform: uppercase;
    letter-spacing: 0.15em;
  }

  /* Hide the tag-cloud handheld nav (Storefront duplicates the menu in a separate handheld element) — we only want one */
  .storefront-handheld-footer-bar,
  .handheld-navigation { display: none !important; }
}

/* ───────────────────────────────────────────────────────────
   19. CART NOTICES — readable text
   ─────────────────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
.woocommerce p.no-comments {
  color: var(--bp-dark) !important;
  font-weight: 600;
}
.woocommerce-message a:not(.button),
.woocommerce-info a:not(.button) { color: var(--bp-pink) !important; font-weight: 700; }
.woocommerce-message .button,
.woocommerce-info .button { float: right; margin-top: -0.2em; }

/* ───────────────────────────────────────────────────────────
   20. QUANTITY STEPPER (cart page + product page)
   ─────────────────────────────────────────────────────────── */
.woocommerce .quantity {
  display: inline-flex !important;
  align-items: center;
  gap: 4px;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}
.woocommerce .quantity input.qty,
.woocommerce-cart-form .quantity input.qty {
  width: 56px !important;
  padding: 0.4em 0.4em !important;
  text-align: center !important;
  font-weight: 800 !important;
  border: 2px solid var(--bp-border) !important;
  border-radius: var(--bp-radius) !important;
  background: #fff !important;
  height: auto !important;
  font-size: 0.95em !important;
}
.woocommerce .quantity .plus,
.woocommerce .quantity .minus,
.wc-block-components-quantity-selector__button {
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  font-size: 1.1em !important;
  line-height: 1 !important;
  box-shadow: none !important;
  background: var(--bp-pink) !important;
  color: #fff !important;
  border: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 800 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.woocommerce .quantity .plus:hover,
.woocommerce .quantity .minus:hover {
  background: var(--bp-pink-light) !important;
  transform: none !important;
  box-shadow: none !important;
}
/* Hide any leftover button/element inside the quantity div */
.woocommerce-cart-form .quantity > *:not(.qty):not(.plus):not(.minus):not(label) {
  display: none !important;
}

/* WC Blocks quantity selector */
.wc-block-components-quantity-selector {
  border: 2px solid var(--bp-pink-light) !important;
  border-radius: var(--bp-radius) !important;
}
.wc-block-components-quantity-selector__input {
  border: none !important;
  background: transparent !important;
  font-weight: 800 !important;
  color: var(--bp-dark) !important;
}

/* Cart page action buttons (Update/Apply coupon) */
.woocommerce-cart-form .actions .button,
.woocommerce-cart .coupon .button {
  padding: 0.6em 1.2em !important;
  font-size: 0.85em !important;
}

/* Remove ✕ link */
.woocommerce a.remove,
.woocommerce-cart-form a.remove {
  background: var(--bp-pink-50) !important;
  color: var(--bp-pink) !important;
  width: 24px !important;
  height: 24px !important;
  line-height: 22px !important;
  text-align: center !important;
  border-radius: 50% !important;
  font-weight: 800 !important;
  font-size: 1em !important;
  display: inline-block !important;
}
.woocommerce a.remove:hover {
  background: var(--bp-pink) !important;
  color: #fff !important;
}

/* ───────────────────────────────────────────────────────────
   21. CHECKOUT — selects, Select2 dropdowns
   ─────────────────────────────────────────────────────────── */
.woocommerce form select,
.woocommerce-checkout select,
.woocommerce-billing-fields select,
.woocommerce-shipping-fields select {
  padding: 0.65em 2.5em 0.65em 1em !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23EC4899' d='M6 8L0 0h12z'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 1em center !important;
  background-color: #fff !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  font-family: var(--bp-font) !important;
  font-weight: 600 !important;
}
/* Select2 (used by WC for country/state dropdowns) */
.select2-container--default .select2-selection--single {
  height: auto !important;
  min-height: 44px !important;
  padding: 0.5em 2.5em 0.5em 1em !important;
  border: 2px solid var(--bp-border) !important;
  border-radius: var(--bp-radius) !important;
  background: #fff !important;
  font-family: var(--bp-font) !important;
  display: flex !important;
  align-items: center !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  padding-left: 0 !important;
  padding-right: 0 !important;
  line-height: 1.5 !important;
  color: var(--bp-dark) !important;
  font-weight: 600 !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100% !important;
  right: 0.6em !important;
  top: 0 !important;
  width: 20px !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: var(--bp-pink) transparent transparent transparent !important;
  border-width: 6px 5px 0 5px !important;
}
.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
  border-color: transparent transparent var(--bp-pink) transparent !important;
  border-width: 0 5px 6px 5px !important;
}
.select2-dropdown {
  border: 2px solid var(--bp-pink-100) !important;
  border-radius: var(--bp-radius) !important;
  box-shadow: var(--bp-shadow-lg) !important;
  overflow: hidden;
}
.select2-search--dropdown .select2-search__field {
  border: 2px solid var(--bp-border) !important;
  border-radius: 8px !important;
  padding: 0.4em 0.7em !important;
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted {
  background: var(--bp-pink) !important;
  color: #fff !important;
}

/* Checkout fields cleanup */
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 { padding: 0 !important; }
.woocommerce-checkout-review-order {
  background: #fff;
  border-radius: var(--bp-radius-lg);
  padding: 1.5em;
  box-shadow: var(--bp-shadow-sm);
  border: 2px solid var(--bp-border);
}

/* ───────────────────────────────────────────────────────────
   22. MINI-CART HOVER POPUP (header cart) — light, readable
   ─────────────────────────────────────────────────────────── */
.site-header-cart .widget_shopping_cart,
.site-header-cart .cart-contents-container,
.site-header-cart .site-header-cart-content {
  background: #fff !important;
  border: 2px solid var(--bp-pink-100) !important;
  border-radius: var(--bp-radius-lg) !important;
  box-shadow: var(--bp-shadow-lg) !important;
  padding: 1em !important;
  color: var(--bp-dark) !important;
  min-width: 280px;
  margin-top: 0.5em;
}
/* Force every nested element to a light theme — overrides Storefront's dark mini-cart */
.site-header-cart .widget_shopping_cart,
.site-header-cart .widget_shopping_cart * {
  background-color: transparent !important;
  background-image: none !important;
  color: var(--bp-dark) !important;
}
.site-header-cart .widget_shopping_cart {
  background: #fff !important;
}
.site-header-cart .widget_shopping_cart h2,
.site-header-cart .widget_shopping_cart .widgettitle {
  font-size: 1em !important;
  margin: 0 0 0.75em 0 !important;
  padding-bottom: 0.5em !important;
  border-bottom: 2px solid var(--bp-pink-100) !important;
  color: var(--bp-dark) !important;
}
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart { padding: 0 !important; margin: 0 !important; }
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart__total,
.site-header-cart .widget_shopping_cart p.total,
.site-header-cart .widget_shopping_cart .total {
  background: var(--bp-pink-50) !important;
  border: none !important;
  border-radius: var(--bp-radius) !important;
  padding: 0.7em 0.95em !important;
  margin: 0.5em 0 !important;
  font-weight: 800 !important;
  color: var(--bp-dark) !important;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart__total strong { color: var(--bp-dark) !important; }
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart__total .amount,
.site-header-cart .widget_shopping_cart .total .amount {
  color: var(--bp-pink) !important;
  font-size: 1.1em !important;
}
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart__empty-message {
  color: var(--bp-muted) !important;
  font-style: italic;
  text-align: center;
  padding: 1em 0 !important;
}
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart__buttons,
.site-header-cart .widget_shopping_cart p.buttons {
  display: flex !important;
  flex-direction: column;
  gap: 0.5em;
  padding: 0 !important;
  margin: 0 !important;
}
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart__buttons .button,
.site-header-cart .widget_shopping_cart p.buttons .button {
  display: block !important;
  text-align: center !important;
  width: 100% !important;
  margin: 0 !important;
  color: #fff !important;
  background: var(--bp-pink) !important;
}
.site-header-cart .widget_shopping_cart .woocommerce-mini-cart__buttons .checkout,
.site-header-cart .widget_shopping_cart p.buttons .checkout {
  background: var(--bp-blue) !important;
  box-shadow: 0 4px 0 #075E8A !important;
  color: #fff !important;
}
.site-header-cart .widget_shopping_cart ul.cart_list,
.site-header-cart .widget_shopping_cart ul.product_list_widget {
  padding: 0 !important;
  margin: 0 0 0.5em 0 !important;
}
.site-header-cart .widget_shopping_cart ul.cart_list li,
.site-header-cart .widget_shopping_cart ul.product_list_widget li {
  padding: 0.5em 0 !important;
  border-bottom: 1px solid var(--bp-border) !important;
  background: transparent !important;
}
.site-header-cart .widget_shopping_cart ul.cart_list li img,
.site-header-cart .widget_shopping_cart ul.product_list_widget li img {
  width: 48px !important;
  height: 48px !important;
  border-radius: 8px !important;
  border: 1px solid var(--bp-border) !important;
  float: right !important;
  margin-left: 0.5em !important;
}
.site-header-cart .widget_shopping_cart ul.cart_list li a.remove {
  background: var(--bp-pink-50) !important;
  color: var(--bp-pink) !important;
  width: 22px !important;
  height: 22px !important;
  line-height: 20px !important;
  border-radius: 50% !important;
  text-align: center !important;
  font-size: 0.9em !important;
}

/* ───────────────────────────────────────────────────────────
   23. WC NOTICES — green check, readable bg, proper text indent
   ─────────────────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  position: relative !important;
  padding: 1em 1.25em 1em 3.25em !important;
  list-style: none !important;
}
.woocommerce-message {
  background: #ECFDF5 !important;
  border-top: 4px solid #10B981 !important;
  color: #065F46 !important;
  border-radius: var(--bp-radius) !important;
}
.woocommerce-message::before {
  color: #10B981 !important;
  background: transparent !important;
  font-size: 1.3em !important;
  position: absolute !important;
  top: 1em !important;
  left: 1.1em !important;
  line-height: 1 !important;
}
.woocommerce-info::before,
.woocommerce-error::before {
  position: absolute !important;
  top: 1em !important;
  left: 1.1em !important;
  font-size: 1.3em !important;
  line-height: 1 !important;
  background: transparent !important;
}
.woocommerce-message a:not(.button) { color: #047857 !important; font-weight: 700; }

.woocommerce-info {
  background: var(--bp-blue-50) !important;
  border-top: 4px solid var(--bp-blue) !important;
  color: #075985 !important;
  border-radius: var(--bp-radius) !important;
}
.woocommerce-info::before { color: var(--bp-blue) !important; background: transparent !important; }

.woocommerce-error {
  background: #FEF2F2 !important;
  border-top: 4px solid #EF4444 !important;
  color: #991B1B !important;
  border-radius: var(--bp-radius) !important;
}
.woocommerce-error::before { color: #EF4444 !important; background: transparent !important; }

/* ───────────────────────────────────────────────────────────
   24. WC BLOCKS CART — quantity selector + remove link
   ─────────────────────────────────────────────────────────── */
.wc-block-cart-items,
.wc-block-cart-item__row {
  background: transparent !important;
}
.wc-block-cart-item__quantity,
.wc-block-components-quantity-selector {
  display: inline-flex !important;
  align-items: center !important;
  border: 2px solid var(--bp-pink-light) !important;
  border-radius: 999px !important;
  background: #fff !important;
  padding: 0 !important;
  width: auto !important;
  min-width: 130px !important;
  overflow: hidden;
}
.wc-block-components-quantity-selector__button,
.wc-block-cart-item__quantity button {
  background: transparent !important;
  color: var(--bp-pink) !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  font-size: 1.2em !important;
  font-weight: 800 !important;
  padding: 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.wc-block-components-quantity-selector__button:hover,
.wc-block-cart-item__quantity button:hover {
  background: var(--bp-pink-50) !important;
  color: var(--bp-pink) !important;
  transform: none !important;
  box-shadow: none !important;
}
.wc-block-components-quantity-selector__input,
.wc-block-cart-item__quantity input {
  border: none !important;
  background: transparent !important;
  text-align: center !important;
  font-weight: 800 !important;
  color: var(--bp-dark) !important;
  width: 50px !important;
  padding: 0 !important;
  height: 36px !important;
  font-size: 0.95em !important;
}

/* WC Blocks remove link — make it a plain text link, NOT a pink button */
.wc-block-cart-item__remove-link,
.wc-block-cart-item__remove,
button.wc-block-cart-item__remove-link,
.wc-block-cart-item__product .wc-block-cart-item__remove-link {
  background: transparent !important;
  color: var(--bp-muted) !important;
  font-size: 0.8em !important;
  padding: 0.3em 0 0 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  text-decoration: underline !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight: 600 !important;
  border: none !important;
  display: inline-block !important;
  width: auto !important;
  height: auto !important;
}
.wc-block-cart-item__remove-link:hover {
  color: var(--bp-pink) !important;
  background: transparent !important;
  transform: none !important;
}

/* ───────────────────────────────────────────────────────────
   25. WC BLOCKS CHECKOUT — floating labels (no overlap), single chevron
   ─────────────────────────────────────────────────────────── */
.wc-block-components-text-input,
.wc-block-components-combobox-control,
.wc-block-components-combobox {
  position: relative !important;
}
.wc-block-components-text-input input,
.wc-block-components-text-input .input-text,
.wc-block-components-combobox-control input,
.wc-block-components-combobox input,
.wc-block-components-text-input textarea {
  padding-top: 30px !important;
  padding-bottom: 8px !important;
  padding-left: 14px !important;
  padding-right: 14px !important;
  height: auto !important;
  min-height: 60px !important;
  border: 2px solid var(--bp-border) !important;
  border-radius: var(--bp-radius) !important;
  font-family: var(--bp-font) !important;
  background: #fff !important;
  font-size: 0.95em !important;
  line-height: 1.3 !important;
  color: var(--bp-dark) !important;
}
/* Combobox: paint pink chevron DIRECTLY on input, more padding on right */
.wc-block-components-combobox-control input,
.wc-block-components-combobox input {
  padding-right: 36px !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23EC4899' d='M6 8L0 0h12z'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  background-size: 12px 8px !important;
}

/* Always-floated label — locked to top of field, no animation, no state-based position */
[class*="wc-block-components-text-input"] label,
[class*="wc-block-components-combobox"] label,
.wc-block-components-text-input label,
.wc-block-components-combobox-control label {
  position: absolute !important;
  top: 8px !important;
  left: 14px !important;
  transform: none !important;
  pointer-events: none !important;
  color: var(--bp-pink) !important;
  background: transparent !important;
  font-weight: 800 !important;
  font-size: 11px !important;
  line-height: 1 !important;
  letter-spacing: 0.02em !important;
  margin: 0 !important;
  padding: 0 !important;
  height: 12px !important;
  z-index: 2 !important;
  transition: none !important;
}

/* ─── NUKE every possible source of the black chevron in WC Blocks combobox ─── */
[class*="wc-block-components-combobox"] svg,
[class*="wc-block-components-combobox"] button svg,
[class*="wc-block-components-combobox"] [aria-hidden="true"] svg,
[class*="components-combobox"] svg,
[class*="combobox"] svg,
.wc-block-components-form .wc-block-components-combobox svg,
.wp-block-woocommerce-checkout svg.components-icon,
.wc-block-checkout svg[viewBox],
[class*="wc-block-components-combobox"] button::before,
[class*="wc-block-components-combobox"] button::after,
[class*="wc-block-components-combobox"] [class*="indicator"],
[class*="wc-block-components-combobox"] [class*="arrow"],
[class*="wc-block-components-combobox"] [class*="chevron"],
[class*="wc-block-components-combobox"] [class*="caret"],
[class*="wc-block-components-combobox"] [class*="suffix"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  background: none !important;
  background-image: none !important;
  content: none !important;
}
/* The chevron-toggle button itself: keep it interactive but make it invisible */
[class*="wc-block-components-combobox"] button,
.wc-block-components-combobox-control .components-button,
.wc-block-components-combobox-control button[type="button"]:not([class*="suggestion"]) {
  background: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  color: transparent !important;
  font-size: 0 !important;
}
/* Native <select> — strip native browser chevron */
.woocommerce-checkout select,
.wp-block-woocommerce-checkout select,
.wc-block-checkout select,
.wc-block-components-form select {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23EC4899' d='M6 8L0 0h12z'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  background-size: 12px 8px !important;
  padding-right: 36px !important;
}

/* (Chevron now painted on the input itself, see input rules above) */
