/* VLR Theme — woocommerce.css
   Additional WooCommerce overrides
*/

/* ─── NOTICES ──────────────────────────────────────────────── */
.woocommerce-notices-wrapper { margin-bottom: 16px; }
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-top: none !important;
  border-left: 3px solid var(--vlr-pink) !important;
  border-radius: var(--vlr-r8) !important;
  color: var(--vlr-snow) !important;
  padding: 14px 18px !important;
  margin-bottom: 16px !important;
  font-size: 13px !important;
  font-family: var(--vlr-body) !important;
  list-style: none !important;
}
.woocommerce .woocommerce-info { border-left-color: var(--vlr-green) !important; }
.woocommerce .woocommerce-error { border-left-color: #ef4444 !important; }
.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-error::before { display: none !important; }
.woocommerce-additional-fields { display: none !important; }
.woocommerce .woocommerce-message a.button,
.woocommerce .woocommerce-info a.button {
  background: var(--vlr-pink) !important; color: white !important;
  border-radius: var(--vlr-r4) !important; border: none !important;
  padding: 8px 16px !important; font-family: var(--vlr-mono) !important;
  font-size: 11px !important; float: right !important; letter-spacing: 0.5px !important;
}

/* ─── BUTTONS GLOBAL ───────────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--vlr-pink) !important;
  color: white !important;
  border-radius: var(--vlr-r8) !important;
  border: none !important;
  font-family: var(--vlr-body) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.4px !important;
  padding: 12px 24px !important;
  transition: background 0.18s !important;
  cursor: pointer !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover { background: var(--vlr-pink2) !important; }

.woocommerce a.button.alt { background: var(--vlr-grey) !important; color: var(--vlr-snow) !important; border: 1px solid var(--vlr-border2) !important; }
.woocommerce a.button.alt:hover { border-color: var(--vlr-pglow) !important; }

/* ─── FORM FIELDS GLOBAL ───────────────────────────────────── */
.woocommerce-page input[type="text"],
.woocommerce-page input[type="email"],
.woocommerce-page input[type="tel"],
.woocommerce-page input[type="password"],
.woocommerce-page input[type="number"],
.woocommerce-page select,
.woocommerce-page textarea {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r8) !important;
  color: var(--vlr-snow) !important;
  padding: 14px 16px !important;
  font-family: var(--vlr-body) !important;
  font-size: 13.5px !important;
  outline: none !important;
  box-shadow: none !important;
  transition: all 0.2s ease !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.woocommerce-page input:focus,
.woocommerce-page select:focus,
.woocommerce-page textarea:focus { 
  border-color: var(--vlr-pink) !important; 
  box-shadow: 0 0 10px rgba(255, 31, 143, 0.18) !important;
}
.woocommerce-page input::placeholder,
.woocommerce-page textarea::placeholder { 
  color: var(--vlr-fog) !important; 
  opacity: 0.75 !important;
}
.woocommerce-page select option { 
  background: var(--vlr-grey2); 
  color: var(--vlr-snow); 
}

/* Fix WooCommerce default labels and floating placeholders */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce-additional-fields__field-wrapper {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
}

.woocommerce-checkout .form-row {
  grid-column: span 2 !important;
  margin: 0 0 16px 0 !important;
  padding: 0 !important;
  float: none !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  box-sizing: border-box !important;
}

@media (min-width: 768px) {
  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last {
    grid-column: span 1 !important;
  }
}

.woocommerce-checkout .form-row label {
  font-family: var(--vlr-mono) !important;
  font-size: 9.5px !important;
  color: var(--vlr-mist) !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  margin-bottom: 10px !important;
  display: inline-block !important;
  line-height: 1.2 !important;
}

.woocommerce-checkout .form-row label .required {
  color: var(--vlr-pink) !important;
  text-decoration: none !important;
}

/* Custom premium checkboxes and radios */
.woocommerce-checkout input[type="checkbox"],
.woocommerce-checkout input[type="radio"],
.woocommerce-form__input-checkbox {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r4) !important;
  width: 16px !important;
  height: 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  vertical-align: middle !important;
  cursor: pointer !important;
  position: relative !important;
  transition: all 0.2s ease !important;
  box-sizing: border-box !important;
}
.woocommerce-checkout input[type="radio"] {
  border-radius: 50% !important;
}
.woocommerce-checkout input[type="checkbox"]:checked,
.woocommerce-checkout input[type="radio"]:checked,
.woocommerce-form__input-checkbox:checked {
  background: var(--vlr-pink) !important;
  border-color: var(--vlr-pink) !important;
  box-shadow: 0 0 8px rgba(255, 31, 143, 0.4) !important;
}
.woocommerce-checkout input[type="checkbox"]:checked::after,
.woocommerce-form__input-checkbox:checked::after {
  content: "✓" !important;
  color: white !important;
  font-size: 11px !important;
  font-weight: 700 !important;
}
.woocommerce-checkout input[type="radio"]:checked::after {
  content: "" !important;
  width: 6px !important;
  height: 6px !important;
  background: white !important;
  border-radius: 50% !important;
}

