/* ═══════════════════════════════════════════════════════════════════
   WooCommerce — JFD styling
   Vervangt WC's standaard CSS volledig. Hergebruikt de site-tokens
   (--orange, --forest, --cream) die in mockup-styles.css gedefinieerd
   staan, dus deze CSS verwacht dat mockup-styles.css eerst geladen is.
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Cart icon in de nav ─────────────────────────────────────────── */
.jfd-cart-icon-wrap {
  position: relative;
  margin-left: 8px;
  display: inline-flex;
  align-items: center;
}
.jfd-cart-icon-wrap.is-empty { display: none; }

.jfd-cart-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  color: var(--forest);
  background: transparent;
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease;
}
.jfd-cart-icon:hover {
  background: var(--orange-soft);
  color: var(--orange);
}

.jfd-cart-count {
  position: absolute;
  top: 4px;
  right: 4px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: var(--orange);
  color: #ffffff;
  font-family: 'Public Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  border-radius: 9px;
  box-shadow: 0 0 0 2px var(--cream);
}

/* ─── Main container voor alle WC-pagina's ────────────────────────── */
.jfd-wc-main {
  padding: 60px 0 100px;
  min-height: 60vh;
}
.jfd-wc-main .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 640px) {
  .jfd-wc-main { padding: 40px 0 60px; }
  .jfd-wc-main .container { padding: 0 20px; }
}

/* ─── Titel (winkel-archief én productpagina) ──────────────────────── */
.woocommerce-products-header__title,
.woocommerce-page .woocommerce-products-header__title,
.woocommerce div.product .product_title,
body.woocommerce .page-title,
body.woocommerce-page .page-title,
body.post-type-archive-product .page-title,
body.post-type-archive-product h1.entry-title {
  font-family: 'Oswald', sans-serif !important;
  font-weight: 600 !important;
  font-size: clamp(36px, 6vw, 56px) !important;
  line-height: 1.1 !important;
  letter-spacing: 0.005em !important;
  color: var(--forest) !important;
  text-transform: uppercase !important;
  margin: 0 0 24px !important;
}

.woocommerce-products-header { margin-bottom: 32px; }

/* ─── Result count + sort dropdown ────────────────────────────────── */
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count {
  display: inline-block;
  font-family: 'Public Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  color: var(--orange);
  text-transform: uppercase;
  margin: 0 0 24px;
  padding: 6px 12px;
  background: var(--orange-soft);
  border-radius: 4px;
  float: none;
}

.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering {
  margin: 0 0 32px;
  float: none;
  display: inline-block;
  vertical-align: middle;
}
.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
  padding: 10px 36px 10px 16px;
  font-family: 'Public Sans', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--forest);
  background: var(--cream-light);
  border: 1.5px solid var(--line);
  border-radius: 10px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23063231' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 12px;
}
.woocommerce .woocommerce-ordering select:focus,
.woocommerce-page .woocommerce-ordering select:focus {
  outline: none;
  border-color: var(--orange);
}

/* Plaats result-count + sort op één rij (clearfix voor WC's defaults) */
.woocommerce .woocommerce-notices-wrapper + .woocommerce-result-count,
.woocommerce-page .woocommerce-notices-wrapper + .woocommerce-result-count {
  margin-right: 16px;
}

/* ─── Buttons — match site .btn met battery-fill hover ───────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-page #payment .place-order .button,
.woocommerce .cart .button,
.woocommerce .cart input.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 18px 28px;
  border-radius: 12px;
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: var(--orange);
  color: #ffffff !important;
  transition: color .25s ease;
  text-shadow: none;
  box-shadow: none;
}
.woocommerce a.button::before,
.woocommerce button.button::before,
.woocommerce input.button::before,
.woocommerce #respond input#submit::before,
.woocommerce .cart .button::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  height: 100%;
  width: 0;
  background: var(--forest);
  transition: width .45s ease;
  z-index: -1;
}
.woocommerce a.button:hover::before,
.woocommerce button.button:hover::before,
.woocommerce input.button:hover::before,
.woocommerce #respond input#submit:hover::before,
.woocommerce .cart .button:hover::before {
  width: 100%;
}

/* Alt button = forest met oranje hover-fill */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce-page #payment #place_order {
  background: var(--forest);
}
.woocommerce a.button.alt::before,
.woocommerce button.button.alt::before,
.woocommerce input.button.alt::before,
.woocommerce-page #payment #place_order::before {
  background: var(--orange);
}

