:root {
  --green: #1f3a2e;
  --charcoal: #1f2a22;
  --gold: #b59a6a;
  --beige: #f5f1e8;
  --sage: #e8efe8;
  --line: #e7e7e2;
  --white: #ffffff;
  --offwhite: #fbfbfa;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Manrope", sans-serif;
  color: var(--charcoal);
  background: var(--white);
}
body.overlay-open { overflow: hidden; }
.container { width: min(1240px, 92%); margin: 0 auto; }
a { color: inherit; }

.top-announcement {
  background: var(--green);
  color: #fff;
  font-size: .82rem;
  text-align: center;
  padding: .45rem 0;
}
.top-announcement a { color: #fff; text-decoration: underline; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: #ffffffee;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.header-inner {
  min-height: 84px;
  display: grid;
  grid-template-columns: 1.2fr auto 1fr;
  align-items: center;
  gap: 18px;
}
.brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  line-height: 1;
}
.brand img {
  display: block;
  width: auto;
  height: 58px;
  max-width: 190px;
  object-fit: contain;
}
.main-nav ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 1.2rem; align-items: center; }
.main-nav a { text-decoration: none; font-size: .9rem; color: #203126; }
.main-nav li { position: relative; }
.sub-menu {
  position: absolute;
  left: 0;
  top: 100%;
  background: #fff;
  border: 1px solid var(--line);
  min-width: 210px;
  padding: .55rem;
  display: none;
}
.menu-item-has-children:hover .sub-menu { display: block; }
.sub-menu li { margin: .3rem 0; }
.mega-menu { display: none; grid-template-columns: 1fr 1fr 1fr; gap: 1rem; min-width: 640px; }
.mega-menu a { display: block; margin: .35rem 0; }
.mega-promo { border: 1px solid var(--line); border-radius: 6px; padding: .6rem; background: var(--offwhite); }
.menu-item-has-children:hover .mega-menu { display: grid; }
.header-actions { justify-self: end; display: flex; gap: .7rem; align-items: center; }
.icon-btn {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 999px;
  padding: .5rem .85rem;
  text-decoration: none;
  font-size: .85rem;
}
.search-toggle { font-size: 1rem; line-height: 1; }
.cart-link { position: relative; padding-right: 2.3rem; }
.cart-count {
  position: absolute;
  right: .45rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.3rem;
  height: 1.3rem;
  border-radius: 50%;
  background: var(--green);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: .72rem;
}
.cart-count.is-success-pop {
  animation: cartPop .7s cubic-bezier(.2, .9, .22, 1.35);
}
.menu-toggle { display: none; }
.overlay-close {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 50%;
  width: 2.2rem;
  height: 2.2rem;
  cursor: pointer;
}

.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 30, 24, .55);
  backdrop-filter: blur(4px);
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transition: .2s ease;
}
.search-overlay.open { opacity: 1; visibility: visible; }
.search-overlay-inner {
  background: #fff;
  width: min(850px, 94%);
  margin: 8vh auto 0;
  border-radius: 10px;
  padding: 1.4rem;
  border: 1px solid var(--line);
}
.overlay-label { margin: .7rem 0 .9rem; color: #4f5d53; }
.premium-search-form { display: grid; grid-template-columns: 1fr auto; gap: .6rem; }
.premium-search-form .search-field {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: .9rem;
  font-size: 1rem;
}
.premium-search-form .search-submit {
  border: 1px solid var(--green);
  border-radius: 6px;
  background: var(--green);
  color: #fff;
  padding: .85rem 1rem;
}
.overlay-suggest { margin-top: 1rem; display: flex; flex-wrap: wrap; gap: .55rem; }
.overlay-suggest a {
  text-decoration: none;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: .45rem .8rem;
  font-size: .85rem;
}

.mini-cart-drawer {
  position: fixed;
  inset: 0;
  z-index: 110;
  background: rgba(20, 30, 24, .35);
  opacity: 0;
  visibility: hidden;
  transition: .2s ease;
}
.mini-cart-drawer.open { opacity: 1; visibility: visible; }
.mini-cart-panel {
  margin-left: auto;
  width: min(460px, 95%);
  height: 100%;
  background: #fff;
  border-left: 1px solid var(--line);
  display: flex;
  flex-direction: column;
}
.mini-cart-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .95rem 1rem;
  border-bottom: 1px solid var(--line);
}
.mini-cart-body { padding: .95rem 1rem; overflow: auto; }
.mini-cart-body.is-processing {
  position: relative;
}
.mini-cart-body.is-processing::after {
  content: "Updating cart...";
  position: sticky;
  top: .5rem;
  z-index: 3;
  display: grid;
  place-items: center;
  min-height: 42px;
  margin-bottom: .65rem;
  border: 1px solid #d9e8da;
  border-radius: 999px;
  background: rgba(246,250,246,.96);
  color: var(--green);
  font-weight: 800;
  box-shadow: 0 10px 22px rgba(31,58,46,.08);
}
.mini-cart-items { list-style: none; margin: 0; padding: 0; display: grid; gap: .8rem; }
.mini-item { display: grid; grid-template-columns: 76px 1fr; gap: .7rem; padding-bottom: .75rem; border-bottom: 1px solid var(--line); }
.mini-item-thumb img { width: 76px; height: 76px; object-fit: cover; border-radius: 6px; }
.mini-item-meta h4 { margin: .15rem 0 .25rem; font-size: .92rem; }
.mini-item-meta p { margin: 0 0 .45rem; font-size: .85rem; color: #55645a; }
.mini-item-meta .mini-volume {
  display: inline-flex;
  width: fit-content;
  padding: .18rem .45rem;
  border-radius: 999px;
  background: #edf4ee;
  color: var(--green);
  font-weight: 700;
}
.mini-item-actions { display: flex; align-items: center; gap: .45rem; flex-wrap: wrap; }
.mini-qty-btn, .mini-remove {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 4px;
  cursor: pointer;
}
.mini-qty-btn { width: 1.6rem; height: 1.6rem; }
.mini-remove { padding: .25rem .5rem; font-size: .75rem; }
.mini-qty { min-width: 1.2rem; text-align: center; }
.mini-cart-foot { margin-top: .95rem; }
.mini-foot-actions { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.mini-btn {
  display: block;
  text-decoration: none;
  text-align: center;
  border: 1px solid var(--green);
  background: var(--green);
  color: #fff;
  border-radius: 6px;
  padding: .65rem .8rem;
  line-height: 1.2;
  white-space: normal;
}
.mini-btn-light { background: #fff; color: var(--green); }
.mini-empty { color: #566458; }

h1, h2, h3, h4 { font-family: "Playfair Display", serif; }
.hero { padding: 4.5rem 0; background: var(--offwhite); border-bottom: 1px solid var(--line); }
.hero-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 2rem; align-items: center; }
.eyebrow { letter-spacing: .1em; text-transform: uppercase; color: #3e5e4f; font-size: .74rem; font-weight: 700; }
.hero h1 { font-size: clamp(2rem, 4.6vw, 3.4rem); margin: .6rem 0 1rem; }
.hero p { line-height: 1.7; color: #4f5d53; max-width: 60ch; }
.btn {
  display: inline-block;
  text-decoration: none;
  background: var(--green);
  color: #fff;
  padding: .92rem 1.4rem;
  border-radius: 6px;
  border: 1px solid var(--green);
  transition: background .25s ease, color .25s ease;
}
.btn:hover { background: transparent; color: var(--green); }
.button,
.btn,
.mini-btn,
.single_add_to_cart_button,
.add_to_cart_button,
.product-view-cart,
.sticky-atc-btn,
.qv-add,
#bundle-add-btn {
  position: relative;
  overflow: hidden;
}

.button.is-processing,
.btn.is-processing,
.mini-btn.is-processing,
.single_add_to_cart_button.is-processing,
.single_add_to_cart_button.loading,
.add_to_cart_button.is-processing,
.add_to_cart_button.loading,
.qv-add.is-processing,
#bundle-add-btn.is-processing,
.mini-qty-btn.is-processing,
.mini-remove.is-processing {
  pointer-events: none;
  opacity: .96;
  padding-right: 2.8rem !important;
}

.button.is-processing::after,
.btn.is-processing::after,
.mini-btn.is-processing::after,
.single_add_to_cart_button.is-processing::after,
.single_add_to_cart_button.loading::after,
.add_to_cart_button.is-processing::after,
.add_to_cart_button.loading::after,
.qv-add.is-processing::after,
#bundle-add-btn.is-processing::after,
.mini-qty-btn.is-processing::after,
.mini-remove.is-processing::after {
  content: "";
  position: absolute;
  right: .95rem;
  top: 50%;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  border: 2px solid rgba(255,255,255,.45);
  border-top-color: #fff;
  border-radius: 50%;
  animation: breuverraSpin .7s linear infinite;
}

.mini-qty-btn.is-processing,
.mini-remove.is-processing {
  color: transparent !important;
  padding-right: 0 !important;
}

.mini-qty-btn.is-processing::after,
.mini-remove.is-processing::after {
  right: 50%;
  margin-right: -8px;
  border-color: rgba(31,58,46,.28);
  border-top-color: var(--green);
}

.product-view-cart.added {
  animation: addedPulse .65s ease both;
}

@keyframes breuverraSpin {
  to { transform: rotate(360deg); }
}

@keyframes addedPulse {
  0% { transform: scale(.98); }
  45% { transform: scale(1.025); }
  100% { transform: scale(1); }
}

@keyframes cartPop {
  0% { transform: translateY(-50%) scale(1); }
  35% { transform: translateY(-50%) scale(1.3); box-shadow: 0 0 0 8px rgba(31,58,46,.14); }
  100% { transform: translateY(-50%) scale(1); box-shadow: 0 0 0 0 rgba(31,58,46,0); }
}
.hero-card {
  border: 1px solid var(--line);
  background: linear-gradient(140deg, #fff, #f5f3ec);
  border-radius: 0 0 8px 8px;
  padding: 2.2rem;
  line-height: 1.7;
}

.category-scroll, .product-band, .dual-collections, .promise, .testimonials { padding: 3.8rem 0; }
.category-row {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(180px, 1fr);
  gap: .95rem;
  overflow-x: auto;
  padding-bottom: .5rem;
}
.category-chip {
  border: 1px solid var(--line);
  border-radius: 8px;
  text-decoration: none;
  color: var(--charcoal);
  padding: .9rem;
  background: #fff;
}
.category-card {
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(31,58,46,.08);
  overflow: hidden;
  padding: .7rem;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.category-card:hover {
  border-color: rgba(31,58,46,.26);
  box-shadow: 0 18px 40px rgba(31,58,46,.14);
  transform: translateY(-4px);
}
.cat-thumb {
  display: block;
  width: 100%;
  height: 150px;
  background: linear-gradient(160deg, var(--sage), var(--beige));
  border-radius: 14px;
  margin-bottom: .7rem;
  overflow: hidden;
}
.cat-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform .35s ease;
}
.category-card:hover .cat-thumb img {
  transform: scale(1.06);
}
.cat-name {
  color: var(--green);
  display: block;
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.2;
  margin: .75rem .25rem .25rem;
}
.category-card small {
  color: #66746b;
  display: block;
  font-size: .84rem;
  line-height: 1.35;
  margin: 0 .25rem .3rem;
}
.section-head { margin-bottom: 1rem; }

.product-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.product-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
  transition: transform .2s ease, box-shadow .2s ease;
}
.product-card:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(28,37,30,.08); }
.product-image { position: relative; display: block; aspect-ratio: 1/1; background: var(--offwhite); }
.product-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease, opacity .3s ease; }
.product-card:hover .product-image img { transform: scale(1.04); opacity: .96; }
.quick-cta {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  background: var(--green);
  color: #fff;
  border-radius: 6px;
  text-align: center;
  padding: .6rem;
  font-weight: 700;
  z-index: 3;
  opacity: 0;
  transform: translateY(6px);
  transition: .22s ease;
}
.product-card:hover .quick-cta { opacity: 1; transform: translateY(0); }
.sale-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--gold);
  color: #fff;
  font-size: .7rem;
  border-radius: 4px;
  padding: .23rem .45rem;
  z-index: 2;
}
.product-card h3 { font-size: 1rem; margin: .8rem .8rem .45rem; }
.product-card h3 a { text-decoration: none; }
.rating, .price-line { margin: 0 .8rem .7rem; font-size: .86rem; }
.rating { color: #6b746d; }
.price-line ins { text-decoration: none; color: var(--green); font-weight: 700; margin-right: .5rem; }
.price-line del { color: #8e8e8e; }
.product-thumb-fallback { width: 100%; height: 100%; background: linear-gradient(170deg, var(--beige), #fff); }
.collection-block + .collection-block { margin-top: 2.4rem; }

.promise { background: var(--offwhite); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.promise-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1rem; }
.promise-grid div { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 1rem; text-align: center; font-weight: 600; }

.testimonial-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; }
.testimonial-grid blockquote { margin: 0; border: 1px solid var(--line); border-radius: 8px; padding: 1.1rem; background: #fff; line-height: 1.65; }
.testimonial-grid cite { display: block; margin-top: .7rem; font-style: normal; color: #4f5e53; }

.site-footer { background: var(--green); border-top: 1px solid rgba(255,255,255,.12); color: #f7fbf7; margin-top: 1.5rem; }
.footer-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 1.1rem; padding: 1.55rem 0 1.25rem; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin: .45rem 0; }
.site-footer a { text-decoration: none; color: #f7fbf7; }
.site-footer p { color: #dce9df; }
.site-footer h3,
.site-footer h4 {
  margin-top: 0;
}
.site-footer p:last-child {
  margin-bottom: 0;
}
.footer-payment-grid {
  display: grid;
  gap: .55rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: .75rem;
}
.payment-chip {
  align-items: center;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 12px;
  box-shadow: 0 12px 26px rgba(0,0,0,.12);
  color: var(--green);
  display: inline-flex;
  gap: .32rem;
  justify-content: center;
  min-height: 42px;
  padding: .45rem .55rem;
}
.payment-chip em {
  font-style: normal;
  font-weight: 900;
  letter-spacing: .02em;
  line-height: 1;
}
.payment-visa em {
  color: #1a4da1;
  font-style: italic;
}
.payment-mastercard {
  position: relative;
}
.payment-mastercard i {
  border-radius: 999px;
  display: inline-block;
  height: 18px;
  margin-right: -8px;
  width: 18px;
}
.payment-mastercard i:first-child { background: #eb001b; }
.payment-mastercard i:nth-child(2) { background: #f79e1b; margin-right: .18rem; }
.payment-mastercard em {
  color: #2b2b2b;
  font-size: .78rem;
}
.payment-upi em {
  color: #168a42;
}
.payment-upi::before {
  color: #f58220;
  content: "◢";
  font-size: 1rem;
  line-height: 1;
}
.payment-paypal em {
  color: #003087;
}
.payment-paypal::before {
  color: #009cde;
  content: "P";
  font-size: 1.05rem;
  font-weight: 900;
}
.payment-note {
  font-size: .88rem;
  line-height: 1.5;
  margin-top: .55rem;
}
.newsletter-form { display: flex; gap: .55rem; }
.newsletter-form input {
  flex: 1;
  padding: .7rem;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 6px;
}
.newsletter-form button {
  border: 1px solid #f7fbf7;
  background: #f7fbf7;
  color: var(--green);
  border-radius: 6px;
  padding: .7rem .95rem;
}
.footer-bottom {
  align-items: center;
  border-top: 1px solid rgba(255,255,255,.16);
  display: flex;
  font-size: .82rem;
  justify-content: center;
  min-height: 34px;
  padding: .32rem 0;
}

.footer-bottom p {
  margin: 0;
}

.bv-info-page {
  background:
    radial-gradient(circle at top right, rgba(189, 158, 79, .13), transparent 30%),
    linear-gradient(180deg, #fff, #f7fbf7);
  border: 1px solid rgba(31, 58, 46, .12);
  border-radius: 28px;
  box-shadow: 0 24px 70px rgba(31, 58, 46, .08);
  margin-top: 1.2rem;
  padding: clamp(1.4rem, 3vw, 3rem);
}

.bv-info-page > h2 {
  color: var(--green);
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .98;
  margin: .25rem 0 1rem;
  max-width: 980px;
}

.bv-info-page > p {
  color: #54645a;
  font-size: 1.05rem;
  line-height: 1.8;
  max-width: 860px;
}

.bv-info-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 2rem 0;
}

.bv-info-grid article,
.bv-policy-list section,
.bv-steps,
.bv-callout {
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(31, 58, 46, .12);
  border-radius: 20px;
  box-shadow: 0 16px 40px rgba(31, 58, 46, .06);
  padding: 1.2rem;
}

.bv-info-grid span {
  align-items: center;
  background: var(--green);
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: .8rem;
  font-weight: 900;
  height: 34px;
  justify-content: center;
  margin-bottom: .9rem;
  width: 34px;
}

.bv-info-grid h3,
.bv-policy-list h3,
.bv-steps h3 {
  color: var(--green);
  margin: 0 0 .55rem;
}

.bv-info-grid p,
.bv-policy-list p,
.bv-steps li,
.bv-callout p {
  color: #5a695f;
  line-height: 1.65;
}

.bv-policy-list {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 2rem;
}

.bv-steps {
  margin-bottom: 1rem;
}

.bv-steps ol {
  margin: .4rem 0 0 1.15rem;
  padding: 0;
}

.bv-callout {
  align-items: center;
  background: linear-gradient(135deg, var(--green), #2d624c);
  color: #fff;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  margin-top: 1rem;
}

.bv-callout strong {
  display: block;
  font-size: 1.18rem;
}

.bv-callout p {
  color: rgba(255,255,255,.82);
  margin: .25rem 0 0;
}

.bv-callout .btn {
  background: #fff;
  border-color: #fff;
  color: var(--green);
  flex: 0 0 auto;
}

.bv-updated {
  border-top: 1px solid rgba(31, 58, 46, .12);
  font-size: .9rem !important;
  margin-top: 1.5rem;
  padding-top: 1rem;
}

/* WooCommerce product page UX */
.single-product .product { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.single-product .woocommerce-product-gallery { border: 1px solid var(--line); border-radius: 8px; padding: .7rem; }
.single-product .summary { border: 1px solid var(--line); border-radius: 8px; padding: 1rem 1.1rem; }
.single-product .summary .product_title { font-size: 2rem; letter-spacing: .01em; }
.woocommerce div.product form.cart .button { width: 100%; background: var(--green); border-radius: 6px; }

.single-product .breuverra-quantity {
  display: grid;
  gap: .5rem;
  float: none !important;
  margin: 1rem 0 1.1rem !important;
  width: 100%;
}

.single-product .breuverra-quantity-label {
  color: var(--green);
  display: block;
  font-weight: 800;
  letter-spacing: .01em;
  line-height: 1.2;
}

.single-product .breuverra-quantity-control {
  align-items: center;
  background: #f7faf6;
  border: 1px solid #dfe9df;
  border-radius: 999px;
  display: grid;
  grid-template-columns: 44px minmax(56px, 1fr) 44px;
  max-width: 190px;
  padding: .28rem;
}

.single-product .breuverra-qty-btn {
  align-items: center;
  appearance: none;
  background: #fff;
  border: 1px solid rgba(31, 58, 46, .14);
  border-radius: 999px;
  color: var(--green);
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 1.05rem;
  font-weight: 900;
  height: 38px;
  justify-content: center;
  line-height: 1;
  transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
  width: 38px;
}

.single-product .breuverra-qty-btn:hover {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
  transform: translateY(-1px);
}

.woocommerce .single-product .breuverra-quantity .qty,
.single-product .breuverra-quantity .qty {
  appearance: textfield;
  background: transparent;
  border: 0 !important;
  border-radius: 0;
  color: var(--green);
  font-size: 1rem;
  font-weight: 900;
  height: 38px;
  padding: 0 .35rem !important;
  text-align: center;
  width: 100%;
}

.single-product .breuverra-quantity .qty::-webkit-outer-spin-button,
.single-product .breuverra-quantity .qty::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}

.single-product form.cart:not(.variations_form) {
  display: grid;
  gap: .7rem;
}

.single-product form.cart:not(.variations_form) .single_add_to_cart_button {
  margin-top: 0 !important;
}

.single-product form.variations_form .woocommerce-variation-add-to-cart {
  align-items: end;
  display: grid;
  gap: .7rem;
}

.size-selector {
  display: block !important;
  margin: 1rem 0 1.1rem;
  padding: .85rem;
  border: 1px solid #dfe9df;
  border-radius: 8px;
  background: #f7faf6;
}
.size-selector strong {
  display: block;
  margin-bottom: .55rem;
  color: var(--green);
}
.size-selector .size-options { display: flex; gap: .5rem; margin-top: .4rem; flex-wrap: wrap; }
.size-selector button {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 999px;
  padding: .55rem .9rem;
  cursor: pointer;
  color: var(--green);
  font-weight: 700;
}
.size-selector button.active { border-color: var(--green); background: var(--green); color: #fff; }

.variation-size-selector .size-options {
  gap: .65rem;
}

.variation-size-selector .variation-size-option {
  min-width: 86px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .12rem;
  line-height: 1.1;
}

.variation-size-selector .variation-size-option small {
  color: inherit;
  font-size: .72rem;
  font-weight: 700;
  opacity: .76;
}

.variation-size-selector .variation-size-option small .amount {
  color: inherit;
}

.single-product form.variations_form table.variations {
  height: 0;
  margin: 0 !important;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  position: absolute;
  width: 1px;
}

.single-product form.variations_form .reset_variations {
  display: none !important;
}

.custom-accordions { margin-top: 1.3rem; border-top: 1px solid var(--line); }
.custom-acc-item { border-bottom: 1px solid var(--line); }
.custom-acc-trigger {
  width: 100%;
  text-align: left;
  padding: .95rem 0;
  border: 0;
  background: transparent;
  font-weight: 600;
  cursor: pointer;
}
.custom-acc-body { display: none; padding-bottom: .9rem; color: #4f5d53; line-height: 1.7; }
.custom-acc-item.open .custom-acc-body { display: block; }
.woocommerce-tabs { display: none; }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: .75rem;
  background: #fff;
}
.woocommerce ul.products li.product .button { border-radius: 6px; background: var(--green); }

.reveal { opacity: 0; transform: translateY(16px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in-view { opacity: 1; transform: none; }
.woocommerce .shop-layout.reveal,
.post-type-archive-product .shop-layout.reveal,
.tax-product_cat .shop-layout.reveal {
  opacity: 1;
  transform: none;
}

@media (max-width: 1100px) {
  .header-inner { grid-template-columns: auto auto 1fr; }
  .main-nav { display: none; position: absolute; left: 0; right: 0; top: 100%; background: #fff; border-bottom: 1px solid var(--line); }
  .main-nav.open { display: block; }
  .main-nav ul { flex-direction: column; align-items: flex-start; padding: 1rem; }
  .menu-toggle { display: inline-block; border: 1px solid var(--line); background: #fff; border-radius: 6px; padding: .55rem .75rem; }
  .brand { text-align: left; justify-self: start; }
  .header-actions { margin-left: auto; }
  .brand img { height: 48px; max-width: 160px; }
  .product-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .promise-grid, .testimonial-grid, .footer-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .single-product .product { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
  .hero-grid, .footer-bottom { grid-template-columns: 1fr; display: grid; gap: .8rem; }
  .product-grid, .promise-grid, .testimonial-grid, .footer-grid { grid-template-columns: 1fr; }
  .header-actions .icon-btn:nth-child(2) { display: none; }
  .brand img { height: 42px; max-width: 136px; }
  .premium-search-form { grid-template-columns: 1fr; }
}

.predictive-results { grid-column: 1 / -1; border: 1px solid var(--line); border-radius: 6px; background: #fff; }
.predictive-item { display: grid; grid-template-columns: 52px 1fr; gap: .6rem; padding: .55rem; text-decoration: none; border-top: 1px solid var(--line); }
.predictive-item:first-child { border-top: 0; }
.predictive-thumb img { width: 52px; height: 52px; object-fit: cover; border-radius: 4px; }
.predictive-item small { display: block; color: #5f6d63; margin-top: .2rem; }
.predictive-empty { margin: 0; padding: .65rem; color: #6a756e; }

.card-tools { display: flex; gap: .35rem; padding: .5rem .75rem 0; flex-wrap: wrap; }
.tool-btn { border: 1px solid var(--line); background: #fff; border-radius: 4px; font-size: .72rem; padding: .25rem .45rem; cursor: pointer; }
.tool-btn.active { border-color: var(--green); color: var(--green); }

.quick-view-modal, .compare-drawer {
  position: fixed;
  inset: 0;
  z-index: 120;
  background: rgba(20,30,24,.4);
  opacity: 0;
  visibility: hidden;
  transition: .2s ease;
}
.quick-view-modal.open, .compare-drawer.open { opacity: 1; visibility: visible; }
.quick-view-dialog {
  width: min(960px, 96%);
  margin: 6vh auto 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1rem;
}
.qv-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.qv-img img { width: 100%; height: auto; border-radius: 6px; border: 1px solid var(--line); }
.qv-price { color: var(--green); font-weight: 700; }
.compare-panel {
  margin-left: auto;
  width: min(420px, 95%);
  height: 100%;
  background: #fff;
  border-left: 1px solid var(--line);
  padding: .9rem;
}
.compare-item { border: 1px solid var(--line); border-radius: 6px; padding: .7rem; margin-bottom: .6rem; }

.bundle-builder, .content-hub, .recently-viewed-wrap { padding: 2.5rem 0; }
.bundle-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: .7rem; }
.bundle-item { border: 1px solid var(--line); border-radius: 6px; padding: .6rem; display: grid; gap: .25rem; background: #fff; }
.bundle-item small { color: #5f6c63; }
.hub-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: .8rem; }
.hub-grid article { border: 1px solid var(--line); border-radius: 8px; padding: .8rem; background: #fff; }
.recently-viewed-rail { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: .7rem; }
.recent-item { border: 1px solid var(--line); border-radius: 6px; padding: .7rem; text-decoration: none; background: #fff; }

.sticky-atc-mobile {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 85;
  background: #fff;
  border-top: 1px solid var(--line);
  padding: .55rem .75rem;
  display: none;
  align-items: center;
  justify-content: space-between;
}
.sticky-atc-mobile span { display: block; color: var(--green); font-weight: 700; }
.sticky-atc-btn { border: 1px solid var(--green); background: var(--green); color: #fff; border-radius: 6px; padding: .55rem .8rem; }

.checkout-trust { border: 1px solid var(--line); border-radius: 8px; padding: .8rem; margin-bottom: 1rem; }
.checkout-steps { display: flex; gap: .5rem; margin-bottom: .35rem; }
.checkout-steps span { border: 1px solid var(--line); border-radius: 999px; padding: .25rem .55rem; font-size: .8rem; }
.trust-badges { color: #4f5c54; font-size: .85rem; }

.ugc-gallery { padding-top: 1rem; }
.ugc-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: .7rem; }
.ugc-card { border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: .8rem; min-height: 120px; }

.thankyou-upsell { padding-top: 2rem; }
.personalized-reco { padding-top: 1rem; }
.wa-widget {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 140;
  align-items: center;
  display: flex;
  gap: .5rem;
}

.wa-float {
  align-items: center;
  border: 1px solid rgba(255,255,255,.38);
  box-shadow: 0 18px 40px rgba(14, 51, 32, .22);
  display: inline-flex;
  text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.wa-float {
  background: linear-gradient(135deg, #1fae62, #0d7f45);
  color: #fff;
  border-radius: 999px;
  gap: .58rem;
  min-height: 52px;
  padding: .46rem .82rem .46rem .52rem;
}

.wa-icon {
  align-items: center;
  background: rgba(255,255,255,.18);
  border-radius: 999px;
  display: inline-flex;
  height: 38px;
  justify-content: center;
  width: 38px;
}

.wa-icon svg {
  fill: #fff;
  height: 25px;
  width: 25px;
}

.wa-float strong,
.wa-float small {
  display: block;
  line-height: 1.05;
}

.wa-float strong {
  color: #fff;
  font-size: .95rem;
  font-weight: 900;
}

.wa-float small {
  color: rgba(255,255,255,.82);
  font-size: .68rem;
  font-weight: 700;
  margin-top: .15rem;
}

.wa-float:hover {
  box-shadow: 0 22px 48px rgba(14, 51, 32, .28);
  transform: translateY(-2px);
}

@media (max-width: 900px) {
  .qv-wrap, .bundle-grid, .hub-grid, .recently-viewed-rail, .ugc-grid { grid-template-columns: 1fr 1fr; }
  .bv-info-grid,
  .bv-policy-list {
    grid-template-columns: 1fr;
  }
  .bv-callout {
    align-items: flex-start;
    flex-direction: column;
  }
}
@media (max-width: 680px) {
  .qv-wrap, .bundle-grid, .hub-grid, .recently-viewed-rail, .ugc-grid { grid-template-columns: 1fr; }
  .sticky-atc-mobile { display: flex; }
  .wa-widget { right: 12px; bottom: 12px; }
}

/* Layout fix pass: single product + related/recommended + mini cart */
.single-product div.product div.images,
.single-product div.product div.summary {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin: 0;
  padding: 0;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  float: none !important;
  margin: 0 !important;
}

.woocommerce div.product .related ul.products,
.woocommerce div.product .upsells ul.products,
.personalized-reco ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

@media (max-width: 1100px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .woocommerce div.product .related ul.products,
  .woocommerce div.product .upsells ul.products,
  .personalized-reco ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .mini-foot-actions { grid-template-columns: 1fr; }

  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .woocommerce div.product .related ul.products,
  .woocommerce div.product .upsells ul.products,
  .personalized-reco ul.products {
    grid-template-columns: 1fr;
  }
}

/* Shop hotfix: button contrast + 4-up product row stability */
.woocommerce.archive ul.products,
.woocommerce-page.archive ul.products {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 1rem;
}

.woocommerce.archive ul.products li.product,
.woocommerce-page.archive ul.products li.product {
  flex: 0 0 calc(25% - 0.75rem) !important;
  max-width: calc(25% - 0.75rem) !important;
  width: calc(25% - 0.75rem) !important;
  margin: 0 !important;
  clear: none !important;
}

.woocommerce.archive ul.products li.product a.button,
.woocommerce-page.archive ul.products li.product a.button,
.woocommerce.archive ul.products li.product .button,
.woocommerce-page.archive ul.products li.product .button {
  color: #fff !important;
}

@media (max-width: 1100px) {
  .woocommerce.archive ul.products li.product,
  .woocommerce-page.archive ul.products li.product {
    flex: 0 0 calc(50% - 0.5rem) !important;
    max-width: calc(50% - 0.5rem) !important;
    width: calc(50% - 0.5rem) !important;
  }
}

@media (max-width: 680px) {
  .woocommerce.archive ul.products li.product,
  .woocommerce-page.archive ul.products li.product {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    width: 100% !important;
  }
}

/* Header layout corrections */
.header-inner {
  grid-template-columns: auto 1fr auto;
}
.brand {
  justify-self: start;
  text-align: left;
  white-space: nowrap;
}
.main-nav { min-width: 0; }
.main-nav ul {
  flex-wrap: nowrap;
  overflow-x: auto;
  white-space: nowrap;
  scrollbar-width: thin;
}
.main-nav li { flex: 0 0 auto; }

.nav-slider {
  border-bottom: 1px solid var(--line);
  background: #f4f7f2;
}
.nav-slide-track {
  position: relative;
  min-height: 40px;
  display: grid;
  align-items: center;
}
.nav-slide {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  opacity: 0;
  transition: opacity .35s ease;
  font-size: .86rem;
  color: #35453c;
}
.nav-slide.active { opacity: 1; }

/* Shop layout bug fixes */
.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product.last { clear: none !important; }

/* Product page button visibility */
.single-product .single_add_to_cart_button,
.single-product .single_add_to_cart_button:hover {
  color: #fff !important;
  background: var(--green) !important;
}

.woocommerce a.added_to_cart {
  margin-left: .7rem;
  padding-left: .6rem;
  color: var(--green);
  text-decoration: none;
  white-space: nowrap;
}
.woocommerce a.added_to_cart::before { margin-right: .3rem; }

/* Sorting + filter bar */
.shop-filters-bar {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-bottom: .9rem;
}
.shop-filters-bar select,
.shop-filters-bar button,
.woocommerce .woocommerce-ordering select {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  padding: .58rem .7rem;
  font-size: .9rem;
}
.shop-filters-bar button {
  border-color: var(--green);
  background: var(--green);
  color: #fff;
}

/* Theme account page */
.woocommerce-account .woocommerce button,
.woocommerce-account .woocommerce .button {
  background: var(--green) !important;
  color: #fff !important;
  border-radius: 6px;
}

.woocommerce-account .site-main > .container,
.woocommerce-account .site-main > section,
.woocommerce-account .woocommerce {
  width: min(1180px, 92vw);
  margin-inline: auto;
}

.woocommerce-account .woocommerce {
  margin-top: 2rem;
  margin-bottom: 3rem;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 1.2rem;
  align-items: start;
}

.woocommerce-account:not(.logged-in) .woocommerce {
  grid-template-columns: minmax(0, 1fr);
  max-width: 1040px;
  padding: 0;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(280px, .78fr);
  gap: 1.25rem;
  align-items: stretch;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
  float: none !important;
  width: auto !important;
  min-width: 0;
  clear: none !important;
  grid-row: 1 !important;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 {
  grid-column: 1 !important;
  position: relative;
  overflow: hidden;
  border: 1px solid #dfe9df;
  border-radius: 16px;
  background:
    radial-gradient(circle at 14% 12%, rgba(181,154,106,.16), transparent 32%),
    linear-gradient(145deg, #ffffff 0%, #f7faf6 100%);
  box-shadow: 0 20px 46px rgba(31,58,46,.08);
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1::before {
  content: "Pure Essence of Nature";
  display: block;
  padding: 1.35rem 1.5rem 0;
  color: var(--gold);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 h2 {
  margin: .35rem 1.5rem 0;
  color: var(--green);
  font-size: clamp(2rem, 4vw, 3rem);
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 form.login {
  margin: 0 !important;
  border: 0 !important;
  box-shadow: none;
  background: transparent;
  padding: 1.25rem 1.5rem 1.5rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
  grid-column: 2 !important;
  display: grid;
  align-content: center;
  border: 1px solid #dfe9df;
  border-radius: 16px;
  background: var(--green);
  color: #fff;
  padding: 1.5rem;
  box-shadow: 0 20px 46px rgba(31,58,46,.1);
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2 h2,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2 form.register {
  display: none !important;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2::before {
  content: "Secure account creation";
  display: block;
  font-family: "Playfair Display", serif;
  font-size: clamp(1.55rem, 3vw, 2.2rem);
  line-height: 1.12;
  margin-bottom: .7rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2::after {
  content: "Registration now uses email OTP verification. Use the OTP button on the login card to create a verified account.";
  display: block;
  color: rgba(255,255,255,.82);
  line-height: 1.65;
}

.woocommerce-account .woocommerce::before,
.woocommerce-account .woocommerce::after {
  content: none !important;
  display: none !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
  float: none !important;
  width: auto !important;
  border: 1px solid #dfe9df;
  border-radius: 16px;
  background:
    linear-gradient(180deg, #f7faf6, #fff),
    radial-gradient(circle at top left, rgba(181,154,106,.13), transparent 38%);
  padding: 1rem;
  position: sticky;
  top: 96px;
  box-shadow: 0 16px 34px rgba(31,58,46,.07);
}

.woocommerce-account .woocommerce-MyAccount-navigation::before {
  content: "Account";
  display: block;
  margin: .15rem .45rem .8rem;
  font-family: "Playfair Display", serif;
  color: var(--green);
  font-size: 1.45rem;
  font-weight: 700;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: .45rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 42px;
  padding: .65rem .8rem;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--green);
  text-decoration: none;
  font-weight: 700;
  transition: background .18s ease, border-color .18s ease, transform .18s ease;
}

.woocommerce-account .woocommerce-MyAccount-navigation a::after {
  content: "›";
  color: rgba(31,58,46,.55);
  font-size: 1.1rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation .is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
  border-color: #cfe0d0;
  background: #edf5ee;
  transform: translateX(2px);
}

.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce form {
  float: none !important;
  width: auto !important;
  border: 1px solid #dfe9df;
  border-radius: 16px;
  background: #fff;
  padding: 1.55rem;
  box-shadow: 0 14px 30px rgba(31,58,46,.06);
}

.woocommerce-account .woocommerce-MyAccount-content {
  min-width: 0;
}

.woocommerce-account .woocommerce-MyAccount-content > p:first-child {
  margin-top: 0;
  max-width: none;
  padding: 1.15rem 1.25rem;
  border: 1px solid #dfe9df;
  border-radius: 14px;
  background: linear-gradient(135deg, #f5f8f4, #fff);
  color: #44584c;
  line-height: 1.75;
}

.woocommerce-account .woocommerce-MyAccount-content a {
  color: var(--green);
  font-weight: 700;
}

.woocommerce-account .page-block > h1 {
  width: min(1180px, 92vw);
  margin: 2rem auto 1rem;
}

.woocommerce-account .woocommerce-MyAccount-content table {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.woocommerce-account .woocommerce-MyAccount-content table th {
  background: #f4f8f4;
  color: var(--green);
}

.woocommerce-account .woocommerce-MyAccount-content input,
.woocommerce-account .woocommerce-MyAccount-content select,
.woocommerce-account .woocommerce-MyAccount-content textarea,
.woocommerce-account .woocommerce form input,
.woocommerce-account .woocommerce form select,
.woocommerce-account .woocommerce form textarea {
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: .75rem .85rem;
}

.woocommerce-account .woocommerce form label {
  color: var(--green);
  font-weight: 800;
}

.woocommerce-account .woocommerce form .form-row {
  margin-bottom: 1rem;
}

.woocommerce-edit-account .woocommerce-EditAccountForm fieldset {
  display: none !important;
}

.breuverra-password-panel {
  display: grid;
  gap: .75rem;
}

.breuverra-password-panel h2 {
  margin: 0;
  color: var(--green);
}

.breuverra-password-panel > p {
  margin: 0 0 .5rem;
  color: #5a6b60;
  line-height: 1.65;
}

.breuverra-password-form {
  display: grid;
  gap: .2rem;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
}

.breuverra-password-form .button {
  width: fit-content;
  min-width: 180px;
}

.woocommerce form .password-input,
.woocommerce-page form .password-input {
  position: relative;
  display: block;
}

.woocommerce form .password-input input,
.woocommerce-page form .password-input input {
  padding-right: 3.25rem !important;
}

.woocommerce form .show-password-input,
.woocommerce-page form .show-password-input {
  position: absolute !important;
  right: .55rem !important;
  top: 50% !important;
  width: 2.15rem !important;
  height: 2.15rem !important;
  margin: 0 !important;
  transform: translateY(-50%);
  display: grid !important;
  place-items: center;
  border: 1px solid #d9e8da;
  border-radius: 999px;
  background: #f6faf6;
  color: var(--green) !important;
  opacity: 1 !important;
  cursor: pointer;
  text-indent: -9999px;
  overflow: hidden;
}

.woocommerce form .show-password-input::after,
.woocommerce-page form .show-password-input::after {
  content: "Show";
  text-indent: 0;
  font-size: .68rem;
  font-weight: 900;
  line-height: 1;
  color: var(--green);
}

.woocommerce form .show-password-input.display-password::after,
.woocommerce-page form .show-password-input.display-password::after {
  content: "Hide";
}

.woocommerce form .show-password-input:hover,
.woocommerce-page form .show-password-input:hover {
  background: var(--green);
  border-color: var(--green);
}

.woocommerce form .show-password-input:hover::after,
.woocommerce-page form .show-password-input:hover::after {
  color: #fff;
}

.woocommerce-account .woocommerce-form-login__rememberme {
  display: inline-flex !important;
  align-items: center;
  gap: .45rem;
  margin: .25rem 0 .9rem;
  color: #4c5f53;
}

.woocommerce-account .woocommerce-form-login__rememberme input {
  width: 18px !important;
  height: 18px;
  accent-color: var(--green);
}

.breuverra-login-helper {
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid #dfe9df;
  border-radius: 14px;
  background: #f6faf6;
}

.breuverra-login-helper span {
  display: block;
  color: var(--green);
  font-weight: 900;
}

.breuverra-login-helper p {
  margin: .25rem 0 .75rem;
  color: #5a6b60;
}

.woocommerce-account .woocommerce .breuverra-register-cta {
  width: 100%;
  display: inline-flex;
  justify-content: center;
  text-decoration: none;
}

.breuverra-account-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
  margin-top: 1.1rem;
}

.breuverra-account-card {
  display: grid;
  gap: .35rem;
  min-height: 150px;
  padding: 1rem;
  border: 1px solid #dfe9df;
  border-radius: 16px;
  background:
    linear-gradient(150deg, #fff 0%, #f7faf6 100%);
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(31,58,46,.045);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.breuverra-account-card:hover {
  transform: translateY(-2px);
  border-color: #c8dac9;
  box-shadow: 0 16px 30px rgba(31,58,46,.08);
}

.breuverra-account-card strong {
  font-family: "Playfair Display", serif;
  color: var(--green);
  font-size: 1.25rem;
}

.breuverra-account-card span {
  color: #5a6b60;
  line-height: 1.55;
}

.breuverra-account-card em {
  align-self: end;
  justify-self: start;
  color: var(--green);
  font-style: normal;
  font-weight: 900;
}

.woocommerce-account .woocommerce-Address,
.woocommerce-account .woocommerce-address-fields,
.woocommerce-account .woocommerce-EditAccountForm {
  background: #fff;
}

.woocommerce-account .woocommerce-Address-title h2,
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
  color: var(--green);
}

.same-address-panel {
  margin: .4rem 0 1rem;
  padding: .75rem .85rem;
  border: 1px solid #dfe9df;
  border-radius: 8px;
  background: #f6faf6;
}

.same-address-panel label {
  display: flex;
  align-items: center;
  gap: .55rem;
  margin: 0;
  color: var(--green);
  font-weight: 700;
}

.same-address-panel input {
  width: 18px !important;
  height: 18px;
  accent-color: var(--green);
}

@media (max-width: 860px) {
  .woocommerce-account .woocommerce {
    grid-template-columns: 1fr;
  }

  .woocommerce-account:not(.logged-in) .woocommerce .u-columns {
    grid-template-columns: 1fr;
  }

  .woocommerce-account:not(.logged-in) .woocommerce .u-column1,
  .woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .woocommerce-account .woocommerce-MyAccount-navigation {
    position: static;
  }

  .breuverra-account-cards {
    grid-template-columns: 1fr;
  }
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  position: relative;
  border: 1px solid rgba(31, 58, 46, .14);
  border-left: 0;
  border-radius: 18px;
  background: linear-gradient(135deg, #f7fbf7 0%, #fffdf5 100%);
  color: var(--green);
  display: block;
  min-height: 0;
  padding: 0 !important;
  box-shadow: 0 18px 42px rgba(31,58,46,.10);
  overflow: hidden;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
  content: none !important;
  display: none !important;
}

.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
  float: none !important;
  border-radius: 999px;
  background: var(--green) !important;
  color: #fff !important;
  padding: .62rem 1rem !important;
  white-space: nowrap;
}

.breuverra-cart-notice {
  align-items: center;
  display: grid;
  gap: .9rem;
  grid-template-columns: auto minmax(0, 1fr) auto;
  padding: 1rem 1.05rem;
}

.breuverra-cart-notice-icon {
  align-items: center;
  background: var(--green);
  border: 4px solid #e7f0e8;
  border-radius: 999px;
  box-shadow: 0 10px 22px rgba(31,58,46,.16);
  color: #fff;
  display: inline-flex;
  font-size: 1rem;
  font-weight: 900;
  height: 42px;
  justify-content: center;
  line-height: 1;
  width: 42px;
}

.breuverra-cart-notice-copy {
  display: grid;
  gap: .2rem;
  min-width: 0;
}

.breuverra-cart-notice-copy strong {
  color: var(--green);
  display: block;
  font-family: var(--serif);
  font-size: 1.08rem;
  line-height: 1.2;
}

.breuverra-cart-notice-copy span {
  color: #46584d;
  display: block;
  font-size: .95rem;
  line-height: 1.45;
}

.breuverra-cart-notice-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  justify-content: flex-end;
}

.breuverra-continue-shopping {
  border: 1px solid #d9e8da;
  border-radius: 999px;
  color: var(--green);
  font-weight: 800;
  padding: .58rem .9rem;
  text-decoration: none;
  white-space: nowrap;
}

.breuverra-continue-shopping:hover {
  background: #eef6ef;
}

@media (max-width: 720px) {
  .breuverra-cart-notice {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .breuverra-cart-notice-actions {
    grid-column: 1 / -1;
    justify-content: stretch;
  }

  .breuverra-cart-notice-actions .button,
  .breuverra-continue-shopping {
    flex: 1 1 150px;
    text-align: center;
  }
}

.woocommerce-error {
  display: block;
}

.woocommerce-error li {
  margin: .2rem 0;
}

.breuverra-auth-panel {
  width: min(920px, 92vw);
  margin: 3rem auto;
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 1.5rem;
  align-items: stretch;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  overflow: hidden;
}

.breuverra-auth-panel .auth-copy {
  padding: 2rem;
  background: linear-gradient(155deg, #f3f7f0, #ffffff);
  border-right: 1px solid var(--line);
}

.breuverra-auth-panel h1 {
  margin: .4rem 0 .8rem;
  color: var(--green);
}

.breuverra-register-form {
  padding: 2rem;
  border: 0 !important;
}

.breuverra-register-wrap {
  padding: 2rem;
}

.breuverra-register-wrap .breuverra-register-form {
  padding: 0;
}

.breuverra-register-form label {
  color: var(--green);
  font-weight: 700;
}

.breuverra-register-form input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: .8rem .9rem;
}

.breuverra-register-form .button {
  width: 100%;
  min-height: 48px;
  background: var(--green) !important;
  color: #fff !important;
  border-radius: 6px;
}

.otp-channel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  margin: .5rem 0 1rem;
}

.otp-channel label {
  display: flex;
  align-items: center;
  gap: .5rem;
  border: 1px solid #d9e8da;
  border-radius: 999px;
  background: #f6faf6;
  padding: .75rem .9rem;
  cursor: pointer;
}

.otp-channel input {
  width: auto;
  accent-color: var(--green);
}

.breuverra-otp-input {
  font-size: 1.35rem;
  letter-spacing: .28em;
  font-weight: 800;
  text-align: center;
}

.dev-otp-code {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 .2rem;
  padding: .15rem .5rem;
  border-radius: 999px;
  background: var(--green);
  color: #fff;
  letter-spacing: .12em;
}

.breuverra-register-success {
  display: grid;
  gap: .75rem;
  align-content: center;
  min-height: 280px;
}

.breuverra-register-success h2 {
  margin: 0;
  color: var(--green);
}

.breuverra-register-success p {
  margin: 0 0 .4rem;
  color: #5a6b60;
}

.breuverra-register-success .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-width: 180px;
  min-height: 48px;
  background: var(--green) !important;
  color: #fff !important;
  border-radius: 6px;
  text-decoration: none;
}

.auth-note,
.auth-switch {
  color: #5a6b60;
}

.auth-switch a {
  color: var(--green);
  font-weight: 700;
}

@media (max-width: 760px) {
  .breuverra-auth-panel {
    grid-template-columns: 1fr;
  }

  .otp-channel {
    grid-template-columns: 1fr;
  }

  .breuverra-auth-panel .auth-copy {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
}

/* Infinite scroll helper */
.infinite-loader {
  text-align: center;
  color: #5f6d63;
  padding: 1rem 0;
}

@media (max-width: 1100px) {
  .header-inner { grid-template-columns: auto 1fr auto; }
  .main-nav ul { white-space: normal; }
}

.shop-category-block {
  margin: 0 0 1rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.shop-category-block h2 {
  margin: 0 0 .75rem;
  font-size: 1.35rem;
}
.shop-category-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: .7rem;
}
.shop-category-item {
  text-decoration: none;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: .7rem;
  background: var(--offwhite);
  transition: transform .2s ease, border-color .2s ease;
}
.shop-category-item:hover {
  transform: translateY(-2px);
  border-color: var(--green);
}
.shop-category-name {
  display: block;
  font-weight: 700;
  color: var(--charcoal);
}
.shop-category-count {
  display: block;
  margin-top: .25rem;
  font-size: .82rem;
  color: #5f6d63;
}

@media (max-width: 1100px) {
  .shop-category-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 680px) {
  .shop-category-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Shop infinite-only + first-row alignment */
.woocommerce nav.woocommerce-pagination,
.woocommerce-pagination,
.page-numbers { display: none !important; }

.woocommerce.archive ul.products,
.woocommerce-page.archive ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 1rem !important;
}
.woocommerce.archive ul.products li.product,
.woocommerce-page.archive ul.products li.product {
  width: auto !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
}
.woocommerce.archive ul.products li.product.first,
.woocommerce.archive ul.products li.product.last,
.woocommerce-page.archive ul.products li.product.first,
.woocommerce-page.archive ul.products li.product.last {
  clear: none !important;
}

.shop-category-block {
  margin: 1rem 0 1rem;
}

.shop-filters-bar.single-line {
  display: flex;
  align-items: center;
  gap: .55rem;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding-bottom: .3rem;
}
.shop-filters-bar.single-line label {
  font-weight: 700;
  white-space: nowrap;
}
.shop-filters-bar.single-line input,
.shop-filters-bar.single-line select,
.shop-filters-bar.single-line button {
  white-space: nowrap;
}
.shop-filters-bar.single-line input {
  width: 96px;
}

@media (max-width: 1100px) {
  .woocommerce.archive ul.products,
  .woocommerce-page.archive ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 680px) {
  .woocommerce.archive ul.products,
  .woocommerce-page.archive ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* Sticky shop filters */
.woocommerce .shop-filters-bar.single-line {
  position: sticky;
  top: 128px;
  z-index: 35;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: .55rem;
}

@media (max-width: 1100px) {
  .woocommerce .shop-filters-bar.single-line {
    top: 118px;
  }
}

@media (max-width: 680px) {
  .woocommerce .shop-filters-bar.single-line {
    top: 106px;
  }
}

/* Sticky category chips above sticky filters */
.woocommerce .shop-category-block {
  position: sticky;
  top: 82px;
  z-index: 36;
  background: #fff;
  padding: .55rem;
}

.woocommerce .shop-category-block h2 {
  font-size: .95rem;
  margin-bottom: .45rem;
}

.woocommerce .shop-category-grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: max-content;
  gap: .5rem;
  overflow-x: auto;
  padding-bottom: .2rem;
}

.woocommerce .shop-category-item {
  border-radius: 999px;
  padding: .45rem .75rem;
  background: #f6f8f5;
}

.woocommerce .shop-category-count {
  display: none;
}

/* push sticky filter below sticky category chips */
.woocommerce .shop-filters-bar.single-line {
  top: 152px;
}

@media (max-width: 1100px) {
  .woocommerce .shop-category-block { top: 74px; }
  .woocommerce .shop-filters-bar.single-line { top: 138px; }
}

@media (max-width: 680px) {
  .woocommerce .shop-category-block { top: 66px; }
  .woocommerce .shop-filters-bar.single-line { top: 126px; }
}

/* Shop layout: left categories + inline sentence sort */
.shop-top-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 1rem 0 1.1rem;
}

.shop-top-row .woocommerce-breadcrumb {
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
  white-space: nowrap;
}

.woocommerce-breadcrumb {
  color: #5f7167;
  font-size: .94rem;
}

.woocommerce-breadcrumb a {
  color: var(--green);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.shop-top-row .shop-filters-bar.single-line {
  flex: 0 0 auto;
}

.shop-shell {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.shop-sidebar {
  position: sticky;
  top: 120px;
}

.shop-sidebar-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 1rem;
}

.shop-sidebar-card h3 {
  margin: 0 0 .8rem;
  font-size: 2rem;
}

.shop-cat-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: .55rem;
}

.shop-cat-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 1px solid #dce7dc;
  border-radius: 999px;
  text-decoration: none;
  padding: .5rem .8rem;
  color: #26372e;
  background: #f3f7f3;
}

.shop-cat-item.is-active,
.shop-cat-item:hover {
  border-color: var(--green);
  background: #eaf2ea;
}

.shop-cat-item em {
  font-style: normal;
  opacity: .85;
}

.shop-cat-item.is-active {
  font-weight: 700;
}

.product-breadcrumb-row {
  margin: 1rem 0 1.1rem;
}

.product-breadcrumb-row .woocommerce-breadcrumb {
  margin: 0;
}

.product-breadcrumb-row .woocommerce-breadcrumb a {
  color: var(--green);
}

.woocommerce .shop-filters-bar.single-line {
  position: static;
  top: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  display: flex;
  justify-content: flex-end;
  gap: .55rem;
  align-items: center;
  flex-wrap: nowrap;
}

.shop-summary-line {
  margin: 0;
  color: #486154;
  font-weight: 600;
  white-space: nowrap;
}

.shop-sort-form {
  margin: 0;
}

.shop-sort-select {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: .58rem .9rem;
  min-width: 210px;
}

.woocommerce .woocommerce-products-header,
.woocommerce .woocommerce-products-header__title,
.woocommerce .page-title {
  display: none !important;
}

@media (max-width: 1024px) {
  .shop-top-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .shop-top-row .woocommerce-breadcrumb,
  .shop-top-row .shop-filters-bar.single-line {
    width: 100%;
  }

  .woocommerce .shop-filters-bar.single-line {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .shop-summary-line {
    white-space: normal;
  }

  .shop-shell {
    grid-template-columns: 1fr;
  }

  .shop-sidebar {
    position: static;
  }
}

/* Match WooCommerce listing sale badges with home best-seller cards. */
.woocommerce ul.products li.product .onsale,
.woocommerce-page ul.products li.product .onsale {
  position: absolute !important;
  top: 10px !important;
  left: 10px !important;
  right: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  padding: .23rem .45rem !important;
  border-radius: 4px !important;
  background: var(--gold) !important;
  color: #fff !important;
  font-size: .7rem !important;
  font-weight: 700 !important;
  text-transform: none !important;
  z-index: 3 !important;
}

.woocommerce ul.products li.product {
  position: relative;
}

.single-product span.onsale {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  right: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  padding: .28rem .52rem !important;
  border-radius: 4px !important;
  background: var(--green) !important;
  color: #fff !important;
  font-size: .74rem !important;
  font-weight: 700 !important;
  z-index: 5 !important;
}

/* Final scoped shop grid and cart-state styling. */
.shop-main .woocommerce ul.products,
.shop-main ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 1rem !important;
  align-items: stretch;
}

.shop-main .woocommerce ul.products::before,
.shop-main .woocommerce ul.products::after,
.shop-main ul.products::before,
.shop-main ul.products::after {
  content: none !important;
  display: none !important;
}

.shop-main .woocommerce ul.products li.product,
.shop-main ul.products li.product {
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  float: none !important;
  clear: none !important;
  margin: 0 !important;
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.shop-main ul.products li.product:hover,
.shop-main ul.products li.product:focus-within {
  z-index: 12;
}

.shop-main.is-loading {
  opacity: .55;
  pointer-events: none;
  position: relative;
}

.shop-main ul.products li.product .button,
.shop-main ul.products li.product a.button,
.shop-main ul.products li.product .product-view-cart {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  width: 100%;
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #fff !important;
  text-align: center;
}

.shop-main ul.products li.product .loop-qty,
.woocommerce ul.products li.product .loop-qty {
  display: grid;
  grid-template-columns: auto 36px minmax(46px, 1fr) 36px;
  gap: .4rem;
  align-items: center;
  margin: auto 0 .65rem;
  width: 100%;
}

.shop-main ul.products li.product .loop-qty-label,
.woocommerce ul.products li.product .loop-qty-label {
  color: rgba(31, 58, 46, .72);
  font-family: var(--sans);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

@media (hover: hover) and (pointer: fine) and (min-width: 769px) {
  .shop-main ul.products li.product .loop-qty,
  .woocommerce ul.products li.product .loop-qty,
  .woocommerce ul.products li.product .loop-variation-qty {
    max-height: 0;
    margin-top: 0;
    margin-bottom: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    transform: translateY(10px) scaleY(.96);
    transform-origin: top;
    transition: max-height .26s ease, margin .26s ease, opacity .2s ease, transform .26s ease;
  }

  .shop-main ul.products li.product:hover .loop-qty,
  .shop-main ul.products li.product:focus-within .loop-qty,
  .woocommerce ul.products li.product:hover .loop-qty,
  .woocommerce ul.products li.product:focus-within .loop-qty {
    max-height: 52px;
    margin: .58rem 0 .72rem;
    opacity: 1;
    overflow: visible;
    pointer-events: auto;
    transform: translateY(0) scaleY(1);
  }

  .woocommerce ul.products li.product:hover .loop-variation-qty,
  .woocommerce ul.products li.product:focus-within .loop-variation-qty {
    max-height: 52px;
    margin-top: .65rem;
    opacity: 1;
    overflow: visible;
    pointer-events: auto;
    transform: translateY(0) scaleY(1);
  }
}

.shop-main ul.products li.product .loop-qty-btn,
.woocommerce ul.products li.product .loop-qty-btn,
.shop-main ul.products li.product .loop-qty-input,
.woocommerce ul.products li.product .loop-qty-input {
  height: 38px;
  border: 1px solid #d9e8da;
  border-radius: 999px;
  background: #f6faf6;
  color: var(--green);
  font-weight: 800;
  text-align: center;
}

.shop-main ul.products li.product .loop-qty-btn,
.woocommerce ul.products li.product .loop-qty-btn {
  cursor: pointer;
  transition: background .18s ease, color .18s ease, border-color .18s ease;
}

.shop-main ul.products li.product .loop-qty-btn:hover,
.woocommerce ul.products li.product .loop-qty-btn:hover {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}

.shop-main ul.products li.product .loop-qty-input,
.woocommerce ul.products li.product .loop-qty-input {
  width: 100%;
  appearance: textfield;
}

.shop-main ul.products li.product .loop-qty-input::-webkit-outer-spin-button,
.shop-main ul.products li.product .loop-qty-input::-webkit-inner-spin-button,
.woocommerce ul.products li.product .loop-qty-input::-webkit-outer-spin-button,
.woocommerce ul.products li.product .loop-qty-input::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}

.shop-main ul.products li.product a.added_to_cart {
  display: none !important;
}

.shop-main ul.products li.product .onsale,
.woocommerce ul.products li.product .onsale,
.woocommerce-page ul.products li.product .onsale {
  background: var(--green) !important;
  color: #fff !important;
}

.same-address-panel.is-saving label::after {
  content: "Saving...";
  margin-left: .55rem;
  color: var(--green);
  font-size: .82rem;
  font-weight: 700;
}

@media (max-width: 1199px) {
  .shop-main .woocommerce ul.products,
  .shop-main ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 1024px) {
  .shop-main .woocommerce ul.products,
  .shop-main ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  .shop-main .woocommerce ul.products,
  .shop-main ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* Centered premium logo header */
.site-header .header-inner {
  min-height: 58px;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  grid-template-areas: "nav brand actions";
}

.site-header {
  background:
    linear-gradient(90deg, rgba(255,255,255,.045), transparent 26%, rgba(255,255,255,.04) 74%, transparent),
    var(--green);
  border-bottom-color: rgba(255,255,255,.14);
  box-shadow: 0 12px 32px rgba(22, 42, 31, .18);
}

.site-header .menu-toggle {
  grid-area: toggle;
}

.site-header .main-nav {
  grid-area: nav;
  justify-self: start;
}

.site-header .brand {
  grid-area: brand;
  justify-self: center;
  padding: .08rem .18rem;
  border: 0;
  background: transparent;
  filter: drop-shadow(0 6px 12px rgba(0,0,0,.18));
  overflow: visible;
}

.site-header .brand img {
  width: 122px;
  height: auto;
  max-width: 20vw;
  background: rgba(255,255,255,.94);
  border-radius: 6px;
  padding: .08rem .16rem;
  object-fit: contain;
}

.site-header .header-actions {
  grid-area: actions;
  justify-self: end;
}

.site-header .main-nav a {
  color: #f7fbf7;
  font-weight: 600;
  opacity: .92;
}

.site-header .main-nav a:hover {
  opacity: 1;
  color: #fff;
}

.site-header .icon-btn,
.site-header .menu-toggle {
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.1);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.site-header .icon-btn:hover,
.site-header .menu-toggle:hover {
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.34);
}

.site-header .cart-count {
  background: #fff;
  color: var(--green);
}

@media (max-width: 1100px) {
  .site-header .header-inner {
    min-height: 54px;
    grid-template-columns: auto 1fr auto;
    grid-template-areas: "toggle brand actions";
  }

  .site-header .brand {
    justify-self: center;
  }

  .site-header .brand img {
    width: 112px;
    max-width: 26vw;
  }
}

@media (max-width: 680px) {
  .site-header .header-inner {
    min-height: 50px;
    gap: .6rem;
  }

  .site-header .brand img {
    width: 96px;
    max-width: 32vw;
    padding: .06rem .12rem;
  }
}

/* Option 2 + option 5: split bar with overlapping centered logo badge. */
.site-header {
  background:
    linear-gradient(to bottom, var(--green) 0 25px, #f7faf6 25px 100%);
  border-bottom: 1px solid #dfe9df;
  box-shadow: 0 12px 26px rgba(31,58,46,.12);
}

.site-header .header-inner {
  min-height: 78px;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  grid-template-rows: 25px 53px;
  grid-template-areas:
    ". brand ."
    "nav nav actions";
  gap: 0 18px;
  position: relative;
}

.site-header .brand {
  align-self: start;
  justify-self: center;
  width: 128px;
  min-height: 62px;
  display: grid;
  place-items: center;
  padding: 6px 10px 8px;
  border-radius: 0 0 8px 8px;
  background: #fff;
  box-shadow: 0 10px 20px rgba(31,58,46,.16);
  filter: none;
  transform: translateY(0);
  z-index: 4;
}

.site-header .brand,
.site-header .brand:where(:link, :visited) {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}

.site-header .brand img {
  border-radius: 0 !important;
}

.site-header .brand img {
  width: 101px;
  max-width: 101px;
  padding: 0;
  background: transparent;
  border-radius: 0;
  filter: none;
}

.site-header .main-nav {
  align-self: center;
  justify-self: start;
  padding-top: .55rem;
  padding-bottom: .55rem;
}

.site-header .main-nav a {
  color: var(--green);
  opacity: 1;
}

.site-header .main-nav a:hover {
  color: #13271e;
}

.site-header .header-actions {
  align-self: center;
  gap: .8rem;
  padding-right: .6rem;
  padding-top: .55rem;
  padding-bottom: .55rem;
}

.site-header .icon-btn,
.site-header .menu-toggle {
  min-height: 32px;
  padding-left: 1rem;
  padding-right: 1rem;
  border-color: #d9e5d9;
  background: #fff;
  color: var(--green);
  box-shadow: none;
}

.site-header .search-toggle {
  width: 36px;
  padding-left: 0;
  padding-right: 0;
}

.site-header .cart-link {
  padding-right: 2.6rem;
}

.site-header .icon-btn:hover,
.site-header .menu-toggle:hover {
  background: #edf4ee;
  border-color: #c8dac9;
}

.site-header .cart-count {
  background: var(--green);
  color: #fff;
}

@media (max-width: 1100px) {
  .site-header {
    background:
      linear-gradient(to bottom, var(--green) 0 25px, #f7faf6 25px 100%);
  }

  .site-header .header-inner {
    min-height: 76px;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: 25px 51px;
    grid-template-areas:
      "toggle brand actions"
      "nav nav nav";
  }

  .site-header .brand {
    width: 119px;
    min-height: 56px;
    padding: 5px 9px 7px;
  }

  .site-header .brand img {
    width: 92px;
    max-width: 92px;
  }

  .site-header .main-nav {
    top: 100%;
  }
}

@media (max-width: 680px) {
  .site-header {
    background:
      linear-gradient(to bottom, var(--green) 0 25px, #f7faf6 25px 100%);
  }

  .site-header .header-inner {
    min-height: 74px;
    grid-template-rows: 25px 49px;
  }

  .site-header .brand {
    width: 102px;
    min-height: 50px;
    padding: 5px 8px 6px;
  }

  .site-header .brand img {
    width: 79px;
    max-width: 79px;
  }
}

/* Product recommendation sections: stable 4-card rows and standard buttons. */
.single-product .related,
.single-product .upsells,
.personalized-reco,
.thankyou-upsell {
  clear: both;
  margin-top: 2rem;
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: none !important;
}

.single-product .related > h2,
.single-product .upsells > h2,
.personalized-reco > h2,
.thankyou-upsell > h2 {
  width: min(1240px, 92%);
  margin: 0 auto 1rem;
  color: var(--green);
}

.single-product .related ul.products,
.single-product .upsells ul.products,
.personalized-reco ul.products,
.thankyou-upsell ul.products {
  width: min(900px, 92%);
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1rem !important;
  align-items: stretch;
}

.single-product .related ul.products::before,
.single-product .related ul.products::after,
.single-product .upsells ul.products::before,
.single-product .upsells ul.products::after,
.personalized-reco ul.products::before,
.personalized-reco ul.products::after,
.thankyou-upsell ul.products::before,
.thankyou-upsell ul.products::after {
  content: none !important;
  display: none !important;
}

.single-product .related ul.products li.product,
.single-product .upsells ul.products li.product,
.personalized-reco ul.products li.product,
.thankyou-upsell ul.products li.product {
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  float: none !important;
  clear: none !important;
  margin: 0 !important;
  display: flex;
  flex-direction: column;
}

.single-product .related ul.products li.product .button,
.single-product .upsells ul.products li.product .button,
.personalized-reco ul.products li.product .button,
.thankyou-upsell ul.products li.product .button,
.single-product .related ul.products li.product .product-view-cart,
.single-product .upsells ul.products li.product .product-view-cart,
.personalized-reco ul.products li.product .product-view-cart,
.thankyou-upsell ul.products li.product .product-view-cart {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  width: 100%;
  margin-top: auto !important;
  background: var(--green) !important;
  border-color: var(--green) !important;
  border-radius: 6px !important;
  color: #fff !important;
  text-align: center;
}

.single-product .related ul.products li.product a.added_to_cart,
.single-product .upsells ul.products li.product a.added_to_cart,
.personalized-reco ul.products li.product a.added_to_cart,
.thankyou-upsell ul.products li.product a.added_to_cart {
  display: none !important;
}

@media (max-width: 1199px) {
  .single-product .related ul.products,
  .single-product .upsells ul.products,
  .personalized-reco ul.products,
  .thankyou-upsell ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 1024px) {
  .single-product .related ul.products,
  .single-product .upsells ul.products,
  .personalized-reco ul.products,
  .thankyou-upsell ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  .single-product .related ul.products,
  .single-product .upsells ul.products,
  .personalized-reco ul.products,
  .thankyou-upsell ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* Storewide add-to-cart chip buttons and text-only processing state. */
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button,
.shop-main ul.products li.product .button,
.shop-main ul.products li.product a.button,
.shop-main ul.products li.product .product-view-cart,
.single-product .single_add_to_cart_button,
.single-product .related ul.products li.product .button,
.single-product .upsells ul.products li.product .button,
.personalized-reco ul.products li.product .button,
.thankyou-upsell ul.products li.product .button,
.qv-add,
#bundle-add-btn,
.sticky-atc-btn {
  border-radius: 999px !important;
  min-height: 44px;
  padding: .72rem 1.15rem !important;
  font-weight: 800 !important;
  letter-spacing: .01em;
  line-height: 1.1 !important;
  box-shadow: 0 8px 18px rgba(31,58,46,.12);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce-page ul.products li.product .button:hover,
.shop-main ul.products li.product .button:hover,
.shop-main ul.products li.product .product-view-cart:hover,
.single-product .single_add_to_cart_button:hover,
.single-product .related ul.products li.product .button:hover,
.single-product .upsells ul.products li.product .button:hover,
.personalized-reco ul.products li.product .button:hover,
.thankyou-upsell ul.products li.product .button:hover,
.qv-add:hover,
#bundle-add-btn:hover,
.sticky-atc-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(31,58,46,.16);
}

.button.is-processing,
.btn.is-processing,
.mini-btn.is-processing,
.single_add_to_cart_button.is-processing,
.single_add_to_cart_button.loading,
.add_to_cart_button.is-processing,
.add_to_cart_button.loading,
.qv-add.is-processing,
#bundle-add-btn.is-processing {
  padding-right: 1.15rem !important;
  animation: addingTextPulse .85s ease-in-out infinite;
}

.button.is-processing::after,
.btn.is-processing::after,
.mini-btn.is-processing::after,
.single_add_to_cart_button.is-processing::after,
.single_add_to_cart_button.loading::after,
.add_to_cart_button.is-processing::after,
.add_to_cart_button.loading::after,
.qv-add.is-processing::after,
#bundle-add-btn.is-processing::after {
  content: none !important;
  display: none !important;
}

.woocommerce a.button.loading::after,
.woocommerce button.button.loading::after,
.woocommerce input.button.loading::after {
  content: none !important;
  display: none !important;
}

.product-view-cart::after,
.product-view-cart.added::after,
.woocommerce ul.products li.product .product-view-cart::after,
.woocommerce-page ul.products li.product .product-view-cart::after,
.woocommerce a.added::after,
.woocommerce a.added_to_cart::after {
  content: none !important;
  display: none !important;
}

.woocommerce ul.products li.product .loop-option-toggle {
  border-radius: 999px !important;
  font-size: .92rem !important;
  min-height: 42px !important;
  padding: .62rem 1rem !important;
  width: 100%;
  text-align: center;
}

.loop-variation-panel[hidden] {
  display: none !important;
}

.woocommerce ul.products li.product .loop-variation-panel {
  bottom: 74px;
  left: .65rem;
  margin-top: 0;
  padding: .7rem .72rem .76rem;
  position: absolute;
  right: .65rem;
  border: 1px solid rgba(31, 58, 46, .14);
  border-radius: 18px;
  background: rgba(249, 252, 248, .97);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 38px rgba(31,58,46,.16), inset 0 1px 0 rgba(255,255,255,.8);
  z-index: 20;
}

.woocommerce ul.products li.product .loop-variation-panel p {
  margin: 0 0 .42rem;
  color: #67776d;
  font-family: var(--sans);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1.2;
  text-transform: uppercase;
}

.woocommerce ul.products li.product .loop-variation-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .38rem;
}

.woocommerce ul.products li.product .loop-variation-chip {
  appearance: none;
  min-width: 0;
  border: 1px solid rgba(31, 58, 46, .18);
  border-radius: 999px;
  background: #fff;
  color: var(--green);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .06rem;
  min-height: 46px;
  padding: .35rem .2rem;
  font: inherit;
  font-size: .9rem;
  font-weight: 900;
  line-height: 1.05;
  box-shadow: none !important;
  transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

.woocommerce ul.products li.product .loop-variation-chip span {
  font-size: 1rem;
  line-height: 1;
}

.woocommerce ul.products li.product .loop-variation-chip small {
  color: inherit;
  font-size: .68rem;
  font-weight: 700;
  opacity: .78;
  white-space: nowrap;
}

.woocommerce ul.products li.product .loop-variation-chip small .amount {
  color: inherit;
}

.woocommerce ul.products li.product .loop-variation-chip:hover,
.woocommerce ul.products li.product .loop-variation-chip.is-selected {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
  transform: translateY(-1px);
}

.woocommerce ul.products li.product .loop-variation-qty {
  display: grid;
  grid-template-columns: auto 34px minmax(42px, 1fr) 34px;
  gap: .34rem;
  margin-top: .48rem;
  align-items: center;
}

.woocommerce ul.products li.product .loop-var-qty-btn,
.woocommerce ul.products li.product .loop-var-qty-input {
  min-height: 34px;
  border: 1px solid rgba(31, 58, 46, .16);
  border-radius: 999px;
  background: #fff;
  color: var(--green);
  box-shadow: none !important;
  font-size: .95rem;
  font-weight: 800;
  line-height: 1 !important;
  padding: 0 !important;
  text-align: center;
}

.woocommerce ul.products li.product .loop-var-qty-btn {
  cursor: pointer;
}

.woocommerce ul.products li.product .loop-var-qty-btn:hover {
  background: rgba(31, 58, 46, .08);
}

.woocommerce ul.products li.product .loop-var-qty-input::-webkit-outer-spin-button,
.woocommerce ul.products li.product .loop-var-qty-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.woocommerce ul.products li.product .loop-variation-add {
  border-radius: 999px !important;
  font-size: .88rem !important;
  min-height: 38px !important;
  padding: .58rem .8rem !important;
  width: 100%;
  margin-top: .5rem !important;
}

.woocommerce ul.products li.product .loop-variation-add:disabled {
  cursor: not-allowed;
  opacity: .58;
  transform: none;
}

@keyframes addingTextPulse {
  0%, 100% { opacity: .72; transform: translateY(0); }
  50% { opacity: 1; transform: translateY(-1px); }
}

/* Final account password visibility toggle override. */
.woocommerce form .show-password-input,
.woocommerce-page form .show-password-input {
  background: #f6faf6 !important;
  border-color: #d9e8da !important;
}

.woocommerce form .show-password-input::after,
.woocommerce-page form .show-password-input::after {
  color: var(--green) !important;
}

.woocommerce form .show-password-input:hover,
.woocommerce-page form .show-password-input:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
}

.woocommerce form .show-password-input:hover::after,
.woocommerce-page form .show-password-input:hover::after {
  color: #fff !important;
}

/* BreuVerra editorial About and Contact pages. */
.brand-page { padding-bottom: 4rem; }
.brand-page .woocommerce-breadcrumb { margin-bottom: 1.4rem; }
.brand-page-hero {
  align-items: center;
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
  padding: 3.2rem 0 2.2rem;
}
.brand-page-hero h1 {
  color: var(--green);
  font-size: clamp(2.25rem, 4vw, 4.4rem);
  line-height: .98;
  margin: .35rem 0 1rem;
  max-width: 850px;
}
.brand-page-hero p:not(.eyebrow) {
  color: #516157;
  font-size: 1.05rem;
  line-height: 1.8;
  max-width: 680px;
}
.brand-page-image {
  background: radial-gradient(circle at 30% 20%, #fff 0, #f4f8f2 48%, #e7efe6 100%);
  border: 1px solid #dce9dd;
  border-radius: 28px;
  box-shadow: 0 28px 70px rgba(31,58,46,.13);
  margin: 0;
  overflow: hidden;
  padding: 1rem;
}
.brand-page-image img {
  border-radius: 22px;
  display: block;
  height: 100%;
  max-height: 560px;
  object-fit: cover;
  width: 100%;
}
.about-story-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 2rem 0;
}
.about-story-grid article,
.about-split,
.contact-card-stack article,
.breuverra-contact-form,
.contact-help-panel {
  background: linear-gradient(135deg, #f8fbf7 0%, #fffdf7 100%);
  border: 1px solid rgba(31,58,46,.13);
  border-radius: 22px;
  box-shadow: 0 16px 40px rgba(31,58,46,.07);
}
.about-story-grid article { padding: 1.35rem; }
.about-story-grid span {
  color: var(--gold);
  display: block;
  font-weight: 900;
  margin-bottom: .85rem;
}
.about-story-grid h2,
.about-split h2,
.breuverra-contact-form h2,
.contact-help-panel h2 {
  color: var(--green);
  font-size: 1.45rem;
  margin: 0 0 .75rem;
}
.about-story-grid p,
.about-split p,
.contact-help-panel p {
  color: #58675e;
  line-height: 1.7;
  margin: 0;
}
.about-split {
  align-items: center;
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .8fr);
  margin-top: 1rem;
  padding: 1.6rem;
}
.about-split ul {
  display: grid;
  gap: .75rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.about-split li {
  background: #fff;
  border: 1px solid #d9e8da;
  border-radius: 999px;
  color: var(--green);
  font-weight: 800;
  padding: .75rem 1rem;
}
.contact-hero { grid-template-columns: minmax(0, 1fr) minmax(320px, 430px); }
.contact-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.25rem;
}
.btn-outline {
  background: #fff;
  border: 1px solid #d9e8da;
  color: var(--green);
}
.contact-card-stack {
  display: grid;
  gap: .85rem;
}
.contact-card-stack article {
  display: grid;
  gap: .25rem;
  padding: 1.1rem 1.2rem;
}
.contact-card-stack strong {
  color: var(--gold);
  font-size: .82rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.contact-card-stack a,
.contact-card-stack span {
  color: var(--green);
  font-size: 1.08rem;
  font-weight: 900;
  text-decoration: none;
}
.contact-grid {
  align-items: start;
  display: grid;
  gap: 1.2rem;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  margin-top: 1rem;
}
.breuverra-contact-form,
.contact-help-panel { padding: 1.35rem; }
.breuverra-contact-form {
  display: grid;
  gap: .9rem;
}
.breuverra-contact-form label {
  color: var(--green);
  display: grid;
  font-weight: 800;
  gap: .35rem;
}
.breuverra-contact-form input,
.breuverra-contact-form textarea {
  background: #fff;
  border: 1px solid #d9e8da;
  border-radius: 14px;
  color: var(--charcoal);
  font: inherit;
  padding: .85rem .95rem;
  width: 100%;
}
.breuverra-contact-form input:focus,
.breuverra-contact-form textarea:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 4px rgba(31,58,46,.08);
  outline: none;
}
.contact-map-card {
  align-items: center;
  background: linear-gradient(135deg, var(--green), #315c4b);
  border-radius: 20px;
  color: #fff;
  display: grid;
  min-height: 210px;
  margin-top: 1rem;
  padding: 1.3rem;
  position: relative;
  overflow: hidden;
}
.contact-map-card::after {
  background: rgba(195,162,76,.22);
  border-radius: 999px;
  content: "";
  height: 210px;
  position: absolute;
  right: -70px;
  top: -70px;
  width: 210px;
}
.contact-map-card span,
.contact-map-card strong {
  position: relative;
  z-index: 1;
}
.contact-map-card span {
  color: #e9d79a;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.contact-map-card strong {
  font-family: var(--serif);
  font-size: 2rem;
}
@media (max-width: 900px) {
  .brand-page-hero,
  .about-split,
  .contact-grid,
  .contact-hero { grid-template-columns: 1fr; }
  .about-story-grid { grid-template-columns: 1fr; }
}

/* Optimized product detail information cards and compact product rails. */
.single-product .pdp-info-suite {
  clear: both;
  display: grid;
  gap: 1rem;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 2rem 0 1.4rem;
  width: 100%;
}

.pdp-info-card {
  background: linear-gradient(135deg, #f8fbf7 0%, #fffdf7 100%);
  border: 1px solid rgba(31,58,46,.13);
  border-radius: 22px;
  box-shadow: 0 18px 42px rgba(31,58,46,.08);
  display: grid;
  gap: 1rem;
  grid-template-columns: auto minmax(0, 1fr);
  padding: 1.25rem;
}

.pdp-info-card-wide {
  grid-column: 1 / -1;
}

.pdp-info-icon {
  align-items: center;
  background: var(--green);
  border: 4px solid #e6f0e7;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 1.05rem;
  font-weight: 900;
  height: 46px;
  justify-content: center;
  width: 46px;
}

.pdp-info-kicker {
  color: var(--gold);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .09em;
  margin: 0 0 .35rem;
  text-transform: uppercase;
}

.pdp-info-card h2 {
  color: var(--green);
  font-size: clamp(1.25rem, 2vw, 1.8rem);
  line-height: 1.15;
  margin: 0 0 .7rem;
}

.pdp-info-copy,
.pdp-info-copy p,
.pdp-use-steps p {
  color: #56665c;
  line-height: 1.75;
}

.pdp-info-copy p:last-child,
.pdp-use-steps p:last-child {
  margin-bottom: 0;
}

.pdp-spec-list {
  display: grid;
  gap: .55rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.pdp-spec-list li,
.pdp-use-steps p {
  background: #fff;
  border: 1px solid #dce9dd;
  border-radius: 14px;
  margin: 0;
  padding: .72rem .8rem;
}

.pdp-spec-list li {
  display: grid;
  gap: .18rem;
}

.pdp-spec-list strong,
.pdp-use-steps strong {
  color: var(--green);
  font-weight: 900;
}

.pdp-spec-list span {
  color: #56665c;
}

.pdp-use-steps {
  display: grid;
  gap: .55rem;
}

.pdp-use-steps strong {
  color: var(--gold);
  display: inline-block;
  margin-right: .65rem;
}

.single-product .ugc-gallery {
  display: none !important;
}

.single-product .related,
.single-product .upsells,
.single-product .personalized-reco {
  clear: both;
  grid-column: 1 / -1 !important;
  margin: 1.6rem auto 0 !important;
  max-width: 1240px;
  width: 100% !important;
}

.single-product .related > h2,
.single-product .upsells > h2,
.single-product .personalized-reco > h2 {
  color: var(--green);
  font-size: clamp(1.35rem, 2vw, 1.9rem);
  margin: 0 0 .8rem !important;
  width: auto !important;
}

.single-product .related ul.products,
.single-product .upsells ul.products,
.single-product .personalized-reco ul.products {
  display: grid !important;
  gap: .75rem !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  margin: 0 !important;
  width: 100% !important;
}

.single-product .related ul.products li.product,
.single-product .upsells ul.products li.product,
.single-product .personalized-reco ul.products li.product {
  border-radius: 14px !important;
  padding: .48rem !important;
}

.single-product .related ul.products li.product img,
.single-product .upsells ul.products li.product img,
.single-product .personalized-reco ul.products li.product img {
  aspect-ratio: 4 / 3;
  border-radius: 10px;
  object-fit: cover;
}

.single-product .related ul.products li.product .woocommerce-loop-product__title,
.single-product .upsells ul.products li.product .woocommerce-loop-product__title,
.single-product .personalized-reco ul.products li.product .woocommerce-loop-product__title {
  font-size: .98rem !important;
  line-height: 1.2;
  margin: .55rem 0 .25rem !important;
}

.single-product .related ul.products li.product .onsale,
.single-product .upsells ul.products li.product .onsale,
.single-product .personalized-reco ul.products li.product .onsale {
  font-size: .62rem !important;
  padding: .18rem .36rem !important;
}

.single-product .related ul.products li.product .price,
.single-product .upsells ul.products li.product .price,
.single-product .personalized-reco ul.products li.product .price {
  font-size: .9rem !important;
  margin-bottom: .5rem !important;
}

.single-product .related ul.products li.product .button,
.single-product .upsells ul.products li.product .button,
.single-product .personalized-reco ul.products li.product .button {
  font-size: .82rem !important;
  min-height: 36px !important;
  padding: .5rem .65rem !important;
}

.single-product .related ul.products li.product .loop-option-toggle,
.single-product .upsells ul.products li.product .loop-option-toggle,
.single-product .personalized-reco ul.products li.product .loop-option-toggle {
  font-size: .8rem !important;
  min-height: 34px !important;
  padding: .45rem .62rem !important;
}

@media (max-width: 980px) {
  .single-product .pdp-info-suite {
    grid-template-columns: 1fr;
  }

  .single-product .related ul.products,
  .single-product .upsells ul.products,
  .single-product .personalized-reco ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  .pdp-info-card {
    grid-template-columns: 1fr;
  }

  .single-product .related ul.products,
  .single-product .upsells ul.products,
  .single-product .personalized-reco ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* Final product-card quantity reveal: overlay on hover/focus, no card height expansion. */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  overflow: hidden;
  position: relative !important;
  transition: min-height .24s ease, transform .2s ease, box-shadow .2s ease;
}

.woocommerce ul.products li.product .loop-qty,
.woocommerce-page ul.products li.product .loop-qty {
  display: grid !important;
  grid-template-columns: auto 36px minmax(46px, 1fr) 36px !important;
  align-items: center !important;
  gap: .4rem !important;
  width: 100% !important;
}

@media (hover: hover) and (pointer: fine) and (min-width: 769px) {
  .woocommerce ul.products li.product .loop-qty,
  .woocommerce-page ul.products li.product .loop-qty {
    background: rgba(255, 253, 247, .96) !important;
    border: 1px solid rgba(31, 58, 46, .12);
    border-radius: 999px;
    box-shadow: 0 16px 34px rgba(31, 58, 46, .18);
    box-sizing: border-box;
    left: .72rem;
    margin: 0 !important;
    max-height: none !important;
    opacity: 0 !important;
    padding: .36rem .42rem !important;
    pointer-events: none !important;
    position: absolute !important;
    right: .72rem;
    top: var(--bv-loop-qty-top, 188px);
    width: auto !important;
    transform: translateY(10px) !important;
    transition: opacity .2s ease, transform .22s ease !important;
    z-index: 18;
  }

  .woocommerce ul.products li.product:hover .loop-qty,
  .woocommerce ul.products li.product:focus-within .loop-qty,
  .woocommerce-page ul.products li.product:hover .loop-qty,
  .woocommerce-page ul.products li.product:focus-within .loop-qty {
    max-height: none !important;
    margin: 0 !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }
}

/* Home hero refresh: editorial essential-oil background with readable premium copy. */
.hero.hero-essential {
  position: relative;
  isolation: isolate;
  min-height: clamp(390px, 50vh, 540px);
  display: flex;
  align-items: center;
  padding: clamp(2.7rem, 5vw, 4.2rem) 0;
  overflow: hidden;
  background: #f5f3ec;
  border-bottom: 1px solid rgba(31, 58, 46, .12);
}

.hero.hero-essential::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: linear-gradient(90deg, rgba(251, 250, 244, .98) 0%, rgba(251, 250, 244, .9) 34%, rgba(251, 250, 244, .38) 62%, rgba(31, 58, 46, .12) 100%), var(--hero-bg);
  background-size: cover;
  background-position: center right;
  transform: scale(1.01);
}

.hero.hero-essential::after {
  content: "";
  position: absolute;
  inset: auto 8% 8% auto;
  width: 220px;
  height: 220px;
  z-index: -1;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(195, 162, 76, .28), rgba(195, 162, 76, 0) 68%);
  filter: blur(4px);
}

.hero.hero-essential .hero-grid {
  width: 100%;
  grid-template-columns: minmax(0, .72fr) minmax(320px, .58fr);
}

.hero.hero-essential .hero-copy {
  max-width: 720px;
  padding: clamp(1.15rem, 2.4vw, 1.75rem);
  border: 1px solid rgba(31, 58, 46, .12);
  background: rgba(255, 255, 255, .68);
  box-shadow: 0 24px 70px rgba(31, 58, 46, .12);
  backdrop-filter: blur(12px);
}

.hero.hero-essential h1 {
  max-width: 11ch;
  color: var(--green);
  font-size: clamp(2.25rem, 4.8vw, 4.75rem);
  line-height: .96;
  letter-spacing: -.045em;
}

.hero.hero-essential p:not(.eyebrow) {
  max-width: 44rem;
  color: #34493d;
  font-size: clamp(1rem, 1.5vw, 1.2rem);
}

.hero.hero-essential .hero-visual {
  align-self: end;
}

.hero.hero-essential .hero-card {
  max-width: 330px;
  margin-left: auto;
  border-color: rgba(255, 255, 255, .42);
  background: rgba(31, 58, 46, .86);
  color: #fff;
  box-shadow: 0 22px 55px rgba(31, 58, 46, .22);
}

@media (max-width: 860px) {
  .hero.hero-essential .hero-grid {
    grid-template-columns: 1fr;
  }

  .hero.hero-essential::before {
    background-image: linear-gradient(180deg, rgba(251, 250, 244, .97), rgba(251, 250, 244, .82)), var(--hero-bg);
    background-position: center;
  }

  .hero.hero-essential .hero-copy {
    padding: 1.25rem;
  }

  .hero.hero-essential .hero-visual {
    display: none;
  }
}

/* Why Us section: richer trust cards replacing the old promise strip. */
.why-us {
  padding: 4.2rem 0;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 10%, rgba(195, 162, 76, .16), transparent 28%),
    linear-gradient(135deg, #f8fbf5 0%, #fff 48%, #eef6ee 100%);
  border-top: 1px solid rgba(31, 58, 46, .12);
  border-bottom: 1px solid rgba(31, 58, 46, .12);
}

.why-us::after {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -120px;
  width: 320px;
  height: 320px;
  border-radius: 999px;
  border: 1px solid rgba(31, 58, 46, .12);
  background: rgba(255, 255, 255, .32);
}

.why-us-head {
  max-width: 760px;
  margin-bottom: 1.4rem;
}

.why-us-head h2 {
  margin: .35rem 0 .55rem;
  color: var(--green);
  font-size: clamp(2rem, 4vw, 3.1rem);
}

.why-us-head > p:not(.eyebrow) {
  margin: 0;
  color: #526457;
  line-height: 1.75;
}

.why-us-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  position: relative;
  z-index: 1;
}

.why-us-card {
  min-height: 245px;
  padding: 1.25rem;
  border: 1px solid rgba(31, 58, 46, .13);
  border-radius: 14px;
  background: rgba(255, 255, 255, .84);
  box-shadow: 0 18px 42px rgba(31, 58, 46, .08);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.why-us-card:hover {
  transform: translateY(-4px);
  border-color: rgba(31, 58, 46, .28);
  box-shadow: 0 24px 54px rgba(31, 58, 46, .12);
}

.why-icon {
  display: inline-grid;
  place-items: center;
  width: 46px;
  height: 46px;
  margin-bottom: 1rem;
  border-radius: 999px;
  background: var(--green);
  color: #fff;
  box-shadow: 0 10px 24px rgba(31, 58, 46, .18);
  font-family: var(--serif);
  font-size: 1.25rem;
  font-weight: 700;
}

.why-us-card h3 {
  margin: 0 0 .55rem;
  color: var(--green);
  font-size: 1.15rem;
}

.why-us-card p {
  margin: 0;
  color: #536358;
  line-height: 1.7;
  font-size: .94rem;
}

@media (max-width: 1100px) {
  .why-us-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .why-us {
    padding: 3rem 0;
  }

  .why-us-grid {
    grid-template-columns: 1fr;
  }

  .why-us-card {
    min-height: 0;
  }
}

/* Single-row Why Us card layout refinement. */
.why-us {
  padding: 3.25rem 0;
}

.why-us-head {
  max-width: none;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 1.3rem;
}

.why-us-head .eyebrow,
.why-us-head h2 {
  flex: 0 0 auto;
}

.why-us-head > p:not(.eyebrow) {
  max-width: 520px;
  text-align: right;
}

.why-us-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
}

.why-us-card {
  min-height: 0;
  display: grid;
  grid-template-rows: auto auto 1fr;
  padding: 1rem;
  border-radius: 12px;
}

.why-icon {
  width: 40px;
  height: 40px;
  margin-bottom: .75rem;
  font-size: 1.05rem;
}

.why-us-card h3 {
  font-size: 1rem;
  line-height: 1.25;
}

.why-us-card p {
  font-size: .86rem;
  line-height: 1.55;
}

@media (max-width: 1180px) and (min-width: 681px) {
  .why-us-grid {
    display: flex;
    gap: .85rem;
    overflow-x: auto;
    padding-bottom: .35rem;
    scroll-snap-type: x proximity;
  }

  .why-us-card {
    flex: 0 0 250px;
    scroll-snap-align: start;
  }
}

@media (max-width: 680px) {
  .why-us-head {
    display: block;
  }

  .why-us-head > p:not(.eyebrow) {
    max-width: none;
    text-align: left;
  }

  .why-us-grid {
    display: flex;
    overflow-x: auto;
    gap: .85rem;
    padding-bottom: .4rem;
    scroll-snap-type: x mandatory;
  }

  .why-us-card {
    flex: 0 0 82%;
    scroll-snap-align: start;
  }
}


/* Match Why Us heading with standard home section headers. */
.why-us-head {
  display: block;
  margin-bottom: 1.25rem;
}

.why-us-head h2 {
  margin: 0 0 .65rem;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}

.why-us-head > p:not(.eyebrow) {
  max-width: 680px;
  text-align: left;
}

.why-us-head h2 {
  font-family: "Playfair Display", serif;
  font-size: clamp(1.75rem, 3.2vw, 2.45rem);
  line-height: 1.15;
  letter-spacing: normal;
  color: var(--green);
}

/* Our Philosophy replaces the old Wellness Guides content hub. */
.philosophy-hub {
  padding: 3.35rem 0;
}

.philosophy-head {
  max-width: 860px;
  margin-bottom: 1.15rem;
}

.philosophy-head h2 {
  margin: 0 0 .65rem;
  color: var(--green);
  font-size: clamp(1.75rem, 3.2vw, 2.45rem);
}

.philosophy-head p {
  margin: 0;
  color: #536358;
  line-height: 1.75;
}

.philosophy-grid.hub-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.philosophy-grid.hub-grid article {
  position: relative;
  min-height: 210px;
  padding: 1.15rem;
  overflow: hidden;
  border: 1px solid rgba(31, 58, 46, .13);
  border-radius: 14px;
  background: linear-gradient(145deg, #fff 0%, #f8fbf6 100%);
  box-shadow: 0 18px 42px rgba(31, 58, 46, .08);
}

.philosophy-grid.hub-grid article::after {
  content: "";
  position: absolute;
  right: -36px;
  top: -42px;
  width: 118px;
  height: 118px;
  border-radius: 999px;
  background: rgba(195, 162, 76, .13);
}

.philosophy-icon {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: .85rem;
  border-radius: 999px;
  background: var(--green);
  color: #fff;
  box-shadow: 0 10px 24px rgba(31, 58, 46, .18);
  font-family: var(--serif);
  font-weight: 700;
}

.philosophy-grid h3 {
  margin: 0 0 .55rem;
  color: var(--green);
  font-size: 1.08rem;
}

.philosophy-grid p {
  margin: 0;
  color: #536358;
  font-size: .92rem;
  line-height: 1.65;
}

@media (max-width: 900px) {
  .philosophy-grid.hub-grid {
    display: flex;
    overflow-x: auto;
    gap: .85rem;
    padding-bottom: .35rem;
    scroll-snap-type: x mandatory;
  }

  .philosophy-grid.hub-grid article {
    flex: 0 0 min(82vw, 320px);
    scroll-snap-align: start;
  }
}

/* Hero background slider using the provided nature image while keeping copy unchanged. */
.hero.hero-essential .hero-bg-slider {
  position: absolute;
  inset: 0;
  z-index: -3;
  overflow: hidden;
}

.hero.hero-essential .hero-bg-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.035);
  animation: breuverraHeroSlide 12s infinite;
}

.hero.hero-essential .hero-bg-slide:nth-child(2) {
  animation-delay: 6s;
}

.hero.hero-essential::before {
  z-index: -2;
  background-image: linear-gradient(90deg, rgba(251, 250, 244, .96) 0%, rgba(251, 250, 244, .86) 34%, rgba(251, 250, 244, .34) 62%, rgba(31, 58, 46, .16) 100%);
  background-color: transparent;
}

@keyframes breuverraHeroSlide {
  0%, 45% { opacity: 1; transform: scale(1.02); }
  50%, 95% { opacity: 0; transform: scale(1.055); }
  100% { opacity: 1; transform: scale(1.02); }
}

@media (prefers-reduced-motion: reduce) {
  .hero.hero-essential .hero-bg-slide {
    animation: none;
  }

  .hero.hero-essential .hero-bg-slide:first-child {
    opacity: 1;
  }
}

@media (max-width: 860px) {
  .hero.hero-essential::before {
    background-image: linear-gradient(180deg, rgba(251, 250, 244, .97), rgba(251, 250, 244, .78));
  }
}

.hero.hero-essential .hero-card span {
  display: block;
}

.hero.hero-essential .hero-card span + span {
  margin-top: .35rem;
}

/* Align Our Philosophy with the Why Us section design language. */
.philosophy-hub {
  padding: 3.25rem 0;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 10%, rgba(195, 162, 76, .16), transparent 28%),
    linear-gradient(135deg, #f8fbf5 0%, #fff 48%, #eef6ee 100%);
  border-top: 1px solid rgba(31, 58, 46, .12);
  border-bottom: 1px solid rgba(31, 58, 46, .12);
}

.philosophy-hub::after {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -120px;
  width: 320px;
  height: 320px;
  border-radius: 999px;
  border: 1px solid rgba(31, 58, 46, .12);
  background: rgba(255, 255, 255, .32);
}

.philosophy-head,
.philosophy-grid.hub-grid {
  position: relative;
  z-index: 1;
}

.philosophy-head h2 {
  font-family: "Playfair Display", serif;
  font-size: clamp(1.75rem, 3.2vw, 2.45rem);
  line-height: 1.15;
  color: var(--green);
}

.philosophy-grid.hub-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
}

.philosophy-grid.hub-grid article {
  min-height: 0;
  display: grid;
  grid-template-rows: auto auto 1fr;
  padding: 1rem;
  border-radius: 12px;
  border: 1px solid rgba(31, 58, 46, .13);
  background: rgba(255, 255, 255, .84);
  box-shadow: 0 18px 42px rgba(31, 58, 46, .08);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.philosophy-grid.hub-grid article:hover {
  transform: translateY(-4px);
  border-color: rgba(31, 58, 46, .28);
  box-shadow: 0 24px 54px rgba(31, 58, 46, .12);
}

.philosophy-grid.hub-grid article::after {
  display: none;
}

.philosophy-icon {
  width: 40px;
  height: 40px;
  margin-bottom: .75rem;
  background: var(--green);
  color: #fff;
  font-size: 1.05rem;
}

.philosophy-grid h3 {
  font-size: 1rem;
  line-height: 1.25;
}

.philosophy-grid p {
  font-size: .86rem;
  line-height: 1.55;
}

/* Final alignment: Our Philosophy must match Why Us card proportions exactly. */
.philosophy-grid.hub-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
}

.philosophy-grid.hub-grid article {
  min-height: 0;
  padding: 1rem;
}

@media (max-width: 1180px) and (min-width: 681px) {
  .philosophy-grid.hub-grid {
    display: flex;
    gap: .85rem;
    overflow-x: auto;
    padding-bottom: .35rem;
    scroll-snap-type: x proximity;
  }

  .philosophy-grid.hub-grid article {
    flex: 0 0 250px;
    scroll-snap-align: start;
  }
}

/* Customer review marquee. */
.testimonials {
  overflow: hidden;
}

.testimonials h2 {
  margin-bottom: 1rem;
}

.testimonial-marquee {
  position: relative;
  overflow: hidden;
  padding: .25rem 0 .45rem;
  mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
}

.testimonial-track {
  display: flex;
  width: max-content;
  gap: 1rem;
  animation: breuverraReviewsScroll 42s linear infinite;
}

.testimonial-marquee:hover .testimonial-track {
  animation-play-state: paused;
}

.testimonial-track blockquote {
  flex: 0 0 360px;
  min-height: 155px;
  margin: 0;
  border: 1px solid rgba(31, 58, 46, .13);
  border-radius: 14px;
  padding: 1.1rem;
  background: #fff;
  box-shadow: 0 16px 36px rgba(31, 58, 46, .07);
  color: #536358;
  line-height: 1.65;
}

.testimonial-track cite {
  display: block;
  margin-top: .8rem;
  color: var(--green);
  font-style: normal;
  font-weight: 800;
}

@keyframes breuverraReviewsScroll {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-50% - .5rem)); }
}

@media (prefers-reduced-motion: reduce) {
  .testimonial-track {
    animation: none;
    flex-wrap: wrap;
    width: auto;
  }
}

@media (max-width: 680px) {
  .testimonial-track blockquote {
    flex-basis: 82vw;
  }
}

/* Unified login/register auth design. */
.breuverra-auth-panel,
.woocommerce-account:not(.logged-in) .woocommerce .u-columns {
  width: min(1040px, 92vw);
  margin: 2rem auto 3.5rem;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(280px, .78fr);
  gap: 1.25rem;
  align-items: stretch;
}

.breuverra-auth-panel {
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow: visible;
}

.breuverra-auth-panel .auth-copy,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
  position: relative;
  display: grid;
  align-content: center;
  min-height: 360px;
  padding: 1.5rem;
  overflow: hidden;
  border: 1px solid rgba(31, 58, 46, .16);
  border-radius: 18px;
  background:
    radial-gradient(circle at 18% 10%, rgba(195, 162, 76, .24), transparent 32%),
    linear-gradient(145deg, #1f3a2e 0%, #274d3d 100%);
  color: #fff;
  box-shadow: 0 22px 52px rgba(31, 58, 46, .13);
}

.breuverra-auth-panel .auth-copy::after,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2::after {
  color: rgba(255, 255, 255, .84);
}

.breuverra-auth-panel .auth-copy .eyebrow {
  color: rgba(255, 255, 255, .76);
}

.breuverra-auth-panel .auth-copy h1,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2::before {
  color: #fff;
  font-family: "Playfair Display", serif;
  font-size: clamp(1.65rem, 3vw, 2.35rem);
  line-height: 1.12;
  margin: .35rem 0 .8rem;
}

.breuverra-auth-panel .auth-copy p:not(.eyebrow) {
  margin: 0;
  color: rgba(255, 255, 255, .84);
  line-height: 1.7;
}

.breuverra-register-wrap,
.woocommerce-account:not(.logged-in) .woocommerce .u-column1 {
  position: relative;
  overflow: hidden;
  border: 1px solid #dfe9df;
  border-radius: 18px;
  background:
    radial-gradient(circle at 14% 12%, rgba(195, 162, 76, .14), transparent 32%),
    linear-gradient(145deg, #ffffff 0%, #f8fbf6 100%);
  box-shadow: 0 22px 52px rgba(31, 58, 46, .09);
}

.breuverra-register-wrap {
  display: grid;
  align-content: center;
  padding: 1.5rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 h2,
.breuverra-register-success h2 {
  color: var(--green);
  font-family: "Playfair Display", serif;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 h2 {
  font-size: clamp(1.85rem, 3.8vw, 2.8rem);
}

.breuverra-register-form,
.woocommerce-account:not(.logged-in) .woocommerce .u-column1 form.login,
.woocommerce-account .woocommerce form.login {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.breuverra-register-form .form-row,
.woocommerce-account:not(.logged-in) .woocommerce form.login .form-row {
  margin-bottom: .95rem;
}

.breuverra-register-form label,
.woocommerce-account:not(.logged-in) .woocommerce form.login label,
.woocommerce-account .woocommerce form label {
  display: inline-flex;
  align-items: center;
  margin-bottom: .35rem;
  color: var(--green);
  font-weight: 900;
  letter-spacing: -.01em;
}

.breuverra-register-form input.input-text,
.breuverra-register-form input[type="text"],
.breuverra-register-form input[type="email"],
.breuverra-register-form input[type="tel"],
.breuverra-register-form input[type="password"],
.woocommerce-account:not(.logged-in) .woocommerce form.login input.input-text,
.woocommerce-account:not(.logged-in) .woocommerce form.login input[type="text"],
.woocommerce-account:not(.logged-in) .woocommerce form.login input[type="password"],
.woocommerce-account:not(.logged-in) .woocommerce form.login input[type="email"] {
  width: 100%;
  min-height: 50px;
  border: 1px solid #d9e8da;
  border-radius: 999px;
  background: rgba(255, 255, 255, .9);
  color: var(--green);
  padding: .85rem 1rem;
  outline: none;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.breuverra-register-form input:focus,
.woocommerce-account:not(.logged-in) .woocommerce form.login input:focus {
  border-color: rgba(31, 58, 46, .42);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(31, 58, 46, .08);
}

.breuverra-register-form .button,
.breuverra-register-success .button,
.woocommerce-account:not(.logged-in) .woocommerce button.button,
.woocommerce-account:not(.logged-in) .woocommerce .button,
.woocommerce-account .woocommerce .breuverra-register-cta {
  min-height: 50px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--green) !important;
  border-radius: 999px !important;
  background: var(--green) !important;
  color: #fff !important;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 12px 24px rgba(31, 58, 46, .14);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.breuverra-register-form .button,
.woocommerce-account .woocommerce .breuverra-register-cta {
  width: 100%;
}

.breuverra-register-form .button:hover,
.breuverra-register-success .button:hover,
.woocommerce-account:not(.logged-in) .woocommerce button.button:hover,
.woocommerce-account:not(.logged-in) .woocommerce .button:hover,
.woocommerce-account .woocommerce .breuverra-register-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(31, 58, 46, .18);
}

.otp-channel {
  gap: .6rem;
}

.otp-channel label,
.woocommerce-account .woocommerce-form-login__rememberme,
.breuverra-login-helper,
.auth-note {
  border: 1px solid #d9e8da;
  border-radius: 16px;
  background: rgba(246, 250, 246, .88);
}

.otp-channel label {
  min-height: 48px;
  border-radius: 999px;
  font-weight: 800;
  color: var(--green);
}

.auth-note,
.auth-switch {
  line-height: 1.65;
}

.auth-note {
  padding: .85rem 1rem;
  color: #536358;
}

.auth-switch {
  margin: 1rem 0 0;
  text-align: center;
}

.auth-switch a,
.woocommerce-account .lost_password a {
  color: var(--green);
  font-weight: 900;
}

.breuverra-login-helper {
  margin-top: 1rem;
  padding: 1rem;
}

.breuverra-login-helper span {
  color: var(--green);
  font-weight: 900;
}

.breuverra-login-helper p {
  color: #536358;
  line-height: 1.6;
}

.breuverra-otp-input {
  border-radius: 18px !important;
}

@media (max-width: 860px) {
  .breuverra-auth-panel,
  .woocommerce-account:not(.logged-in) .woocommerce .u-columns {
    grid-template-columns: 1fr;
  }

  .breuverra-auth-panel .auth-copy,
  .woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
    min-height: 0;
  }
}

/* Make the hero copy panel more transparent over the background slider. */
.hero.hero-essential .hero-copy {
  background: rgba(255, 255, 255, .46);
  border-color: rgba(255, 255, 255, .42);
  box-shadow: 0 22px 62px rgba(31, 58, 46, .10);
  backdrop-filter: blur(10px) saturate(1.04);
}

/* Login screen polish: compact, consistent BreuVerra account design. */
.woocommerce-account:not(.logged-in) .page-block > h1,
.woocommerce-account:not(.logged-in) .entry-title {
  width: min(1040px, 92vw);
  margin: 1.25rem auto .65rem;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1.05;
}

.woocommerce-account:not(.logged-in) .woocommerce {
  margin-top: .75rem;
  margin-bottom: 2.6rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns {
  align-items: stretch;
  gap: 1rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
  border-radius: 18px;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 {
  min-height: auto;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1::before {
  padding: 1.15rem 1.35rem 0;
  color: #b59a6a;
  font-size: .72rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 h2 {
  margin: .28rem 1.35rem .85rem;
  font-size: clamp(2rem, 3.6vw, 3.35rem);
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column1 form.login {
  padding: 0 1.35rem 1.25rem !important;
}

.woocommerce-account:not(.logged-in) .woocommerce form.login label {
  margin-bottom: .35rem;
  font-size: .98rem;
}

.woocommerce-account:not(.logged-in) .woocommerce form.login input.input-text {
  min-height: 48px;
  border-radius: 14px;
  background: #fbfdf9 !important;
  box-shadow: inset 0 0 0 999px #fbfdf9;
  -webkit-text-fill-color: var(--green);
}

.woocommerce-account:not(.logged-in) .woocommerce form.login input.input-text:-webkit-autofill,
.woocommerce-account:not(.logged-in) .woocommerce form.login input.input-text:-webkit-autofill:hover,
.woocommerce-account:not(.logged-in) .woocommerce form.login input.input-text:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px #fbfdf9 inset, 0 0 0 4px rgba(31, 58, 46, .08) !important;
  -webkit-text-fill-color: var(--green) !important;
  caret-color: var(--green);
}

.woocommerce-account:not(.logged-in) .woocommerce form.login .password-input input {
  padding-right: 3.4rem !important;
}

.woocommerce-account:not(.logged-in) .woocommerce form .show-password-input,
.woocommerce-account:not(.logged-in) .woocommerce-page form .show-password-input {
  right: .7rem !important;
  width: 2rem !important;
  height: 2rem !important;
  border-color: rgba(31, 58, 46, .16);
  background: #fff;
  box-shadow: 0 6px 16px rgba(31, 58, 46, .08);
}

.woocommerce-account:not(.logged-in) .woocommerce form .show-password-input::after,
.woocommerce-account:not(.logged-in) .woocommerce-page form .show-password-input::after {
  content: "Show";
  font-size: .56rem;
}

.woocommerce-account:not(.logged-in) .woocommerce form .show-password-input.display-password::after,
.woocommerce-account:not(.logged-in) .woocommerce-page form .show-password-input.display-password::after {
  content: "Hide";
}

.woocommerce-account:not(.logged-in) .woocommerce .form-row:has(.woocommerce-form-login__submit) {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: .8rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .woocommerce-form-login__submit {
  min-width: 112px;
  padding-inline: 1.25rem !important;
}

.woocommerce-account:not(.logged-in) .woocommerce .woocommerce-form-login__rememberme {
  min-height: 44px;
  margin: 0;
  padding: .55rem .85rem;
  border-radius: 999px;
  background: #fff;
  font-size: .95rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .woocommerce-form-login__rememberme input {
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
}

.woocommerce-account:not(.logged-in) .woocommerce .lost_password {
  margin: .2rem 0 .9rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .lost_password a {
  display: inline-flex;
  color: var(--green);
  font-weight: 900;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.woocommerce-account:not(.logged-in) .breuverra-login-helper {
  margin-top: .85rem;
  padding: 1rem;
  border-radius: 16px;
  background: linear-gradient(145deg, rgba(247, 250, 246, .96), #fff);
}

.woocommerce-account:not(.logged-in) .breuverra-login-helper p {
  margin-bottom: .85rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
  min-height: 500px;
  align-content: end;
  padding: 1.9rem;
  background:
    radial-gradient(circle at 20% 16%, rgba(195, 162, 76, .18), transparent 34%),
    radial-gradient(circle at 84% 78%, rgba(255, 255, 255, .08), transparent 36%),
    linear-gradient(145deg, #1f3a2e 0%, #274d3d 100%);
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2::before {
  content: "Welcome to BreuVerra";
  max-width: 9ch;
  margin-bottom: .85rem;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2::after {
  content: "Create a verified account with email OTP, save your addresses, track orders, and reorder your favourite oils faster.";
  max-width: 430px;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
  position: relative;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2 .woocommerce-form-register,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2 form.register {
  display: none !important;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-column2 h2 {
  display: none !important;
}

@media (max-width: 860px) {
  .woocommerce-account:not(.logged-in) .woocommerce .u-column2 {
    min-height: 260px;
    align-content: center;
  }
}

/* Home product cards aligned with shop listing UI. */
.home-product-card {
  display: flex;
  flex-direction: column;
  padding: .75rem;
  border-radius: 8px;
  overflow: hidden;
}

.home-product-card .product-image {
  overflow: hidden;
  border-radius: 0;
}

.home-product-card .quick-cta,
.home-product-card .card-tools {
  display: none !important;
}

.home-product-card h3 {
  margin: .8rem 0 .45rem;
  color: var(--green);
  font-size: 1rem;
  line-height: 1.25;
}

.home-product-card h3 a {
  color: inherit;
}

.home-product-card .rating,
.home-product-card .price-line {
  margin-left: 0;
  margin-right: 0;
}

.home-product-card .price-line {
  min-height: 1.35rem;
  color: #9b8f28;
  font-weight: 700;
}

.home-product-card .price-line del {
  margin-right: .25rem;
  color: rgba(155, 143, 40, .62);
}

.home-product-card .price-line ins {
  color: #9b8f28;
  text-decoration: none;
}

.home-product-card .home-product-button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 48px;
  margin-top: auto;
  border: 1px solid var(--green) !important;
  border-radius: 999px !important;
  background: var(--green) !important;
  color: #fff !important;
  font-weight: 900;
  text-align: center;
  text-decoration: none;
  box-shadow: none;
}

.home-product-card .home-product-button:hover {
  background: #2b5946 !important;
  color: #fff !important;
}

/* BreuVerra journal and blog filters. */
.breu-blog-page,
.breu-single-post {
  background: linear-gradient(180deg, #fbfdf9 0%, #fff 42%, #f7fbf4 100%);
  color: var(--green);
}

.breu-blog-breadcrumbs {
  padding-top: 1.35rem;
  padding-bottom: .35rem;
}

.breu-blog-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 290px;
  gap: 1.5rem;
  align-items: end;
  padding: 2rem 0 1.25rem;
}

.breu-blog-hero h1,
.breu-single-header h1 {
  max-width: 860px;
  margin: .25rem 0 .75rem;
  color: var(--green);
  font-family: var(--font-serif);
  font-size: clamp(2.35rem, 5vw, 4.8rem);
  line-height: .98;
  letter-spacing: -.04em;
}

.breu-blog-hero p:not(.section-kicker) {
  max-width: 760px;
  margin: 0;
  color: rgba(29, 65, 49, .72);
  font-size: 1.08rem;
  line-height: 1.7;
}

.breu-blog-hero-card {
  display: grid;
  gap: .55rem;
  padding: 1.35rem;
  border: 1px solid rgba(29, 65, 49, .14);
  border-radius: 22px;
  background: rgba(255, 255, 255, .82);
  box-shadow: 0 22px 50px rgba(29, 65, 49, .08);
}

.breu-blog-hero-card span {
  width: max-content;
  padding: .35rem .8rem;
  border-radius: 999px;
  background: var(--green);
  color: #fff;
  font-weight: 900;
  font-size: .82rem;
}

.breu-blog-hero-card strong {
  color: var(--green);
  font-size: 1.05rem;
  line-height: 1.35;
}

.breu-blog-tools {
  display: grid;
  gap: 1rem;
  margin-bottom: 1.45rem;
}

.breu-blog-filter {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(210px, 280px) auto auto;
  gap: .75rem;
  align-items: center;
  padding: .8rem;
  border: 1px solid rgba(29, 65, 49, .14);
  border-radius: 22px;
  background: rgba(255, 255, 255, .88);
  box-shadow: 0 18px 42px rgba(29, 65, 49, .06);
}

.breu-blog-filter input,
.breu-blog-filter select {
  width: 100%;
  min-height: 52px;
  border: 1px solid rgba(29, 65, 49, .16);
  border-radius: 999px;
  background: #fbfdf9;
  color: var(--green);
  font: inherit;
  font-weight: 800;
  outline: none;
  padding: 0 1.1rem;
}

.breu-blog-filter input:focus,
.breu-blog-filter select:focus {
  border-color: rgba(29, 65, 49, .42);
  box-shadow: 0 0 0 4px rgba(29, 65, 49, .08);
}

.breu-blog-filter button,
.breu-blog-reset,
.breu-blog-empty a,
.breu-single-footer a {
  display: inline-flex;
  min-height: 52px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--green);
  border-radius: 999px;
  background: var(--green);
  color: #fff !important;
  font-weight: 900;
  text-decoration: none;
  padding: 0 1.35rem;
  cursor: pointer;
}

.breu-blog-reset {
  background: transparent;
  color: var(--green) !important;
}

.breu-blog-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}

.breu-blog-chips a {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .65rem 1rem;
  border: 1px solid rgba(29, 65, 49, .14);
  border-radius: 999px;
  background: rgba(245, 250, 244, .92);
  color: var(--green);
  font-weight: 850;
  text-decoration: none;
}

.breu-blog-chips a.active,
.breu-blog-chips a:hover {
  background: var(--green);
  color: #fff;
}

.breu-blog-chips span {
  opacity: .72;
}

.breu-blog-count {
  margin: 0 0 1rem;
  color: rgba(29, 65, 49, .72);
  font-weight: 850;
}

.breu-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  padding-bottom: 2rem;
}

.breu-blog-card {
  overflow: hidden;
  border: 1px solid rgba(29, 65, 49, .14);
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(29, 65, 49, .07);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.breu-blog-card:hover {
  transform: translateY(-4px);
  border-color: rgba(29, 65, 49, .26);
  box-shadow: 0 26px 58px rgba(29, 65, 49, .12);
}

.breu-blog-thumb {
  position: relative;
  display: block;
  aspect-ratio: 1.52 / 1;
  overflow: hidden;
  background: linear-gradient(135deg, #edf5ed, #f8f4e8);
}

.breu-blog-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}

.breu-blog-card:hover .breu-blog-thumb img {
  transform: scale(1.045);
}

.breu-blog-thumb span {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: rgba(29, 65, 49, .72);
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 900;
}

.breu-blog-card-body {
  display: grid;
  gap: .7rem;
  padding: 1.2rem;
}

.breu-blog-meta,
.breu-single-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  align-items: center;
  color: rgba(29, 65, 49, .62);
  font-size: .86rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.breu-blog-meta span:first-child {
  color: #a88e2a;
}

.breu-blog-card h2 {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(1.35rem, 2vw, 1.75rem);
  line-height: 1.08;
  letter-spacing: -.025em;
}

.breu-blog-card h2 a {
  color: var(--green);
  text-decoration: none;
}

.breu-blog-card p {
  margin: 0;
  color: rgba(29, 65, 49, .7);
  line-height: 1.6;
}

.breu-blog-read {
  display: inline-flex;
  width: max-content;
  align-items: center;
  color: var(--green);
  font-weight: 950;
  text-decoration: underline;
  text-underline-offset: 5px;
}

.breu-blog-pagination ul {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: center;
  margin: 1rem 0 3rem;
  padding: 0;
  list-style: none;
}

.breu-blog-pagination a,
.breu-blog-pagination span {
  display: inline-flex;
  min-width: 44px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(29, 65, 49, .16);
  border-radius: 999px;
  color: var(--green);
  font-weight: 900;
  text-decoration: none;
  padding: 0 .9rem;
}

.breu-blog-pagination .current,
.breu-blog-pagination a:hover {
  background: var(--green);
  color: #fff;
}

.breu-blog-empty {
  margin: 2rem 0 4rem;
  padding: 2rem;
  border: 1px solid rgba(29, 65, 49, .14);
  border-radius: 24px;
  background: #fff;
  text-align: center;
}

.breu-single-article {
  max-width: 980px;
  padding-bottom: 4rem;
}

.breu-single-header {
  padding: 1.5rem 0 1rem;
}

.breu-single-featured {
  overflow: hidden;
  margin: 0 0 2rem;
  border-radius: 28px;
  border: 1px solid rgba(29, 65, 49, .12);
  box-shadow: 0 28px 70px rgba(29, 65, 49, .1);
}

.breu-single-featured img {
  display: block;
  width: 100%;
  max-height: 520px;
  object-fit: cover;
}

.breu-single-content {
  max-width: 760px;
  margin: 0 auto;
  color: rgba(29, 65, 49, .78);
  font-size: 1.1rem;
  line-height: 1.85;
}

.breu-single-content p:first-child::first-letter {
  float: left;
  margin: .08em .12em 0 0;
  color: var(--green);
  font-family: var(--font-serif);
  font-size: 4.2rem;
  line-height: .8;
}

.breu-single-footer {
  max-width: 760px;
  margin: 2rem auto 0;
}

@media (max-width: 980px) {
  .breu-blog-hero,
  .breu-blog-filter {
    grid-template-columns: 1fr;
  }

  .breu-blog-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .breu-blog-hero {
    padding-top: 1rem;
  }

  .breu-blog-grid {
    grid-template-columns: 1fr;
  }

  .breu-blog-filter {
    padding: .7rem;
    border-radius: 18px;
  }

  .breu-blog-filter button,
  .breu-blog-reset {
    width: 100%;
  }
}

/* Home product sections now reuse the exact WooCommerce shop loop card UI. */
.breu-home-product-loop ul.products.breu-home-products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 1rem !important;
  align-items: stretch;
  margin: 0 !important;
  padding: 0 !important;
}

.breu-home-product-loop ul.products.breu-home-products::before,
.breu-home-product-loop ul.products.breu-home-products::after {
  content: none !important;
  display: none !important;
}

.breu-home-product-loop ul.products.breu-home-products li.product {
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  float: none !important;
  clear: none !important;
  margin: 0 !important;
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.breu-home-product-loop ul.products.breu-home-products li.product:hover,
.breu-home-product-loop ul.products.breu-home-products li.product:focus-within {
  z-index: 12;
}

.breu-home-product-loop ul.products.breu-home-products li.product .button,
.breu-home-product-loop ul.products.breu-home-products li.product a.button,
.breu-home-product-loop ul.products.breu-home-products li.product .product-view-cart {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #fff !important;
  text-align: center;
}

.breu-home-product-loop ul.products.breu-home-products li.product a.added_to_cart {
  display: none !important;
}

@media (max-width: 1100px) {
  .breu-home-product-loop ul.products.breu-home-products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 680px) {
  .breu-home-product-loop ul.products.breu-home-products {
    grid-template-columns: 1fr !important;
  }
}

/* Safer compact size chips on product listing cards for future extra variants. */
.woocommerce ul.products li.product .loop-variation-panel {
  padding: .62rem .58rem .66rem;
}

.woocommerce ul.products li.product .loop-variation-options {
  grid-template-columns: repeat(auto-fit, minmax(58px, 1fr));
  gap: .32rem;
}

.woocommerce ul.products li.product .loop-variation-chip {
  min-height: 40px;
  padding: .32rem .18rem;
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: -.01em;
}

.woocommerce ul.products li.product .loop-variation-chip span {
  font-size: clamp(.8rem, 1.55vw, .9rem) !important;
  line-height: 1;
  white-space: nowrap;
}

.woocommerce ul.products li.product .loop-variation-chip small {
  font-size: .58rem;
  line-height: 1.05;
}

@media (max-width: 680px) {
  .woocommerce ul.products li.product .loop-variation-options {
    grid-template-columns: repeat(auto-fit, minmax(54px, 1fr));
  }

  .woocommerce ul.products li.product .loop-variation-chip span {
    font-size: .8rem !important;
  }
}