/* Checkout Page Grid Layout */
@media (min-width: 992px) {
  form.checkout {
    display: grid !important;
    grid-template-columns: 1.25fr 1fr !important;
    gap: 48px !important;
    align-items: start !important;
  }
  .col2-set {
    grid-column: 1 !important;
    margin-bottom: 0 !important;
  }
  #order_review_heading {
    grid-column: 2 !important;
    grid-row: 1 !important;
    margin-top: 0 !important;
  }
  #order_review {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }
}

.woocommerce-checkout h3 {
  font-family: var(--vlr-disp) !important;
  font-size: 24px !important;
  letter-spacing: 1.5px !important;
  margin: 0 0 24px 0 !important;
  text-transform: uppercase !important;
  color: var(--vlr-snow) !important;
  border-bottom: 1px solid var(--vlr-border) !important;
  padding-bottom: 8px !important;
}

/* ─── SINGLE PRODUCT BUNDLE / KIT SELECTION ────────────────── */
.vlr-bundle-selection {
  margin: 24px 0 20px 0;
  display: block;
}
.vlr-bundle-title {
  display: block;
  font-family: var(--vlr-mono);
  font-size: 10px;
  color: var(--vlr-mist);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.vlr-bundle-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 576px) {
  .vlr-bundle-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.vlr-bundle-card {
  background: var(--vlr-grey);
  border: 1px solid var(--vlr-border2);
  border-radius: var(--vlr-r12);
  padding: 16px;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: all 0.22s ease;
  box-sizing: border-box;
}
.vlr-bundle-card:hover {
  border-color: rgba(255, 31, 143, 0.4);
  transform: translateY(-2px);
}
.vlr-bundle-card.active {
  border-color: var(--vlr-green) !important;
  background: rgba(166, 255, 0, 0.03) !important;
  box-shadow: 0 0 16px rgba(166, 255, 0, 0.15) !important;
}

/* Badges for bundle cards */
.vlr-bundle-badge {
  position: absolute;
  top: -9px;
  font-family: var(--vlr-mono);
  font-size: 8px;
  font-weight: 700;
  color: white;
  padding: 2px 8px;
  border-radius: 4px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.vlr-bundle-badge.badge-popular {
  background: var(--vlr-green);
  color: var(--vlr-black);
}
.vlr-bundle-badge.badge-value {
  background: #fb923c; /* Orange */
}

/* Vial graphics inside card */
.vlr-bundle-vials {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  margin-bottom: 8px;
  height: 32px;
}
.vlr-vial-svg {
  color: var(--vlr-mist);
  transition: color 0.2s ease;
}
.vlr-bundle-card.active .vlr-vial-svg {
  color: var(--vlr-green);
  filter: drop-shadow(0 0 6px var(--vlr-green));
}
.vlr-bundle-card:hover .vlr-vial-svg {
  color: var(--vlr-pink);
}

/* Info section inside card */
.vlr-bundle-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.vlr-bundle-name {
  font-family: var(--vlr-disp);
  font-size: 16px;
  letter-spacing: 0.5px;
  color: var(--vlr-snow);
}
.vlr-bundle-price-desc {
  font-family: var(--vlr-mono);
  font-size: 9px;
  color: var(--vlr-fog);
  letter-spacing: 0.2px;
}
.vlr-bundle-card.active .vlr-bundle-price-desc {
  color: var(--vlr-green);
}

/* Price savings tag */
.vlr-price-savings {
  font-family: var(--vlr-mono);
  font-size: 11px;
  color: var(--vlr-green);
  background: rgba(166, 255, 0, 0.1);
  border: 1px solid var(--vlr-gglow);
  border-radius: 4px;
  padding: 2px 6px;
  margin-left: 8px;
  letter-spacing: 0.5px;
  vertical-align: middle;
}

/* ─── SINGLE PRODUCT TRUST BADGES ──────────────────────────── */
.vlr-sp-trust {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 24px;
  border-top: 1px solid var(--vlr-border);
  padding-top: 18px;
}
.vlr-sp-trust-item {
  background: var(--vlr-grey);
  border: 1px solid var(--vlr-border2);
  border-radius: var(--vlr-r8);
  padding: 12px 6px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  transition: all 0.2s;
}
.vlr-sp-trust-item:hover {
  border-color: rgba(255, 31, 143, 0.25);
  background: var(--vlr-grey2);
}
.vlr-sp-trust-item svg {
  color: var(--vlr-pink);
  filter: drop-shadow(0 0 4px rgba(255, 31, 143, 0.2));
}
.vlr-sp-trust-item small {
  font-family: var(--vlr-mono);
  font-size: 8px;
  color: var(--vlr-mist);
  letter-spacing: 0.5px;
  line-height: 1.1;
  text-transform: uppercase;
}


/* ─── ACCOUNT PAGES ────────────────────────────────────────── */
.woocommerce-account .woocommerce { padding: 48px 0; }
.woocommerce-MyAccount-navigation ul { list-style: none; display: flex; flex-direction: column; gap: 4px; }
.woocommerce-MyAccount-navigation ul li a {
  display: block; padding: 10px 14px; font-family: var(--vlr-mono); font-size: 11px;
  color: var(--vlr-mist); letter-spacing: 0.8px; border-radius: var(--vlr-r4);
  background: var(--vlr-grey); border: 1px solid var(--vlr-border); transition: all 0.15s;
}
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--vlr-pdim); color: var(--vlr-pink2); border-color: var(--vlr-pglow);
}
.woocommerce-MyAccount-content { padding: 0 !important; }
.woocommerce-MyAccount-content p { color: var(--vlr-mist); font-size: 14px; }

