/* ============================================
   WOOCOMMERCE OVERRIDES
   ============================================ */

/* Product Grid */
.woocommerce .products { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important; gap: var(--space-lg) !important; }
.woocommerce ul.products li.product { background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--border-radius); overflow: hidden; margin: 0 !important; padding: 0 !important; width: 100% !important; float: none !important; transition: all var(--transition); }
.woocommerce ul.products li.product:hover { border-color: rgba(232,69,28,0.3); transform: translateY(-4px); }
.woocommerce ul.products li.product a img { margin: 0 !important; border-radius: 0; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family: var(--font-heading); font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--color-text); padding: var(--space-md) var(--space-lg) var(--space-xs) !important; }
.woocommerce ul.products li.product .price { font-family: var(--font-heading); font-size: 1.2rem !important; color: var(--color-accent) !important; padding: 0 var(--space-lg) var(--space-md); }
.woocommerce ul.products li.product .price del { color: var(--color-text-dim) !important; font-size: 0.85rem !important; }

/* Buttons */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce .cart .button, .woocommerce .checkout-button,
.woocommerce ul.products li.product .button {
  background: var(--color-primary) !important; color: #fff !important; border: none !important;
  border-radius: var(--border-radius-sm) !important; font-family: var(--font-heading) !important;
  text-transform: uppercase !important; letter-spacing: 0.08em !important;
  padding: 0.75rem 1.5rem !important; transition: all var(--transition) !important;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover {
  background: var(--color-primary-hover) !important; color: #fff !important;
}
.woocommerce a.button.alt, .woocommerce button.button.alt { background: var(--color-accent) !important; color: var(--color-bg) !important; }
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover { background: var(--color-accent-hover) !important; }

/* Cart */
.woocommerce-cart .woocommerce table.shop_table { background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--border-radius); }
.woocommerce table.shop_table th, .woocommerce table.shop_table td { border-color: var(--color-border) !important; color: var(--color-text); padding: var(--space-md) !important; }
.woocommerce table.shop_table th { font-family: var(--font-heading); text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-muted); }

/* Forms */
.woocommerce form .form-row label { color: var(--color-text-muted); font-size: 0.9rem; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select {
  background: var(--color-surface) !important; border: 1px solid var(--color-border) !important;
  border-radius: var(--border-radius-sm) !important; color: var(--color-text) !important;
  padding: 0.75rem var(--space-md) !important; transition: border-color var(--transition-fast);
}
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus, .woocommerce form .form-row select:focus {
  border-color: var(--color-primary) !important; outline: none; box-shadow: 0 0 0 3px var(--color-primary-glow) !important;
}

/* My Account */
.woocommerce-MyAccount-navigation ul { display: flex; flex-direction: column; gap: var(--space-xs); }
.woocommerce-MyAccount-navigation ul li a { display: block; padding: var(--space-sm) var(--space-md); border-radius: var(--border-radius-sm); color: var(--color-text-muted); transition: all var(--transition-fast); }
.woocommerce-MyAccount-navigation ul li.is-active a, .woocommerce-MyAccount-navigation ul li a:hover { background: var(--color-surface); color: var(--color-primary); }

/* Notices */
.woocommerce-message, .woocommerce-info { background: var(--color-surface) !important; border-top-color: var(--color-primary) !important; color: var(--color-text) !important; }
.woocommerce-error { background: var(--color-surface) !important; border-top-color: var(--color-danger) !important; color: var(--color-text) !important; }

/* Sale Badge */
.woocommerce span.onsale { background: var(--color-primary) !important; color: #fff; font-family: var(--font-heading); text-transform: uppercase; letter-spacing: 0.05em; }

/* Pagination */
.woocommerce nav.woocommerce-pagination ul { border: none !important; }
.woocommerce nav.woocommerce-pagination ul li { border: none !important; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
  background: var(--color-surface) !important; color: var(--color-text-muted) !important;
  border-radius: var(--border-radius-sm) !important; padding: 0.5rem 1rem !important;
}
.woocommerce nav.woocommerce-pagination ul li a:hover, .woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--color-primary) !important; color: #fff !important;
}

/* Breadcrumbs */
.breadcrumbs { padding: calc(var(--header-height) + var(--space-md)) 0 var(--space-md); font-size: 0.85rem; color: var(--color-text-muted); }
.breadcrumbs a { color: var(--color-text-muted); }
.breadcrumbs a:hover { color: var(--color-primary); }
.breadcrumb-sep { margin: 0 0.3rem; opacity: 0.5; }

/* Mini Cart Widget */
.widget_shopping_cart { background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--border-radius); padding: var(--space-md); }
.widget_shopping_cart .mini_cart_item { padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-border); }
.widget_shopping_cart .total { font-family: var(--font-heading); font-size: 1.1rem; }

/* Coupon Field */
.woocommerce .coupon .input-text { max-width: 200px; }


/* ============================================
   SINGLE PRODUCT PAGE – Layout Fix
   ============================================ */

