/* =============================================================
   Arabic Arts — WooCommerce & Global Overrides
   Kleurenpalet: zie DESIGN.md
   ============================================================= */

/* =============================================================
   Global layout — FSE block containers
   ============================================================= */

/* WP:group constrained containers — zorg dat ze de volledige breedte gebruiken */
.wp-site-blocks > * { margin-block-start: 0 !important; }

/* =============================================================
   Globale input / form velden — DESIGN.md compliant
   ============================================================= */

input[type="text"],
input[type="number"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="search"],
input[type="url"],
textarea,
select {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  color: #3D2B1F !important;
  background: #FAF6F0 !important;
  border: 1px solid #C4956A !important;
  border-radius: 3px !important;
  padding: 9px 12px !important;
  line-height: 1.5 !important;
  outline: none !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  box-shadow: none !important;
}

input[type="text"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
textarea:focus,
select:focus {
  border-color: #8B4513 !important;
  box-shadow: 0 0 0 3px rgba(139,69,19,0.1) !important;
  outline: none !important;
}

input::placeholder,
textarea::placeholder {
  color: #A89080 !important;
  opacity: 1 !important;
}

/* Single product — WooCommerce wrapper gebruikt 2-koloms grid; main moet alles beslaan */
.aa-single-product {
  grid-column: 1 / -1;
}

/* Outline button style voor WP block buttons */
.wp-block-button.is-style-outline .wp-block-button__link,
.wp-block-button.is-style-outline .wp-element-button {
  background: transparent !important;
  color: #8B4513 !important;
  border: 1.5px solid #8B4513 !important;
  border-radius: 2px !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover,
.wp-block-button.is-style-outline .wp-element-button:hover {
  background: #8B4513 !important;
  color: #fff !important;
}

/* Secundaire knop variant op lichte achtergrond */
.wp-block-button__link:focus-visible,
.wp-element-button:focus-visible {
  outline: 2px solid #8B4513;
  outline-offset: 3px;
}

/* Header */
.aa-header {
  position: sticky;
  top: 0;
  z-index: 100;
  padding: 0 24px;
}

.aa-header__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 16px 0;
}

.aa-header__nav .wp-block-navigation__responsive-container-open,
.aa-header__nav .wp-block-navigation a {
  color: #3D2B1F !important;
}

.aa-header__nav .wp-block-navigation a:hover {
  color: #8B4513 !important;
}

/* Footer */
.aa-footer {
  padding: 64px 24px 32px;
}

.aa-footer__grid {
  max-width: 1200px;
  margin: 0 auto 40px;
  gap: 40px;
}

.aa-footer__grid h4 {
  margin: 0 0 16px;
}

.aa-footer__nav .wp-block-navigation__container {
  flex-direction: column;
  align-items: flex-start;
}

.aa-footer__nav a,
.aa-footer__nav .wp-block-navigation-item__label {
  color: #3D2B1F !important;
  font-size: 13px;
  line-height: 2;
}

.aa-footer__nav a:hover {
  color: #8B4513 !important;
}

.aa-footer__social.wp-block-social-links .wp-block-social-link a {
  background: transparent !important;
  color: #3D2B1F !important;
  padding: 0;
}

.aa-footer__social.wp-block-social-links .wp-block-social-link svg {
  fill: #3D2B1F !important;
  width: 20px;
  height: 20px;
}

.aa-footer__payment {
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.aa-payment-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #D8C9B8;
  border-radius: 4px;
  padding: 6px 14px;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: #3D2B1F;
  background: #fff;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.aa-payment-logo {
  display: inline-block;
  vertical-align: middle;
  border-radius: 5px;
}

.aa-footer__social {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.aa-footer__social a {
  line-height: 0;
  text-decoration: none !important;
}

/* =============================================================
   WooCommerce Global
   ============================================================= */

/* Verwijder standaard WC kleuren */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  background: #8B4513;
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 2px;
  padding: 12px 24px;
  border: none;
  transition: opacity 0.2s;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover {
  background: #732C03;
  color: #fff;
}

/* Prijs */
.woocommerce .price,
.woocommerce .woocommerce-Price-amount {
  color: #8B4513;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
}

/* =============================================================
   Single Product
   ============================================================= */

.woocommerce div.product {
  max-width: 1200px;
  margin: 0 auto;
  padding: 64px 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.woocommerce div.product .woocommerce-product-gallery {
  border-radius: 3px;
  overflow: hidden;
}

.woocommerce div.product .product_title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 36px;
  font-style: italic;
  font-weight: 400;
  color: #3D2B1F;
  margin-bottom: 12px;
}

.aa-single-product .wp-block-post-title {
  font-size: 36px;
  line-height: 1.2;
}

.woocommerce div.product .price {
  font-size: 24px;
  margin-bottom: 24px;
}

.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: 15px;
  color: #6B5B4E;
  line-height: 1.65;
  margin-bottom: 24px;
}

.woocommerce div.product form.cart .single_add_to_cart_button {
  width: 100%;
  text-align: center;
}

/* =============================================================
   Shop Archive
   ============================================================= */

.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 0 !important;
  padding: 40px 24px;
}