/* Disabled / loading state */
.woocommerce a.button.disabled,
.woocommerce a.button:disabled,
.woocommerce a.button:disabled[disabled],
.woocommerce button.button:disabled,
.woocommerce button.button:disabled[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ─── WC notices (succes / info / error) ──────────────────────────── */
.woocommerce-notices-wrapper:empty { display: none; }
.woocommerce-notices-wrapper { margin-bottom: 24px; }

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  padding: 16px 20px;
  border-radius: 10px;
  border-left: 4px solid;
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink);
  list-style: none;
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before { display: none; }

.woocommerce-message {
  border-left-color: var(--orange);
  background: var(--orange-soft);
}
.woocommerce-info {
  border-left-color: var(--forest);
  background: rgba(6, 50, 49, 0.04);
}
.woocommerce-error {
  border-left-color: #c0392b;
  background: rgba(192, 57, 43, 0.06);
  color: #8a2118;
}

.woocommerce-message .button,
.woocommerce-info .button {
  padding: 12px 18px !important;
  font-size: 13px !important;
  margin-left: auto;
}

/* ─── Product loop (winkel-overzicht) ─────────────────────────────── */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 32px;
  margin: 32px 0;
  padding: 0;
  list-style: none;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  position: relative;
  background: var(--cream-light);
  border: 1px solid var(--hairline);
  border-radius: 12px;
  padding: 24px;
  list-style: none;
  text-align: left;
  margin: 0;
  width: auto;
  float: none;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

/* ─── Sale "Aanbieding!" badge ───────────────────────────────────── */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale,
.woocommerce div.product .onsale {
  position: absolute;
  top: 16px;
  left: 16px;
  background: var(--orange);
  color: #ffffff;
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 4px;
  margin: 0;
  min-height: auto;
  min-width: auto;
  max-width: none;
  line-height: 1.2;
  z-index: 2;
  border: none;
  text-shadow: none;
  box-shadow: none;
}

/* ─── Star rating (5-sterren met CSS, geen WC-iconfont nodig) ─────── */
.woocommerce .star-rating,
.woocommerce-page .star-rating {
  position: relative;
  display: inline-block;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
  font-size: 16px;
  width: 5.4em;
  height: 1em;
  line-height: 1;
  color: rgba(6, 50, 49, 0.18);
  margin: 0 0 12px;
  letter-spacing: 0.08em;
  overflow: hidden;
  float: none;
}
.woocommerce .star-rating::before {
  content: "★★★★★";
  position: absolute;
  top: 0;
  left: 0;
  font-family: inherit;
}
.woocommerce .star-rating > span,
.woocommerce-page .star-rating > span {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  color: var(--orange);
  padding: 0;
  text-indent: 0;
  font-size: inherit;
  white-space: nowrap;
}
.woocommerce .star-rating > span::before {
  content: "★★★★★";
  position: absolute;
  top: 0;
  left: 0;
  font-family: inherit;
}
.woocommerce .star-rating > span strong,
.woocommerce .star-rating > span > * {
  display: none !important;
}

/* Single product page rating */
.woocommerce div.product .woocommerce-product-rating {
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.woocommerce div.product .woocommerce-product-rating .woocommerce-review-link {
  font-family: 'Public Sans', sans-serif;
  font-size: 13px;
  color: var(--ink-soft);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.woocommerce ul.products li.product:hover {
  border-color: var(--orange);
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -16px rgba(6, 50, 49, 0.18);
}
.woocommerce ul.products li.product a img {
  border-radius: 8px;
  margin: 0 0 16px;
  width: 100%;
  height: auto;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--forest);
  padding: 0;
  margin: 0 0 8px;
}
.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product .price ins,
.woocommerce ul.products li.product .price bdi {
  display: inline-block;
  font-family: 'Public Sans', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--orange);
  margin: 0;
  text-decoration: none;
  background: transparent;
  border-bottom: none;
}
.woocommerce ul.products li.product .price {
  margin: 0 0 16px;
}
.woocommerce ul.products li.product .price del {
  color: var(--ink-soft);
  font-weight: 400;
  opacity: 0.7;
  margin-right: 8px;
  text-decoration: line-through;
}
.woocommerce ul.products li.product .price del bdi {
  color: var(--ink-soft);
  font-weight: 400;
  font-size: 16px;
}

/* Productlink in cards niet onderstrepen */
.woocommerce ul.products li.product a,
.woocommerce ul.products li.product a:hover {
  text-decoration: none;
  border-bottom: none;
}