/* Haupt-Layout: 2-Spalten Grid */
.woocommerce div.product {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  grid-template-rows: auto auto auto !important;
  gap: 32px 48px !important;
  align-items: start !important;
  max-width: 1100px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-top: calc(var(--header-height) + var(--space-xl)) !important;
  padding-left: var(--space-lg) !important;
  padding-right: var(--space-lg) !important;
}

/* Produktbild: linke Spalte, volle Breite, sticky */
.woocommerce div.product div.images,
.woocommerce div.product .woocommerce-product-gallery {
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  position: static !important;
}

.woocommerce div.product div.images img,
.woocommerce div.product .woocommerce-product-gallery img,
.woocommerce div.product div.images .woocommerce-product-gallery__image img {
  width: 100% !important;
  height: auto !important;
  border-radius: var(--border-radius) !important;
  object-fit: cover !important;
}

.woocommerce div.product div.images .flex-viewport,
.woocommerce div.product .woocommerce-product-gallery .flex-viewport {
  border-radius: var(--border-radius) !important;
  overflow: hidden !important;
}

.woocommerce div.product div.images .woocommerce-product-gallery__trigger {
  z-index: 5 !important;
}

/* Summary: rechte Spalte */
.woocommerce div.product .summary,
.woocommerce div.product .summary.entry-summary {
  grid-column: 2 !important;
  grid-row: 1 !important;
  width: 100% !important;
  float: none !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Produktname */
.woocommerce div.product .product_title {
  font-family: var(--font-display) !important;
  font-size: 2rem !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  line-height: 1.15 !important;
  margin-bottom: var(--space-sm) !important;
  color: var(--color-text) !important;
}

/* Preis */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--font-heading) !important;
  font-size: 1.5rem !important;
  color: var(--color-accent) !important;
  margin-bottom: var(--space-md) !important;
}

/* Kurzbeschreibung */
.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--color-text-muted) !important;
  line-height: 1.7 !important;
  margin-bottom: var(--space-md) !important;
}

/* ── Add-on Dropdowns (SBAP Plugin) ──────────── */
.woocommerce div.product .sbap-fields {
  margin: var(--space-sm) 0 var(--space-md) !important;
  width: 100% !important;
  max-width: 100% !important;
}

.woocommerce div.product .sbap-fields .form-row,
.woocommerce div.product .sbap-fields p.form-row {
  margin-bottom: 12px !important;
  padding: 0 !important;
}

.woocommerce div.product .sbap-fields label,
.woocommerce div.product .sbap-fields .form-row label {
  display: block !important;
  font-family: var(--font-heading) !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 4px !important;
}

.woocommerce div.product .sbap-fields select,
.woocommerce div.product .sbap-fields .form-row select {
  display: block !important;
  width: 100% !important;
  min-height: auto !important;
  height: auto !important;
  padding: 10px 36px 10px 14px !important;
  font-size: 0.9rem !important;
  font-family: var(--font-body, 'DM Sans', sans-serif) !important;
  border: 2px solid var(--color-border) !important;
  border-radius: var(--border-radius-sm) !important;
  background-color: var(--color-surface) !important;
  color: var(--color-text) !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  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='%23999' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  cursor: pointer !important;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
  box-sizing: border-box !important;
}

.woocommerce div.product .sbap-fields select:focus {
  outline: none !important;
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-glow, rgba(232,69,28,0.1)) !important;
  background-color: var(--color-bg-card, #fff) !important;
}

.woocommerce div.product .sbap-fields select:hover {
  border-color: rgba(232,69,28,0.3) !important;
}

/* ── Warenkorb-Formular (Menge + Button) ─────── */
.woocommerce div.product form.cart {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: stretch !important;
  margin-top: var(--space-sm) !important;
}

.woocommerce div.product form.cart .sbap-fields {
  flex: 1 1 100% !important;
  order: -1 !important;
}

.woocommerce div.product form.cart .quantity {
  width: auto !important;
  flex-shrink: 0 !important;
}

.woocommerce div.product .quantity .qty {
  background: var(--color-surface) !important;
  border: 2px solid var(--color-border) !important;
  border-radius: var(--border-radius-sm) !important;
  color: var(--color-text) !important;
  padding: 0 !important;
  width: 52px !important;
  height: 48px !important;
  text-align: center !important;
  font-size: 1rem !important;
  font-family: var(--font-body, 'DM Sans', sans-serif) !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button {
  flex: 1 !important;
  min-width: 0 !important;
  height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--border-radius-sm) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 16px rgba(232,69,28,0.25) !important;
}

/* ── Kategorie-Link ──────────────────────────── */
.woocommerce div.product .summary .posted_in {
  font-size: 0.82rem !important;
  color: var(--color-text-dim, #999) !important;
  margin-top: var(--space-md) !important;
}

.woocommerce div.product .summary .posted_in a {
  color: var(--color-accent) !important;
  text-decoration: none !important;
}

/* ── Tabs (Beschreibung) – volle Breite ──────── */
.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  clear: both !important;
  margin-top: var(--space-md) !important;
  width: 100% !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  margin-bottom: var(--space-md) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-heading) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  font-size: 0.9rem !important;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
  font-family: var(--font-display) !important;
  font-size: 1.3rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  margin-bottom: var(--space-sm) !important;
}