.woocommerce ul.products li.product {
  border: 1px solid #E8D5B0;
  border-radius: 3px;
  background: #fff;
  overflow: hidden;
  margin: 0 !important;
  float: none !important;
  width: auto !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(61, 43, 31, 0.1);
}

.woocommerce ul.products li.product img {
  aspect-ratio: 4/3;
  object-fit: cover;
  margin: 0 !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #3D2B1F;
  padding: 12px 14px 4px;
}

.woocommerce ul.products li.product .price {
  padding: 0 14px 8px;
  font-size: 14px;
}

.woocommerce ul.products li.product .button {
  display: block;
  width: calc(100% - 28px);
  margin: 4px 14px 14px;
  text-align: center;
}

/* =============================================================
   Cart & Checkout
   ============================================================= */

.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
  max-width: 1200px;
  margin: 0 auto;
  padding: 64px 24px;
}

.woocommerce table.shop_table {
  border: 1px solid #E8D5B0;
  border-radius: 3px;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
}

.woocommerce table.shop_table th {
  font-weight: 600;
  color: #3D2B1F;
  border-bottom: 2px solid #E8D5B0;
  padding: 12px 16px;
}

.woocommerce table.shop_table td {
  padding: 12px 16px;
  border-bottom: 1px solid #E8D5B0;
}

.woocommerce .cart_totals h2,
.woocommerce #order_review_heading {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 24px;
  font-style: italic;
  color: #3D2B1F;
}

.woocommerce form .form-row label {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #3D2B1F;
}

.woocommerce form .form-row input,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  border: 1px solid #E8D5B0;
  border-radius: 2px;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  color: #3D2B1F;
  padding: 10px 14px;
  background: #fff;
}

.woocommerce form .form-row input:focus {
  border-color: #8B4513;
  outline: none;
  box-shadow: 0 0 0 2px rgba(139, 69, 19, 0.15);
}

/* =============================================================
   Lege winkelwagen
   ============================================================= */

/* Verberg WooCommerce smiley-icoon */
.with-empty-cart-icon::before,
.wc-block-cart__empty-cart__title::before {
  display: none !important;
}

.wp-block-woocommerce-empty-cart-block {
  text-align: center;
  padding: 48px 24px;
}

.wc-block-cart__empty-cart__title,
.wp-block-woocommerce-empty-cart-block h2:first-child {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 28px !important;
  font-style: italic;
  font-weight: 400;
  color: #3D2B1F;
}

/* =============================================================
   Breadcrumbs
   ============================================================= */

.woocommerce .woocommerce-breadcrumb {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  color: #6B5B4E;
  padding: 16px 24px;
  max-width: 1200px;
  margin: 0 auto;
}