/* ─── ORDER TABLE ──────────────────────────────────────────── */
.woocommerce table.shop_table {
  width: 100%; border-collapse: collapse;
  border: 1px solid var(--vlr-border) !important;
  border-radius: var(--vlr-r8); overflow: hidden;
}
.woocommerce table.shop_table th {
  background: var(--vlr-grey) !important;
  font-family: var(--vlr-mono) !important; font-size: 9.5px !important;
  color: var(--vlr-fog) !important; letter-spacing: 1.2px !important;
  padding: 12px 16px !important; text-align: left !important;
  border: none !important; border-bottom: 1px solid var(--vlr-border) !important;
}
.woocommerce table.shop_table td {
  padding: 14px 16px !important; font-size: 13px !important;
  color: var(--vlr-snow) !important; border: none !important;
  border-bottom: 1px solid var(--vlr-border) !important;
  background: var(--vlr-black) !important;
}
.woocommerce table.shop_table tfoot td {
  background: var(--vlr-grey) !important;
  font-family: var(--vlr-mono) !important; font-size: 11px !important;
  color: var(--vlr-fog) !important;
}
.woocommerce table.shop_table tfoot tr.order-total td { color: var(--vlr-snow) !important; font-size: 15px !important; font-weight: 700 !important; }
.woocommerce table.shop_table .amount { font-family: var(--vlr-mono) !important; }

/* ─── CHECKOUT PAYMENT ─────────────────────────────────────── */
#payment { background: transparent !important; }
#payment .payment_methods { list-style: none !important; margin: 0 0 20px 0 !important; padding: 0 !important; }
#payment .payment_methods li { padding: 14px 0 !important; border-bottom: 1px solid var(--vlr-border) !important; }
#payment .payment_methods li label {
  font-family: var(--vlr-body) !important; font-size: 13.5px !important;
  color: var(--vlr-snow) !important; cursor: pointer !important;
  display: inline-flex !important; align-items: center !important; gap: 10px !important;
}
#payment .payment_methods li img { max-height: 20px; margin-left: 8px; vertical-align: middle; }
#payment .payment_box {
  background: var(--vlr-grey) !important; border: 1px solid var(--vlr-border) !important;
  border-radius: var(--vlr-r8) !important; padding: 16px !important; margin: 12px 0 0 0 !important;
  font-size: 12.5px !important;
}
#payment .payment_box p { color: var(--vlr-mist) !important; font-size: 12.5px !important; line-height: 1.6 !important; }
#payment #place_order {
  width: 100% !important; background: var(--vlr-pink) !important; color: white !important;
  border: none !important; border-radius: var(--vlr-r8) !important;
  padding: 16px !important; font-family: var(--vlr-mono) !important;
  font-size: 14px !important; font-weight: 700 !important; letter-spacing: 1.5px !important;
  cursor: pointer !important; transition: all 0.2s ease !important; margin-top: 16px !important;
  display: block !important;
  box-shadow: 0 4px 15px rgba(255, 31, 143, 0.2) !important;
}
#payment #place_order:hover { 
  background: var(--vlr-pink2) !important; 
  box-shadow: 0 4px 20px rgba(255, 31, 143, 0.4) !important;
  transform: translateY(-1px) !important;
}