.woocommerce div.product .woocommerce-tabs .panel p {
  font-size: 0.95rem !important;
  line-height: 1.7 !important;
  color: var(--color-text-muted) !important;
  max-width: 720px !important;
}

/* ── Ähnliche Produkte – volle Breite, Grid ──── */
.woocommerce div.product .related.products,
.woocommerce div.product section.related,
.single-product .related.products {
  grid-column: 1 / -1 !important;
  grid-row: 3 !important;
  width: 100% !important;
  margin-top: var(--space-lg) !important;
  clear: both !important;
}

.woocommerce div.product .related.products h2,
.woocommerce div.product section.related > h2 {
  font-family: var(--font-display) !important;
  font-size: 1.4rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  margin-bottom: var(--space-md) !important;
}

.woocommerce div.product .related.products ul.products {
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  gap: 16px !important;
  padding-bottom: 8px !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: thin !important;
}

.woocommerce div.product .related.products ul.products li.product {
  width: 170px !important;
  min-width: 170px !important;
  max-width: 170px !important;
  float: none !important;
  margin: 0 !important;
  font-size: 0.85rem !important;
}

.woocommerce div.product .related.products ul.products li.product .woocommerce-loop-product__title {
  font-size: 0.8rem !important;
  padding: 8px 10px 4px !important;
}

.woocommerce div.product .related.products ul.products li.product .price {
  font-size: 0.9rem !important;
  padding: 0 10px 8px !important;
}

.woocommerce div.product .related.products ul.products li.product .button {
  font-size: 0.7rem !important;
  padding: 0.5rem 0.8rem !important;
  margin: 0 10px 10px !important;
}

.woocommerce div.product .related.products ul.products li.product a img {
  border-radius: var(--border-radius-sm) var(--border-radius-sm) 0 0 !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  width: 100% !important;
}

/* ── Responsive: Mobile ──────────────────────── */
@media (max-width: 768px) {
  .woocommerce div.product {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    padding-left: var(--space-md) !important;
    padding-right: var(--space-md) !important;
  }

  .woocommerce div.product div.images,
  .woocommerce div.product .woocommerce-product-gallery {
    grid-column: 1 !important;
    grid-row: 1 !important;
    position: static !important;
  }

  .woocommerce div.product .summary,
  .woocommerce div.product .summary.entry-summary {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  .woocommerce div.product .product_title {
    font-size: 1.5rem !important;
  }

  .woocommerce div.product p.price,
  .woocommerce div.product span.price {
    font-size: 1.3rem !important;
  }

  .woocommerce div.product .woocommerce-tabs {
    grid-column: 1 !important;
    grid-row: 3 !important;
  }

  .woocommerce div.product .related.products,
  .woocommerce div.product section.related {
    grid-column: 1 !important;
    grid-row: 4 !important;
  }

  .woocommerce div.product .related.products ul.products {
    gap: 12px !important;
  }

  .woocommerce div.product .related.products ul.products li.product {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
  }
}

@media (max-width: 480px) {
  .woocommerce div.product .related.products ul.products li.product {
    width: 140px !important;
    min-width: 140px !important;
    max-width: 140px !important;
  }
}
/* ============================================
   CHECKOUT - "Zahlungspflichtig bestellen" Button
   Füge diesen Code am Ende deiner main.css 
   oder woocommerce.css ein
   ============================================ */

/* Block-Checkout Button */
.wc-block-components-checkout-place-order-button,
.wc-block-cart__submit-button,
.wp-block-woocommerce-proceed-to-checkout-block a,
.wc-block-components-button.wp-element-button.wc-block-components-checkout-place-order-button {
    background: linear-gradient(135deg, #d32f2f, #b71c1c) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 18px 32px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    font-family: 'Oswald', 'Bebas Neue', sans-serif !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    width: 100% !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 15px rgba(211, 47, 47, 0.4) !important;
    margin-top: 12px !important;
}

.wc-block-components-checkout-place-order-button:hover,
.wc-block-cart__submit-button:hover,
.wp-block-woocommerce-proceed-to-checkout-block a:hover {
    background: linear-gradient(135deg, #e53935, #c62828) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 24px rgba(211, 47, 47, 0.5) !important;
}

.wc-block-components-checkout-place-order-button:active,
.wc-block-cart__submit-button:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 8px rgba(211, 47, 47, 0.3) !important;
}

/* Warenkorb "Zur Kasse" Button gleicher Style */
.wc-block-cart__submit-container .wc-block-cart__submit-button {
    background: linear-gradient(135deg, #d32f2f, #b71c1c) !important;
    color: #fff !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1.5px !important;
}