/* =========================================================================
   von prüll – WooCommerce-Theming (auf die Markentokens gemappt)
   Tokens stammen aus main.css (@theme -> :root --color-*, --font-*).
   ========================================================================= */

/* ---- Produktraster ------------------------------------------------------ */
.woocommerce ul.products,
.woocommerce-page ul.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
  gap: 2.5rem 2rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
@media (min-width: 640px) { .woocommerce ul.products, .woocommerce-page ul.products, ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; } }
@media (min-width: 1024px) { .woocommerce ul.products, .woocommerce-page ul.products, ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; } }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
ul.products li.product {
  width: auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: none !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
ul.products::before,
ul.products::after { content: none !important; display: none !important; }
.woocommerce ul.products li.product::before { display: none; }
.woocommerce ul.products li.product a img { margin: 0; }

/* Preis */
.vp-price del { color: var(--color-brown-soft); opacity: 0.8; font-weight: 400; margin-right: 0.45rem; font-size: 0.85em; }
.vp-price ins { text-decoration: none; color: var(--color-terra-deep); }
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--font-display);
  color: var(--color-ink);
  font-weight: 500;
}

/* ---- Buttons (Pill) ----------------------------------------------------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #place_order {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 0.84rem;
  letter-spacing: 0.03em;
  line-height: 1;
  padding: 0.95rem 1.6rem;
  border-radius: 999px;
  border: 1px solid var(--color-ink);
  background: var(--color-ink);
  color: var(--color-cream);
  cursor: pointer;
  transition: transform 0.3s ease, background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  text-transform: none;
  text-shadow: none;
  box-shadow: none;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce .button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce #place_order:hover {
  background: var(--color-forest);
  border-color: var(--color-forest);
  color: var(--color-cream);
  transform: translateY(-1px);
}

/* Kompakter Button in der Produktkarte */
.woocommerce ul.products li.product .button {
  padding: 0.7rem 1.15rem;
  font-size: 0.76rem;
  margin: 0;
}
.woocommerce ul.products li.product .added_to_cart {
  display: inline-flex; align-items: center;
  margin-left: 0.5rem; font-size: 0.76rem; font-weight: 700;
  color: var(--color-accent); text-decoration: none;
  border-bottom: 1px solid var(--color-accent-soft);
}

/* Sekundärer Button-Stil (z.B. „Warenkorb aktualisieren") */
.woocommerce button.button[name="update_cart"],
.woocommerce .cart .button.alt[disabled] { opacity: 1; }
.woocommerce button.button[name="update_cart"] {
  background: transparent; color: var(--color-ink); border-color: var(--color-line);
}
.woocommerce button.button[name="update_cart"]:hover { border-color: var(--color-ink); background: transparent; color: var(--color-ink); }

/* Loading/added states */
.woocommerce ul.products li.product .button.loading::after,
.woocommerce .button.loading::after { font-family: WooCommerce; }
.woocommerce ul.products li.product .button.added::before { display: none; }

/* ---- Sale-Flash --------------------------------------------------------- */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale {
  position: static;
  display: inline-flex;
  min-height: 0; min-width: 0;
  padding: 0.38rem 0.8rem;
  margin: 0; top: auto; right: auto;
  border-radius: 999px;
  background: var(--color-accent-soft);
  color: var(--color-terra-deep);
  font-family: var(--font-sans); font-weight: 700; font-size: 0.72rem; line-height: 1;
}
.woocommerce div.product .onsale { position: absolute; top: 1rem; left: 1rem; z-index: 3; }

/* ---- Bewertungssterne --------------------------------------------------- */
.woocommerce .star-rating span::before,
.woocommerce p.stars a::before { color: var(--color-caramel); }
.woocommerce .star-rating::before { color: var(--color-brown-soft); opacity: 0.4; }

/* ---- Result count & Ordering ------------------------------------------- */
.woocommerce .woocommerce-result-count {
  color: var(--color-ink-soft); font-size: 0.92rem; margin: 0 0 1.5rem;
}
.woocommerce .woocommerce-ordering { margin: 0 0 1.5rem; }
.woocommerce .woocommerce-ordering select,
.woocommerce select,
.woocommerce-page select {
  font-family: var(--font-sans);
  padding: 0.7rem 2.4rem 0.7rem 1rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background-color: var(--color-cream);
  color: var(--color-ink);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232b2620' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.9rem center;
}

/* ---- Breadcrumb --------------------------------------------------------- */
.woocommerce .woocommerce-breadcrumb {
  color: var(--color-ink-soft); font-size: 0.88rem; margin-bottom: 1.5rem;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--color-ink-soft); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--color-ink); }