/* ─── PRODUCT PRICE ────────────────────────────────────────── */
.woocommerce .price .woocommerce-Price-amount,
.woocommerce .price { font-family: var(--vlr-mono); color: var(--vlr-snow); }
.woocommerce .price ins { text-decoration: none; }
.woocommerce .price del { opacity: 0.5; }
.woocommerce .price del .woocommerce-Price-amount { font-size: 0.8em; }

/* ─── STAR RATINGS ─────────────────────────────────────────── */
.woocommerce .star-rating { color: var(--vlr-pink) !important; }
.woocommerce .star-rating::before { color: var(--vlr-fog) !important; }

/* ─── ORDER RECEIVED / THANK YOU ───────────────────────────── */
.woocommerce-order { padding: 48px 0; }
.woocommerce-order .woocommerce-thankyou-order-received {
  font-family: var(--vlr-disp); font-size: 32px; color: var(--vlr-green);
  letter-spacing: 1px; margin-bottom: 20px;
}
.woocommerce-order-overview {
  display: flex; gap: 24px; list-style: none; flex-wrap: wrap;
  background: var(--vlr-grey); border: 1px solid var(--vlr-border);
  border-radius: var(--vlr-r12); padding: 20px 24px; margin-bottom: 28px;
}
.woocommerce-order-overview li { font-family: var(--vlr-mono); font-size: 11px; color: var(--vlr-fog); letter-spacing: 0.5px; }
.woocommerce-order-overview li strong { display: block; font-size: 15px; color: var(--vlr-snow); margin-top: 4px; }

/* ─── STRIPE ELEMENTS ──────────────────────────────────────── */
.StripeElement {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r8) !important;
  padding: 14px 16px !important;
}
.StripeElement--focus { border-color: var(--vlr-pink) !important; }
.StripeElement--invalid { border-color: #ef4444 !important; }

/* ─── SELECT2 OVERRIDES ────────────────────────────────────── */
.select2-container .select2-selection--single {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r8) !important;
  height: 48px !important; 
  padding: 11px 16px !important;
  display: flex !important;
  align-items: center !important;
  box-sizing: border-box !important;
}
.select2-container .select2-selection--single .select2-selection__rendered {
  color: var(--vlr-snow) !important; 
  font-family: var(--vlr-body) !important; 
  font-size: 13.5px !important; 
  padding: 0 !important;
  line-height: 1.2 !important;
}
.select2-container .select2-selection--single .select2-selection__arrow { 
  top: 50% !important; 
  transform: translateY(-50%) !important;
  right: 14px !important; 
}
.select2-dropdown { 
  background: var(--vlr-grey2) !important; 
  border: 1px solid var(--vlr-border2) !important; 
  border-radius: var(--vlr-r8) !important; 
}
.select2-results__option { 
  font-family: var(--vlr-body) !important; 
  font-size: 13px !important; 
  color: var(--vlr-mist) !important; 
  padding: 10px 16px !important; 
}
.select2-results__option--highlighted { 
  background: var(--vlr-pink) !important; 
  color: white !important; 
}
.select2-search--dropdown {
  padding: 8px 12px !important;
}
.select2-search--dropdown input { 
  background: var(--vlr-grey) !important; 
  border: 1px solid var(--vlr-border2) !important; 
  border-radius: var(--vlr-r4) !important;
  color: var(--vlr-snow) !important; 
  padding: 8px 12px !important;
}