/* ─── Single product layout ───────────────────────────────────────── */
.woocommerce div.product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}
.woocommerce div.product .woocommerce-product-gallery,
.woocommerce div.product .summary {
  float: none;
  width: 100%;
  margin: 0;
}
.woocommerce div.product .woocommerce-product-gallery img {
  border-radius: 12px;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: 'Public Sans', sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--orange);
  margin: 0 0 24px;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-soft);
  margin-bottom: 24px;
}
.woocommerce div.product .woocommerce-product-details__short-description p {
  margin-bottom: 12px;
}

.woocommerce div.product form.cart {
  display: flex;
  gap: 16px;
  align-items: center;
  margin: 24px 0;
}
.woocommerce div.product form.cart div.quantity {
  margin: 0;
}

/* Tabs (description / reviews) */
.woocommerce div.product .woocommerce-tabs {
  margin-top: 60px;
  grid-column: 1 / -1;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0;
  margin: 0 0 24px;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 4px;
  list-style: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 14px 20px;
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--forest);
  border-bottom-color: var(--orange);
}

@media (max-width: 768px) {
  .woocommerce div.product {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .woocommerce div.product p.price,
  .woocommerce div.product span.price { font-size: 24px; }
  .woocommerce div.product form.cart {
    flex-direction: column;
    align-items: stretch;
  }
}

/* ─── Quantity input ──────────────────────────────────────────────── */
.woocommerce .quantity .qty,
.woocommerce-page .quantity .qty {
  width: 80px;
  padding: 16px 12px;
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  color: var(--forest);
  background: var(--cream-light);
  border: 1.5px solid var(--line);
  border-radius: 10px;
}
.woocommerce .quantity .qty:focus {
  outline: none;
  border-color: var(--orange);
  background: #ffffff;
}

/* ─── Forms (login, checkout, account) ────────────────────────────── */
.woocommerce form .form-row label,
.woocommerce-page form .form-row label {
  display: block;
  font-family: 'Public Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--ink-soft);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row textarea,
.woocommerce-page form .form-row select,
.select2-container--default .select2-selection--single {
  width: 100%;
  padding: 14px 18px;
  font-family: 'Public Sans', sans-serif;
  font-size: 16px;
  line-height: 1.4;
  color: var(--forest);
  background: var(--cream-light);
  border: 1.5px solid var(--line);
  border-radius: 10px;
  transition: border-color .2s ease, box-shadow .2s ease;
  box-sizing: border-box;
  height: auto;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  outline: none;
  border-color: var(--orange);
  box-shadow: 0 0 0 4px var(--orange-soft);
  background: #ffffff;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 1.4;
  padding: 0;
  color: var(--forest);
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100%;
  right: 12px;
}

/* ─── Cart-table & checkout-tables ────────────────────────────────── */
.woocommerce table.shop_table {
  border-radius: 12px;
  border: 1px solid var(--hairline);
  background: var(--cream-light);
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
}
.woocommerce table.shop_table th {
  background: transparent;
  padding: 16px 20px;
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--forest);
  border-bottom: 1px solid var(--hairline);
}
.woocommerce table.shop_table td {
  padding: 20px;
  border-top: 1px dashed var(--hairline);
  font-family: 'Public Sans', sans-serif;
  font-size: 15px;
  color: var(--ink);
}
.woocommerce table.shop_table tr:first-child td { border-top: none; }
.woocommerce table.shop_table tfoot td,
.woocommerce table.shop_table tfoot th {
  background: rgba(247, 87, 9, 0.04);
  font-weight: 700;
  color: var(--forest);
}

/* ─── Mijn account — sidebar nav ──────────────────────────────────── */
.woocommerce-MyAccount-navigation ul {
  padding: 0;
  margin: 0;
  list-style: none;
}
.woocommerce-MyAccount-navigation ul li {
  margin: 0 0 4px;
}
.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 12px 16px;
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-decoration: none;
  border-radius: 8px;
  transition: background .2s, color .2s;
}
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--orange-soft);
  color: var(--orange);
}

.woocommerce-account .woocommerce {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 768px) {
  .woocommerce-account .woocommerce {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

/* ─── Thank you / order received pagina ───────────────────────────── */
.woocommerce-order .woocommerce-notice--success,
.woocommerce-thankyou-order-received {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.15;
  color: var(--forest);
  text-transform: uppercase;
  margin: 0 0 32px;
}