.woocommerce .woocommerce-breadcrumb a { color: #8B4513; }

/* =============================================================
   Notices
   ============================================================= */

.woocommerce-message,
.woocommerce-info {
  border-top-color: #8B4513 !important;
  background: #F7F0E6;
  font-family: 'DM Sans', sans-serif;
}

.woocommerce-error {
  border-top-color: #c0392b !important;
  background: #fff5f5;
  font-family: 'DM Sans', sans-serif;
}

/* =============================================================
   Media Queries
   ============================================================= */

@media (max-width: 1023px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  .woocommerce div.product {
    grid-template-columns: 1fr;
    padding: 40px 20px;
    gap: 32px;
  }
}

@media (max-width: 479px) {
  .woocommerce ul.products {
    grid-template-columns: 1fr;
  }
}

/* =============================================================
   Shop — sidebar layout
   ============================================================= */

.aa-shop__layout .wp-block-columns {
  align-items: flex-start;
}

/* Sidebar */
.aa-shop__sidebar {
  position: sticky;
  top: 100px;
  min-width: 0;
  width: 260px;
}

/* Filter wrapper volledig opvullen zonder overflow */
.aa-shop__sidebar .wp-block-woocommerce-product-filters,
.aa-shop__sidebar .aa-filters {
  width: 100%;
  min-width: 0;
}

/* Desktop: verberg overlay-toggle, toon filters altijd inline */
@media (min-width: 768px) {
  .aa-shop__sidebar .wc-block-product-filters__open-overlay {
    display: none !important;
  }
  .aa-shop__sidebar .wc-block-product-filters__overlay {
    display: block !important;
    position: static !important;
    background: transparent !important;
    inset: auto !important;
    z-index: auto !important;
  }
  .aa-shop__sidebar .wc-block-product-filters__overlay-wrapper {
    position: static !important;
    max-width: none !important;
    height: auto !important;
    overflow: visible !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
  }
  .aa-shop__sidebar .wc-block-product-filters__overlay-dialog {
    position: static !important;
    height: auto !important;
    overflow: visible !important;
    background: transparent !important;
    padding: 0 !important;
  }
  .aa-shop__sidebar .wc-block-product-filters__overlay-header {
    display: none !important;
  }
}

.aa-filter-label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #3D2B1F !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
}

.aa-shop__sidebar .wc-block-product-filters__overlay-content > .wp-block-group {
  padding: 20px 0;
}

.aa-shop__sidebar .wc-block-product-filters__overlay-content > .wp-block-group:first-child {
  padding-top: 0;
}

/* Scheidingslijn alleen tússen filter-secties */
.aa-shop__sidebar .wc-block-product-filters__overlay-content > .wp-block-group + .wp-block-group {
  border-top: 1px solid #E8D5B0;
}

/* Verwijder fieldset standaard browser-styling (border + min-width overflow) */
.aa-shop__sidebar fieldset,
.wp-block-woocommerce-product-filter-checkbox-list fieldset {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  min-width: 0 !important;
  max-width: 100% !important;
}

/* Categorie-checkboxen */
.aa-filter-taxonomy .wc-block-checkbox-list,
.wp-block-woocommerce-product-filter-taxonomy .wc-block-checkbox-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.aa-filter-taxonomy .wc-block-checkbox-list__item,
.wp-block-woocommerce-product-filter-taxonomy li {
  padding: 6px 0;
}

.aa-filter-taxonomy .wc-block-checkbox-list__item label,
.wp-block-woocommerce-product-filter-taxonomy label {
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  color: #6B5B4E;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
}

.aa-filter-taxonomy input[type="checkbox"],
.wp-block-woocommerce-product-filter-taxonomy input[type="checkbox"] {
  accent-color: #8B4513;
  width: 16px;
  height: 16px;
  cursor: pointer;
  flex-shrink: 0;
}

/* Prijs slider */
.aa-filter-price .wp-block-woocommerce-product-filter-price-slider__range-input,
.wc-block-price-slider {
  accent-color: #8B4513;
}

/* Slider container: 2 gelijke kolommen — geen overflow meer */
.aa-shop__sidebar .wp-block-woocommerce-product-filter-price-slider {
  width: 100%;
  min-width: 0;
}