/* ─── WOOCOMMERCE BLOCKS CHECKOUT & CART OVERRIDES ─────────── */
.wc-block-checkout,
.wc-block-cart {
  color: var(--vlr-snow) !important;
  font-family: var(--vlr-body) !important;
}

/* Static Label Layout for WooCommerce Blocks Form Fields to prevent cramped overlaps */
.wc-block-components-text-input,
.wc-blocks-components-text-input,
.wc-block-components-combobox,
.wc-blocks-components-combobox,
.wc-block-components-textarea,
.wc-blocks-components-textarea,
.wc-block-components-select,
.wc-blocks-components-select {
  display: flex !important;
  flex-direction: column-reverse !important;
  position: relative !important;
  margin-bottom: 22px !important;
}

.wc-block-components-text-input input,
.wc-blocks-components-text-input input,
.wc-block-components-text-input__input,
.wc-blocks-components-text-input__input,
.wc-block-components-combobox input,
.wc-blocks-components-combobox input,
.wc-block-components-textarea textarea,
.wc-blocks-components-textarea textarea,
.wc-block-components-select select,
.wc-blocks-components-select select,
.wc-block-components-select__select,
.wc-blocks-components-select__select,
.wc-block-components-totals-coupon__input input,
.wc-blocks-components-totals-coupon__input input {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r8) !important;
  color: var(--vlr-snow) !important;
  padding: 12px 16px !important;
  font-family: var(--vlr-body) !important;
  font-size: 14px !important;
  height: 48px !important;
  outline: none !important;
  box-shadow: none !important;
  transition: all 0.2s ease !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

.wc-block-components-text-input label,
.wc-blocks-components-text-input label,
.wc-block-components-combobox label,
.wc-blocks-components-combobox label,
.wc-block-components-textarea label,
.wc-blocks-components-textarea label,
.wc-block-components-select label,
.wc-blocks-components-select label,
.wc-block-components-combobox-controls label,
.wc-blocks-components-combobox-controls label,
.wc-block-components-select-controls label,
.wc-blocks-components-select-controls label,
.wc-block-components-combobox .wc-block-components-combobox-controls label,
.wc-blocks-components-combobox .wc-blocks-components-combobox-controls label,
.wc-block-components-select .wc-block-components-select-controls label,
.wc-blocks-components-select .wc-blocks-components-select-controls label,
.wc-block-components-text-input.is-active label,
.wc-blocks-components-text-input.is-active label,
.wc-block-components-combobox.is-active label,
.wc-blocks-components-combobox.is-active label,
.wc-block-components-textarea.is-active label,
.wc-blocks-components-textarea.is-active label,
.wc-block-components-select.is-active label,
.wc-blocks-components-select.is-active label,
.wc-block-components-combobox.is-active .wc-block-components-combobox-controls label,
.wc-blocks-components-combobox.is-active .wc-blocks-components-combobox-controls label,
.wc-block-components-select.is-active .wc-block-components-select-controls label,
.wc-blocks-components-select.is-active .wc-blocks-components-select-controls label,
.wc-blocks-components-select__label,
.wc-blocks-components-select__label.is-active {
  position: static !important;
  display: block !important;
  font-family: var(--vlr-mono) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  color: var(--vlr-mist) !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  margin-bottom: 8px !important;
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  height: auto !important;
  width: auto !important;
}

/* Active and focus states for inputs and labels */
.wc-block-components-text-input input:focus,
.wc-blocks-components-text-input input:focus,
.wc-block-components-combobox input:focus,
.wc-blocks-components-combobox input:focus,
.wc-block-components-textarea textarea:focus,
.wc-blocks-components-textarea textarea:focus,
.wc-block-components-select select:focus,
.wc-blocks-components-select select:focus,
.wc-block-components-totals-coupon__input input:focus,
.wc-blocks-components-totals-coupon__input input:focus {
  border-color: var(--vlr-pink) !important;
  box-shadow: 0 0 10px rgba(255, 31, 143, 0.18) !important;
}

.wc-block-components-text-input:focus-within label,
.wc-blocks-components-text-input:focus-within label,
.wc-block-components-combobox:focus-within label,
.wc-blocks-components-combobox:focus-within label,
.wc-block-components-textarea:focus-within label,
.wc-blocks-components-textarea:focus-within label,
.wc-block-components-select:focus-within label,
.wc-blocks-components-select:focus-within label,
.wc-block-components-combobox-controls:focus-within label,
.wc-blocks-components-combobox-controls:focus-within label,
.wc-block-components-select-controls:focus-within label,
.wc-blocks-components-select-controls:focus-within label {
  color: var(--vlr-pink) !important;
}

