.bb-woocommerce-main,
.bb-woo-archive,
.bb-single-product-page {
  padding-block: 1.1rem 2.2rem;
}

/* Allow cart & checkout pages to use full container width */
.woocommerce-cart .bb-entry-content,
.woocommerce-checkout .bb-entry-content {
  max-width: none;
}

.bb-shop-header {
  margin-bottom: 1rem;
}

.bb-shop-header .woocommerce-products-header__description {
  max-width: 62ch;
  color: var(--bb-muted);
}

.bb-shop-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.bb-shop-toolbar .woocommerce-result-count {
  margin: 0;
  color: var(--bb-muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.bb-shop-toolbar .woocommerce-ordering select {
  border: 1px solid var(--bb-line);
  background: #fff;
  padding: 0.58rem 0.75rem;
  font: inherit;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ── Product grid (Oliver Bonas–inspired) ── */

ul.products.bb-products-grid,
ul.products {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3px;
  padding: 0;
  margin: 0;
  list-style: none;
}

/* Remove WooCommerce clearfix pseudo-elements that break grid layout */
ul.products::before,
ul.products::after,
.woocommerce ul.products::before,
.woocommerce ul.products::after {
  content: none !important;
  display: none !important;
}

.bb-product-card,
.woocommerce ul.products li.product.bb-product-card {
  margin: 0;
  border: none;
  background: #FBF7F1;
  display: flex;
  flex-direction: column;
  float: none;
  width: auto;
}

.bb-product-card__media {
  display: block;
  position: relative;
  overflow: hidden;
}

.bb-product-card__media img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  background: #ece9e2;
  display: block;
  transition: transform 0.35s ease;
}

.bb-product-card:hover .bb-product-card__media img {
  transform: scale(1.03);
}

/* ── Card footer: "+ Dodaj" and wishlist ── */

.bb-product-card__footer {
  display: flex;
  align-items: center;
  border-top: 1px solid var(--bb-line);
}

.bb-product-card__add {
  flex: 1;
}

.bb-product-card__add .button,
.woocommerce ul.products li.product .button {
  display: block;
  width: 100%;
  border: none;
  border-radius: 0;
  background: transparent;
  color: var(--bb-charcoal);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 0.6rem 0.8rem;
  text-align: center;
  cursor: pointer;
  transition: background 0.15s;
}

.bb-product-card__add .button::before,
.woocommerce ul.products li.product .button::before {
  content: "+ ";
}

.bb-product-card__add .button:hover,
.woocommerce ul.products li.product .button:hover {
  background: var(--bb-cream);
}

/* Cart toggle: "in cart" state → "- USUŃ Z KOSZYKA" */
.bb-product-card__add .bb-in-cart::before,
.woocommerce ul.products li.product .bb-in-cart::before {
  content: "- ";
}
/* Hide WC "View cart" link and checkmark after AJAX add */
.bb-product-card__add .added_to_cart,
.woocommerce ul.products li.product .added_to_cart {
  display: none;
}
.bb-product-card__add .added::after,
.woocommerce ul.products li.product .added::after {
  display: none !important;
}

.bb-product-card__wishlist {
  width: 2.6rem;
  height: auto;
  align-self: stretch;
  border: none;
  border-left: 1px solid var(--bb-line);
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--bb-muted);
  transition: color 0.15s;
}

.bb-product-card__wishlist:hover {
  color: var(--bb-charcoal);
}

/* ── YITH: hide ALL feedback popups (white rectangle artifact + messages) ── */
#yith-wcwl-popup-message,
.yith-wcwl-add-to-wishlist__feedback,
.yith-wcwl-feedback-messages-container,
.yith-wcwl-popup-feedback,
.yith-wcwl-feedback-modal {
  display: none !important;
}

/* ── YITH Wishlist – global heart colours ── */
.yith-wcwl-add-to-wishlist .yith-wcwl-icon-svg {
  width: 1.1em;
  height: 1.1em;
  vertical-align: middle;
}
/* Filled heart (added / exists / remove) → red */
.yith-wcwl-wishlistaddedbrowse .yith-wcwl-icon-svg,
.yith-wcwl-wishlistexistsbrowse .yith-wcwl-icon-svg,
.yith-wcwl-add-to-wishlist .delete_item .yith-wcwl-icon-svg,
.yith-wcwl-add-to-wishlist.exists .yith-wcwl-icon-svg {
  color: #e74c3c !important;
}

/* ── YITH Wishlist inside product card (loop) ── */
.bb-product-card__footer .yith-wcwl-add-to-wishlist {
  width: 2.6rem;
  align-self: stretch;
  border-left: 1px solid var(--bb-line);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}
/* Hide all text — show only the SVG icon */
.bb-product-card__footer .yith-wcwl-add-to-wishlist a,
.bb-product-card__footer .yith-wcwl-add-to-wishlist .feedback {
  font-size: 0;
  line-height: 0;
  color: var(--bb-muted);
  transition: color 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bb-product-card__footer .yith-wcwl-add-to-wishlist .yith-wcwl-icon-svg {
  font-size: initial;
  width: 1.1rem;
  height: 1.1rem;
}
.bb-product-card__footer .yith-wcwl-add-to-wishlist a:hover {
  color: var(--bb-charcoal);
}
/* "Added/Remove" state in card: red heart for delete_item links */
.bb-product-card__footer .yith-wcwl-add-to-wishlist .delete_item,
.bb-product-card__footer .yith-wcwl-add-to-wishlist.exists a {
  color: #e74c3c;
}
/* "Browse" fallback: show red filled heart from .feedback, hide text */
.bb-product-card__footer .yith-wcwl-wishlistaddedbrowse .feedback,
.bb-product-card__footer .yith-wcwl-wishlistexistsbrowse .feedback {
  display: flex;
  color: #e74c3c;
}
/* Hide the browse link in card — only the heart is needed */
.bb-product-card__footer .yith-wcwl-wishlistaddedbrowse a,
.bb-product-card__footer .yith-wcwl-wishlistexistsbrowse a {
  display: none;
}

/* ── YITH Wishlist on single product page ── */
.bb-single-product__summary .yith-wcwl-add-to-wishlist {
  margin-top: 0.6rem;
}
.bb-single-product__summary .yith-wcwl-add-to-wishlist a {
  color: var(--bb-charcoal);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
}
.bb-single-product__summary .yith-wcwl-add-to-wishlist a:hover {
  color: #e74c3c;
}
.bb-single-product__summary .yith-wcwl-wishlistaddedbrowse .feedback {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  color: #e74c3c;
}
.bb-single-product__summary .yith-wcwl-wishlistaddedbrowse a {
  font-size: 0.8rem;
  color: var(--bb-muted);
  margin-left: 0.3rem;
}
.bb-single-product__summary .yith-wcwl-wishlistaddedbrowse a:hover {
  color: var(--bb-charcoal);
}

/* ── Card content: name + price ── */

.bb-product-card__content {
  text-align: left;
  padding: 0.45rem 0.6rem 0.6rem;
}

.bb-product-card__content h2 {
  margin: 0;
  font-size: 0.78rem;
  font-family: var(--bb-sans);
  font-weight: 400;
  text-transform: none;
  line-height: 1.35;
}

.bb-product-card__content h2 a {
  color: var(--bb-charcoal);
}

.bb-product-card__content .price {
  display: block;
  margin-top: 0.15rem;
  color: var(--bb-muted);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* ── General WooCommerce buttons (single product, cart, etc.) ── */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  border: 1px solid var(--bb-black);
  background: var(--bb-black);
  color: #fff;
  font-size: 0.73rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  border-radius: 0;
  padding: 0.7rem 1rem;
  font-weight: 700;
}

.bb-single-product {
  display: grid;
  grid-template-columns: minmax(0, 420px) 1fr;
  gap: 1.4rem;
  margin-bottom: 1.2rem;
}

.bb-single-product__gallery .woocommerce-product-gallery {
  margin-bottom: 0;
}

/* Gallery thumbnail navigation */
.woocommerce-product-gallery .flex-control-thumbs {
  list-style: none;
  display: flex;
  gap: 0.5rem;
  margin: 0.5rem 0 0;
  padding: 0;
}

.woocommerce-product-gallery .flex-control-thumbs li {
  flex: 0 0 auto;
  width: 80px;
}

.woocommerce-product-gallery .flex-control-thumbs li img {
  width: 100%;
  height: auto;
  cursor: pointer;
  opacity: 0.6;
  transition: opacity 0.2s;
}

.woocommerce-product-gallery .flex-control-thumbs li img.flex-active {
  opacity: 1;
}


.bb-single-product__summary {
  border: 1px solid var(--bb-line);
  background: #FBF7F1;
  padding: 1rem;
}

.bb-single-product__summary .product_title {
  font-size: clamp(2rem, 3.5vw, 3.4rem);
  text-transform: uppercase;
}

.bb-single-product__summary .price {
  margin: 0.55rem 0 1rem;
  color: var(--bb-muted);
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 700;
}

.bb-single-product__summary .quantity input {
  border: 1px solid var(--bb-line);
  padding: 0.44rem;
}

.bb-single-product__summary .single_add_to_cart_button {
  margin-left: 0.6rem;
  background: #000000 !important;
  color: #ffffff !important;
}

/* Hide SKU, category, stock count on product page */
.bb-single-product__summary .product_meta {
  display: none;
}

.bb-single-product__summary .stock {
  display: none;
}

/* Out of stock button style */
.bb-single-product__summary .out-of-stock-notice {
  display: inline-block;
  padding: 0.7rem 1.6rem;
  background: #D3D3D3;
  color: var(--bb-charcoal);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: none;
  cursor: default;
}

.bb-single-product__tabs {
  margin-top: 1.2rem;
}

/* Legacy accordion styles — superseded by .bb-product-accordion editorial rules below.
   Keep selectors but neutralize box-borders/backgrounds. */
.bb-product-accordion {
  border: 0;
  background: transparent;
}
.bb-accordion-item + .bb-accordion-item {
  border-top: 0;
}
.bb-accordion-trigger {
  width: 100%;
  border: 0;
  background: transparent;
  text-align: left;
  padding: 0;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.bb-accordion-panel {
  padding: 0 0 1.5rem;
  border-top: 0;
  background: transparent;
}

.bb-single-product__related {
  margin-top: 1.7rem;
}

.bb-single-product__related > h2 {
  margin-bottom: 0.9rem;
  text-transform: uppercase;
  font-size: clamp(1.7rem, 3.3vw, 3rem);
}

.bb-myaccount-nav {
  border: 1px solid var(--bb-line);
  background: #fff;
}

.bb-myaccount-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.bb-myaccount-nav li + li {
  border-top: 1px solid var(--bb-line);
}

.bb-myaccount-nav a {
  display: block;
  padding: 0.72rem 0.9rem;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  font-weight: 700;
}

.bb-account-page {
  padding-block: 0;
}

/* Legacy account layout — neutralized. New editorial Mockup A layout is below. */
.woocommerce-account .bb-account-shell .woocommerce {
  display: block;
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-navigation,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content {
  float: none;
  width: auto;
  margin: 0;
  grid-column: auto;
  grid-row: auto;
  border: 0;
  background: transparent;
  padding: 0;
  min-width: 0;
}

.bb-myaccount-nav .is-active > a {
  background: var(--bb-cream);
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content table.shop_table {
  width: 100%;
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-info {
  width: 100%;
  display: block;
  position: relative;
  padding: 0.95rem 1rem;
  padding-left: 2.6rem;
  line-height: 1.4;
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-message::before,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-info::before {
  left: 1rem;
  top: 1rem;
  margin-top: 0;
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-message .button,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-info .button {
  float: none;
  margin: 0.75rem 0 0;
  vertical-align: baseline;
  display: inline-flex;
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.1rem;
  align-items: start;
}

/* WooCommerce adds float clearfix pseudo-elements to .col2-set; remove them for grid layout. */
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses::before,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses::after {
  content: none !important;
  display: none !important;
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address {
  border: 1px solid var(--bb-line);
  background: var(--bb-cream);
  padding: 1rem;
  float: none !important;
  clear: none !important;
  width: auto !important;
  margin: 0 !important;
  align-self: start;
}

.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address.col-1,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address.col-2,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address.u-column1,
.woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address.u-column2 {
  float: none !important;
  clear: none !important;
  width: auto !important;
  margin: 0 !important;
}

.woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address header {
  margin-bottom: 0.6rem;
}

.woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address h3 {
  margin: 0;
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address address {
  font-style: normal;
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--bb-muted);
  margin-bottom: 0.6rem;
}

.woocommerce-MyAccount-content .woocommerce-Addresses .woocommerce-Address .edit {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

@media (max-width: 600px) {
  .woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 1px solid var(--bb-line);
  padding: 0.68rem 0.75rem;
  font: inherit;
}

/* ── WooCommerce notices — Editorial restyle ── */
.woocommerce-notices-wrapper:empty { display: none; }
.bb-shop__notices { margin-top: 0.75rem; }

.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  position: relative !important;
  background: #F5F2ED !important;
  border: 1px solid var(--bb-line, #E5E1DB) !important;
  border-left: 3px solid #6B1F2E !important;
  border-top-color: var(--bb-line, #E5E1DB) !important;
  color: #0A0A0A !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.9rem !important;
  line-height: 1.5 !important;
  padding: 1rem 1.25rem 1rem 3rem !important;
  margin: 0 0 1.5rem !important;
  list-style: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  flex-wrap: wrap !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.woocommerce .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-info { border-left-color: #0A0A0A !important; }
.woocommerce .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-error { border-left-color: #B5462E !important; }
.woocommerce-message > *,
.woocommerce-info > *,
.woocommerce-error > * { flex: 1 1 auto; }

/* Replace WooCommerce default ::before icons with editorial SVG */
.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-error::before,
.woocommerce-notices-wrapper .woocommerce-message::before,
.woocommerce-notices-wrapper .woocommerce-info::before,
.woocommerce-notices-wrapper .woocommerce-error::before,
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
  content: '' !important;
  position: absolute !important;
  left: 1.25rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 18px !important;
  height: 18px !important;
  font-family: inherit !important;
  background-color: transparent !important;
  color: transparent !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 18px 18px !important;
}
.woocommerce .woocommerce-message::before,
.woocommerce-notices-wrapper .woocommerce-message::before,
.woocommerce-message::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B1F2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") !important;
}
.woocommerce .woocommerce-info::before,
.woocommerce-notices-wrapper .woocommerce-info::before,
.woocommerce-info::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230A0A0A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 8h.01M11 12h1v4h1'/%3E%3C/svg%3E") !important;
}
.woocommerce .woocommerce-error::before,
.woocommerce-notices-wrapper .woocommerce-error::before,
.woocommerce-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B5462E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M15 9l-6 6M9 9l6 6'/%3E%3C/svg%3E") !important;
}
/* Inline action button (e.g. "Zobacz koszyk") */
.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  background: #0A0A0A;
  color: #fff;
  border: 1px solid #0A0A0A;
  font-family: 'Inter', sans-serif;
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 0.65rem 1rem;
  border-radius: 0;
  text-decoration: none;
  min-height: 36px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  order: 2;
  margin-left: auto;
}
.woocommerce-message .button:hover,
.woocommerce-info .button:hover,
.woocommerce-error .button:hover {
  background: #6B1F2E;
  border-color: #6B1F2E;
  color: #fff;
}

/* Italic burgundy on quoted text inside product name in the notice */
.woocommerce-message strong { font-weight: 500; }
.woocommerce-message em,
.woocommerce-info em,
.woocommerce-error em {
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: #6B1F2E;
  font-weight: 400;
}

/* Mobile */
@media (max-width: 540px) {
  .woocommerce-message,
  .woocommerce-info,
  .woocommerce-error {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem 1.25rem 1rem 2.75rem;
    font-size: 0.85rem;
  }
  .woocommerce-message .button,
  .woocommerce-info .button,
  .woocommerce-error .button {
    margin-left: 0;
    width: 100%;
    justify-content: center;
  }
}

/* ── Wishlist page styling ── */
.tinv-wishlist,
.yith-wcwl-wishlist-page,
.bb-wishlist-page .entry-content {
  background: #fff;
  padding: 0;
}
.bb-wishlist-page .wishlist_table {
  width: 100%;
  border-collapse: collapse;
}
.bb-wishlist-page .wishlist_table thead th {
  background: var(--bb-cream);
  padding: 0.8rem 1rem;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-bottom: 1px solid var(--bb-line);
  text-align: left;
}
.bb-wishlist-page .wishlist_table tbody td {
  padding: 1rem;
  border-bottom: 1px solid var(--bb-line);
  vertical-align: middle;
  font-size: 0.88rem;
}
.bb-wishlist-page .wishlist_table .product-thumbnail img {
  width: 80px;
  height: auto;
}
.bb-wishlist-page .wishlist_table .product-name a {
  color: var(--bb-charcoal);
  font-weight: 600;
  text-decoration: none;
}
.bb-wishlist-page .wishlist_table .product-name a:hover {
  text-decoration: underline;
}
.bb-wishlist-page .wishlist_table .product-add-to-cart a,
.bb-wishlist-page .wishlist_table .product-add-to-cart .button {
  display: inline-block;
  background: #000;
  color: #fff;
  border: none;
  padding: 0.5rem 1.2rem;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  transition: opacity 0.15s;
}
.bb-wishlist-page .wishlist_table .product-add-to-cart a:hover,
.bb-wishlist-page .wishlist_table .product-add-to-cart .button:hover {
  opacity: 0.85;
}
.bb-wishlist-page .wishlist_table .product-stock-status .wishlist-in-stock {
  color: #2e7d32;
  font-weight: 600;
}
.bb-wishlist-page .wishlist_table .product-stock-status .wishlist-out-of-stock {
  color: #c0392b;
  font-weight: 600;
}
.bb-wishlist-page .wishlist_table .remove_from_wishlist {
  color: var(--bb-muted);
  font-size: 1.2rem;
  text-decoration: none;
}
.bb-wishlist-page .wishlist_table .remove_from_wishlist:hover {
  color: #e74c3c;
}
.bb-wishlist-page .wishlist_table .wishlist-empty td {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--bb-muted);
}
.bb-wishlist-page h2.wishlist-title {
  font-size: 1.4rem;
  margin: 0 0 1rem;
}

/* ── Auth (login / register / 2FA) — Centered card (Mockup B) ──── */

/* Hide legacy hero image */
.bb-account-page:has(.bb-auth-page) .bb-account-hero {
  display: none;
}

/* Give whole page cream background when auth is visible */
.bb-account-page:has(.bb-auth-page) {
  background: var(--bb-cream);
}
.bb-account-page:has(.bb-auth-page) .bb-account-shell {
  background: transparent;
  padding: 0;
}
.bb-account-page:has(.bb-auth-page) .woocommerce {
  display: block !important;
}

.bb-auth-page {
  padding: 3.5rem 1rem 5rem;
  display: grid;
  place-items: center;
  justify-items: center;
}

.bb-auth-card {
  max-width: 480px;
  width: 100%;
  background: #fff;
  position: relative;
  box-shadow: 0 20px 60px rgba(10, 10, 10, 0.07);
}
.bb-auth-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--bb-black);
}

/* Tabs */
.bb-auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid var(--bb-line);
}
.bb-auth-tab {
  background: transparent;
  border: 0;
  padding: 1.25rem;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-muted);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.15s, border-color 0.15s;
}
.bb-auth-tab:hover {
  color: var(--bb-charcoal);
}
.bb-auth-tab.on {
  color: var(--bb-charcoal);
  border-bottom-color: var(--bb-black);
}

/* Card body */
.bb-auth-card__body {
  padding: 2.5rem 2.5rem 2.25rem;
  text-align: center;
}
.bb-auth-card__eyebrow {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-accent);
  margin-bottom: 0.75rem;
}
.bb-auth-card__title {
  font-family: var(--bb-serif);
  font-size: 2.25rem;
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0 0 0.6rem;
  text-transform: none;
}
.bb-auth-card__title em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-auth-card__intro {
  color: var(--bb-muted);
  font-size: 0.95rem;
  margin: 0 0 2rem;
  line-height: 1.55;
}

/* Form */
.bb-auth-form {
  text-align: left;
}
.bb-auth-field {
  margin-bottom: 1.25rem;
  position: relative;
}
.bb-auth-field label {
  display: block;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  margin-bottom: 0.4rem;
}
.bb-auth-field input {
  width: 100%;
  padding: 0.9rem 0;
  border: 0;
  border-bottom: 1px solid var(--bb-line);
  background: transparent;
  font: inherit;
  font-size: 1rem;
  color: var(--bb-charcoal);
  border-radius: 0;
  transition: border-color 0.15s;
}
.bb-auth-field input:focus {
  outline: 0;
  border-bottom-color: var(--bb-black);
}
.bb-auth-field input:-webkit-autofill,
.bb-auth-field input:-webkit-autofill:hover,
.bb-auth-field input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
  box-shadow: 0 0 0 1000px #fff inset;
  -webkit-text-fill-color: var(--bb-charcoal);
  transition: background-color 9999s ease-in-out 0s;
}
.bb-auth-field--pw input {
  padding-right: 2.25rem;
}
.bb-auth-pw-toggle {
  position: absolute;
  right: 0;
  bottom: 0.7rem;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0.35rem;
  color: var(--bb-muted);
  transition: color 0.15s;
}
.bb-auth-pw-toggle:hover {
  color: var(--bb-charcoal);
}
.bb-auth-pw-toggle svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  display: block;
}

.bb-auth-options {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 0 1.5rem;
  font-size: 0.85rem;
}
.bb-auth-check {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  color: var(--bb-muted);
  font-family: var(--bb-sans);
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}
.bb-auth-check input {
  width: 14px;
  height: 14px;
  accent-color: var(--bb-black);
  margin: 0;
}
.bb-auth-forgot {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-accent);
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  text-decoration: none;
}
.bb-auth-forgot:hover {
  border-bottom-color: var(--bb-accent);
}