.aa-shop__sidebar .wc-block-product-filter-price-slider__content {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  grid-template-areas:
    "price-slider price-slider"
    "left-input   right-input" !important;
  column-gap: 16px !important;
  row-gap: 12px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.aa-shop__sidebar .wc-block-product-filter-price-slider__range {
  grid-area: price-slider !important;
  width: 100% !important;
  min-width: 0 !important;
}

.aa-shop__sidebar .wc-block-product-filter-price-slider__left {
  grid-area: left-input !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

.aa-shop__sidebar .wc-block-product-filter-price-slider__right {
  grid-area: right-input !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

/* Min / Max labels boven de invoervelden */
.aa-shop__sidebar .wc-block-product-filter-price-slider__left::before {
  content: "Min";
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: #7A6248;
  text-transform: uppercase;
}

.aa-shop__sidebar .wc-block-product-filter-price-slider__right::before {
  content: "Max";
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: #7A6248;
  text-transform: uppercase;
}

/* Prijs-inputs: volledige breedte van hun kolom (erft globale input-stijl) */
.aa-shop__sidebar .wp-block-woocommerce-product-filter-price-slider__amount {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* Toepassen-knop: volledige breedte + ruimte boven */
.aa-shop__sidebar .wc-block-product-filters__apply {
  display: block !important;
  width: 100% !important;
  margin-top: 16px !important;
  box-sizing: border-box !important;
}

/* Active filter chips */
.wp-block-woocommerce-product-filter-active {
  margin-bottom: 8px;
}

.wc-block-active-filters__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.wc-block-active-filters__list-item-name {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  background: #F2E8DC;
  border: 1px solid #D8C9B8;
  border-radius: 100px;
  padding: 3px 10px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #3D2B1F;
}

/* Product-collection grid */
.wp-block-woocommerce-product-collection > .wp-block-post-template {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.wp-block-woocommerce-product-collection .wp-block-post-template li {
  margin: 0 !important;
}

.aa-product-card {
  height: 100%;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  background: #fff;
}

.aa-product-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(61,43,31,0.1);
}

.aa-product-card .wp-block-woocommerce-product-image img {
  aspect-ratio: 4/3;
  object-fit: cover;
  width: 100%;
  display: block;
}

.aa-product-card .wp-block-post-title a,
.aa-product-card .wp-block-woocommerce-product-title a {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #3D2B1F;
  text-decoration: none;
  line-height: 1.3;
}

.aa-product-card .wp-block-post-title {
  margin: 0;
}

.aa-product-card .wp-block-woocommerce-product-price {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #8B4513;
}

.aa-product-card .wp-block-woocommerce-product-button .wp-block-button__link,
.aa-product-card .wp-block-woocommerce-add-to-cart-button .wp-block-button__link,
.aa-product-card .wp-block-button__link {
  background: #8B4513 !important;
  color: #fff !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  border-radius: 2px !important;
  padding: 10px 16px !important;
  width: 100% !important;
  text-align: center !important;
  border: none !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
}

.aa-product-card .wp-block-button__link:hover {
  background: #732C03 !important;
}

@media (max-width: 1023px) {
  .wp-block-woocommerce-product-collection > .wp-block-post-template {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 767px) {
  .aa-shop__sidebar {
    position: static;
  }
  .wp-block-woocommerce-product-collection > .wp-block-post-template {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* =============================================================
   Shop — mobiele filter toggle (≤ 767px)
   ============================================================= */

@media (max-width: 767px) {

  /* Sidebar bovenaan producten */
  .wp-block-column.aa-shop__sidebar {
    order: -1 !important;
    padding: 0 !important;
    margin-bottom: 8px;
  }

  /* "Filter producten" toggle knop */
  .aa-shop__sidebar .wc-block-product-filters__open-overlay {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: calc(100% - 32px) !important;
    margin: 0 16px !important;
    padding: 13px 20px !important;
    background: transparent !important;
    border: 1.5px solid #8B4513 !important;
    color: #8B4513 !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    cursor: pointer;
    border-radius: 2px !important;
    box-sizing: border-box !important;
    box-shadow: none !important;
  }

  .aa-shop__sidebar .wc-block-product-filters__open-overlay svg {
    width: 16px !important;
    height: 16px !important;
    fill: #8B4513 !important;
    flex-shrink: 0;
  }

  /* Overlay: verborgen by default; toon via .aa-filter-open class (JS) */
  .aa-shop__sidebar .wc-block-product-filters__overlay {
    display: none !important;
    margin: 0 16px;
    border: 1px solid #E8D5B0;
    border-top: none;
    border-radius: 0 0 3px 3px;
    background: #FAF5EF;
  }

  .aa-shop__sidebar.aa-filter-open .wc-block-product-filters__overlay {
    display: block !important;
  }

  /* Dialog content */
  .aa-shop__sidebar .wc-block-product-filters__overlay-dialog {
    padding: 16px;
  }

  /* Header rij (Sluiten-knop) */
  .aa-shop__sidebar .wc-block-product-filters__overlay-header {
    display: flex !important;
    align-items: center;
    justify-content: flex-end;
    padding-bottom: 12px;
    margin-bottom: 16px;
    border-bottom: 1px solid #E8D5B0;
  }

  /* "Sluiten" knop */
  .aa-shop__sidebar .wc-block-product-filters__close-overlay {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    padding: 4px 0 !important;
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #3D2B1F !important;
    cursor: pointer;
    text-transform: none !important;
    letter-spacing: normal !important;
  }

  .aa-shop__sidebar .wc-block-product-filters__close-overlay svg {
    width: 14px !important;
    height: 14px !important;
    fill: #3D2B1F !important;
  }

  /* "TOEPASSEN" knop */
  .aa-shop__sidebar .wc-block-product-filters__apply {
    display: block !important;
    width: 100% !important;
    padding: 13px 20px !important;
    background: #8B4513 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 2px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    cursor: pointer;
    margin-top: 16px !important;
    text-align: center;
    box-shadow: none !important;
  }

  /* Filter labels (CATEGORIEËN, PRIJS) inspringing */
  .aa-shop__sidebar .aa-filter-label {
    padding: 0 !important;
    margin-top: 0 !important;
  }
}

@media (max-width: 479px) {
  .wp-block-woocommerce-product-collection > .wp-block-post-template {
    grid-template-columns: 1fr !important;
  }
}

/* =============================================================
   Contact Form 7
   ============================================================= */

.wpcf7 form .wpcf7-form-control-wrap {
  display: block;
  margin-bottom: 16px;
}

.wpcf7 form input[type="text"],
.wpcf7 form input[type="email"],
.wpcf7 form input[type="tel"],
.wpcf7 form textarea {
  width: 100%;
  border: 1px solid #E8D5B0;
  border-radius: 2px;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  color: #3D2B1F;
  padding: 12px 16px;
  background: #fff;
  box-sizing: border-box;
  transition: border-color 0.2s;
}

.wpcf7 form input:focus,
.wpcf7 form textarea:focus {
  border-color: #8B4513;
  outline: none;
  box-shadow: 0 0 0 2px rgba(139, 69, 19, 0.12);
}

.wpcf7 form label {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #3D2B1F;
  display: block;
  margin-bottom: 6px;
}

.wpcf7 form textarea { min-height: 140px; resize: vertical; }

.wpcf7 form input[type="submit"] {
  background: #8B4513;
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: none;
  border-radius: 2px;
  padding: 12px 32px;
  cursor: pointer;
  transition: opacity 0.2s;
}

.wpcf7 form input[type="submit"]:hover { opacity: 0.88; }

.wpcf7-response-output {
  border: 1px solid #E8D5B0 !important;
  border-radius: 2px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  padding: 12px 16px !important;
  margin-top: 16px !important;
}

/* Sorteer-balk */
.aa-shop__sort-bar {
  margin-bottom: 20px;
}

.aa-shop__sort-bar .woocommerce-ordering {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
}

/* Label "Sorteren op" */
.aa-shop__sort-bar .woocommerce-ordering label {
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #7A6248;
  white-space: nowrap;
  margin: 0;
}

/* Dropdown */
.aa-shop__sort-bar .woocommerce-ordering select.orderby {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: #3D2B1F;
  background-color: #FDFAF6;
  border: 1px solid #D8C9B8;
  border-radius: 2px;
  padding: 7px 32px 7px 12px;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A6248' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  cursor: pointer;
  min-width: 180px;
  box-shadow: none;
}

.aa-shop__sort-bar .woocommerce-ordering select.orderby:focus {
  outline: none;
  border-color: #8B4513;
  box-shadow: none;
}

/* ══════════════════════════════════════════════
   SINGLE PRODUCT PAGINA
   ══════════════════════════════════════════════ */

/* Breadcrumb */
.aa-product-breadcrumb {
  padding-left: 20px;
  padding-right: 20px;
}

.aa-product-breadcrumb .wc-block-breadcrumbs {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  color: #9E8B78;
  padding-bottom: 16px;
  border-bottom: 1px solid #EDE6D6;
}

.aa-product-breadcrumb .wc-block-breadcrumbs a {
  color: #9E8B78;
  text-decoration: none;
}

.aa-product-breadcrumb .wc-block-breadcrumbs a:hover {
  color: #8B4513;
}

/* ── Categorie badge boven de titel (core/post-terms) ── */
.aa-product-category-badge {
  margin-bottom: 12px !important;
}

.aa-product-category-badge a {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 3px 12px !important;
  border-radius: 100px !important;
  background: #F2E8DC !important;
  border: 1px solid #D8C9B8 !important;
  color: #8B4513 !important;
  text-decoration: none !important;
  display: inline-block !important;
}

.aa-product-category-badge a:hover {
  background: #E8D5B0 !important;
}

/* ── Rating ── */
.aa-single-product .wp-block-woocommerce-product-rating {
  margin-bottom: 10px !important;
}

/* ── Korte beschrijving ── */
.aa-single-product .wc-block-product-short-description {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  color: #5C4A3A;
  line-height: 1.7;
  margin-bottom: 16px !important;
  padding-bottom: 16px;
  border-bottom: 1px solid #EDE6D6;
}

/* ── USP blok ── */
.aa-product-usp {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  background: #F7F1E6;
  border: 1px solid #E8D5B0;
  border-radius: 3px;
  margin-bottom: 20px;
}

.aa-usp-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: #4A3728;
}

.aa-usp-item i {
  width: 32px;
  height: 32px;
  background: #8B4513;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 13px;
  flex-shrink: 0;
}

.aa-usp-item strong {
  font-weight: 700;
  color: #3D2B1F;
}

/* ── Product meta rij (categorie + SKU) ── */
.aa-product-meta {
  margin-top: 12px !important;
  margin-bottom: 16px !important;
}

.aa-product-meta .wc-block-product-meta {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.aa-product-meta .wc-block-product-details-section {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  color: #9E8B78;
  margin: 0 !important;
  display: flex;
  align-items: center;
  gap: 4px;
}

.aa-product-meta .wc-block-product-meta__label {
  font-weight: 600;
  color: #7A6248;
}

.aa-product-meta .wc-block-product-details-section--categories a {
  color: #5C4A3A;
  text-decoration: none;
  font-weight: 600;
}

.aa-product-meta .wc-block-product-details-section--categories a:hover {
  color: #8B4513;
}

/* ── Vertrouwenssignalen ── */
.aa-product-trust {
  display: flex;
  gap: 0;
  border: 1px solid #E8D5B0;
  border-radius: 3px;
  overflow: hidden;
  margin-top: 4px;
}

.aa-trust-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px 8px;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  color: #7A6248;
  text-align: center;
  border-right: 1px solid #E8D5B0;
}

.aa-trust-item:last-child {
  border-right: none;
}

.aa-trust-item i {
  font-size: 16px;
  color: #8B4513;
}

/* ── Gerelateerde producten ── */
.aa-related-section {
  padding-top: 40px;
  border-top: 2px solid #E8D5B0;
}

.aa-related-section h2,
.aa-related-section .wp-block-woocommerce-related-products h2 {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #7A6248 !important;
  font-style: normal !important;
  margin-bottom: 20px !important;
}

.aa-related-section .wp-block-woocommerce-related-products .wp-block-post-template,
.aa-related-section .wc-block-product-template,
.aa-related-section ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  flex-wrap: unset !important;
}

.aa-related-section .wp-block-woocommerce-related-products li.product,
.aa-related-section ul.products li.product {
  border: 1px solid #E8D5B0 !important;
  border-radius: 3px !important;
  overflow: hidden !important;
  background: #FAF5EF !important;
  margin: 0 !important;
  padding: 0 !important;
}

.aa-related-section ul.products li.product a img {
  width: 100% !important;
  aspect-ratio: 4/3 !important;
  object-fit: cover !important;
  display: block !important;
}

.aa-related-section ul.products li.product .woocommerce-loop-product__title {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #3D2B1F !important;
  padding: 10px 12px 4px !important;
}

.aa-related-section ul.products li.product .price {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #8B4513 !important;
  padding: 0 12px 10px !important;
  display: block !important;
}

.aa-related-section ul.products li.product .button {
  display: none !important;
}

/* =============================================================
   Global — overflow fix
   ============================================================= */

.wp-interactivity-router-loading-bar {
  max-width: 100% !important;
  overflow: hidden !important;
}

/* =============================================================
   Responsive — mobiel (≤ 767px)
   ============================================================= */

@media (max-width: 767px) {

  /* ── Pagina's (privacy, AV, cookies, contact) ── */
  .aa-page__content,
  .aa-page-contact {
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
  }

  /* ── Header ── */
  .aa-header__search {
    display: none !important;
  }

  /* ── Footer ── */
  .aa-footer {
    padding: 40px 16px 24px;
  }

  .aa-footer__grid {
    grid-template-columns: 1fr !important;
  }

  /* ── Shop banner ── */
  main.aa-shop > .wp-block-group:first-child {
    padding-top: 32px !important;
    padding-bottom: 24px !important;
  }

  /* ── Shop layout ── */
  .aa-shop__layout {
    padding-top: 24px !important;
    padding-bottom: 40px !important;
  }

  .aa-shop__layout .wp-block-columns {
    flex-direction: column !important;
    flex-wrap: wrap !important;
  }

  .wp-block-column.aa-shop__sidebar {
    flex-basis: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    order: 2;
    position: static !important;
  }

  .wp-block-column.aa-shop__grid-col {
    flex-basis: 100% !important;
    width: 100% !important;
    order: 1;
  }

  /* ── Single product ── */
  .aa-single-product > .wp-block-group {
    padding-top: 24px !important;
    padding-bottom: 48px !important;
  }

  .woocommerce-product-gallery,
  .wp-block-woocommerce-product-image-gallery {
    max-height: 420px;
    overflow: hidden;
  }

  .woocommerce-product-gallery .woocommerce-product-gallery__image img,
  .wp-block-woocommerce-product-image-gallery img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    object-position: center top;
  }

  /* ── Cart / Checkout ── */
  .woocommerce-cart .woocommerce,
  .woocommerce-checkout .woocommerce {
    padding: 32px 16px;
  }

  .wp-block-woocommerce-cart,
  .wp-block-woocommerce-checkout {
    padding: 32px 16px !important;
  }

  /* ── Gerelateerde producten ── */
  .aa-related-section .wp-block-woocommerce-related-products .wp-block-post-template,
  .aa-related-section .wc-block-product-template,
  .aa-related-section ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* =============================================================
   Responsive — klein mobiel (≤ 479px)
   ============================================================= */

@media (max-width: 479px) {

  /* ── Gerelateerde producten ── */
  .aa-related-section .wp-block-woocommerce-related-products .wp-block-post-template,
  .aa-related-section .wc-block-product-template,
  .aa-related-section ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* WP Interactivity zet overflow:hidden op body bij filter-overlay open — op mobiel nooit blokkeren */
@media (max-width: 767px) {
  body {
    overflow: auto !important;
  }
}

/* =============================================================
   Mobiel navigatie overlay
   ============================================================= */

/* Forceer full-screen (viewport, niet pagina-hoogte) — voorkomt scroll-bug op lange pagina's */
.aa-header__nav .wp-block-navigation__responsive-container.is-menu-open {
  position: fixed !important;
  inset: 0 !important;
  height: 100dvh !important;
  max-height: 100dvh !important;
  min-height: unset !important;
  overflow-y: auto !important;
  background: #F7F0E6 !important;
}

/* Tussenelementen uitrekken zodat de content-container de volledige viewport vult */
.aa-header__nav .wp-block-navigation__responsive-close,
.aa-header__nav .wp-block-navigation__responsive-dialog {
  height: 100% !important;
}

/* Nav-container: items verticaal gecentreerd in de overlay */
.aa-header__nav .wp-block-navigation__responsive-container-content {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  height: 100% !important;
}

/* Nav-items: kolomvorm met scheidingslijnen; niet uitrekken zodat justify-content:center werkt */
.aa-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
  flex: 0 0 auto !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

.aa-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item {
  width: 100% !important;
  border-bottom: 1px solid #E8D5B0 !important;
}

.aa-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item:first-child {
  border-top: 1px solid #E8D5B0 !important;
}

.aa-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item a {
  display: block !important;
  padding: 16px 28px !important;
  font-size: 14px !important;
  letter-spacing: 0.06em !important;
  color: #3D2B1F !important;
}

.aa-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item a:hover {
  color: #8B4513 !important;
  background: #FAF6F0 !important;
}