/* Fix combobox/dropdown height alignment and layout */
.wc-block-components-combobox .wc-block-components-combobox-controls,
.wc-blocks-components-combobox .wc-blocks-components-combobox-controls,
.wc-block-components-select .wc-block-components-select-controls,
.wc-blocks-components-select .wc-blocks-components-select-controls,
.wc-block-components-combobox-controls,
.wc-blocks-components-combobox-controls,
.wc-block-components-select-controls,
.wc-blocks-components-select-controls {
  display: flex !important;
  flex-direction: column-reverse !important;
  position: relative !important;
  height: auto !important;
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
}

.wc-block-components-combobox .wc-block-components-combobox-controls input,
.wc-blocks-components-combobox .wc-blocks-components-combobox-controls input,
.wc-block-components-combobox-controls input,
.wc-blocks-components-combobox-controls input,
.wc-block-components-select-controls select,
.wc-blocks-components-select-controls select,
.wc-block-components-select-controls__select,
.wc-blocks-components-select-controls__select {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r8) !important;
  color: var(--vlr-snow) !important;
  padding: 12px 16px !important;
  height: 48px !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* Position dropdown chevron/arrow to bottom relative to input height */
.wc-block-components-combobox-controls > button,
.wc-blocks-components-combobox-controls > button,
.wc-block-components-combobox-controls__button,
.wc-blocks-components-combobox-controls__button,
.wc-block-components-select-controls::after,
.wc-blocks-components-select-controls::after,
.wc-block-components-select-controls .wc-block-components-select__arrow,
.wc-blocks-components-select-controls .wc-blocks-components-select__arrow,
.wc-block-components-select-controls .wc-block-components-select-controls__arrow,
.wc-blocks-components-select-controls .wc-blocks-components-select-controls__arrow {
  position: absolute !important;
  right: 14px !important;
  bottom: 14px !important;
  top: auto !important;
  transform: none !important;
  height: auto !important;
}

.wc-block-components-combobox .wc-block-components-combobox-controls input,
.wc-block-components-combobox-controls input,
.wc-block-components-select-controls select {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r8) !important;
  color: var(--vlr-snow) !important;
  padding: 12px 16px !important;
  height: 48px !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* Position dropdown chevron/arrow to bottom relative to input height */
.wc-block-components-combobox-controls > button,
.wc-block-components-combobox-controls__button,
.wc-block-components-select-controls::after,
.wc-block-components-select-controls .wc-block-components-select__arrow {
  position: absolute !important;
  right: 14px !important;
  bottom: 14px !important;
  top: auto !important;
  transform: none !important;
  height: auto !important;
}

/* Checkbox container gaps and label layouts */
.wc-block-components-checkbox {
  display: flex !important;
  align-items: center !important;
  margin-bottom: 12px !important;
}
.wc-block-components-checkbox input[type="checkbox"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r4) !important;
  width: 18px !important;
  height: 18px !important;
  margin-right: 12px !important;
  cursor: pointer !important;
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.wc-block-components-checkbox input[type="checkbox"]:checked {
  background: var(--vlr-pink) !important;
  border-color: var(--vlr-pink) !important;
}
.wc-block-components-checkbox input[type="checkbox"]:checked::after {
  content: "✓" !important;
  color: white !important;
  font-size: 11px !important;
  font-weight: bold !important;
}
.wc-block-components-checkbox label {
  font-family: var(--vlr-body) !important;
  font-size: 13.5px !important;
  color: var(--vlr-snow) !important;
  cursor: pointer !important;
  margin: 0 !important;
}

/* Coupon block (WC Blocks - BEM naming with __) */
.wc-block-components-totals-coupon__form {
  display: flex !important;
  gap: 8px !important;
  margin-top: 12px !important;
  width: 100% !important;
  align-items: flex-end !important;
}
.wc-block-components-totals-coupon__form .wc-block-components-totals-coupon__input {
  flex: 1 !important;
  margin-bottom: 0 !important;
}
.wc-block-components-totals-coupon__form .wc-block-components-totals-coupon__button {
  height: 48px !important;
  min-height: 48px !important;
  margin-bottom: 0 !important;
}