/* ---- Einzelprodukt ------------------------------------------------------ */
.woocommerce div.product { display: grid; gap: 2.5rem 3.5rem; }
@media (min-width: 1024px) {
  .woocommerce div.product { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); align-items: start; }
  .woocommerce div.product .woocommerce-product-gallery { position: sticky; top: 7rem; }
  .woocommerce div.product .woocommerce-tabs,
  .woocommerce div.product .related,
  .woocommerce div.product .upsells { grid-column: 1 / -1; }
}
.woocommerce div.product .woocommerce-product-gallery {
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  border: 1px solid var(--color-line);
  margin: 0;
}
.woocommerce div.product .woocommerce-product-gallery__wrapper { border-radius: var(--radius-md); overflow: hidden; }
.woocommerce div.product .product_title {
  font-family: var(--font-display); font-weight: 500; letter-spacing: -0.015em;
  font-size: clamp(2rem, 4vw, 3rem); line-height: 1.06; color: var(--color-ink); margin-bottom: 0.5rem;
}
.woocommerce div.product .summary > .price,
.woocommerce div.product .summary p.price { font-size: 1.8rem; margin: 1rem 0 1.25rem; }
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 1rem; }
.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--color-ink-soft); line-height: 1.7; font-size: 1.05rem;
  border-top: 1px solid var(--color-line); padding-top: 1.25rem; margin-top: 0.5rem;
}
.woocommerce div.product form.cart { margin: 1.75rem 0; display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; }
.woocommerce div.product form.cart .quantity { margin: 0; }
.woocommerce .quantity input.qty {
  width: 4.5rem; padding: 0.85rem 0.5rem; text-align: center;
  border: 1px solid var(--color-line); border-radius: 999px; background: var(--color-cream); color: var(--color-ink);
  font-family: var(--font-sans);
}
.woocommerce div.product .product_meta {
  margin-top: 1.75rem; padding-top: 1.25rem; border-top: 1px solid var(--color-line);
  font-size: 0.88rem; color: var(--color-ink-soft);
}
.woocommerce div.product .product_meta > span { display: block; margin-bottom: 0.4rem; }
.woocommerce div.product .product_meta a { color: var(--color-accent); }

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs { padding: 0; margin: 0 0 1.5rem; border-bottom: 1px solid var(--color-line); display: flex; flex-wrap: wrap; gap: 0.5rem; }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent; border: 0; border-radius: 0; margin: 0; padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-sans); font-weight: 700; font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--color-ink-soft); padding: 0.85rem 0.25rem; display: inline-block; border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover { color: var(--color-ink); border-color: var(--color-terra); }
.woocommerce div.product .woocommerce-tabs .panel {
  color: var(--color-ink-soft); line-height: 1.72; font-size: 1.05rem; margin: 0;
}
.woocommerce div.product .woocommerce-tabs .panel h2 { font-family: var(--font-display); font-weight: 500; color: var(--color-ink); font-size: 1.7rem; }
.woocommerce-Tabs-panel table.shop_attributes th { color: var(--color-ink); font-weight: 700; }
.woocommerce table.shop_attributes { border: 0; }
.woocommerce table.shop_attributes th, .woocommerce table.shop_attributes td { border-bottom: 1px solid var(--color-line); padding: 0.75rem 0.5rem; }
.woocommerce table.shop_attributes td { font-style: normal; color: var(--color-ink-soft); }

/* Related/Upsell-Überschriften */
.woocommerce .related > h2, .woocommerce .upsells > h2, .woocommerce .cross-sells > h2 {
  font-family: var(--font-display); font-weight: 500; font-size: 2rem; color: var(--color-ink); margin-bottom: 1.5rem;
}

/* ---- Tabellen (Warenkorb, Konto) --------------------------------------- */
.woocommerce table.shop_table {
  border: 1px solid var(--color-line); border-radius: var(--radius-md); border-collapse: separate; border-spacing: 0;
}
.woocommerce table.shop_table th { font-family: var(--font-sans); font-weight: 700; color: var(--color-ink); background: var(--color-cream); }
.woocommerce table.shop_table td, .woocommerce table.shop_table th { border-top: 1px solid var(--color-line); padding: 1rem; }
.woocommerce table.shop_table thead th { border-top: 0; }
.woocommerce .cart_totals h2, .woocommerce-checkout h3, .woocommerce .cart-collaterals h2 {
  font-family: var(--font-display); font-weight: 500; color: var(--color-ink); font-size: 1.6rem; margin-bottom: 1rem;
}
.woocommerce a.remove { color: var(--color-terra-deep) !important; border-color: var(--color-line); }
.woocommerce a.remove:hover { background: var(--color-terra) !important; color: var(--color-cream) !important; }

/* ---- Formulare ---------------------------------------------------------- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce .woocommerce-form-login input,
.woocommerce #customer_details input,
.woocommerce #customer_details textarea,
.woocommerce-page table.cart td.actions .coupon .input-text,
.select2-container .select2-selection {
  border: 1px solid var(--color-line) !important;
  border-radius: var(--radius-md) !important;
  background: var(--color-cream) !important;
  color: var(--color-ink) !important;
  padding: 0.85rem 1rem !important;
  font-family: var(--font-sans) !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { outline: 2px solid var(--color-accent); outline-offset: 1px; border-color: var(--color-accent) !important; }
.woocommerce form .form-row label { color: var(--color-ink); font-weight: 600; }

/* ---- Hinweise / Notices ------------------------------------------------- */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews {
  border-top: 0; border-radius: var(--radius-md); background: var(--color-cream);
  border: 1px solid var(--color-line); border-left: 3px solid var(--color-sage-deep);
  color: var(--color-ink); padding: 1rem 1.25rem;
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--color-sage-deep); }
.woocommerce-error { border-left-color: var(--color-terra-deep); }
.woocommerce-error::before { color: var(--color-terra-deep); }

/* ---- Pagination --------------------------------------------------------- */
.woocommerce nav.woocommerce-pagination ul { border: 0; gap: 0.4rem; display: flex; justify-content: center; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
  border-radius: 999px; min-width: 2.5rem; height: 2.5rem; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-line); color: var(--color-ink); padding: 0 0.5rem;
}
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--color-ink); color: var(--color-cream); border-color: var(--color-ink); }
.woocommerce nav.woocommerce-pagination ul li a:hover { background: var(--color-sand); }

/* Tabs-Inhalte ul Marker zurücksetzen */
.woocommerce .woocommerce-tabs .panel ul { list-style: none; padding-left: 1.3rem; }
.woocommerce .woocommerce-tabs .panel ul li { position: relative; }
.woocommerce .woocommerce-tabs .panel ul li::before { content: ""; position: absolute; left: -1.3rem; top: 0.62em; width: 7px; height: 7px; background: var(--color-terra); transform: rotate(45deg); }