.bb-auth-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1.15rem 2rem;
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  border: 0;
  border-radius: 0;
  transition: background 0.2s;
  width: 100%;
}
.bb-auth-btn::after {
  content: "→";
  display: inline-block;
  transition: transform 0.2s;
}
.bb-auth-btn:hover {
  background: var(--bb-accent);
}
.bb-auth-btn:hover::after {
  transform: translateX(4px);
}

.bb-auth-hint {
  font-size: 0.85rem;
  color: var(--bb-muted);
  background: var(--bb-cream);
  padding: 0.75rem 1rem;
  margin: 0 0 1.25rem;
  border-left: 2px solid var(--bb-accent);
}

.bb-auth-card__foot {
  padding: 1.5rem 2.5rem;
  background: var(--bb-cream);
  border-top: 1px solid var(--bb-line);
  text-align: center;
  font-family: var(--bb-sans);
  font-size: 0.88rem;
  color: var(--bb-muted);
}
.bb-auth-card__foot a {
  font-weight: 600;
  color: var(--bb-charcoal);
  border-bottom: 1px solid var(--bb-charcoal);
  padding-bottom: 1px;
  text-decoration: none;
  transition: color 0.15s, border-color 0.15s;
}
.bb-auth-card__foot a:hover {
  color: var(--bb-accent);
  border-bottom-color: var(--bb-accent);
}

/* Benefits strip below card */
.bb-auth-benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 2.5rem;
  max-width: 680px;
  width: 100%;
}
.bb-auth-benefit {
  text-align: center;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  color: var(--bb-muted);
  line-height: 1.5;
}
.bb-auth-benefit svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  margin: 0 auto 0.4rem;
  display: block;
}
.bb-auth-benefit b {
  display: block;
  font-family: var(--bb-serif);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--bb-charcoal);
  margin-bottom: 0.15rem;
  letter-spacing: -0.01em;
}

/* 2FA-specific tweaks inside the card */
.bb-2fa-code-input {
  text-align: center;
  letter-spacing: 0.5em;
  font-size: 1.5rem;
  font-family: var(--bb-serif);
  font-weight: 400;
}
.bb-2fa-timer {
  text-align: center;
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  color: var(--bb-muted);
  margin: 0 0 1.25rem;
}
.bb-2fa-timer__countdown {
  font-family: var(--bb-serif);
  font-weight: 500;
  color: var(--bb-accent);
  margin: 0 0.15rem;
}
.bb-2fa-resend-form {
  text-align: center;
  margin-top: 1.25rem;
}
.bb-2fa-resend-btn {
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-muted);
  padding: 0.25rem 0;
  border-bottom: 1px solid var(--bb-muted);
}
.bb-2fa-resend-btn:hover {
  color: var(--bb-charcoal);
  border-bottom-color: var(--bb-charcoal);
}
.bb-2fa-spam-hint {
  text-align: center;
  font-size: 0.82rem;
  color: var(--bb-muted);
  margin: 1rem 0 0;
  line-height: 1.5;
}
.bb-2fa-cancel-link {
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-muted);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
}
.bb-2fa-cancel-link:hover {
  color: var(--bb-charcoal);
  border-bottom-color: var(--bb-charcoal);
}

@media (max-width: 600px) {
  .bb-auth-card__body {
    padding: 2rem 1.5rem 1.75rem;
  }
  .bb-auth-card__foot {
    padding: 1.25rem 1.5rem;
  }
  .bb-auth-benefits {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
}

/* ── Logout confirmation page (Mockup A) ──── */
/* Reset link underlines that wp-login.php might inject site-wide */
body.login a,
body.bb-logout-active a {
  text-decoration: none;
}
body.bb-logout-active .bb-header a,
body.bb-logout-active .bb-footer a,
body.bb-logout-active .bb-logout-page a {
  text-decoration: none !important;
}
.bb-logout-page {
  background: var(--bb-cream);
  min-height: calc(100vh - 200px);
}
.bb-logout-page__inner {
  display: grid;
  place-items: center;
  padding: 5rem 1rem;
}
.bb-logout-card {
  max-width: 480px;
  width: 100%;
  background: #fff;
  position: relative;
  box-shadow: 0 20px 60px rgba(10, 10, 10, 0.07);
}
.bb-logout-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--bb-black);
}
.bb-logout-card__body {
  padding: 3rem 2.5rem 2.5rem;
  text-align: center;
}
.bb-logout-card__eye {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bb-accent);
  font-weight: 600;
  margin-bottom: 0.75rem;
}
.bb-logout-card__title {
  font-family: var(--bb-serif);
  font-size: clamp(1.85rem, 3vw, 2.5rem);
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0 0 0.75rem;
  text-transform: none;
}
.bb-logout-card__title em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-logout-card__intro {
  color: var(--bb-muted);
  font-size: 1rem;
  line-height: 1.55;
  margin: 0 0 2rem;
}
.bb-logout-card__actions {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  align-items: center;
}
.bb-logout-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1.1rem 2rem;
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s;
  width: 100%;
  max-width: 300px;
}
.bb-logout-card__btn::after {
  content: "→";
  display: inline-block;
  transition: transform 0.2s;
}
.bb-logout-card__btn:hover {
  background: var(--bb-accent);
  color: #fff;
}
.bb-logout-card__btn:hover::after {
  transform: translateX(4px);
}
.bb-logout-card__cancel {
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-muted);
  text-decoration: none;
  border-bottom: 1px solid var(--bb-muted);
  padding-bottom: 1px;
  transition: color 0.15s, border-color 0.15s;
}
.bb-logout-card__cancel:hover {
  color: var(--bb-charcoal);
  border-bottom-color: var(--bb-charcoal);
}
.bb-logout-card__foot {
  padding: 1.25rem 2.5rem;
  background: var(--bb-cream);
  border-top: 1px solid var(--bb-line);
  text-align: center;
  font-family: var(--bb-sans);
  font-size: 0.85rem;
  color: var(--bb-muted);
  line-height: 1.5;
}

@media (max-width: 600px) {
  .bb-logout-card__body {
    padding: 2.25rem 1.5rem 1.75rem;
  }
  .bb-logout-card__foot {
    padding: 1rem 1.5rem;
  }
}

.bb-auth-intro {
  color: var(--bb-muted);
  font-size: 0.78rem;
  margin-bottom: 0.7rem;
  line-height: 1.45;
}

.bb-auth-hint {
  color: var(--bb-muted);
  font-size: 0.75rem;
  line-height: 1.4;
}

.bb-auth-wrap .form-row {
  margin-bottom: 0.45rem;
}

.bb-auth-wrap .form-row label {
  display: block;
  margin-bottom: 0.15rem;
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: #1A1A1A;
}

.bb-auth-wrap .form-row .input-text {
  width: 100%;
  border: 1px solid var(--bb-line);
  padding: 0.42rem 0.6rem;
  font: inherit;
  font-size: 0.85rem;
  background: rgba(255, 255, 255, 0.96);
  transition: border-color 0.15s;
}

.bb-auth-wrap .form-row .input-text:focus {
  border-color: var(--bb-charcoal);
  outline: none;
}

.bb-auth-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.6rem;
  margin-top: 0.6rem;
}

.bb-auth-actions .woocommerce-form-login__submit,
.bb-auth-wrap .woocommerce-form-register__submit {
  width: 100%;
  padding: 0.5rem 1rem;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
}

.bb-auth-wrap .lost_password {
  margin-top: 0.35rem;
  text-align: right;
}

.bb-auth-wrap .lost_password a {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: var(--bb-muted);
}

.bb-auth-wrap .lost_password a:hover {
  color: var(--bb-charcoal);
}

.bb-auth-switch {
  margin: 0.7rem 0 0;
  text-align: center;
  font-size: 0.78rem;
  color: var(--bb-muted);
}

.bb-auth-switch__link {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  color: var(--bb-charcoal);
}

.bb-auth-switch__link:hover {
  text-decoration: underline;
}

.bb-auth-wrap .woocommerce-privacy-policy-text p {
  font-size: 0.68rem;
  color: var(--bb-muted);
  line-height: 1.4;
  margin: 0.4rem 0 0;
}

.bb-auth-wrap + .woocommerce-notices-wrapper,
.bb-auth-col .woocommerce-error,
.bb-auth-col .woocommerce-message,
.bb-auth-col .woocommerce-info {
  font-size: 0.78rem;
  padding: 0.5rem 0.7rem;
  margin-bottom: 0.5rem;
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.5);
}

/* ── 2FA Form ────────────────────────────────────── */

.bb-auth-col--2fa {
  max-width: 400px;
  margin: 0 auto;
}

.bb-2fa-code-input {
  text-align: center;
  font-size: 1.5rem;
  letter-spacing: 0.5em;
  font-weight: 700;
  font-family: var(--bb-sans);
  padding: 0.5rem 0.6rem;
}

.bb-2fa-code-input::placeholder {
  color: var(--bb-taupe);
  letter-spacing: 0.3em;
}