/* Premium Buttons Styling for WooCommerce Blocks */
.wc-block-cart__submit-button,
.wc-block-checkout__action-button,
.wc-block-components-checkout-step__submit-button,
.wc-block-components-totals-coupon__button,
.wc-block-components-button {
  background: var(--vlr-pink) !important;
  color: white !important;
  border-radius: var(--vlr-r8) !important;
  font-family: var(--vlr-body) !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
  padding: 12px 24px !important;
  border: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-transform: uppercase !important;
  font-size: 13px !important;
  box-shadow: 0 4px 15px rgba(255, 31, 143, 0.2) !important;
}

.wc-block-cart__submit-button:hover,
.wc-block-checkout__action-button:hover,
.wc-block-components-checkout-step__submit-button:hover,
.wc-block-components-totals-coupon__button:hover,
.wc-block-components-button:hover {
  background: var(--vlr-pink2) !important;
  box-shadow: 0 4px 20px rgba(255, 31, 143, 0.4) !important;
  transform: translateY(-1px) !important;
}

.wc-block-cart__submit-button:disabled,
.wc-block-checkout__action-button:disabled,
.wc-block-components-checkout-step__submit-button:disabled,
.wc-block-components-totals-coupon__button:disabled,
.wc-block-components-button:disabled {
  background: var(--vlr-grey2) !important;
  color: var(--vlr-fog) !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: not-allowed !important;
  opacity: 0.6 !important;
}

/* Payment Methods and Express Checkout Container */
.wc-block-checkout__payment-method,
.wc-block-components-express-payment {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-radius: var(--vlr-r8) !important;
  padding: 16px !important;
  margin-bottom: 12px !important;
  color: var(--vlr-snow) !important;
}

/* Order Summary & Sidebar styling */
.wc-block-checkout__sidebar,
.wc-block-cart__sidebar,
.wc-block-components-sidebar {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border) !important;
  border-radius: var(--vlr-r12) !important;
  padding: 24px !important;
  color: var(--vlr-snow) !important;
}

/* Totals lines */
.wc-block-components-totals-item,
.wc-block-components-totals-shipping,
.wc-block-components-totals-discount,
.wc-block-components-totals-coupon,
.wc-block-components-totals-taxes,
.wc-block-components-totals-footer {
  border-color: var(--vlr-border) !important;
  color: var(--vlr-snow) !important;
  padding: 8px 0 !important;
}
.wc-block-components-totals-item__label,
.wc-block-components-totals-shipping__label,
.wc-block-components-totals-discount__label,
.wc-block-components-totals-taxes__label {
  font-family: var(--vlr-mono) !important;
  font-size: 11px !important;
  color: var(--vlr-mist) !important;
}
.wc-block-components-totals-item__value,
.wc-block-components-totals-shipping__value,
.wc-block-components-totals-discount__value,
.wc-block-components-totals-taxes__value {
  font-family: var(--vlr-mono) !important;
  font-size: 12px !important;
  color: var(--vlr-snow) !important;
}
.wc-block-components-totals-footer {
  border-top: 1px solid var(--vlr-border) !important;
  padding-top: 12px !important;
  margin-top: 12px !important;
}
.wc-block-components-totals-footer__label {
  font-family: var(--vlr-mono) !important;
  font-size: 13px !important;
  color: var(--vlr-snow) !important;
}
.wc-block-components-totals-footer__value {
  font-family: var(--vlr-mono) !important;
  font-size: 18px !important;
  color: var(--vlr-pink2) !important;
  font-weight: 700 !important;
}

/* Order Summary Items */
.wc-block-components-order-summary-item {
  border-color: var(--vlr-border) !important;
  padding: 12px 0 !important;
}
.wc-block-components-order-summary-item__title {
  font-family: var(--vlr-disp) !important;
  font-size: 16px !important;
  color: var(--vlr-snow) !important;
}
.wc-block-components-order-summary-item__description {
  font-family: var(--vlr-body) !important;
  font-size: 12px !important;
  color: var(--vlr-mist) !important;
}

/* Fix order summary quantity badge visibility */
.wc-block-components-order-summary-item__quantity {
  background: var(--vlr-pink) !important;
  border-radius: 50% !important;
  width: 20px !important;
  height: 20px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid var(--vlr-black) !important;
}
.wc-block-components-order-summary-item__quantity,
.wc-block-components-order-summary-item__quantity * {
  color: white !important;
  font-family: var(--vlr-mono) !important;
  font-size: 9.5px !important;
  font-weight: 700 !important;
}

/* Cart Page Block Items & Table Styling */
.wc-block-cart-items,
.wc-block-cart-items__header,
.wc-block-cart-item {
  border-color: var(--vlr-border) !important;
  background: transparent !important;
}
.wc-block-cart-items__header th,
.wc-block-cart-items__header span {
  font-family: var(--vlr-mono) !important;
  font-size: 9.5px !important;
  color: var(--vlr-fog) !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid var(--vlr-border) !important;
  padding-bottom: 12px !important;
}
.wc-block-cart-item__wrap {
  padding: 20px 0 !important;
  border-bottom: 1px solid var(--vlr-border) !important;
}
.wc-block-cart-item__image img {
  border-radius: var(--vlr-r8) !important;
  border: 1px solid var(--vlr-border2) !important;
}
.wc-block-cart-item__title {
  font-family: var(--vlr-disp) !important;
  font-size: 18px !important;
  letter-spacing: 0.3px !important;
  color: var(--vlr-snow) !important;
}
.wc-block-cart-item__title:hover {
  color: var(--vlr-pink2) !important;
}
.wc-block-cart-item__price {
  font-family: var(--vlr-mono) !important;
  font-size: 15px !important;
  color: var(--vlr-snow) !important;
}
.wc-block-cart-item__total {
  font-family: var(--vlr-mono) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--vlr-pink2) !important;
}
.wc-block-cart-item__remove-link {
  color: var(--vlr-fog) !important;
  font-size: 12px !important;
  font-family: var(--vlr-mono) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
}
.wc-block-cart-item__remove-link:hover {
  color: var(--vlr-pink) !important;
  text-shadow: 0 0 8px var(--vlr-pglow) !important;
}

/* Cart Block Quantity Selector overrides to match theme */
.wc-block-components-quantity-selector {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border) !important;
  border-radius: var(--vlr-r8) !important;
  padding: 3px !important;
  display: inline-flex !important;
  align-items: center !important;
  height: 40px !important;
  box-sizing: border-box !important;
}
.wc-block-components-quantity-selector__button {
  background: none !important;
  border: none !important;
  color: var(--vlr-snow) !important;
  font-size: 16px !important;
  width: 30px !important;
  height: 30px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: color 0.15s !important;
}
.wc-block-components-quantity-selector__button:hover {
  color: var(--vlr-pink2) !important;
}
.wc-block-components-quantity-selector__input {
  background: none !important;
  border: none !important;
  font-family: var(--vlr-mono) !important;
  font-size: 14px !important;
  color: var(--vlr-snow) !important;
  text-align: center !important;
  width: 36px !important;
  padding: 0 !important;
  outline: none !important;
}

/* Notice Banner */
.wc-block-components-notice-banner {
  background: var(--vlr-grey) !important;
  border: 1px solid var(--vlr-border2) !important;
  border-left: 3px solid var(--vlr-pink) !important;
  border-radius: var(--vlr-r8) !important;
  color: var(--vlr-snow) !important;
}

/* Responsive Checkout Form Fields and Layout fixes */
@media (max-width: 768px) {
  .woocommerce-billing-fields__field-wrapper,
  .woocommerce-shipping-fields__field-wrapper,
  .woocommerce-additional-fields__field-wrapper {
    grid-template-columns: 1fr !important;
  }
  .woocommerce-checkout .form-row {
    grid-column: span 1 !important;
  }
  .vlr-field-row {
    grid-template-columns: 1fr !important;
  }
}

/* Checkout Form Layout Grid Overrides */
form.checkout.vlr-checkout-form {
  display: block !important;
}

/* Fields inside .vlr-field-row must span 1 col, not 2 */
.vlr-field-row .form-row,
.vlr-field-row p.form-row {
  grid-column: span 1 !important;
  margin: 0 !important;
}

/* Ensure checkout container has breathing room below site header */
.vlr-checkout-wrap {
  padding-top: 32px;
  padding-bottom: 80px;
}

/* Hide secondary logo inside checkout head — main header already shows it */
.vlr-checkout-head .vlr-logo {
  display: none;
}
.vlr-checkout-head {
  justify-content: flex-end;
  padding-top: 0;
  margin-bottom: 32px;
}

/* Cart page hero matches shop hero */
.woocommerce-cart .vlr-shop-hero {
  padding: 40px 0 !important;
}