.bb-2fa-timer {
  text-align: center;
  margin: 0.6rem 0 1rem;
  font-size: 0.82rem;
  color: var(--bb-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.bb-2fa-timer__countdown {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--bb-charcoal);
}

.bb-2fa-timer.is-expired {
  color: #b44;
}

.bb-2fa-timer.is-expired .bb-2fa-timer__countdown {
  color: #b44;
}

.bb-2fa-actions {
  text-align: center;
}

.bb-2fa-submit {
  width: 100%;
}

.bb-2fa-resend {
  margin-top: 1.2rem;
  text-align: center;
  border-top: 1px solid var(--bb-line);
  padding-top: 1rem;
}

.bb-2fa-resend-btn {
  background: none;
  border: 1px solid var(--bb-line);
  color: var(--bb-charcoal);
  font-size: 0.73rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 0.6rem 1.2rem;
  cursor: pointer;
}

.bb-2fa-resend-btn:hover {
  background: var(--bb-cream);
}

.bb-2fa-resend-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.bb-2fa-spam-hint {
  margin-top: 0.7rem;
  font-size: 0.78rem;
  color: var(--bb-muted);
  line-height: 1.5;
}

.bb-2fa-cancel-link {
  font-size: 0.78rem;
}

@media (max-width: 1080px) {
  .bb-single-product {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  ul.products,
  ul.products.bb-products-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {

  .woocommerce-account .bb-account-shell .woocommerce {
    grid-template-columns: 1fr;
  }

  .woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-message .button,
  .woocommerce-account .bb-account-shell .woocommerce-MyAccount-content .woocommerce-info .button {
    margin-left: 0;
    margin-top: 0.7rem;
  }

}

/* ═══════════════════════════════════════════════════════════════════
   CART PAGE
   ═══════════════════════════════════════════════════════════════════ */

/* Table reset */
.woocommerce-cart table.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: none;
  border-radius: 0;
  table-layout: fixed;
}
/* Column widths */
.woocommerce-cart table.shop_table .product-remove {
  width: 2.5rem;
}
.woocommerce-cart table.shop_table .product-thumbnail {
  width: 80px;
}
.woocommerce-cart table.shop_table .product-name {
  width: auto; /* takes remaining space */
}
.woocommerce-cart table.shop_table .product-price {
  width: 100px;
}
.woocommerce-cart table.shop_table .product-quantity {
  width: 90px;
}
.woocommerce-cart table.shop_table .product-subtotal {
  width: 110px;
}
/* Hide "Remove item" / "Thumbnail image" header text */
.woocommerce-cart table.shop_table th.product-remove,
.woocommerce-cart table.shop_table th.product-thumbnail {
  font-size: 0;
}

.woocommerce-cart table.shop_table th {
  font-family: var(--bb-sans, "Manrope", sans-serif);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bb-muted, #6c655d);
  padding: 0 0.5rem 0.8rem;
  border-bottom: 1px solid var(--bb-line, #e6dfd3);
  text-align: left;
}
.woocommerce-cart table.shop_table td {
  padding: 1rem 0.5rem;
  border-bottom: 1px solid var(--bb-line, #e6dfd3);
  vertical-align: middle;
  font-size: 0.88rem;
}

/* Product thumbnail in cart */
.woocommerce-cart .product-thumbnail img {
  width: 70px;
  height: 88px;
  object-fit: cover;
  background: var(--bb-cream, #f6f2eb);
  display: block;
}

/* Product name */
.woocommerce-cart td.product-name a {
  color: var(--bb-charcoal, #22201d);
  text-decoration: none;
  font-weight: 500;
}
.woocommerce-cart td.product-name a:hover {
  text-decoration: underline;
}

/* Remove "×" button */
.woocommerce-cart .product-remove a.remove {
  color: var(--bb-muted, #6c655d) !important;
  font-size: 1.3rem;
  text-decoration: none;
  transition: color 0.15s;
}
.woocommerce-cart .product-remove a.remove:hover {
  color: var(--bb-charcoal, #22201d) !important;
  background: none !important;
}

/* Quantity input */
.woocommerce-cart .quantity .qty {
  width: 3.5rem;
  text-align: center;
  border: 1px solid var(--bb-line, #e6dfd3);
  padding: 0.4rem 0.3rem;
  font: inherit;
  font-size: 0.85rem;
  background: #fff;
  border-radius: 0;
}
.woocommerce-cart .quantity .qty:focus {
  border-color: var(--bb-charcoal, #22201d);
  outline: none;
}

/* Cart actions row (coupon + update) */
.woocommerce-cart .cart .actions {
  padding-top: 1.2rem;
  border: none;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.woocommerce-cart .cart .actions .coupon {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
}
.woocommerce-cart .cart .actions .coupon label {
  display: none;
}
.woocommerce-cart .cart .actions .coupon #coupon_code {
  border: 1px solid var(--bb-line, #e6dfd3);
  padding: 0.5rem 0.75rem;
  font: inherit;
  font-size: 0.8rem;
  width: 14rem;
  max-width: 100%;
  border-radius: 0;
  background: #fff;
}
.woocommerce-cart .cart .actions .coupon #coupon_code:focus {
  border-color: var(--bb-charcoal, #22201d);
  outline: none;
}

/* All cart buttons */
.woocommerce-cart .cart .button,
.woocommerce-cart .cart input.button {
  background: var(--bb-charcoal, #22201d);
  color: #fff;
  border: none;
  border-radius: 0;
  font-family: var(--bb-sans, "Manrope", sans-serif);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.55rem 1.2rem;
  cursor: pointer;
  transition: background 0.15s;
}
.woocommerce-cart .cart .button:hover,
.woocommerce-cart .cart input.button:hover {
  background: var(--bb-black, #121212);
}
/* "Update cart" align right */
.woocommerce-cart .cart .actions > input.button[name="update_cart"] {
  margin-left: auto;
}
/* Disabled state (e.g. Update cart when no changes) */
.woocommerce-cart .cart .button:disabled,
.woocommerce-cart .cart input.button:disabled {
  background: var(--bb-taupe, #d8cec0);
  color: #fff;
  cursor: default;
  opacity: 0.6;
}

/* Cart totals box */
.woocommerce-cart .cart-collaterals {
  margin-top: 2rem;
  display: flex;
  justify-content: flex-end;
}
.woocommerce-cart .cart_totals {
  width: 380px;
  max-width: 100%;
  background: var(--bb-cream, #f6f2eb);
  padding: 1.5rem 1.8rem;
}
.woocommerce-cart .cart_totals > h2 {
  font-family: var(--bb-serif, "Cormorant Garamond", serif);
  font-size: 1.3rem;
  font-weight: 600;
  margin: 0 0 1rem;
  letter-spacing: 0;
  text-transform: none;
}
.woocommerce-cart .cart_totals table {
  width: 100%;
  border: none;
}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--bb-sand, #ebe3d6);
  font-size: 0.85rem;
  text-align: left;
}
.woocommerce-cart .cart_totals table th {
  font-weight: 600;
  color: var(--bb-muted, #6c655d);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.woocommerce-cart .cart_totals table .order-total th,
.woocommerce-cart .cart_totals table .order-total td {
  font-size: 1.05rem;
  font-weight: 700;
  border-bottom: none;
  padding-top: 0.8rem;
}

/* Proceed to checkout */
.woocommerce-cart .wc-proceed-to-checkout {
  padding: 0;
  margin-top: 1.2rem;
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
.woocommerce .cart .checkout-button {
  background: var(--bb-black, #121212) !important;
  color: #fff !important;
  border: none;
  border-radius: 0;
  font-family: var(--bb-sans, "Manrope", sans-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.9rem 2rem;
  text-align: center;
  display: block;
  width: 100%;
  transition: background 0.15s;
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover {
  background: var(--bb-charcoal, #22201d) !important;
}

/* Empty cart */
.woocommerce-cart .cart-empty {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--bb-muted, #6c655d);
  font-size: 0.95rem;
}
.woocommerce-cart .return-to-shop .button {
  background: var(--bb-black, #121212);
  color: #fff;
  border: none;
  border-radius: 0;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.8rem 2rem;
  transition: background 0.15s;
}
.woocommerce-cart .return-to-shop .button:hover {
  background: var(--bb-charcoal, #22201d);
}

/* Cart notices */
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .woocommerce-info {
  border-top-color: var(--bb-charcoal, #22201d);
  background: var(--bb-cream, #f6f2eb);
  color: var(--bb-charcoal, #22201d);
  font-size: 0.85rem;
  padding: 0.8rem 1rem;
  margin-bottom: 1.5rem;
}
.woocommerce-cart .woocommerce-message::before,
.woocommerce-cart .woocommerce-info::before {
  color: var(--bb-charcoal, #22201d);
}

@media (max-width: 768px) {
  .woocommerce-cart .cart-collaterals {
    justify-content: stretch;
  }
  .woocommerce-cart .cart_totals {
    width: 100%;
  }
  .woocommerce-cart .cart .actions {
    flex-direction: column;
    align-items: stretch;
  }
  .woocommerce-cart .cart .actions .coupon {
    flex-direction: column;
  }
  .woocommerce-cart .cart .actions .coupon #coupon_code {
    width: 100%;
  }
  .woocommerce-cart .cart .actions > input.button[name="update_cart"] {
    margin-left: 0;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   CHECKOUT PAGE
   ═══════════════════════════════════════════════════════════════════ */

/* Grid layout: form left, order right */
.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: 1fr 380px;
  grid-template-rows: auto 1fr;
  gap: 0 2.5rem;
  align-items: start;
}
.woocommerce-checkout .col2-set {
  grid-column: 1;
  grid-row: 1 / -1;
}
.woocommerce-checkout #order_review_heading {
  grid-column: 2;
  grid-row: 1;
}
.woocommerce-checkout #order_review {
  grid-column: 2;
  grid-row: 2;
}

/* Override WC default col-1/col-2 float layout — stack vertically */
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
  float: none !important;
  width: 100% !important;
}
.woocommerce-checkout .col2-set::after {
  content: "";
  display: table;
  clear: both;
}

/* Hide the "Additional information" heading on checkout */
.woocommerce-checkout .woocommerce-additional-fields > h3 {
  display: none;
}

/* Order notes section — small top gap, stays in left column */
.woocommerce-checkout .woocommerce-additional-fields {
  margin-top: 1.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--bb-line, #e6dfd3);
}

/* Notices */
.woocommerce-checkout .woocommerce-NoticeGroup,
.woocommerce-checkout .woocommerce-notices-wrapper {
  grid-column: 1 / -1;
}

/* ── Section headings ── */
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
  font-family: var(--bb-serif, "Cormorant Garamond", serif);
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  margin: 0 0 1.2rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--bb-line, #e6dfd3);
}
/* Billing "Dane płatności" is the first heading — no extra top margin */
.woocommerce-checkout .col2-set .col-1 h3:first-child {
  margin-top: 0;
}
/* Shipping heading */
.woocommerce-checkout .col2-set .col-2 h3 {
  margin-top: 1.5rem;
}

/* ── Form fields ── */
.woocommerce-checkout .form-row {
  margin-bottom: 0.65rem;
  padding: 0;
  float: none;
  width: 100%;
}
/* Inputs: fill available grid cell width, don't let WC's default 47% squeeze them */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
/* side-by-side first/last name */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem 0.8rem;
}
/* Mobile: stack all fields full-width — name inputs must fit "Krzysztof" */
@media (max-width: 860px) {
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
    grid-template-columns: 1fr !important;
  }
  .woocommerce-checkout #billing_postcode_field,
  .woocommerce-checkout #shipping_postcode_field,
  .woocommerce-checkout #billing_city_field,
  .woocommerce-checkout #shipping_city_field,
  .woocommerce-checkout #billing_phone_field,
  .woocommerce-checkout #billing_email_field {
    grid-column: 1 / -1 !important;
  }
  /* Beat WC's default .form-row-first / .form-row-last { width: 47% } */
  .woocommerce-checkout .form-row,
  .woocommerce-checkout .form-row.form-row-first,
  .woocommerce-checkout .form-row.form-row-last,
  .woocommerce-checkout .form-row.form-row-wide {
    width: 100% !important;
    float: none !important;
    clear: both !important;
  }
  .woocommerce-checkout .form-row input.input-text,
  .woocommerce-checkout .form-row textarea,
  .woocommerce-checkout .form-row select {
    padding: 0.85rem 0.85rem;
    min-height: 48px;
    font-size: 16px; /* iOS won't zoom on focus */
    width: 100% !important;
  }
}
/* Full-width fields */
.woocommerce-checkout #billing_country_field,
.woocommerce-checkout #billing_address_1_field,
.woocommerce-checkout #billing_address_2_field,
.woocommerce-checkout #shipping_country_field,
.woocommerce-checkout #shipping_address_1_field,
.woocommerce-checkout #shipping_address_2_field {
  grid-column: 1 / -1;
}
/* Postcode + city side by side */
.woocommerce-checkout #billing_postcode_field,
.woocommerce-checkout #shipping_postcode_field {
  grid-column: 1;
}
.woocommerce-checkout #billing_city_field,
.woocommerce-checkout #shipping_city_field {
  grid-column: 2;
}
/* State field (hidden for Poland, but keep grid-friendly) */
.woocommerce-checkout #billing_state_field,
.woocommerce-checkout #shipping_state_field {
  grid-column: 1 / -1;
}
/* Phone + email side by side */
.woocommerce-checkout #billing_phone_field {
  grid-column: 1;
}
.woocommerce-checkout #billing_email_field {
  grid-column: 2;
}

.woocommerce-checkout .form-row label {
  display: block;
  font-family: var(--bb-sans, "Manrope", sans-serif);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--bb-muted, #6c655d);
  margin-bottom: 0.25rem;
}
.woocommerce-checkout .form-row label .required {
  color: var(--bb-muted, #6c655d);
}
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select {
  width: 100%;
  border: 1px solid var(--bb-line, #e6dfd3);
  padding: 0.5rem 0.7rem;
  font: inherit;
  font-size: 0.88rem;
  background: #fff;
  border-radius: 0;
  transition: border-color 0.15s;
  box-sizing: border-box;
}
.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout .form-row select:focus {
  border-color: var(--bb-charcoal, #22201d);
  outline: none;
}
/* Textarea for order notes */
.woocommerce-checkout .form-row textarea {
  min-height: 5rem;
  resize: vertical;
}

/* ── Order review sidebar ── */
.woocommerce-checkout #order_review {
  background: var(--bb-cream, #f6f2eb);
  padding: 1.4rem 1.6rem;
  position: sticky;
  top: 1rem;
}
.woocommerce-checkout #order_review_heading {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0.4rem;
}

/* Order table */
.woocommerce-checkout #order_review .shop_table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
  border: none;
}
.woocommerce-checkout #order_review .shop_table thead th {
  font-family: var(--bb-sans, "Manrope", sans-serif);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bb-muted, #6c655d);
  padding: 0 0 0.5rem;
  border-bottom: 1px solid var(--bb-sand, #ebe3d6);
  text-align: left;
}
.woocommerce-checkout #order_review .shop_table td,
.woocommerce-checkout #order_review .shop_table th {
  padding: 0.55rem 0;
  border-bottom: 1px solid var(--bb-sand, #ebe3d6);
  text-align: left;
}
.woocommerce-checkout #order_review .shop_table .cart_item td {
  font-size: 0.84rem;
}
.woocommerce-checkout #order_review .shop_table .cart_item .product-name {
  color: var(--bb-charcoal, #22201d);
}
.woocommerce-checkout #order_review .shop_table .cart_item .product-total {
  text-align: right;
  font-weight: 600;
}
.woocommerce-checkout #order_review .shop_table tfoot th {
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--bb-muted, #6c655d);
}
.woocommerce-checkout #order_review .shop_table tfoot td {
  text-align: right;
}
.woocommerce-checkout #order_review .shop_table .order-total th,
.woocommerce-checkout #order_review .shop_table .order-total td {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--bb-charcoal, #22201d);
  border-bottom: none;
  padding-top: 0.7rem;
}

/* ── Shipping methods ── */
/* Break the table row layout so the list gets the full width.
   Use #order_review in the selector to beat the existing tfoot td rule. */
.woocommerce-checkout #order_review .woocommerce-shipping-totals {
  display: block;
}
.woocommerce-checkout #order_review .woocommerce-shipping-totals th {
  display: block;
  width: 100%;
  text-align: left;
  padding-right: 0;
  padding-bottom: 0.35rem;
}
.woocommerce-checkout #order_review .woocommerce-shipping-totals td {
  display: block;
  width: 100% !important;
  text-align: left !important;
  padding: 0;
}
/* Shipping method rules — ZASTĄPIONE inline CSS w bb_apaczka_checkout_ship_styles()
   w functions.php (Mockup B, 2026-04-23). Stare reguły Mockup A (display:flex,
   sand hover, prostokątne labele) konfliktowały specificity, usunięte. */

/* ── Payment section ── */
.woocommerce-checkout #payment {
  background: transparent;
  padding: 0;
  margin-top: 1rem;
  border-radius: 0;
}
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 0.8rem;
  border-bottom: 1px solid var(--bb-sand, #ebe3d6);
}
.woocommerce-checkout #payment ul.payment_methods li {
  padding: 0.5rem 0;
  border-top: 1px solid var(--bb-sand, #ebe3d6);
  background: transparent !important; /* Override WC default lavender/pink */
}
.woocommerce-checkout #payment ul.payment_methods li label {
  font-size: 0.84rem;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  color: var(--bb-charcoal, #22201d);
  cursor: pointer;
}
.woocommerce-checkout #payment .payment_box,
.woocommerce-checkout #payment .wc_payment_method .payment_box {
  font-size: 0.8rem;
  color: var(--bb-muted, #6c655d);
  padding: 0.4rem 0 0.4rem 1.5rem;
  background: transparent !important; /* Override WC default pink (#dfdcde / #fbfaff) */
  margin: 0;
  border: none;
}
.woocommerce-checkout #payment .payment_box::before {
  display: none;
}

/* ─── PayU payment fields — icon strip only (subtitle + powered-by removed 2026-05-09) ─── */
.bb-pay-fields {
  display: block;
  padding: 4px 0 0;
}
.bb-pay-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 0;
}
.bb-pay-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid var(--bb-line, #e5e0d8);
  border-radius: 4px;
  height: 30px;
  padding: 0 10px;
  flex-shrink: 0;
}
.bb-pay-logo img {
  display: block;
  height: 18px;
  width: auto;
  max-width: 60px;
}
.bb-pay-logo--apple-pay img,
.bb-pay-logo--google-pay img {
  height: 20px;
}
.bb-pay-logo--blik img {
  height: 14px;
}
.bb-pay-logo--transfer img {
  height: 18px;
}

/* ─── Carrier brand icons (in shipping options) ─────────────────────── */
.bb-carrier-icon {
  display: inline-block !important;
  height: 22px !important;
  max-height: 22px !important;
  width: auto !important;
  max-width: 64px !important;
  vertical-align: middle !important;
  margin-right: 10px !important;
  object-fit: contain !important;
  flex-shrink: 0 !important;
}
/* Selected (highlighted) row uses charcoal bg → DPD/Orlen/Pocztex/GLS need white tile for visibility (InPost yellow already visible) */
.bb-cart-ship__item.on .bb-carrier-icon--dpd,
.bb-cart-ship__item.on .bb-carrier-icon--orlen,
.bb-cart-ship__item.on .bb-carrier-icon--pocztex,
.bb-cart-ship__item.on .bb-carrier-icon--gls {
  background: #fff !important;
  border-radius: 3px !important;
  padding: 2px 5px !important;
  height: 20px !important;
  max-height: 20px !important;
}

/* ─── BB Points Modal — search helper row + filter pills with carrier logos ─── */
.bb-pts-search-helper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
  font-size: 11px;
}
.bb-pts-search-hint {
  color: var(--bb-muted, #6B6561);
  flex: 1;
  min-width: 0;
}
.bb-pts-use-location {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: #fff;
  border: 1px solid var(--bb-line, #E5E0D8);
  font-size: 11px;
  font-weight: 500;
  color: var(--bb-charcoal, #0A0A0A);
  cursor: pointer;
  border-radius: 0;
  white-space: nowrap;
  flex-shrink: 0;
}
.bb-pts-use-location:hover {
  background: var(--bb-paper, #F8F5F0);
}
.bb-pts-use-location svg {
  color: var(--bb-accent, #6B1F2E);
  flex-shrink: 0;
}
/* Filter pills: pokazują brand-logo carrier zamiast tekstu */
.bb-pts-filters .bb-pts-filter img {
  display: inline-block;
  height: 14px;
  width: auto;
  max-width: 50px;
  vertical-align: middle;
  object-fit: contain;
}
.bb-pts-filters .bb-pts-filter.is-on img {
  filter: brightness(0) invert(1); /* na czarnym tle wszystkie logosy na białe */
}

/* Place order button */
.woocommerce-checkout #place_order {
  background: var(--bb-black, #121212) !important;
  color: #fff !important;
  border: none;
  border-radius: 0;
  font-family: var(--bb-sans, "Manrope", sans-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.9rem 2rem;
  width: 100%;
  cursor: pointer;
  text-align: center;
  display: block;
  margin-top: 0.5rem;
  transition: background 0.15s;
}
.woocommerce-checkout #place_order:hover {
  background: var(--bb-charcoal, #22201d) !important;
}

/* Coupon toggle link */
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0 0 1.2rem;
  font-size: 0.82rem;
  color: var(--bb-muted, #6c655d);
}
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info::before {
  display: none;
}
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a {
  color: var(--bb-charcoal, #22201d);
  text-decoration: underline;
}

/* Coupon form */
.woocommerce-checkout .checkout_coupon {
  border: 1px solid var(--bb-line, #e6dfd3);
  padding: 1rem;
  margin-bottom: 1.5rem;
  display: flex;
  gap: 0.5rem;
  align-items: center;
  border-radius: 0;
}
.woocommerce-checkout .checkout_coupon .input-text {
  flex: 1;
  border: 1px solid var(--bb-line, #e6dfd3);
  padding: 0.5rem 0.7rem;
  font: inherit;
  font-size: 0.85rem;
  border-radius: 0;
}
.woocommerce-checkout .checkout_coupon .button {
  background: var(--bb-charcoal, #22201d);
  color: #fff;
  border: none;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.55rem 1.2rem;
  cursor: pointer;
  border-radius: 0;
  white-space: nowrap;
}

/* Terms & privacy on checkout */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  font-size: 0.78rem;
  color: var(--bb-muted, #6c655d);
  margin-top: 0.5rem;
}
.woocommerce-checkout .woocommerce-privacy-policy-text p {
  font-size: 0.75rem;
  color: var(--bb-muted, #6c655d);
}

/* Checkout notices */
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-info {
  font-size: 0.84rem;
}

/* ── Responsive ── */
@media (max-width: 860px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .woocommerce-checkout .col2-set,
  .woocommerce-checkout #order_review_heading,
  .woocommerce-checkout #order_review,
  .woocommerce-checkout .woocommerce-additional-fields {
    grid-column: 1;
  }
  .woocommerce-checkout #order_review_heading {
    grid-row: auto;
    margin-top: 2rem;
  }
  .woocommerce-checkout #order_review {
    grid-row: auto;
    position: static;
  }
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
    grid-template-columns: 1fr;
  }
  .woocommerce-checkout #billing_email_field {
    grid-column: 1;
  }

  /* Larger touch targets for shipping options on mobile */
  .woocommerce-checkout ul#shipping_method li label,
  .woocommerce-cart ul#shipping_method li label {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  /* InPost picker between RAZEM and PayU */
  #bb-inpost-widget-wrap {
    margin-top: 0 !important;
    margin-bottom: 1rem;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   ORDER RECEIVED (Thank you) PAGE
   ═══════════════════════════════════════════════════════════════════ */
.woocommerce-order-received .woocommerce-thankyou-order-received {
  font-family: var(--bb-serif, "Cormorant Garamond", serif);
  font-size: 1.5rem;
  text-align: center;
  margin-bottom: 1.5rem;
}
.woocommerce-order-received .woocommerce-order-overview {
  list-style: none;
  padding: 1rem 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  border-top: 1px solid var(--bb-line, #e6dfd3);
  border-bottom: 1px solid var(--bb-line, #e6dfd3);
}
.woocommerce-order-received .woocommerce-order-overview li {
  font-size: 0.84rem;
}
.woocommerce-order-received .woocommerce-order-overview li strong {
  display: block;
  font-size: 1rem;
}

/* ── Order view return CTA ── */
.bb-order-return-cta {
  margin-top: 1.5rem;
  padding: 1rem 1.2rem;
  background: var(--bb-cream, #f6f2eb);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.bb-order-return-cta p {
  margin: 0;
  font-size: 0.88rem;
  color: var(--bb-charcoal, #3a3632);
}

/* ── Guest return — Split layout (Wariant C) ── */
.bb-site-main--split {
  display: block;
}

.bb-gr-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: calc(100vh - 66px);
}

/* Left panel */
.bb-gr-left {
  background: var(--bb-cream, #f6f2eb);
  padding: 56px 52px 60px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.bb-gr-eyebrow {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bb-muted, #7a7268);
  margin-bottom: 1rem;
}
.bb-gr-title {
  font-family: var(--bb-serif, 'Cormorant Garamond', serif);
  font-size: clamp(2.2rem, 3.5vw, 3.4rem);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: 0.02em;
  margin-bottom: 1.2rem;
  color: var(--bb-charcoal, #22201d);
}
.bb-gr-desc {
  font-size: 0.82rem;
  color: var(--bb-muted, #7a7268);
  line-height: 1.65;
  max-width: 36ch;
  margin-bottom: 2rem;
}
.bb-gr-steps {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0;
  margin: 0;
}
.bb-gr-step {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.bb-gr-step__num {
  width: 26px;
  height: 26px;
  border: 1px solid var(--bb-charcoal, #22201d);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 600;
  flex-shrink: 0;
  margin-top: 1px;
  color: var(--bb-charcoal, #22201d);
}
.bb-gr-step__text {
  font-size: 0.78rem;
  color: var(--bb-muted, #7a7268);
  line-height: 1.55;
}
.bb-gr-step__text strong {
  color: var(--bb-charcoal, #22201d);
  font-weight: 600;
}
.bb-gr-left__contact {
  font-size: 0.73rem;
  color: var(--bb-muted, #7a7268);
  padding-top: 2rem;
  border-top: 1px solid var(--bb-line, #e0d7cb);
}
.bb-gr-left__contact a {
  color: var(--bb-charcoal, #22201d);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Right panel */
.bb-gr-right {
  background: #fff;
  padding: 56px 52px 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.bb-gr-form-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bb-muted, #7a7268);
  margin-bottom: 2rem;
}
.bb-gr-form {
  display: flex;
  flex-direction: column;
}
.bb-gr-field {
  margin-bottom: 1.6rem;
}
.bb-gr-field label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--bb-muted, #7a7268);
  margin-bottom: 0.5rem;
}
.bb-gr-field input {
  display: block;
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--bb-line, #e0d7cb);
  padding: 0.5rem 0 0.65rem;
  font-size: 1rem;
  font-family: var(--bb-sans, 'Montserrat', sans-serif);
  color: var(--bb-charcoal, #22201d);
  outline: none;
  transition: border-color 0.2s;
}
.bb-gr-field input:focus {
  border-bottom-color: var(--bb-charcoal, #22201d);
}
.bb-gr-field input::placeholder {
  color: #c2bab0;
  font-size: 0.9rem;
}
.bb-gr-btn {
  display: block;
  width: 100%;
  margin-top: 1rem;
  padding: 0.9rem;
  background: var(--bb-charcoal, #22201d);
  color: #fff;
  font-family: var(--bb-sans, 'Montserrat', sans-serif);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.2s;
}
.bb-gr-btn:hover { opacity: 0.85; color: #fff; }
.bb-gr-btn--outline {
  margin-top: 0.6rem;
  background: transparent;
  color: var(--bb-muted, #7a7268);
  border: 1px solid var(--bb-line, #e0d7cb);
}
.bb-gr-btn--outline:hover {
  background: var(--bb-cream, #f6f2eb);
  color: var(--bb-charcoal, #22201d);
  opacity: 1;
}
.bb-gr-hint {
  margin-top: 1.5rem;
  font-size: 0.73rem;
  color: var(--bb-muted, #7a7268);
  line-height: 1.5;
}
.bb-gr-error {
  padding: 0.75rem 1rem;
  background: #fdf0f0;
  border: 1px solid #e8b4b4;
  font-size: 0.85rem;
  color: #a33;
  margin-bottom: 1rem;
}

/* Mobile */
@media (max-width: 700px) {
  .bb-gr-split {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .bb-gr-left {
    padding: 40px 24px 36px;
  }
  .bb-gr-right {
    padding: 40px 24px 48px;
  }
  .bb-gr-title {
    font-size: 2.2rem;
  }
}
/* Result step */
.bb-guest-return--result {
  max-width: 560px;
}
.bb-guest-return__order-summary {
  padding: 1rem 1.2rem;
  background: var(--bb-cream, #f6f2eb);
  border-radius: 2px;
  margin-bottom: 1rem;
}
.bb-guest-return__order-number {
  font-weight: 700;
  font-size: 0.95rem;
  margin: 0 0 0.75rem;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
}
.bb-guest-return__order-date {
  font-size: 0.8rem;
  font-weight: 400;
  color: var(--bb-muted, #6b6560);
}
.bb-guest-return__items {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.bb-guest-return__items li {
  display: flex;
  gap: 0.6rem;
  font-size: 0.85rem;
  align-items: baseline;
}
.bb-guest-return__item-name { flex: 1; }
.bb-guest-return__item-qty  { color: var(--bb-muted, #6b6560); white-space: nowrap; }
.bb-guest-return__item-price { white-space: nowrap; font-weight: 600; }
.bb-guest-return__warranty {
  margin-top: 1rem;
  padding: 1rem 1.2rem;
  border: 1px solid var(--bb-border, #d8d0c4);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.bb-guest-return__warranty-desc {
  margin: 0;
  font-size: 0.83rem;
  color: var(--bb-muted, #6b6560);
}
.bb-guest-return__back {
  margin-top: 1.5rem;
  font-size: 0.82rem;
}
.bb-guest-return__back a {
  color: var(--bb-muted, #6b6560);
  text-decoration: none;
}
.bb-guest-return__back a:hover {
  text-decoration: underline;
}

/* ── EU 2023/2673 — Right-of-Withdrawal CTA ── */
.bb-withdrawal-cta {
  margin-top: 1rem;
  padding: 1rem 1.2rem;
  border: 1px solid var(--bb-border, #d8d0c4);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.bb-withdrawal-cta__desc {
  margin: 0;
  font-size: 0.83rem;
  color: var(--bb-muted, #6b6560);
}
.bb-withdrawal-notice--done,
.bb-withdrawal-notice--pending {
  margin-top: 1rem;
  padding: 0.85rem 1.2rem;
  border-radius: 2px;
  font-size: 0.83rem;
  color: var(--bb-charcoal, #3a3632);
}
.bb-withdrawal-notice--done {
  background: #f0f7f0;
  border: 1px solid #b6d9b6;
}
.bb-withdrawal-notice--pending {
  background: #fdf8ec;
  border: 1px solid #e8d48a;
}
.bb-withdrawal-notice--done p,
.bb-withdrawal-notice--pending p {
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════════════
   RETURNS (ZWROTY)
   ═══════════════════════════════════════════════════════════════════ */

.bb-returns h2 {
  font-family: var(--bb-serif, "Cormorant Garamond", serif);
  font-size: 1.6rem;
  font-weight: 600;
  margin-bottom: 0.4rem;
}
.bb-returns__intro {
  color: var(--bb-muted, #8a7e72);
  font-size: 0.88rem;
  margin-bottom: 1.5rem;
}
.bb-returns__empty {
  color: var(--bb-muted, #8a7e72);
  font-style: italic;
}

/* Product list */
.bb-returns__list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.bb-returns__item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid var(--bb-line, #e6dfd3);
  background: #fff;
}
.bb-returns__thumb {
  width: 72px;
  height: 72px;
  flex-shrink: 0;
  overflow: hidden;
  background: var(--bb-cream, #f6f2eb);
}
.bb-returns__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.bb-returns__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.bb-returns__name {
  font-size: 0.92rem;
}
.bb-returns__meta {
  font-size: 0.8rem;
  color: var(--bb-muted, #8a7e72);
}
.bb-returns__days {
  font-size: 0.78rem;
  color: var(--bb-charcoal, #3a3632);
  font-weight: 600;
}
.bb-returns__action {
  flex-shrink: 0;
}
.bb-returns__too-big {
  font-size: 0.78rem;
  color: var(--bb-muted, #8a7e72);
  font-style: italic;
}

/* ── Buttons ── */
.bb-btn {
  display: inline-block;
  padding: 0.65rem 1.6rem;
  font-family: var(--bb-sans, "DM Sans", sans-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  border: none;
  cursor: pointer;
  background: var(--bb-black, #1a1816);
  color: #fff;
  transition: opacity 0.2s;
}
.bb-btn:hover { opacity: 0.85; }
.bb-btn:disabled {
  opacity: 0.4;
  cursor: default;
}
.bb-btn--sm {
  padding: 0.5rem 1.2rem;
  font-size: 0.72rem;
}
.bb-btn--outline {
  background: transparent;
  color: var(--bb-black, #1a1816);
  border: 1px solid var(--bb-line, #e6dfd3);
}
.bb-btn--outline:hover {
  background: var(--bb-cream, #f6f2eb);
  opacity: 1;
}

/* ── Modal ── */
.bb-returns__modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(26, 24, 22, 0.55);
  backdrop-filter: blur(3px);
}
.bb-returns__modal[hidden] { display: none; }
.bb-returns__modal-inner {
  position: relative;
  width: 94%;
  max-width: 640px;
  max-height: 90vh;
  overflow-y: auto;
  background: #fff;
  padding: 2rem;
}
.bb-returns__modal-close {
  position: absolute;
  top: 0.8rem;
  right: 1rem;
  background: none;
  border: none;
  font-size: 1.6rem;
  cursor: pointer;
  color: var(--bb-muted, #8a7e72);
  line-height: 1;
}
.bb-returns__modal-close:hover { color: var(--bb-black, #1a1816); }
.bb-returns__modal-title {
  font-family: var(--bb-serif, "Cormorant Garamond", serif);
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 1.2rem;
}

/* Step 1: Product summary */
.bb-returns__modal-product {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.2rem;
}
.bb-returns__modal-img {
  width: 64px;
  height: 64px;
  object-fit: cover;
  background: var(--bb-cream, #f6f2eb);
}
.bb-returns__modal-name {
  font-size: 0.92rem;
  display: block;
}
.bb-returns__modal-order {
  font-size: 0.8rem;
  color: var(--bb-muted, #8a7e72);
}
.bb-returns__size-info {
  background: var(--bb-cream, #f6f2eb);
  padding: 1rem 1.2rem;
  margin-bottom: 1.2rem;
}
.bb-returns__size-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.88rem;
  padding: 0.25rem 0;
}
.bb-returns__size-row + .bb-returns__size-row {
  border-top: 1px solid var(--bb-line, #e6dfd3);
}
.bb-returns__next-btn {
  width: 100%;
}

/* Step 2: Locker selection */
.bb-returns__locker-hint {
  font-size: 0.88rem;
  margin-bottom: 0.8rem;
  color: var(--bb-muted, #8a7e72);
}
.bb-returns__geowidget-wrap {
  width: 100%;
  height: 380px;
  margin-bottom: 1rem;
  border: 1px solid var(--bb-line, #e6dfd3);
}
.bb-returns__geowidget-wrap inpost-geowidget {
  width: 100%;
  height: 100%;
}
.bb-returns__no-token {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--bb-muted, #8a7e72);
  font-size: 0.88rem;
  text-align: center;
  padding: 2rem;
}
.bb-returns__selected-locker {
  background: var(--bb-cream, #f6f2eb);
  padding: 0.8rem 1rem;
  margin-bottom: 1rem;
  font-size: 0.88rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}
.bb-returns__selected-locker[hidden] { display: none; }
.bb-returns__locker-name {
  font-weight: 700;
}
.bb-returns__locker-address {
  color: var(--bb-muted, #8a7e72);
}
.bb-returns__modal-actions {
  display: flex;
  gap: 0.8rem;
}
.bb-returns__modal-actions .bb-btn {
  flex: 1;
}

/* Step 3: Done */
.bb-returns__step--done {
  text-align: center;
  padding: 2rem 0;
}
.bb-returns__done-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 1rem;
  border-radius: 50%;
  background: var(--bb-cream, #f6f2eb);
  color: #4a7c59;
  font-size: 1.6rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bb-returns__step--done h4 {
  font-family: var(--bb-serif, "Cormorant Garamond", serif);
  font-size: 1.2rem;
  margin-bottom: 0.6rem;
}
.bb-returns__done-msg {
  font-size: 0.88rem;
  color: var(--bb-muted, #8a7e72);
  margin-bottom: 1.5rem;
  max-width: 420px;
  margin-left: auto;
  margin-right: auto;
}

/* Loading spinner */
.bb-returns__loading {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
}
.bb-returns__loading[hidden] { display: none; }
.bb-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--bb-line, #e6dfd3);
  border-top-color: var(--bb-black, #1a1816);
  border-radius: 50%;
  animation: bb-spin 0.7s linear infinite;
}
@keyframes bb-spin {
  to { transform: rotate(360deg); }
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .bb-returns__item {
    flex-wrap: wrap;
  }
  .bb-returns__action {
    width: 100%;
  }
  .bb-returns__action .bb-btn {
    width: 100%;
  }
  .bb-returns__modal-inner {
    padding: 1.2rem;
  }
  .bb-returns__geowidget-wrap {
    height: 300px;
  }
  .bb-returns__modal-actions {
    flex-direction: column;
  }
}

/* ============================================================
   CART — Editorial layout (Mockup A)
   ============================================================ */
.bb-cart-head {
  padding: 4rem 0 1rem;
}
.bb-cart-head__title {
  font-family: var(--bb-serif);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0 0 1rem;
  text-transform: none;
}
.bb-cart-head__title em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-cart-head__meta {
  color: var(--bb-muted);
  font-size: 0.95rem;
  margin: 0;
}
.bb-cart-head__meta b {
  color: var(--bb-charcoal);
  font-weight: 500;
}

.bb-cart-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr;
  gap: 4rem;
  padding: 3rem 0 6rem;
  align-items: start;
}

/* Left — products list */
.bb-cart-left .woocommerce-cart-form {
  margin: 0;
}

.bb-cart-items {
  border-top: 1px solid var(--bb-black);
}

.bb-cart-items__head {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 2rem;
  padding: 1rem 0;
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--bb-muted);
  border-bottom: 1px solid var(--bb-line);
}
.bb-cart-items__head-qty {
  min-width: 120px;
  text-align: center;
}
.bb-cart-items__head-sum {
  min-width: 80px;
  text-align: right;
}

.bb-cart-item {
  display: grid;
  grid-template-columns: 110px 1fr auto;
  gap: 1.5rem;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--bb-line);
  align-items: center;
}

.bb-cart-item__img {
  aspect-ratio: 4 / 5;
  background: var(--bb-cream);
  overflow: hidden;
}
.bb-cart-item__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.bb-cart-item__info h3 {
  font-family: var(--bb-serif);
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 0.25rem;
  line-height: 1.2;
  text-transform: none;
}
.bb-cart-item__info h3 a {
  color: inherit;
  text-decoration: none;
}
.bb-cart-item__info h3 a:hover {
  color: var(--bb-accent);
}
.bb-cart-item__cat {
  color: var(--bb-muted);
  font-size: 0.85rem;
  margin-bottom: 0.75rem;
  text-transform: capitalize;
}
.bb-cart-item__price {
  font-family: var(--bb-serif);
  font-size: 1.05rem;
  font-weight: 500;
}
.bb-cart-item__price del,
.bb-cart-item__price .woocommerce-Price-amount {
  font-family: var(--bb-serif);
}

.bb-cart-item__ctrls {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 1rem;
  min-width: 140px;
}

.bb-cart-item__qty .quantity {
  display: flex;
  border: 1px solid var(--bb-line);
  align-items: center;
}
.bb-cart-item__qty input.qty,
.bb-cart-item__qty .quantity input[type="number"] {
  width: 2.5rem;
  border: 0;
  text-align: center;
  font: inherit;
  padding: 0.5rem 0;
  background: transparent;
  border-left: 1px solid var(--bb-line);
  border-right: 1px solid var(--bb-line);
  -moz-appearance: textfield;
}
.bb-cart-item__qty input.qty::-webkit-outer-spin-button,
.bb-cart-item__qty input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.bb-cart-item__qty button,
.bb-cart-item__qty .quantity button {
  padding: 0.5rem 0.9rem;
  font-size: 1.1rem;
  line-height: 1;
  color: var(--bb-muted);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: color 0.15s;
}
.bb-cart-item__qty button:hover {
  color: var(--bb-black);
}

.bb-cart-item__subtotal {
  font-family: var(--bb-serif);
  font-size: 1.1rem;
  font-weight: 500;
}
.bb-cart-item__subtotal .woocommerce-Price-amount {
  font-family: var(--bb-serif);
}

.bb-cart-item__remove {
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  transition: color 0.15s, border-color 0.15s;
  text-decoration: none;
}
.bb-cart-item__remove:hover {
  color: var(--bb-accent);
  border-bottom-color: var(--bb-accent);
}

/* Actions row */
.bb-cart-actions {
  padding-top: 1.5rem;
}
.bb-cart-actions__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}
.bb-cart-coupon-toggle {
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  border: 0;
  background: transparent;
  padding: 0 0 2px;
  border-bottom: 1px solid var(--bb-black);
  cursor: pointer;
  color: inherit;
}
.bb-cart-coupon-toggle:hover {
  color: var(--bb-accent);
  border-bottom-color: var(--bb-accent);
}
.bb-cart-continue {
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bb-muted);
  border-bottom: 1px solid var(--bb-muted);
  padding-bottom: 1px;
  text-decoration: none;
}
.bb-cart-continue:hover {
  color: var(--bb-charcoal);
  border-bottom-color: var(--bb-charcoal);
}

.bb-cart-coupon {
  margin-top: 1.5rem;
  display: flex;
  gap: 0.5rem;
  max-width: 400px;
}
.bb-cart-coupon[hidden] {
  display: none;
}
.bb-cart-coupon input {
  flex: 1;
  padding: 0.9rem 1rem;
  border: 1px solid var(--bb-line);
  background: #fff;
  font: inherit;
}
.bb-cart-coupon input:focus {
  outline: 0;
  border-color: var(--bb-black);
}
.bb-cart-coupon button {
  padding: 0.9rem 1.25rem;
  background: var(--bb-black);
  color: #fff;
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  border: 0;
  cursor: pointer;
  transition: background 0.2s;
}
.bb-cart-coupon button:hover {
  background: var(--bb-accent);
}

.bb-cart-update {
  margin-top: 1.5rem;
  padding: 0.75rem 1.25rem;
  background: transparent;
  border: 1px solid var(--bb-line);
  color: var(--bb-muted);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
.bb-cart-update:hover {
  border-color: var(--bb-black);
  color: var(--bb-black);
}

/* Right — Summary sidebar */
.bb-cart-right {
  position: sticky;
  top: 2rem;
}

.bb-cart-summary {
  background: var(--bb-cream);
  padding: 2rem;
}
.bb-cart-right .cart_totals,
.bb-cart-right .bb-cart-summary,
.bb-cart-right .cart-collaterals > * {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
}
.bb-cart-summary h2 {
  font-family: var(--bb-serif);
  font-size: 1.5rem;
  font-weight: 400;
  margin: 0 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-line);
  letter-spacing: -0.01em;
  text-transform: none;
}

.bb-cart-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.65rem 0;
  font-size: 0.95rem;
}
.bb-cart-summary__row span:last-child {
  font-weight: 500;
}
.bb-cart-summary__row--muted {
  color: var(--bb-muted);
}
.bb-cart-summary__row--discount {
  color: var(--bb-accent);
}

.bb-cart-summary__shipping {
  margin: 1rem 0;
  padding-top: 1.25rem;
  border-top: 1px solid var(--bb-line);
}
.bb-cart-summary__label {
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--bb-muted);
  margin-bottom: 0.75rem;
  font-weight: 600;
}

/* Mockup A shipping rules (.bb-cart-ship__*) — ZASTĄPIONE przez Mockup B
   w bb_apaczka_checkout_ship_styles() w functions.php (2026-04-23).
   Było: border+white bg, checked = black slab z border — konfliktowało
   z nowym "editorial" design (Fraunces, sand hover, bez borderów). */

.bb-cart-ship__destination,
.bb-cart-ship__hint {
  font-size: 0.8rem;
  color: var(--bb-muted);
  margin: 0.75rem 0 0;
  line-height: 1.5;
}

.bb-cart-summary__shipping .shipping-calculator-button,
.woocommerce-shipping-totals .shipping-calculator-button {
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bb-muted);
  border-bottom: 1px solid var(--bb-muted);
  padding-bottom: 1px;
  margin-top: 0.5rem;
  display: inline-block;
}
.bb-cart-summary__shipping .shipping-calculator-button:hover,
.woocommerce-shipping-totals .shipping-calculator-button:hover {
  color: var(--bb-black);
  border-bottom-color: var(--bb-black);
}

.bb-cart-summary__total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin: 1.5rem 0 1.25rem;
  padding-top: 1.5rem;
  border-top: 2px solid var(--bb-black);
}
.bb-cart-summary__total > span {
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
}
.bb-cart-summary__total b,
.bb-cart-summary__total b strong,
.bb-cart-summary__total b .woocommerce-Price-amount,
.bb-cart-summary__total b bdi {
  font-family: var(--bb-serif);
  font-size: 2rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--bb-charcoal);
}
.bb-cart-summary__total b strong {
  font-size: inherit;
  font-weight: 400;
}

.bb-cart-summary__cta {
  margin-top: 1rem;
}
.bb-cart-summary__cta .checkout-button,
.bb-cart-summary__cta .wc-forward {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1.1rem 1.75rem;
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
  width: 100%;
  text-decoration: none;
  border: 0;
  border-radius: 0;
}
.bb-cart-summary__cta .checkout-button:hover,
.bb-cart-summary__cta .wc-forward:hover {
  background: var(--bb-accent);
  color: #fff;
}
.bb-cart-summary__cta .checkout-button::after,
.bb-cart-summary__cta .wc-forward::after {
  content: "→";
  display: inline-block;
  transition: transform 0.2s;
}
.bb-cart-summary__cta .checkout-button:hover::after,
.bb-cart-summary__cta .wc-forward:hover::after {
  transform: translateX(4px);
}

.bb-cart-summary__trust {
  margin-top: 1rem;
  text-align: center;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bb-muted);
}

@media (max-width: 1000px) {
  .bb-cart-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .bb-cart-right {
    position: static;
  }
  .bb-cart-items__head-qty,
  .bb-cart-items__head-sum {
    display: none;
  }
  .bb-cart-items__head {
    grid-template-columns: 1fr;
  }
  .bb-cart-item {
    grid-template-columns: 90px 1fr;
    gap: 1rem;
  }
  .bb-cart-item__ctrls {
    grid-column: 1 / -1;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    min-width: 0;
  }
}

/* ============================================================
   MOJE KONTO — Editorial Dashboard (Mockup A)
   ============================================================ */
.bb-account {
  padding: 0;
}

/* Override WooCommerce 10+ grid on .woocommerce wrapper — we want our own grid */
.bb-account-page .woocommerce,
.bb-account-shell .woocommerce {
  display: block !important;
  grid-template-columns: none !important;
}

.bb-account__hero {
  padding: 4rem 0 2rem;
}

.bb-account__title {
  font-family: var(--bb-serif);
  font-size: clamp(2.25rem, 4vw, 3.5rem);
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0 0 0.75rem;
  text-transform: none;
}
.bb-account__title em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-account__intro {
  color: var(--bb-muted);
  font-size: 1.05rem;
  margin: 0;
}

.bb-account-shell {
  padding: 2rem 0 6rem;
}

.bb-account-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 3rem;
  align-items: start;
}

/* Sidebar */
.bb-account-sidebar {
  background: var(--bb-cream);
  padding: 2rem 1.75rem;
  position: sticky;
  top: 2rem;
}

.bb-account-sidebar__profile {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 1.5rem;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--bb-line);
}

.bb-account-sidebar__avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--bb-black);
  color: #fff;
  display: grid;
  place-items: center;
  font-family: var(--bb-serif);
  font-size: 1.4rem;
  font-weight: 400;
  flex-shrink: 0;
  line-height: 1;
}

.bb-account-sidebar__who b {
  font-family: var(--bb-serif);
  font-size: 1.1rem;
  font-weight: 500;
  display: block;
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.bb-account-sidebar__who span {
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  color: var(--bb-muted);
  word-break: break-all;
}

.bb-account-sidebar__menu {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
  padding: 0;
}
.bb-account-sidebar__menu li {
  margin: 0;
  padding: 0;
}
.bb-account-sidebar__menu a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 0.25rem;
  font-family: var(--bb-sans);
  font-size: 0.92rem;
  color: var(--bb-muted);
  border-bottom: 1px solid transparent;
  text-decoration: none;
  transition: color 0.15s, border-color 0.15s;
}
.bb-account-sidebar__menu a:hover {
  color: var(--bb-charcoal);
}
.bb-account-sidebar__menu .is-active a,
.bb-account-sidebar__menu .bb-on a {
  color: var(--bb-charcoal);
  font-weight: 500;
  border-bottom-color: var(--bb-charcoal);
}

.bb-account-sidebar__logout {
  display: inline-block;
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--bb-line);
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  width: 100%;
  transition: color 0.15s;
  text-decoration: none;
}
.bb-account-sidebar__logout:hover {
  color: var(--bb-accent);
}

/* Main content */
.bb-account-main {
  min-width: 0;
}

.bb-account-dashboard {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

.bb-account-dashboard__head {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-black);
  margin-bottom: 0.5rem;
}
.bb-account-dashboard__head h2 {
  font-family: var(--bb-serif);
  font-size: 1.75rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0;
  text-transform: none;
}
.bb-account-dashboard__head h2 em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-account-dashboard__head span {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
}

/* Card */
.bb-account-card {
  background: #fff;
  border: 1px solid var(--bb-line);
  padding: 1.5rem 1.5rem 1.25rem;
  display: flex;
  flex-direction: column;
  min-height: 200px;
  transition: border-color 0.15s;
}
.bb-account-card:hover {
  border-color: var(--bb-black);
}
.bb-account-card--wide {
  grid-column: 1 / -1;
}
.bb-account-card__label {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  margin-bottom: 0.6rem;
}
.bb-account-card h3 {
  font-family: var(--bb-serif);
  font-size: 1.25rem;
  font-weight: 500;
  margin: 0 0 0.75rem;
  letter-spacing: -0.01em;
  line-height: 1.25;
  text-transform: none;
}
.bb-account-card h3 em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-account-card p {
  color: var(--bb-muted);
  font-size: 0.92rem;
  line-height: 1.55;
  margin: 0 0 1rem;
}
.bb-account-card__empty {
  color: var(--bb-muted);
  font-style: italic;
}
.bb-account-card__foot {
  margin-top: auto;
  font-family: var(--bb-sans);
  font-size: 0.76rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  border-bottom: 1px solid var(--bb-black);
  padding-bottom: 2px;
  align-self: flex-start;
  text-decoration: none;
  color: var(--bb-charcoal);
  transition: color 0.15s, border-color 0.15s;
}
.bb-account-card__foot:hover {
  color: var(--bb-accent);
  border-bottom-color: var(--bb-accent);
}
.bb-account-card__addr {
  font-family: var(--bb-serif);
  font-size: 1rem;
  line-height: 1.55;
  margin-bottom: 0.75rem;
}
.bb-account-card__addr-extra {
  font-size: 0.82rem;
  color: var(--bb-muted);
  margin-bottom: 1rem;
}

/* Order row inside card */
.bb-account-order-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem 0;
  border-top: 1px solid var(--bb-line);
  text-decoration: none;
  color: inherit;
  transition: background 0.15s;
}
.bb-account-order-row:first-of-type {
  border-top: 0;
  padding-top: 0.25rem;
}
.bb-account-order-row:hover {
  background: var(--bb-cream);
}
.bb-account-order-row__thumb {
  width: 48px;
  height: 60px;
  background: var(--bb-cream);
  overflow: hidden;
  flex-shrink: 0;
}
.bb-account-order-row__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bb-account-order-row__info {
  flex: 1;
  min-width: 0;
}
.bb-account-order-row__info b {
  display: block;
  font-family: var(--bb-serif);
  font-size: 0.95rem;
  font-weight: 500;
}
.bb-account-order-row__info span {
  font-family: var(--bb-sans);
  font-size: 0.8rem;
  color: var(--bb-muted);
}
.bb-account-order-row__status {
  font-family: var(--bb-sans);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 0.25rem 0.5rem;
  background: var(--bb-cream);
  color: var(--bb-charcoal);
  white-space: nowrap;
}
.bb-account-order-row__status--done {
  background: var(--bb-black);
  color: #fff;
}

/* Quick actions */
.bb-account-card--quick {
  min-height: 0;
}
.bb-account-quick-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}
.bb-account-quick-btn {
  padding: 1rem 0.75rem;
  background: var(--bb-cream);
  border: 1px solid var(--bb-line);
  text-align: center;
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--bb-charcoal);
  cursor: pointer;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.bb-account-quick-btn:hover {
  background: var(--bb-black);
  color: #fff;
  border-color: var(--bb-black);
}
.bb-account-quick-btn svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  display: block;
  margin: 0 auto 0.4rem;
}

/* Non-dashboard content styling — forms, tables, addresses */
.bb-account-main .woocommerce-MyAccount-content > h2,
.bb-account-main .woocommerce-MyAccount-content > h3 {
  font-family: var(--bb-serif);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-bottom: 1.25rem;
  text-transform: none;
}
.bb-account-main .woocommerce-MyAccount-content > h2 {
  font-size: 1.75rem;
}

.bb-account-main .shop_table {
  border: 0;
  width: 100%;
  border-collapse: collapse;
}
.bb-account-main .shop_table thead th {
  text-align: left;
  padding: 0.75rem 0.5rem;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  border-bottom: 1px solid var(--bb-black);
}
.bb-account-main .shop_table tbody td {
  padding: 1rem 0.5rem;
  border-bottom: 1px solid var(--bb-line);
  font-size: 0.95rem;
}
.bb-account-main .shop_table .woocommerce-orders-table__cell-order-number a {
  font-family: var(--bb-serif);
  font-size: 1.05rem;
  font-weight: 500;
}

.bb-account-main .woocommerce-Address {
  background: var(--bb-cream);
  padding: 1.75rem 1.5rem;
  margin-bottom: 1.5rem;
}
.bb-account-main .woocommerce-Address-title {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 1rem;
}
.bb-account-main .woocommerce-Address-title h2,
.bb-account-main .woocommerce-Address-title h3 {
  font-family: var(--bb-serif);
  font-size: 1.25rem;
  font-weight: 500;
  margin: 0;
}
.bb-account-main .woocommerce-Address-title .edit {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  border-bottom: 1px solid var(--bb-black);
  padding-bottom: 1px;
}
.bb-account-main .woocommerce-Address address {
  font-family: var(--bb-serif);
  font-style: normal;
  font-size: 1rem;
  line-height: 1.55;
}

.bb-account-main form .form-row {
  margin-bottom: 1.25rem;
}
.bb-account-main form label {
  display: block;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  margin-bottom: 0.4rem;
}
.bb-account-main form input[type="text"],
.bb-account-main form input[type="email"],
.bb-account-main form input[type="password"],
.bb-account-main form input[type="tel"],
.bb-account-main form select,
.bb-account-main form textarea {
  width: 100%;
  padding: 0.85rem 0;
  border: 0;
  border-bottom: 1px solid var(--bb-line);
  background: transparent;
  font: inherit;
  font-size: 1rem;
  color: var(--bb-charcoal);
  border-radius: 0;
  transition: border-color 0.15s;
}
.bb-account-main form input:focus,
.bb-account-main form select:focus,
.bb-account-main form textarea:focus {
  outline: none;
  border-bottom-color: var(--bb-black);
}
.bb-account-main form .button,
.bb-account-main form button[type="submit"] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1rem 1.75rem;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  border: 0;
  cursor: pointer;
  transition: background 0.2s;
  border-radius: 0;
}
.bb-account-main form .button::after,
.bb-account-main form button[type="submit"]::after {
  content: "→";
  transition: transform 0.2s;
}
.bb-account-main form .button:hover,
.bb-account-main form button[type="submit"]:hover {
  background: var(--bb-accent);
}
.bb-account-main form .button:hover::after,
.bb-account-main form button[type="submit"]:hover::after {
  transform: translateX(4px);
}

@media (max-width: 1000px) {
  .bb-account-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .bb-account-sidebar {
    position: static;
  }
  .bb-account-dashboard {
    grid-template-columns: 1fr;
  }
  .bb-account-quick-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ── View Order page (#208 itp.) — Editorial styling ── */
.bb-account-main .woocommerce-order-details,
.bb-account-main .woocommerce-customer-details {
  background: #fff;
  border: 1px solid var(--bb-line);
  padding: 2rem 1.75rem;
  margin-bottom: 1.5rem;
}
.bb-account-main .woocommerce-order-details__title,
.bb-account-main .woocommerce-column__title {
  font-family: var(--bb-serif);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-line);
  text-transform: none;
}
.bb-account-main > p:first-of-type {
  font-family: var(--bb-serif);
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 1.75rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--bb-black);
}
.bb-account-main > p:first-of-type strong {
  color: var(--bb-accent);
  font-weight: 500;
}
.bb-account-main .woocommerce-order-details .woocommerce-table tfoot tr,
.bb-account-main .woocommerce-table--order-details tfoot tr {
  background: transparent;
}
.bb-account-main .woocommerce-table__line-item .wc-item-meta {
  font-size: 0.85rem;
  color: var(--bb-muted);
  margin: 0.35rem 0 0;
  padding: 0;
  list-style: none;
}
.bb-account-main .woocommerce-table__line-item .product-quantity {
  color: var(--bb-muted);
  font-weight: 400;
}
.bb-account-main .woocommerce-customer-details address {
  font-family: var(--bb-serif);
  font-style: normal;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--bb-charcoal);
  padding: 0;
  border: 0;
}
.bb-account-main .woocommerce-column {
  margin-bottom: 1.5rem;
}

/* ── Order list (zamówienia) ── */
.bb-account-main .woocommerce-orders-table,
.bb-account-main .account-orders-table {
  width: 100%;
  border-collapse: collapse;
  border: 0;
}
.bb-account-main .woocommerce-orders-table__cell-order-actions {
  text-align: right;
}
.bb-account-main .woocommerce-orders-table__cell-order-actions .button,
.bb-account-main .woocommerce-orders-table .woocommerce-button {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.55rem 0.95rem;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  background: transparent;
  color: var(--bb-charcoal);
  border: 1px solid var(--bb-line);
  margin-left: 0.35rem;
  transition: all 0.15s;
  text-decoration: none;
}
.bb-account-main .woocommerce-orders-table__cell-order-actions .button:hover {
  background: var(--bb-black);
  color: #fff;
  border-color: var(--bb-black);
}
.bb-account-main .woocommerce-orders-table__cell-order-actions .button.view {
  background: var(--bb-black);
  color: #fff;
  border-color: var(--bb-black);
}
.bb-account-main .woocommerce-orders-table__cell-order-actions .button.view:hover {
  background: var(--bb-accent);
  border-color: var(--bb-accent);
}
.bb-account-main .woocommerce-orders-table__cell-order-status {
  display: inline-block;
  padding: 0.25rem 0.55rem;
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  background: var(--bb-cream);
  font-weight: 600;
}
.bb-account-main .woocommerce-Pagination,
.bb-account-main .woocommerce-pagination {
  margin-top: 2rem;
}

/* ── Edit address (My Addresses list) ── */
.bb-account-main .u-columns,
.bb-account-main .addresses {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.bb-account-main .u-column1,
.bb-account-main .u-column2,
.bb-account-main .col-1,
.bb-account-main .col-2 {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.bb-account-main .woocommerce-Addresses {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin: 0;
}
.bb-account-main .woocommerce-Address {
  margin: 0;
}
.bb-account-main .woocommerce-Address a.edit,
.bb-account-main a.edit {
  display: inline-block;
  margin-top: 0.75rem;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-charcoal);
  border-bottom: 1px solid var(--bb-charcoal);
  padding-bottom: 1px;
  text-decoration: none;
  transition: color 0.15s, border-color 0.15s;
}
.bb-account-main .woocommerce-Address a.edit:hover,
.bb-account-main a.edit:hover {
  color: var(--bb-accent);
  border-bottom-color: var(--bb-accent);
}

/* ── Edit account + address forms ── */
.bb-account-main fieldset {
  border: 0;
  padding: 1.75rem 0 0;
  margin: 1.75rem 0 0;
  border-top: 1px solid var(--bb-line);
}
.bb-account-main fieldset legend {
  font-family: var(--bb-serif);
  font-size: 1.25rem;
  font-weight: 500;
  margin-bottom: 1rem;
  letter-spacing: -0.01em;
}
.bb-account-main .woocommerce-password-hint {
  display: block;
  font-size: 0.82rem;
  color: var(--bb-muted);
  margin-top: 0.35rem;
  line-height: 1.5;
}

/* ── Zwroty (Returns) ── */
.bb-account-main .bb-returns h2 {
  font-family: var(--bb-serif);
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 0.5rem;
}
.bb-account-main .bb-returns__intro {
  color: var(--bb-muted);
  font-size: 0.95rem;
  line-height: 1.55;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--bb-line);
}
.bb-account-main .bb-returns__empty {
  color: var(--bb-muted);
  font-style: italic;
  padding: 2rem 0;
  text-align: center;
  background: var(--bb-cream);
  border: 1px dashed var(--bb-line);
}
.bb-account-main .bb-returns__list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.bb-account-main .bb-returns__item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.25rem 1.5rem;
  background: var(--bb-cream);
  border-left: 3px solid var(--bb-black);
  transition: border-color 0.15s;
}
.bb-account-main .bb-returns__item:hover {
  border-left-color: var(--bb-accent);
}
.bb-account-main .bb-returns__info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.bb-account-main .bb-returns__name {
  font-family: var(--bb-serif);
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.bb-account-main .bb-returns__meta {
  font-size: 0.88rem;
  color: var(--bb-muted);
}
.bb-account-main .bb-returns__days {
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-accent);
  font-weight: 600;
  margin-top: 0.25rem;
}
.bb-account-main .bb-returns__action .bb-btn,
.bb-account-main .bb-returns__action button[type="submit"] {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 0.85rem 1.5rem;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  border: 0;
  cursor: pointer;
  transition: background 0.2s;
}
.bb-account-main .bb-returns__action button[type="submit"]::after {
  content: "→";
  transition: transform 0.2s;
}
.bb-account-main .bb-returns__action button[type="submit"]:hover {
  background: var(--bb-accent);
}
.bb-account-main .bb-returns__action button[type="submit"]:hover::after {
  transform: translateX(4px);
}

/* ── Editorial head for every account sub-page ── */
.bb-account-main .woocommerce-MyAccount-content > h2:first-child,
.bb-account-main .woocommerce-MyAccount-content > form > h2:first-child,
.bb-account-main > h2:first-child {
  font-family: var(--bb-serif);
  font-size: clamp(1.8rem, 3vw, 2.25rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-black);
}

@media (max-width: 900px) {
  .bb-account-main .u-columns,
  .bb-account-main .addresses,
  .bb-account-main .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }
  .bb-account-main .bb-returns__item {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   ULUBIONE — Magazine layout (Mockup C)
   ============================================================ */
.bb-wishlist {
  padding: 0;
}

/* Override the existing YITH bb-wishlist-page table styles — we render our own markup. */
.bb-wishlist .wishlist_table,
.bb-wishlist .yith-wcwl-wishlist-items-wrapper {
  display: none;
}

.bb-wishlist__hero {
  padding: 4rem 0 2rem;
}
.bb-wishlist__title {
  font-family: var(--bb-serif);
  font-size: clamp(2.25rem, 4vw, 3.5rem);
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0 0 0.5rem;
  text-transform: none;
}
.bb-wishlist__title em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-wishlist__intro {
  color: var(--bb-muted);
  font-size: 1rem;
  margin: 0;
}

/* Empty state */
.bb-wishlist__empty {
  padding: 4rem 2rem 6rem;
  text-align: center;
}
.bb-wishlist__empty p {
  font-family: var(--bb-serif);
  font-size: 1.35rem;
  font-style: italic;
  color: var(--bb-muted);
  margin-bottom: 1.5rem;
}
.bb-wishlist__empty-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1rem 1.75rem;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s;
}
.bb-wishlist__empty-cta:hover {
  background: var(--bb-accent);
  color: #fff;
}

.bb-wishlist__split {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 3rem;
  padding: 2rem 0 6rem;
  align-items: start;
}

/* Sidebar */
.bb-wishlist__sidebar {
  background: var(--bb-cream);
  padding: 2rem 1.75rem;
  position: sticky;
  top: 2rem;
}
.bb-wishlist__sidebar-eye {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.bb-wishlist__stat {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 1rem 0;
  border-bottom: 1px solid var(--bb-line);
  font-size: 0.95rem;
}
.bb-wishlist__stat:last-of-type {
  border-bottom: 0;
  padding-bottom: 0;
}
.bb-wishlist__stat span {
  color: var(--bb-muted);
}
.bb-wishlist__stat b {
  font-family: var(--bb-serif);
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.bb-wishlist__stat-big {
  font-size: 1.8rem !important;
  color: var(--bb-accent);
}
.bb-wishlist__stat bdi,
.bb-wishlist__stat .woocommerce-Price-amount {
  font-family: var(--bb-serif);
  font-weight: 500;
}

.bb-wishlist__divider {
  height: 1px;
  background: var(--bb-black);
  margin: 1.5rem 0;
}

.bb-wishlist__cats {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1.5rem;
}
.bb-wishlist__cat-chip {
  display: flex;
  justify-content: space-between;
  padding: 0.5rem 0;
  font-size: 0.88rem;
  color: var(--bb-muted);
  border-bottom: 1px solid var(--bb-line);
  letter-spacing: 0.05em;
}
.bb-wishlist__cat-chip:last-child {
  border-bottom: 0;
}
.bb-wishlist__cat-chip span {
  font-family: var(--bb-serif);
  font-size: 1rem;
  color: var(--bb-charcoal);
}

.bb-wishlist__sidebar-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1rem 1.25rem;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  width: 100%;
  margin-bottom: 0.6rem;
  text-decoration: none;
  transition: background 0.2s;
  cursor: pointer;
}
.bb-wishlist__sidebar-cta::after {
  content: "→";
  transition: transform 0.2s;
}
.bb-wishlist__sidebar-cta:hover {
  background: var(--bb-accent);
  color: #fff;
}
.bb-wishlist__sidebar-cta:hover::after {
  transform: translateX(4px);
}
.bb-wishlist__sidebar-clear {
  display: block;
  text-align: center;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bb-muted);
  padding: 0.5rem 0;
  border-bottom: 1px solid transparent;
  text-decoration: none;
  transition: color 0.15s, border-color 0.15s;
}
.bb-wishlist__sidebar-clear:hover {
  color: var(--bb-accent);
  border-bottom-color: var(--bb-accent);
}

/* Main area */
.bb-wishlist__main {
  min-width: 0;
}
.bb-wishlist__main-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.5rem;
  align-items: baseline;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-black);
  margin-bottom: 2rem;
}
.bb-wishlist__main-num {
  font-family: var(--bb-serif);
  font-size: 0.95rem;
  letter-spacing: 0.1em;
  color: var(--bb-muted);
}
.bb-wishlist__main-head h2 {
  font-family: var(--bb-serif);
  font-size: 1.75rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0;
  text-transform: none;
}
.bb-wishlist__main-head h2 em {
  font-style: italic;
  color: var(--bb-accent);
}

/* Grid */
.bb-wishlist__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem 1.5rem;
}
.bb-wishlist__card {
  position: relative;
  display: flex;
  flex-direction: column;
}
.bb-wishlist__card-img {
  aspect-ratio: 4 / 5;
  background: var(--bb-cream);
  overflow: hidden;
  position: relative;
  margin-bottom: 1rem;
}
.bb-wishlist__card-img a {
  display: block;
  width: 100%;
  height: 100%;
}
.bb-wishlist__card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s ease;
}
.bb-wishlist__card:hover .bb-wishlist__card-img img {
  transform: scale(1.03);
}
.bb-wishlist__card-num {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  font-family: var(--bb-serif);
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  color: #fff;
  background: rgba(10, 10, 10, 0.75);
  padding: 0.2rem 0.5rem;
  font-weight: 500;
  z-index: 2;
}
.bb-wishlist__card-remove {
  position: absolute;
  top: 0.6rem;
  right: 0.6rem;
  width: 32px;
  height: 32px;
  background: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 1rem;
  color: var(--bb-muted);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: color 0.15s, background 0.15s;
  border: 0;
  cursor: pointer;
  z-index: 2;
}
.bb-wishlist__card-remove:hover {
  color: var(--bb-accent);
  background: var(--bb-cream);
}
.bb-wishlist__card-hover {
  position: absolute;
  inset: auto 0 0 0;
  background: linear-gradient(to top, rgba(10, 10, 10, 0.8) 0%, rgba(10, 10, 10, 0) 100%);
  padding: 1rem;
  opacity: 0;
  transition: opacity 0.2s;
  display: flex;
  gap: 0.5rem;
}
.bb-wishlist__card:hover .bb-wishlist__card-hover {
  opacity: 1;
}
.bb-wishlist__card-hover button {
  flex: 1;
  padding: 0.75rem;
  background: #fff;
  color: var(--bb-charcoal);
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  transition: background 0.15s, color 0.15s;
  border: 0;
  cursor: pointer;
}
.bb-wishlist__card-hover button:hover {
  background: var(--bb-accent);
  color: #fff;
}
.bb-wishlist__card-cat {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  margin-bottom: 0.25rem;
  font-weight: 600;
}
.bb-wishlist__card-name {
  font-family: var(--bb-serif);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin: 0 0 0.35rem;
  text-transform: none;
}
.bb-wishlist__card-name a {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s;
}
.bb-wishlist__card-name a:hover {
  color: var(--bb-accent);
}
.bb-wishlist__card-price {
  font-family: var(--bb-serif);
  font-size: 1rem;
  font-weight: 500;
  color: var(--bb-accent);
}
.bb-wishlist__card-price del {
  opacity: 0.5;
  margin-right: 0.35rem;
}

@media (max-width: 1000px) {
  .bb-wishlist__split {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .bb-wishlist__sidebar {
    position: static;
  }
  .bb-wishlist__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem 1rem;
  }
}

/* ============================================================
   PŁATNOŚCI — Payment methods (Mockup A)
   ============================================================ */
.bb-payments {
  max-width: 820px;
}
.bb-payments__head {
  border-bottom: 1px solid var(--bb-black);
  padding-bottom: 1.25rem;
  margin-bottom: 2rem;
}
.bb-payments__head h2 {
  font-family: var(--bb-serif);
  font-size: clamp(1.8rem, 3vw, 2.25rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 0.5rem;
  text-transform: none;
}
.bb-payments__head h2 em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-payments__head p {
  color: var(--bb-muted);
  font-size: 0.95rem;
  line-height: 1.55;
  margin: 0;
  max-width: 58ch;
}

/* Saved card list */
.bb-payments__list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 2rem;
}
.bb-payments__card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.25rem 1.5rem;
  border: 1px solid var(--bb-line);
  background: #fff;
  transition: border-color 0.15s;
}
.bb-payments__card:hover {
  border-color: var(--bb-muted);
}
.bb-payments__card--default {
  border-left: 3px solid var(--bb-black);
}
.bb-payments__card-brand {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.bb-payments__card-brand svg {
  width: 32px;
  height: 32px;
  stroke: var(--bb-charcoal);
  fill: none;
  stroke-width: 1.4;
  flex-shrink: 0;
}
.bb-payments__card-brand b {
  font-family: var(--bb-serif);
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  display: block;
}
.bb-payments__card-brand span {
  display: block;
  color: var(--bb-muted);
  font-size: 0.85rem;
  margin-top: 0.15rem;
}
.bb-payments__card-brand span em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-payments__card-actions {
  display: flex;
  gap: 0.75rem;
}
.bb-payments__action {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--bb-muted);
  padding: 0.45rem 0.85rem;
  border: 1px solid var(--bb-line);
  text-decoration: none;
  transition: all 0.15s;
}
.bb-payments__action:hover {
  border-color: var(--bb-charcoal);
  color: var(--bb-charcoal);
}
.bb-payments__action--delete:hover {
  border-color: var(--bb-accent);
  color: var(--bb-accent);
}
.bb-payments__action--default:hover {
  border-color: var(--bb-black);
  background: var(--bb-black);
  color: #fff;
}

/* Empty state */
.bb-payments__empty {
  background: var(--bb-cream);
  padding: 3rem 2rem;
  text-align: center;
  margin-bottom: 2rem;
  border-left: 3px solid var(--bb-accent);
}
.bb-payments__empty-icon {
  margin: 0 auto 1rem;
}
.bb-payments__empty-icon svg {
  width: 48px;
  height: 48px;
  stroke: var(--bb-muted);
  fill: none;
  stroke-width: 1.3;
}
.bb-payments__empty h3 {
  font-family: var(--bb-serif);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 0.5rem;
  text-transform: none;
}
.bb-payments__empty h3 em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-payments__empty p {
  color: var(--bb-muted);
  max-width: 46ch;
  margin: 0 auto;
  line-height: 1.55;
  font-size: 0.95rem;
}

/* Add CTA block */
.bb-payments__add {
  border-top: 1px solid var(--bb-line);
  padding-top: 1.5rem;
  margin-bottom: 3rem;
}
.bb-payments__add-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1.1rem 1.75rem;
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s;
}
.bb-payments__add-btn:hover {
  background: var(--bb-accent);
  color: #fff;
}
.bb-payments__security {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--bb-muted);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 500;
  margin: 1rem 0 0;
}
.bb-payments__security svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
}

/* Info cards */
.bb-payments__info {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding-top: 2rem;
  border-top: 1px solid var(--bb-line);
}
.bb-payments__info-card {
  padding: 1.5rem 1.25rem;
  background: var(--bb-cream);
}
.bb-payments__info-label {
  font-family: var(--bb-sans);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--bb-accent);
  font-weight: 600;
  margin-bottom: 0.6rem;
}
.bb-payments__info-card h4 {
  font-family: var(--bb-serif);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 0.5rem;
}
.bb-payments__info-card p {
  color: var(--bb-muted);
  font-size: 0.88rem;
  line-height: 1.55;
  margin: 0;
}

@media (max-width: 800px) {
  .bb-payments__card {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  .bb-payments__card-actions {
    justify-content: flex-start;
  }
  .bb-payments__info {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   NOWOŚCI — Editorial grid (Mockup A)
   ============================================================ */
.bb-nowosci {
  padding: 0;
}
.bb-nowosci__hero {
  padding: 5rem 0 2rem;
}

.bb-nowosci__head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: end;
  gap: 2rem;
  padding: 3rem 0 2rem;
  border-top: 1px solid var(--bb-line);
}
.bb-nowosci__num {
  font-family: var(--bb-serif);
  font-size: 0.95rem;
  letter-spacing: 0.1em;
  color: var(--bb-charcoal);
}
.bb-nowosci__title {
  font-family: var(--bb-serif);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0;
  text-transform: none;
}
.bb-nowosci__title em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-nowosci__count {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
}

.bb-nowosci__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem 2.5rem;
  padding: 2rem 0 5rem;
}
.bb-nowosci__card {
  position: relative;
}
.bb-nowosci__card-imgwrap {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  background: var(--bb-cream);
  overflow: hidden;
  margin-bottom: 1.25rem;
  position: relative;
}
@supports not (aspect-ratio: 1) {
  .bb-nowosci__card-imgwrap { aspect-ratio: auto; padding-top: 133.333%; height: 0; }
}
.bb-nowosci__card-imgwrap img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  transition: transform 0.8s ease;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  aspect-ratio: auto !important;
}
.bb-nowosci__card:hover .bb-nowosci__card-imgwrap img {
  transform: scale(1.04);
}
.bb-nowosci__card-badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  background: var(--bb-black);
  color: #fff;
  padding: 0.35rem 0.7rem;
  font-family: var(--bb-sans);
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  z-index: 2;
}
.bb-nowosci__card-name {
  font-family: var(--bb-serif);
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 0.4rem;
  line-height: 1.25;
  text-transform: none;
}
.bb-nowosci__card-name a {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s;
}
.bb-nowosci__card-name a:hover {
  color: var(--bb-accent);
}
.bb-nowosci__card-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  color: var(--bb-muted);
  font-family: var(--bb-sans);
  font-size: 0.85rem;
}
.bb-nowosci__card-price {
  color: var(--bb-charcoal);
  font-weight: 600;
}
.bb-nowosci__card-cat {
  text-transform: capitalize;
}

/* Image-only inner anchor (decoupled from CTA so add-to-cart works) */
.bb-nowosci__card-img {
  display: block;
  position: absolute;
  inset: 0;
  text-decoration: none;
  z-index: 1;
}
.bb-nowosci__card-img img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}

/* Add-to-cart CTA — editorial pill (matches shop archive) */
.bb-nowosci__card-cta { margin-top: 0.85rem; }

.bb-nowosci__card-cta .bb-nowosci__card-add,
.bb-nowosci__card-cta .button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.4rem !important;
  width: 100% !important;
  padding: 0.7rem 1rem !important;
  background: #fff !important;
  color: #0A0A0A !important;
  border: 1px solid #0A0A0A !important;
  border-radius: 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  cursor: pointer !important;
  min-height: 40px !important;
  transition: background 0.2s, color 0.2s, border-color 0.2s !important;
  position: relative;
  z-index: 2;
}
.bb-nowosci__card-cta .bb-nowosci__card-add::before,
.bb-nowosci__card-cta .button::before { content: '+' !important; font-size: 0.95rem; line-height: 1; margin-right: 0.15rem; }
.bb-nowosci__card-cta .product_type_variable::before,
.bb-nowosci__card-cta .product_type_grouped::before,
.bb-nowosci__card-cta .product_type_external::before { content: '→' !important; }
.bb-nowosci__card-cta .bb-nowosci__card-add:hover,
.bb-nowosci__card-cta .button:hover {
  background: #0A0A0A !important;
  color: #fff !important;
  border-color: #0A0A0A !important;
}
/* Hide WC AJAX feedback link / loading state inside card */
.bb-nowosci__card-cta .added_to_cart { display: none !important; }
.bb-nowosci__card-cta .added::after,
.bb-nowosci__card-cta .button.loading::after { display: none !important; }
.bb-nowosci__card-cta .button.loading { opacity: 0.6; pointer-events: none; }

.bb-nowosci__empty {
  padding: 4rem 0 6rem;
  text-align: center;
  color: var(--bb-muted);
}

@media (max-width: 900px) {
  .bb-nowosci__head {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
  .bb-nowosci__grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem 1rem;
  }
}

/* ============================================================
   PRODUCT — single product (Mockup A wariant A)
   ============================================================ */
.bb-product {
  padding: 0;
}

/* Breadcrumbs */
.bb-product__crumbs {
  padding: 1.5rem 0;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bb-muted);
}
.bb-product__crumbs a {
  color: inherit;
  text-decoration: none;
}
.bb-product__crumbs a:hover {
  color: var(--bb-charcoal);
}
.bb-product__crumbs span {
  margin: 0 0.5rem;
}

/* Product article: 2-col split */
.bb-product__article {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 4rem;
  padding: 1rem 0 5rem;
  align-items: start;
}

/* Gallery (left) — sticky */
.bb-product__gallery {
  position: sticky;
  top: 2rem;
}
.bb-product__gallery .woocommerce-product-gallery {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  opacity: 1 !important;
}
.bb-product__gallery .woocommerce-product-gallery__wrapper {
  margin: 0;
}
.bb-product__gallery .woocommerce-product-gallery__image {
  background: var(--bb-cream);
  overflow: hidden;
  margin-bottom: 0.75rem;
}
.bb-product__gallery .woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}
.bb-product__gallery .flex-control-thumbs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5rem;
  list-style: none;
  margin: 0.5rem 0 0;
  padding: 0;
}
.bb-product__gallery .flex-control-thumbs li {
  margin: 0;
  width: auto !important;
  float: none !important;
}
.bb-product__gallery .flex-control-thumbs img {
  width: 100% !important;
  aspect-ratio: 1 !important;
  height: auto !important;
  object-fit: cover;
  cursor: pointer;
  opacity: 0.7;
  border: 2px solid transparent;
  transition: opacity 0.15s, border-color 0.15s;
}
.bb-product__gallery .flex-control-thumbs img:hover,
.bb-product__gallery .flex-control-thumbs img.flex-active {
  opacity: 1;
  border-color: var(--bb-black);
}
.bb-product__gallery .onsale {
  position: absolute;
  top: 1rem;
  left: 1rem;
  background: var(--bb-accent);
  color: #fff;
  padding: 0.35rem 0.7rem;
  font-family: var(--bb-sans);
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  border-radius: 0;
  min-height: 0;
  min-width: 0;
  line-height: 1;
  z-index: 9;
}

/* Summary (right) */
.bb-product__summary {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0;
}

/* Category eyebrow before title via posted_in */
.bb-product__summary .product_meta {
  font-size: 0.85rem;
  color: var(--bb-muted);
  padding-top: 1rem;
  margin-top: 1.5rem;
  border-top: 1px solid var(--bb-line);
}
.bb-product__summary .product_meta .posted_in,
.bb-product__summary .product_meta .sku_wrapper,
.bb-product__summary .product_meta .tagged_as {
  display: block;
  margin-bottom: 0.35rem;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.05em;
}
.bb-product__summary .product_meta a {
  color: var(--bb-charcoal);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s, color 0.15s;
}
.bb-product__summary .product_meta a:hover {
  color: var(--bb-accent);
  border-bottom-color: var(--bb-accent);
}

/* Eyebrow above title (category) */
.bb-product__eyebrow {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bb-accent);
  font-weight: 600;
  margin-bottom: 1rem;
}

/* Title */
.bb-product__summary .product_title {
  font-family: var(--bb-serif) !important;
  font-size: clamp(2rem, 3.5vw, 3.25rem) !important;
  font-weight: 300 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.05 !important;
  margin: 0 0 1.25rem !important;
  text-transform: none !important;
  color: var(--bb-charcoal) !important;
}
.bb-product__summary .product_title em {
  font-style: italic;
  color: var(--bb-accent);
}

/* Size attribute chips */
.bb-product__size {
  margin: 0 0 1.5rem;
}
.bb-product__size-label {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  margin-bottom: 0.75rem;
}
.bb-product__size-chips {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.bb-product__size-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.75rem 1.15rem;
  border: 1px solid var(--bb-line);
  background: #fff;
  font-family: var(--bb-sans);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: default;
}
.bb-product__size-chip.on {
  background: var(--bb-black);
  color: #fff;
  border-color: var(--bb-black);
}

/* Hide WC SKU/categories meta — we have our own breadcrumb + eyebrow */
.bb-product__summary .product_meta {
  display: none !important;
}

/* Price */
.bb-product__summary .price {
  font-family: var(--bb-serif);
  font-size: 1.75rem;
  font-weight: 500;
  margin: 0 0 1.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--bb-line);
  color: var(--bb-charcoal);
  display: block;
}
.bb-product__summary .price bdi,
.bb-product__summary .price .woocommerce-Price-amount {
  font-family: var(--bb-serif);
  font-weight: 500;
}
.bb-product__summary .price ins {
  text-decoration: none;
  color: var(--bb-accent);
}
.bb-product__summary .price del {
  opacity: 0.5;
  margin-right: 0.5rem;
  font-size: 1.15rem;
}

/* Short description */
.bb-product__summary .woocommerce-product-details__short-description {
  color: var(--bb-muted);
  line-height: 1.65;
  margin-bottom: 2rem;
  font-size: 1rem;
  max-width: 52ch;
}
.bb-product__summary .woocommerce-product-details__short-description p {
  margin-bottom: 0.75rem;
}

/* Stock */
.bb-product__summary .stock {
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  margin: 1rem 0 0;
  padding: 0;
}
.bb-product__summary .stock.in-stock {
  color: #4A7C4A;
}
.bb-product__summary .stock.out-of-stock {
  color: var(--bb-accent);
}

/* Add-to-cart form (cart) */
.bb-product__summary form.cart {
  margin: 0 0 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: stretch;
}
.bb-product__summary form.cart .quantity {
  display: flex;
  border: 1px solid var(--bb-line);
  background: #fff;
  align-items: center;
  margin: 0;
}
.bb-product__summary form.cart .quantity .qty,
.bb-product__summary form.cart .quantity input[type="number"] {
  width: 3rem;
  border: 0;
  text-align: center;
  font: inherit;
  padding: 0.85rem 0;
  background: transparent;
  border-left: 1px solid var(--bb-line);
  border-right: 1px solid var(--bb-line);
  -moz-appearance: textfield;
}
.bb-product__summary form.cart .quantity input::-webkit-outer-spin-button,
.bb-product__summary form.cart .quantity input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.bb-product__summary form.cart .quantity button,
.bb-product__summary form.cart .quantity-button {
  padding: 0 1rem;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
  color: var(--bb-muted);
}
.bb-product__summary form.cart .quantity button:hover {
  color: var(--bb-charcoal);
}
.bb-product__summary form.cart .single_add_to_cart_button,
.bb-product__summary form.cart button.single_add_to_cart_button {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1.1rem 1.5rem;
  font-family: var(--bb-sans);
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  border: 0;
  border-radius: 0;
  cursor: pointer;
  transition: background 0.2s;
  min-height: 0;
  height: auto;
}
.bb-product__summary form.cart .single_add_to_cart_button::after {
  content: "→";
  display: inline-block;
  transition: transform 0.2s;
}
.bb-product__summary form.cart .single_add_to_cart_button:hover {
  background: var(--bb-accent);
}
.bb-product__summary form.cart .single_add_to_cart_button:hover::after {
  transform: translateX(4px);
}

/* Wishlist heart button — square icon-only */
.bb-product__summary .yith-wcwl-add-to-wishlist,
.bb-product__summary .yith-wcwl-add-to-wishlist-button {
  margin: 0 !important;
  display: inline-flex;
  align-items: stretch;
  flex: 0 0 auto;
}
.bb-product__summary .yith-wcwl-add-to-wishlist .yith-wcwl-add-button,
.bb-product__summary .yith-wcwl-add-to-wishlist .yith-wcwl-wishlistaddedbrowse,
.bb-product__summary .yith-wcwl-add-to-wishlist .yith-wcwl-wishlistexistsbrowse {
  display: inline-flex;
  align-items: stretch;
  margin: 0;
  padding: 0;
}
.bb-product__summary .yith-wcwl-add-to-wishlist .yith-wcwl-add-button a,
.bb-product__summary .yith-wcwl-add-to-wishlist a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  min-width: 56px;
  padding: 0;
  border: 1px solid var(--bb-line);
  background: #fff;
  color: var(--bb-charcoal);
  text-decoration: none;
  transition: all 0.15s;
  font-size: 0;
  line-height: 1;
}
.bb-product__summary .yith-wcwl-add-to-wishlist a::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background: currentColor;
  -webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z"/></svg>') center / contain no-repeat;
  mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z"/></svg>') center / contain no-repeat;
}
.bb-product__summary .yith-wcwl-add-to-wishlist a:hover {
  border-color: var(--bb-accent);
  color: var(--bb-accent);
}
.bb-product__summary .yith-wcwl-add-to-wishlist a i,
.bb-product__summary .yith-wcwl-add-to-wishlist a svg,
.bb-product__summary .yith-wcwl-add-to-wishlist a img {
  display: none !important;
}
.bb-product__summary .yith-wcwl-add-to-wishlist .feedback,
.bb-product__summary .yith-wcwl-add-to-wishlist .ajax-loading {
  display: none !important;
}

/* Variation/attribute selector (variable products) */
.bb-product__summary .variations {
  margin: 0 0 1.5rem;
  width: 100%;
  border-collapse: collapse;
}
.bb-product__summary .variations th {
  text-align: left;
  padding: 0 0 0.4rem;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  width: 30%;
}
.bb-product__summary .variations td {
  padding: 0 0 1rem;
}
.bb-product__summary .variations select {
  width: 100%;
  padding: 0.85rem 1rem;
  border: 1px solid var(--bb-line);
  background: #fff;
  font: inherit;
  font-size: 0.95rem;
  cursor: pointer;
}
.bb-product__summary .reset_variations {
  display: inline-block;
  margin-top: 0.5rem;
  font-size: 0.78rem;
  color: var(--bb-muted);
  border-bottom: 1px solid var(--bb-muted);
  padding-bottom: 1px;
  text-decoration: none;
}

/* Trust row */
.bb-product__trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding: 1.5rem 0;
  margin-top: 1rem;
  border-top: 1px solid var(--bb-line);
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  color: var(--bb-muted);
}
.bb-product__trust b {
  display: block;
  font-family: var(--bb-serif);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--bb-charcoal);
  margin-bottom: 0.15rem;
}

/* Tabs (accordion) — editorial */
.bb-product__tabs {
  padding: 3rem 0 5rem;
  border-top: 1px solid var(--bb-line);
}
.bb-product__tabs-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2rem;
  align-items: end;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-black);
}
.bb-product__tabs-num {
  font-family: var(--bb-serif);
  font-size: 0.95rem;
  letter-spacing: 0.1em;
  color: var(--bb-muted);
}
.bb-product__tabs-head h2 {
  font-family: var(--bb-serif);
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0;
  text-transform: none;
}
.bb-product__tabs-head h2 em {
  font-style: italic;
  color: var(--bb-accent);
}

/* Accordion items */
.bb-product__tabs .bb-accordion-item,
.bb-product-accordion .bb-accordion-item {
  border-bottom: 1px solid var(--bb-line);
}
.bb-product-accordion .bb-accordion-item h3 {
  margin: 0;
}
.bb-product-accordion .bb-accordion-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 0;
  background: transparent;
  border: 0;
  font-family: var(--bb-serif);
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--bb-charcoal);
  cursor: pointer;
  text-align: left;
  text-transform: none;
}
.bb-product-accordion .bb-accordion-trigger::after {
  content: "+";
  font-family: var(--bb-sans);
  font-size: 1.5rem;
  color: var(--bb-muted);
  font-weight: 300;
  transition: transform 0.2s;
}
.bb-product-accordion .bb-accordion-item.is-open .bb-accordion-trigger::after {
  content: "−";
}
.bb-product-accordion .bb-accordion-panel {
  padding: 0 0 1.5rem;
  color: var(--bb-muted);
  line-height: 1.7;
  font-size: 0.98rem;
}
.bb-product-accordion .bb-accordion-panel p {
  margin: 0 0 0.75rem;
}
.bb-product-accordion .bb-accordion-panel ul,
.bb-product-accordion .bb-accordion-panel ol {
  padding-left: 1.5rem;
  margin: 0 0 0.75rem;
}
.bb-product-accordion .bb-accordion-panel a {
  color: var(--bb-accent);
  border-bottom: 1px solid var(--bb-accent);
}
/* Hide duplicate first-h2/h3 inside accordion panel (often "Opis" from product description) */
.bb-product-accordion .bb-accordion-panel > h2:first-child,
.bb-product-accordion .bb-accordion-panel > h3:first-child {
  display: none;
}
/* Strip background from old WP block styles if any */
.bb-product-accordion .bb-accordion-panel,
.bb-product-accordion .bb-accordion-panel * {
  background: transparent !important;
  box-shadow: none;
}
.bb-product-accordion .bb-accordion-panel ul {
  list-style: disc;
  padding-left: 1.25rem;
}
.bb-product-accordion .bb-accordion-panel li {
  margin-bottom: 0.4rem;
  color: var(--bb-muted);
}
.bb-product-accordion .bb-accordion-panel strong {
  color: var(--bb-charcoal);
}

/* Related products */
.bb-product__related {
  padding: 4rem 0 6rem;
  border-top: 1px solid var(--bb-line);
}
.bb-product__related .related h2 {
  font-family: var(--bb-serif);
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-black);
  text-transform: none;
}
.bb-product__related .related ul.products,
.bb-product__related .related .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 2rem 1.5rem !important;
  list-style: none;
  margin: 0;
  padding: 0;
}
.bb-product__related .related li.product {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  padding: 0 !important;
}
.bb-product__related .related li.product .woocommerce-loop-product__link,
.bb-product__related .related li.product a {
  display: block;
  text-decoration: none;
  color: inherit;
}
.bb-product__related .related li.product img {
  width: 100% !important;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  margin: 0 0 0.75rem !important;
  background: var(--bb-cream);
  transition: transform 0.8s ease;
}
.bb-product__related .related li.product:hover img {
  transform: scale(1.04);
}
.bb-product__related .related li.product .woocommerce-loop-product__title {
  font-family: var(--bb-serif) !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em;
  margin: 0 0 0.25rem !important;
  text-transform: none !important;
  padding: 0 !important;
}
.bb-product__related .related li.product .price {
  font-family: var(--bb-serif);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--bb-charcoal);
  display: block;
  margin: 0;
}
.bb-product__related .related li.product .button,
.bb-product__related .related li.product .add_to_cart_button {
  display: none;
}

@media (max-width: 900px) {
  .bb-product__article {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  /* BB-MOBILE-PRODUCT-REORDER 2026-05-18 — Clarity finding #2:
     pokaż title+price+ATC NAD obrazem na mobile (DOM order zachowany, CSS order swap). */
  .bb-product__article .bb-product__summary { order: 1; }
  .bb-product__article .bb-product__gallery { order: 2; position: static; }
  /* Cap obraz max 65vh na <=640px — user widzi pełen image bez excessive scroll */
  .bb-product__gallery {
    position: static;
  }
  .bb-product__trust {
    grid-template-columns: 1fr;
    gap: 0.75rem;
    text-align: left;
  }
  .bb-product__related .related ul.products,
  .bb-product__related .related .products {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ============================================================
   ACCOUNT — Orders table with thumbnails + View-order editorial
   ============================================================ */

/* Orders list — editorial rows with thumbnails */
.bb-orders__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bb-black);
  margin-bottom: 1.5rem;
}
.bb-orders__head h2 {
  font-family: var(--bb-serif);
  font-size: 1.75rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0;
  text-transform: none;
}
.bb-orders__head h2 em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-orders__count {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
}

.bb-orders__list {
  display: flex;
  flex-direction: column;
}
.bb-orders__row {
  display: grid;
  grid-template-columns: 90px 1fr auto auto auto;
  gap: 1.5rem;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--bb-line);
  align-items: center;
}
.bb-orders__thumb {
  width: 90px;
  height: 110px;
  background: var(--bb-cream);
  overflow: hidden;
  display: block;
  flex-shrink: 0;
}
.bb-orders__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.bb-orders__row:hover .bb-orders__thumb img {
  transform: scale(1.03);
}
.bb-orders__info {
  min-width: 0;
}
.bb-orders__number {
  display: block;
  font-family: var(--bb-serif);
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--bb-charcoal);
  text-decoration: none;
  margin-bottom: 0.2rem;
}
.bb-orders__number:hover {
  color: var(--bb-accent);
}
.bb-orders__meta {
  color: var(--bb-muted);
  font-size: 0.85rem;
  margin-bottom: 0.3rem;
}
.bb-orders__items {
  font-size: 0.9rem;
  color: var(--bb-charcoal);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 340px;
}
.bb-orders__total {
  font-family: var(--bb-serif);
  font-size: 1.1rem;
  font-weight: 500;
  text-align: right;
  white-space: nowrap;
}
.bb-orders__total bdi,
.bb-orders__total .woocommerce-Price-amount {
  font-family: var(--bb-serif);
  font-weight: 500;
}
.bb-orders__status {
  font-family: var(--bb-sans);
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 0.35rem 0.7rem;
  background: var(--bb-cream);
  color: var(--bb-charcoal);
  white-space: nowrap;
}
.bb-orders__status--completed {
  background: var(--bb-black);
  color: #fff;
}
.bb-orders__status--processing {
  background: #fff;
  border: 1px solid var(--bb-accent);
  color: var(--bb-accent);
}
.bb-orders__status--pending,
.bb-orders__status--on-hold {
  background: #fff;
  border: 1px solid var(--bb-muted);
  color: var(--bb-muted);
}
.bb-orders__actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.bb-orders__action {
  font-family: var(--bb-sans);
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 0.5rem 0.85rem;
  border: 1px solid var(--bb-line);
  color: var(--bb-charcoal);
  text-decoration: none;
  transition: all 0.15s;
  white-space: nowrap;
}
.bb-orders__action:hover {
  border-color: var(--bb-black);
  background: var(--bb-black);
  color: #fff;
}
.bb-orders__action--view {
  background: var(--bb-black);
  color: #fff;
  border-color: var(--bb-black);
}
.bb-orders__action--view:hover {
  background: var(--bb-accent);
  border-color: var(--bb-accent);
}

/* Empty orders */
.bb-orders__empty {
  padding: 3rem 2rem 5rem;
  text-align: center;
  background: var(--bb-cream);
  border-left: 3px solid var(--bb-accent);
}
.bb-orders__empty h2 {
  font-family: var(--bb-serif);
  font-size: 2rem;
  font-weight: 300;
  letter-spacing: -0.02em;
  margin: 0 0 0.5rem;
  text-transform: none;
}
.bb-orders__empty h2 em {
  font-style: italic;
  color: var(--bb-accent);
}
.bb-orders__empty p {
  color: var(--bb-muted);
  max-width: 42ch;
  margin: 0 auto 1.5rem;
}
.bb-orders__browse-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--bb-black);
  color: #fff;
  padding: 1rem 1.75rem;
  font-family: var(--bb-sans);
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s;
}
.bb-orders__browse-btn:hover {
  background: var(--bb-accent);
  color: #fff;
}

/* View order — editorial detail */
.bb-account-main .woocommerce-table--order-details,
.bb-account-main table.woocommerce-table.woocommerce-table--order-details {
  border-collapse: collapse;
  width: 100%;
}
.bb-account-main .woocommerce-table--order-details thead th {
  text-align: left;
  padding: 0.85rem 0.75rem;
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
  border-bottom: 1px solid var(--bb-black);
  background: transparent;
}
.bb-account-main .woocommerce-table--order-details tbody td {
  padding: 1.25rem 0.75rem;
  border-bottom: 1px solid var(--bb-line);
  vertical-align: middle;
  font-size: 0.95rem;
}
.bb-account-main .woocommerce-table--order-details tbody tr:last-child td {
  border-bottom: 1px solid var(--bb-black);
}
.bb-account-main .woocommerce-table--order-details .woocommerce-table__product-name {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.bb-account-main .woocommerce-table--order-details .woocommerce-table__product-name > a:first-child,
.bb-account-main .woocommerce-table--order-details .woocommerce-table__product-name .bb-view-order-thumb {
  width: 64px;
  height: 80px;
  flex-shrink: 0;
  background: var(--bb-cream);
  overflow: hidden;
  display: block;
}
.bb-account-main .woocommerce-table--order-details .woocommerce-table__product-name img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bb-account-main .woocommerce-table--order-details .woocommerce-table__product-name > a.bb-view-order-name {
  font-family: var(--bb-serif);
  font-size: 1.05rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  text-decoration: none;
  color: var(--bb-charcoal);
  width: auto;
  height: auto;
  background: transparent;
}
.bb-account-main .woocommerce-table--order-details .woocommerce-table__product-name > a.bb-view-order-name:hover {
  color: var(--bb-accent);
}
.bb-account-main .woocommerce-table--order-details .product-quantity {
  color: var(--bb-muted);
  font-weight: 400;
  margin-left: 0.25rem;
}
.bb-account-main .woocommerce-table--order-details tfoot th {
  text-align: right;
  padding: 0.75rem;
  font-family: var(--bb-sans);
  font-size: 0.85rem;
  color: var(--bb-muted);
  font-weight: 500;
  border-bottom: 1px solid var(--bb-line);
}
.bb-account-main .woocommerce-table--order-details tfoot td {
  text-align: right;
  padding: 0.75rem;
  font-family: var(--bb-serif);
  font-weight: 500;
  border-bottom: 1px solid var(--bb-line);
}
.bb-account-main .woocommerce-table--order-details tfoot tr:last-child th,
.bb-account-main .woocommerce-table--order-details tfoot tr:last-child td {
  font-family: var(--bb-serif);
  font-size: 1.25rem;
  color: var(--bb-charcoal);
  border-bottom: 0;
  padding-top: 1.25rem;
  border-top: 2px solid var(--bb-black);
}
.bb-account-main .woocommerce-table--order-details tfoot tr:last-child th {
  font-family: var(--bb-sans);
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--bb-muted);
  font-weight: 600;
}

/* Customer details (billing/shipping) layout */
.bb-account-main .woocommerce-customer-details .col2-set,
.bb-account-main .woocommerce-customer-details > section,
.bb-account-main .woocommerce-customer-details .u-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.bb-account-main .woocommerce-customer-details .woocommerce-column {
  background: var(--bb-cream);
  padding: 1.75rem 1.5rem;
  margin: 0 !important;
  float: none !important;
  width: 100% !important;
}
.bb-account-main .woocommerce-customer-details h2,
.bb-account-main .woocommerce-customer-details .woocommerce-column__title {
  font-family: var(--bb-serif);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 0.75rem;
  padding: 0;
  border: 0;
  text-transform: none;
}
.bb-account-main .woocommerce-customer-details address {
  font-family: var(--bb-serif);
  font-style: normal;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--bb-charcoal);
  padding: 0;
  border: 0;
  background: transparent;
}

@media (max-width: 900px) {
  .bb-account-main .woocommerce-orders-table tbody tr.woocommerce-orders-table__row {
    grid-template-columns: 80px 1fr;
    gap: 0.75rem;
  }
  .bb-account-main .woocommerce-orders-table__cell-order-total,
  .bb-account-main .woocommerce-orders-table__cell-order-status,
  .bb-account-main .woocommerce-orders-table__cell-order-actions {
    grid-column: 2;
  }
  .bb-account-main .woocommerce-customer-details .col2-set,
  .bb-account-main .woocommerce-customer-details > section,
  .bb-account-main .woocommerce-customer-details .u-columns {
    grid-template-columns: 1fr;
  }
}


/* ============================================================
   SHOP ARCHIVE — Editorial collection (Wariant A)
   Overrides legacy .bb-product-card / .bb-shop-toolbar styles
   ============================================================ */

.bb-shop-archive { padding: 1.5rem 0 5rem; background: #fff; }

/* Breadcrumb */
.bb-shop__crumbs {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #6b6b6b;
  padding: 0.4rem 0 0.2rem;
}
.bb-shop__crumbs a { color: inherit; text-decoration: none; transition: color 0.15s; }
.bb-shop__crumbs a:hover { color: #0a0a0a; }
.bb-shop__crumbs span { margin: 0 0.4rem; color: #d9d4ca; }

/* Editorial header */
.bb-shop__head {
  padding: 1.75rem 0 2.5rem;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.25rem 3rem;
  align-items: end;
  border-bottom: 1px solid #0a0a0a;
}
.bb-shop__head-num {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #6b1f2e;
  font-weight: 600;
  padding-bottom: 0.5rem;
}
.bb-shop__head-title {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: clamp(2rem, 5vw, 3.4rem);
  letter-spacing: -0.02em;
  line-height: 1;
  color: #0a0a0a;
  margin: 0;
}
.bb-shop__head-title em { font-style: italic; color: #6b1f2e; }
.bb-shop__head-intro {
  grid-column: 2;
  max-width: 60ch;
  color: #6b6b6b;
  font-size: 1rem;
  margin: 0;
  padding-bottom: 0.4rem;
  font-family: 'Inter', sans-serif;
  line-height: 1.6;
}

/* Filter bar (NOT sticky — sticky was blocking CTA clicks on top products) */
.bb-shop__bar {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.25rem 0;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--bb-line, #e5e1db);
  background: #fff;
}
.bb-shop__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.bb-shop__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 1rem;
  border: 1px solid var(--bb-line, #e5e1db);
  background: #fff;
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #0a0a0a;
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
  min-height: 36px;
  font-weight: 500;
}
.bb-shop__chip:hover { border-color: #0a0a0a; }
.bb-shop__chip.on {
  background: #0a0a0a;
  color: #fff;
  border-color: #0a0a0a;
}
.bb-shop__chip .ct {
  font-size: 0.7rem;
  font-weight: 400;
  opacity: 0.6;
}

/* Sort dropdown — override legacy .woocommerce-ordering */
.bb-shop__sort .woocommerce-ordering { margin: 0; }
.bb-shop__sort select,
.bb-shop__sort .woocommerce-ordering select {
  font-family: 'Inter', sans-serif;
  font-size: 0.78rem;
  border: 1px solid var(--bb-line, #e5e1db);
  padding: 0.55rem 0.85rem;
  background: #fff;
  outline: 0;
  cursor: pointer;
  color: #0a0a0a;
  min-height: 36px;
  letter-spacing: 0.04em;
  text-transform: none;
}

/* PRODUCT GRID — fully replaces ul.products defaults */
.bb-shop-archive ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 3rem 2rem !important;
  padding: 2.5rem 0 0 !important;
  margin: 0 !important;
  list-style: none !important;
}
.bb-shop-archive ul.products::before,
.bb-shop-archive ul.products::after { content: none !important; display: none !important; }

/* CARD — editorial */
.bb-shop-archive ul.products li.product.bb-shop__card,
.bb-shop-archive .bb-shop__card {
  display: flex !important;
  flex-direction: column !important;
  background: transparent !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  float: none !important;
  list-style: none !important;
  cursor: pointer;
  transition: transform 0.25s ease;
}
.bb-shop-archive ul.products li.product.bb-shop__card:hover { transform: translateY(-3px); }

/* Media wrapper — positioning context for tag + heart, NOT a link
   Belt-and-suspenders aspect ratio: aspect-ratio (modern) + padding-top (fallback). */
.bb-shop__card-media {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4;
  background: #f5f2ed;
  border: 1px solid var(--bb-line, #e5e1db);
  overflow: hidden;
}
/* Padding-top fallback for browsers without aspect-ratio */
@supports not (aspect-ratio: 1) {
  .bb-shop__card-media { aspect-ratio: auto; padding-top: 133.333%; height: 0; }
}
.bb-shop__card-img {
  display: block;
  position: absolute;
  inset: 0;
  text-decoration: none;
  z-index: 1;
  overflow: hidden;
}
.bb-shop-archive ul.products li.product .bb-shop__card-img img,
.bb-shop__card-img img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  aspect-ratio: auto !important;
  background: transparent !important;
  transition: transform 0.4s ease;
}
.bb-shop__card:hover .bb-shop__card-img img { transform: scale(1.03); }
.bb-shop__card-placeholder {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: #6b6b6b;
  font-size: 0.95rem;
  padding: 1rem;
  text-align: center;
}

.bb-shop__card-tag {
  position: absolute;
  top: 0.85rem;
  left: 0.85rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.92);
  color: #0a0a0a;
  padding: 0.32rem 0.55rem;
  font-weight: 600;
  z-index: 3;
  pointer-events: none;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.bb-shop__card-tag--accent { background: #6b1f2e; color: #fff; backdrop-filter: none; -webkit-backdrop-filter: none; }

/* Heart — circular, transparent until hover */
.bb-shop__card-heart {
  position: absolute;
  top: 0.6rem;
  right: 0.6rem;
  width: 36px;
  height: 36px;
  background: transparent;
  border-radius: 50%;
  display: grid;
  place-items: center;
  z-index: 3;
  transition: background 0.2s;
}
.bb-shop__card-heart:hover { background: rgba(255, 255, 255, 0.92); }

.bb-shop__card-heart-link,
.bb-shop__card-heart .yith-wcwl-add-to-wishlist a {
  display: grid !important;
  place-items: center !important;
  width: 36px !important;
  height: 36px !important;
  color: #0a0a0a !important;
  text-decoration: none !important;
  border: 0 !important;
  background: transparent !important;
  cursor: pointer !important;
  /* Hide the YITH text label without zeroing font (which would shrink em-sized SVGs) */
  text-indent: -9999px;
  overflow: hidden;
}
/* Restore SVG visibility — set explicit pixel size, NOT em (em becomes 0 if parent font-size is 0) */
.bb-shop__card-heart svg,
.bb-shop__card-heart .yith-wcwl-icon-svg {
  width: 18px !important;
  height: 18px !important;
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 1.6 !important;
  text-indent: 0 !important;
  flex-shrink: 0 !important;
  display: block !important;
  /* Re-anchor over the absolutely-positioned text-indent */
  position: relative;
  margin: auto;
}
.bb-shop__card-heart .yith-wcwl-add-to-wishlist {
  width: auto !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
  background: transparent !important;
}
.bb-shop__card-heart .yith-wcwl-add-button {
  display: grid !important;
  place-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
}
.bb-shop__card-heart .yith-wcwl-add-to-wishlist span,
.bb-shop__card-heart .yith-wcwl-add-to-wishlist .feedback {
  display: none !important;
}
.bb-shop__card-heart .yith-wcwl-add-to-wishlist .delete_item,
.bb-shop__card-heart .yith-wcwl-add-to-wishlist.exists a { color: #e74c3c !important; }
.bb-shop__card-heart .yith-wcwl-add-to-wishlist.exists .yith-wcwl-icon-svg { fill: #e74c3c !important; }

.bb-shop__card-body { padding: 0.95rem 0 0; }
.bb-shop__card-cat {
  font-family: 'Inter', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: #6b1f2e;
  font-weight: 600;
}
.bb-shop__card-name {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 1.1rem;
  margin: 0.4rem 0 0.55rem;
  line-height: 1.3;
  color: #0a0a0a;
  text-transform: none;
  letter-spacing: 0;
}
.bb-shop__card-name em { font-style: italic; color: #6b1f2e; }
.bb-shop__card-name a { color: inherit; text-decoration: none; transition: color 0.15s; }
.bb-shop__card-name a:hover { color: #6b1f2e; }

.bb-shop__card-lede {
  color: #6b6b6b;
  font-size: 0.95rem;
  line-height: 1.55;
  margin: 0.4rem 0 0.7rem;
  font-family: 'Inter', sans-serif;
  max-width: 55ch;
}

.bb-shop__card-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}
.bb-shop__card-price {
  font-family: 'Fraunces', serif;
  font-size: 1.05rem;
  font-weight: 500;
  color: #0a0a0a;
  letter-spacing: 0;
  text-transform: none;
  display: inline-flex;
  align-items: baseline;
  gap: 0.4em;
}
.bb-shop__card-price del {
  color: #6b6b6b;
  font-weight: 300;
  font-size: 0.85em;
  margin-right: 0;
}
.bb-shop__card-price ins { background: transparent; text-decoration: none; }
.bb-shop__card-avail {
  font-family: 'Inter', sans-serif;
  font-size: 0.7rem;
  color: #6b6b6b;
}
.bb-shop__card-avail::before { content: '●'; color: #2d7a4f; margin-right: 0.3rem; }
.bb-shop__card-avail--low::before { color: #c87a1e; }
.bb-shop__card-avail--out::before { color: #b5462e; }

/* FEATURED card — every 6th, spans 2 columns */
.bb-shop__card--featured { grid-column: span 2; }
.bb-shop__card--featured .bb-shop__card-media { aspect-ratio: 16 / 9; }
.bb-shop__card--featured .bb-shop__card-body {
  padding: 1.3rem 0 0;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 2rem;
}
.bb-shop__card--featured .bb-shop__card-cat { grid-column: 1; }
.bb-shop__card--featured .bb-shop__card-name {
  grid-column: 1;
  font-size: 1.5rem;
  margin: 0.3rem 0 0;
}
.bb-shop__card--featured .bb-shop__card-lede { grid-column: 1; margin-top: 0.5rem; }
.bb-shop__card--featured .bb-shop__card-row {
  grid-column: 2;
  grid-row: 1 / span 4;
  flex-direction: column;
  align-items: flex-end;
  align-self: end;
  gap: 0.4rem;
}
.bb-shop__card--featured .bb-shop__card-price { font-size: 1.4rem; }

/* INTERMISSION strip — full-width grid item */
.bb-shop__intermission {
  grid-column: 1 / -1;
  margin: 1rem 0;
  padding: 3rem 2.5rem;
  background: #f5f2ed;
  border: 1px solid var(--bb-line, #e5e1db);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
  list-style: none;
}
.bb-shop__intermission-num {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #6b1f2e;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.bb-shop__intermission-title {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: 2rem;
  line-height: 1.1;
  margin: 0 0 0.7rem;
  color: #0a0a0a;
}
.bb-shop__intermission-title em { font-style: italic; color: #6b1f2e; }
.bb-shop__intermission-text p {
  color: #6b6b6b;
  font-size: 0.95rem;
  margin: 0;
  font-family: 'Inter', sans-serif;
  line-height: 1.6;
}
.bb-shop__intermission-cta {
  display: inline-block;
  margin-top: 1.2rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: #0a0a0a;
  text-decoration: none;
  border-bottom: 1px solid #0a0a0a;
  padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
}
.bb-shop__intermission-cta:hover { color: #6b1f2e; border-color: #6b1f2e; }
.bb-shop__intermission-visual {
  aspect-ratio: 5 / 4;
  background: #fff;
  border: 1px solid var(--bb-line, #e5e1db);
  background-image: linear-gradient(135deg, #f5f2ed 25%, transparent 25%, transparent 50%, #f5f2ed 50%, #f5f2ed 75%, transparent 75%);
  background-size: 24px 24px;
  opacity: 0.55;
}

/* Pagination */
.bb-shop__pager { margin-top: 3rem; padding-bottom: 1rem; }
.bb-shop__pager .woocommerce-pagination { text-align: center; }
.bb-shop__pager .woocommerce-pagination ul {
  display: inline-flex !important;
  flex-wrap: wrap;
  gap: 0.4rem;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.bb-shop__pager .woocommerce-pagination ul li {
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  display: inline-block;
  float: none !important;
}
.bb-shop__pager .page-numbers {
  padding: 0.55rem 0.85rem !important;
  font-family: 'Fraunces', serif !important;
  font-size: 0.95rem !important;
  color: #0a0a0a !important;
  border: 1px solid var(--bb-line, #e5e1db) !important;
  background: #fff !important;
  text-decoration: none !important;
  min-width: 44px;
  min-height: 44px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.bb-shop__pager .page-numbers:hover { border-color: #0a0a0a !important; }
.bb-shop__pager .page-numbers.current {
  background: #0a0a0a !important;
  color: #fff !important;
  border-color: #0a0a0a !important;
}

/* Hide legacy WC result count (we put count in chips) */
.bb-shop-archive .woocommerce-result-count { display: none !important; }

/* Empty state */
.bb-shop__empty {
  text-align: center;
  padding: 5rem 1rem;
}
.bb-shop__empty-num {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #6b1f2e;
  font-weight: 600;
  margin-bottom: 0.6rem;
}
.bb-shop__empty h2 {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  letter-spacing: -0.015em;
  margin: 0 0 1rem;
}
.bb-shop__empty h2 em { font-style: italic; color: #6b1f2e; }
.bb-shop__empty p { color: #6b6b6b; max-width: 50ch; margin: 0 auto 2rem; }
.bb-shop__empty-cta {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: #0a0a0a;
  text-decoration: none;
  border-bottom: 1px solid #0a0a0a;
  padding-bottom: 3px;
}
.bb-shop__empty-cta:hover { color: #6b1f2e; border-color: #6b1f2e; }

/* RESPONSIVE */
@media (max-width: 1100px) {
  .bb-shop-archive ul.products { grid-template-columns: repeat(2, 1fr) !important; }
  .bb-shop__card--featured { grid-column: span 2; }
}
@media (max-width: 900px) {
  .bb-shop__head { grid-template-columns: 1fr; gap: 0.75rem; padding-bottom: 1.75rem; }
  .bb-shop__head-intro { grid-column: 1; }
  .bb-shop__bar {
    grid-template-columns: 1fr;
    gap: 1rem;
    position: static;
  }
  .bb-shop__sort { justify-self: flex-start; }
  .bb-shop__intermission { grid-template-columns: 1fr; padding: 2rem 1.5rem; gap: 1.5rem; }
  .bb-shop__intermission-visual { aspect-ratio: 16/9; }
  .bb-shop__card--featured .bb-shop__card-body { grid-template-columns: 1fr; }
  .bb-shop__card--featured .bb-shop__card-row { grid-column: 1; grid-row: auto; flex-direction: row; align-items: center; align-self: auto; }
  .bb-shop__card--featured .bb-shop__card-name { font-size: 1.25rem; }
  .bb-shop__card--featured .bb-shop__card-price { font-size: 1.1rem; }
}
@media (max-width: 540px) {
  .bb-shop-archive ul.products { gap: 2rem 1rem !important; padding-top: 2rem !important; }
  .bb-shop__card-name { font-size: 1rem; }
  .bb-shop__card-tag { font-size: 0.58rem; padding: 0.25rem 0.45rem; }
  .bb-shop__card-heart { width: 32px; height: 32px; }
  .bb-shop__card-heart-link,
  .bb-shop__card-heart .yith-wcwl-add-to-wishlist a { width: 32px; height: 32px; }
}
@media (max-width: 380px) {
  .bb-shop-archive ul.products { grid-template-columns: 1fr !important; }
  .bb-shop__card--featured { grid-column: span 1; }
  .bb-shop__card--featured .bb-shop__card-media { aspect-ratio: 4/5; }
}

/* ── Shop card add-to-cart (Wariant A — Editorial) ── */
.bb-shop__card-cta { margin-top: 0.85rem; }

.bb-shop-archive .bb-shop__card-cta .bb-shop__card-add,
.bb-shop-archive ul.products li.product .bb-shop__card-cta .button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.4rem !important;
  width: 100% !important;
  padding: 0.7rem 1rem !important;
  background: #fff !important;
  color: #0A0A0A !important;
  border: 1px solid #0A0A0A !important;
  border-radius: 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  cursor: pointer !important;
  min-height: 40px !important;
  transition: background 0.2s, color 0.2s, border-color 0.2s !important;
}
.bb-shop-archive .bb-shop__card-cta .bb-shop__card-add::before,
.bb-shop-archive ul.products li.product .bb-shop__card-cta .button::before {
  content: '+' !important;
  font-size: 0.95rem;
  line-height: 1;
  margin-right: 0.15rem;
}
.bb-shop-archive .bb-shop__card-cta .bb-shop__card-add:hover,
.bb-shop-archive ul.products li.product .bb-shop__card-cta .button:hover {
  background: #0A0A0A !important;
  color: #fff !important;
  border-color: #0A0A0A !important;
}
/* "View product" (variable / external) — keep editorial styling */
.bb-shop-archive .bb-shop__card-cta .product_type_variable::before,
.bb-shop-archive .bb-shop__card-cta .product_type_grouped::before,
.bb-shop-archive .bb-shop__card-cta .product_type_external::before {
  content: '→' !important;
}

/* AJAX states */
.bb-shop-archive ul.products li.product .bb-shop__card-cta .added_to_cart {
  display: none !important;
}
.bb-shop-archive ul.products li.product .bb-shop__card-cta .added::after,
.bb-shop-archive ul.products li.product .bb-shop__card-cta .button.loading::after {
  display: none !important;
}
.bb-shop-archive ul.products li.product .bb-shop__card-cta .button.loading {
  opacity: 0.6;
  pointer-events: none;
}

/* Featured cards: align CTA with row */
.bb-shop__card--featured .bb-shop__card-cta {
  grid-column: 2;
  grid-row: 5;
  align-self: end;
  margin-top: 0;
}
.bb-shop__card--featured .bb-shop__card-cta .bb-shop__card-add { width: auto !important; padding: 0.8rem 1.4rem !important; }

@media (max-width: 900px) {
  .bb-shop__card--featured .bb-shop__card-cta { grid-column: 1; grid-row: auto; }
  .bb-shop__card--featured .bb-shop__card-cta .bb-shop__card-add { width: 100% !important; }
}

/* ============================================================
   STOCK INFO — hidden globally (editorial UX decision)
   ============================================================ */
.stock,
p.stock,
.woocommerce-stock,
.woocommerce-loop-product__stock,
.bb-shop__card-avail,
.bb-product__size ~ .stock,
.availability {
  display: none !important;
}

/* ============================================================
   WAITLIST ("Nie przegap powrotu!") — single product form
   ============================================================ */
.bb-waitlist {
  margin-top: 1.5rem;
  padding: 1.75rem;
  background: #F5F2ED;
  border: 1px solid var(--bb-line, #E5E1DB);
  border-left: 3px solid #6B1F2E;
}
.bb-waitlist__eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #6B1F2E;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.bb-waitlist__title {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: 1.6rem;
  letter-spacing: -0.015em;
  line-height: 1.1;
  margin: 0 0 0.6rem;
  color: #0A0A0A;
}
.bb-waitlist__title em {
  font-style: italic;
  color: #6B1F2E;
}
.bb-waitlist__lede {
  color: #6B6B6B;
  font-size: 0.9rem;
  line-height: 1.55;
  margin: 0 0 1.25rem;
  font-family: 'Inter', sans-serif;
}
.bb-waitlist__fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-bottom: 0.9rem;
}
.bb-waitlist__field {
  display: flex;
  flex-direction: column;
}
.bb-waitlist__label {
  font-family: 'Inter', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #6B6B6B;
  font-weight: 600;
  margin-bottom: 0.3rem;
}
.bb-waitlist__field input {
  border: 1px solid var(--bb-line, #E5E1DB);
  background: #fff;
  padding: 0.75rem 0.85rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  outline: 0;
  color: #0A0A0A;
  width: 100%;
  min-height: 44px;
  transition: border-color 0.15s;
}
.bb-waitlist__field input:focus {
  border-color: #0A0A0A;
}
.bb-waitlist__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 0.9rem 1.2rem;
  background: #0A0A0A;
  color: #fff;
  border: 1px solid #0A0A0A;
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  min-height: 48px;
  transition: background 0.2s, border-color 0.2s;
}
.bb-waitlist__submit:hover,
.bb-waitlist__submit:focus {
  background: #6B1F2E;
  border-color: #6B1F2E;
}
.bb-waitlist__submit:disabled,
.bb-waitlist__submit.is-loading {
  opacity: 0.6;
  cursor: not-allowed;
}
.bb-waitlist__msg {
  margin-top: 0.85rem;
  font-size: 0.85rem;
  font-family: 'Inter', sans-serif;
  min-height: 1.2em;
}
.bb-waitlist__msg.is-success {
  color: #2D7A4F;
  font-weight: 500;
}
.bb-waitlist__msg.is-error {
  color: #B5462E;
  font-weight: 500;
}

@media (max-width: 540px) {
  .bb-waitlist__fields { grid-template-columns: 1fr; }
  .bb-waitlist { padding: 1.25rem; }
  .bb-waitlist__title { font-size: 1.3rem; }
}

/* ============================================================
   OOS on product cards — pill instead of "Add to cart"
   Replaces the standard button with a link to product page
   where the waitlist form lives.
   ============================================================ */
.bb-shop__card.outofstock .bb-shop__card-cta .button,
.bb-shop__card.outofstock .bb-shop__card-cta .bb-shop__card-add {
  background: #fff !important;
  color: #6B1F2E !important;
  border: 1px solid #6B1F2E !important;
}
.bb-shop__card.outofstock .bb-shop__card-cta .button::before,
.bb-shop__card.outofstock .bb-shop__card-cta .bb-shop__card-add::before {
  content: '⏰ ' !important;
  margin-right: 0.25rem;
}
.bb-shop__card.outofstock .bb-shop__card-cta .button:hover,
.bb-shop__card.outofstock .bb-shop__card-cta .bb-shop__card-add:hover {
  background: #6B1F2E !important;
  color: #fff !important;
}


/* BB-MOBILE-PRODUCT-REORDER 2026-05-18 — cap product gallery image height on mobile */
@media (max-width: 640px) {
  .bb-product__gallery .woocommerce-product-gallery__image img,
  .bb-product__gallery .woocommerce-product-gallery img {
    max-height: 65vh;
    object-fit: contain;
    width: auto;
    margin: 0 auto;
  }
  .bb-product__gallery .flex-viewport {
    max-height: 65vh;
  }
}


/* BB-FEATURED-ROW 2026-05-18 — Clarity finding #1: featured products row on /sklep/ */
.bb-featured-row {
  margin: 1.5rem 0 2.5rem;
  padding-bottom: 1.75rem;
  border-bottom: 1px solid var(--bb-line);
}
.bb-featured-row__title {
  font-family: var(--bb-serif);
  font-size: clamp(1.2rem, 2.2vw, 1.7rem);
  font-weight: 600;
  margin: 0 0 1rem;
  letter-spacing: 0.01em;
  color: var(--bb-charcoal);
}
.bb-featured-row__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.bb-featured-card {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease;
}
.bb-featured-card:hover {
  transform: translateY(-3px);
}
.bb-featured-card__img {
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--bb-sand);
  margin-bottom: 0.55rem;
}
.bb-featured-card__img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.bb-featured-card:hover .bb-featured-card__img img {
  transform: scale(1.03);
}
.bb-featured-card__title {
  font-family: var(--bb-sans);
  font-size: 0.86rem;
  margin: 0.4rem 0 0.2rem;
  font-weight: 600;
  line-height: 1.3;
}
.bb-featured-card__price {
  font-size: 0.8rem;
  color: var(--bb-muted);
  margin: 0;
  letter-spacing: 0.02em;
}
@media (max-width: 640px) {
  .bb-featured-row__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.85rem;
  }
  .bb-featured-card__title {
    font-size: 0.78rem;
  }
  .bb-featured-card__price {
    font-size: 0.75rem;
  }
  .bb-featured-row {
    margin: 1rem 0 1.5rem;
    padding-bottom: 1.2rem;
  }
}
