/* ---------------------------------------------------------------------------
   store.css — WooCommerce-Spezifika fuer das Atelier-Theme.

   Das Fundament (Palette, Typografie, Buttons, Links, Headings) kommt aus
   theme.json. Diese Datei ergaenzt nur das, was sich dort nicht ausdruecken
   laesst: Template-Parts (Topbar/Footer), klassisches Woo-Markup,
   Block-Komponenten und Plugin-Overrides.
   --------------------------------------------------------------------------- */

/* ---------- Token-Aliase ----------------------------------------------------
   theme.json erzeugt --wp--preset--color--* und --wp--preset--font-family--*.
   Wir spiegeln sie auf die kanonischen Kurznamen aus dem Prototyp, plus die
   beiden Tokens, die theme.json nicht abbildet (--line, --ease).
   --------------------------------------------------------------------------- */
:root {
	--bg: var(--wp--preset--color--bg);
	--bg-2: var(--wp--preset--color--bg-2);
	--surface: var(--wp--preset--color--surface);
	--ink: var(--wp--preset--color--ink);
	--ink-soft: var(--wp--preset--color--ink-soft);
	--accent: var(--wp--preset--color--accent);
	--accent-ink: var(--wp--preset--color--accent-ink);
	--line: rgba(236, 231, 223, .18);
	--ease: cubic-bezier(.22, .61, .36, 1);
	--font-head: var(--wp--preset--font-family--head);
	--font-body: var(--wp--preset--font-family--body);
}

/* ===========================================================================
   TOPBAR (parts/header.html) — identische Optik zum Prototyp
   =========================================================================== */
.topbar {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(13, 11, 10, .92);
	-webkit-backdrop-filter: blur(14px);
	backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--line);
}
.topbar__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: .8rem 2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

/* Marke */
.topbar .brand {
	display: flex;
	align-items: center;
	gap: .7rem;
	color: var(--ink);
	text-decoration: none;
}
.topbar .brand:hover { opacity: 1; }
.topbar .brand img { height: 38px; width: auto; display: block; }
.topbar .brand span {
	font-family: var(--font-head);
	font-size: 1.25rem;
	font-weight: 500;
	letter-spacing: .02em;
	line-height: 1.1;
}
.topbar .brand small {
	font-family: var(--font-body);
	font-weight: 600;
	font-size: .62rem;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--accent);
	display: block;
	margin-top: -.2rem;
}

/* Chips */
.topbar__nav {
	display: flex;
	align-items: center;
	gap: .55rem;
	flex-wrap: wrap;
}
.topbar .chip {
	font-size: .74rem;
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--ink-soft);
	padding: .5em 1.1em;
	border: 1px solid var(--line);
	border-radius: 999px;
	text-decoration: none;
	transition: color .25s var(--ease), border-color .25s var(--ease);
}
.topbar .chip:hover {
	color: var(--accent);
	border-color: var(--accent);
	opacity: 1;
}

/* Icons-Cluster: WooCommerce mini-cart + customer-account */
.topbar__icons {
	display: flex;
	align-items: center;
	gap: 1.1rem;
}
.topbar__icons .wp-block-woocommerce-mini-cart,
.topbar__icons .wp-block-woocommerce-customer-account { margin: 0; }
.topbar__icons a,
.topbar__icons .wc-block-mini-cart__button,
.topbar__icons .wc-block-customer-account__account-link {
	color: var(--ink-soft);
	font-family: var(--font-body);
	font-weight: 600;
	font-size: .78rem;
	letter-spacing: .06em;
	text-transform: uppercase;
	background: none;
	border: none;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	text-decoration: none;
	transition: color .25s var(--ease);
}
.topbar__icons a:hover,
.topbar__icons .wc-block-mini-cart__button:hover,
.topbar__icons .wc-block-customer-account__account-link:hover {
	color: var(--accent);
	opacity: 1;
}
.topbar__icons svg {
	width: 1.1rem;
	height: 1.1rem;
	fill: currentColor;
}

/* ===========================================================================
   FOOTER (parts/footer.html)
   =========================================================================== */
.site-footer {
	border-top: 1px solid var(--line);
	padding: 3rem 2rem 3.5rem;
}
.foot__inner {
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 2rem;
	flex-wrap: wrap;
}
.foot__brand {
	font-family: var(--font-head);
	font-size: 1.1rem;
	color: var(--ink-soft);
}
.site-footer .foot__links {
	display: flex;
	gap: 1.4rem;
	flex-wrap: wrap;
	font-size: .8rem;
}
.site-footer .foot__links a,
.site-footer .foot__links .wp-block-navigation-item__content {
	color: var(--ink-soft);
	text-decoration: none;
}
.site-footer .foot__links a:hover,
.site-footer .foot__links .wp-block-navigation-item__content:hover {
	color: var(--accent);
	opacity: 1;
}
.foot__note {
	width: 100%;
	margin-top: 1.6rem;
	padding-top: 1.4rem;
	border-top: 1px solid var(--line);
	color: var(--ink-soft);
	font-size: .76rem;
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

/* ---------------------------------------------------------------------------
   Rechtsleiste des deichmann-legal-age-Plugins (Klasse .df-legal-footer,
   injiziert via wp_footer mit Inline-<style>). Dunkler Hintergrund war
   #0f1115 — auf die Atelier-Tokens angleichen. body-Praefix schlaegt das
   Inline-CSS des Plugins (1 Klasse) per Spezifitaet.
   --------------------------------------------------------------------------- */
body .df-legal-footer {
	background: var(--bg-2);
	color: var(--ink-soft);
	border-top: 1px solid var(--line);
}
body .df-legal-footer a {
	color: var(--ink-soft);
}
body .df-legal-footer a:hover {
	color: var(--accent);
}
body .df-legal-footer .note {
	opacity: .8;
}

/* ===========================================================================
   SHOP / ARCHIV — klassisches Woo-Markup (ul.products > li.product)
   Die store-tweaks-Hooks feuern, also laeuft der klassische Template-Pfad.
   =========================================================================== */

/* Produkt-Kopf (Woo-Archivkopf) — ruhig, zentriert, Cormorant */
.woocommerce-products-header {
	max-width: 1280px;
	margin: 0 auto;
	padding: 4.5rem 2rem 2.5rem;
	text-align: center;
}
.woocommerce-products-header__title {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: clamp(2.6rem, 5vw, 3.8rem);
	line-height: 1.05;
	color: var(--ink);
}
/* Eyebrow ueber dem Shop-Titel */
.woocommerce-products-header__title::before {
	content: "Atelier · Content-Store";
	display: block;
	margin-bottom: .6rem;
	font-family: var(--font-body);
	font-size: .68rem;
	font-weight: 600;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--accent);
}
/* Unterzeile im Shop-Kopf */
.shop-lead {
	max-width: 46ch;
	margin: .9rem auto 0;
	font-size: 1.02rem;
	font-weight: 300;
	line-height: 1.65;
	color: var(--ink-soft);
}
.woocommerce-products-header .term-description,
.woocommerce-products-header + .woocommerce-result-count {
	color: var(--ink-soft);
}

/* Filter-Zeile (v2) — Produktkategorien als Chips (functions.php) */
.filter {
	max-width: 1280px;
	margin: 0 auto 1.6rem;
	padding: 0 2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}
.filter__tags { display: flex; gap: .5rem; flex-wrap: wrap; }
.filter .chip {
	font-size: .74rem;
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--ink-soft);
	padding: .5em 1.1em;
	border: 1px solid var(--line);
	border-radius: 999px;
	text-decoration: none;
	transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.filter .chip:hover { color: var(--accent); border-color: var(--accent); opacity: 1; }
.filter .chip.is-active {
	color: var(--accent-ink);
	background: var(--accent);
	border-color: var(--accent);
}
.filter__count { font-size: .8rem; color: var(--ink-soft); }

/* Produkt-Raster (kuratierte Galerie) */
.woocommerce ul.products,
.woocommerce-page ul.products {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 2rem 4rem;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.2rem 1.8rem;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none; display: none; }

.woocommerce ul.products li.product {
	width: auto;
	float: none;
	margin: 0;
	padding: 0;
	background: var(--surface);
	border: 1px solid var(--line);
	display: flex;
	flex-direction: column;
	transition: border-color .3s var(--ease);
}
.woocommerce ul.products li.product:hover { border-color: rgba(194, 163, 107, .55); }

/* Der Loop-Link umschliesst Bild + Titel + Preis */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
.woocommerce ul.products li.product a.woocommerce-loop-product__link {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	color: var(--ink);
}
.woocommerce ul.products li.product a:hover { opacity: 1; }

/* Bild 4:5, cover, sanfter Scale-Hover */
.woocommerce ul.products li.product img {
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	margin: 0;
	background: var(--bg-2);
	transition: transform 1.1s var(--ease);
}
.woocommerce ul.products li.product:hover img { transform: scale(1.035); }

/* Titel — Cormorant 500 */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 1.55rem;
	line-height: 1.15;
	color: var(--ink);
	padding: 1.4rem 1.5rem 0;
}

/* Preis — Cormorant gross; §19-Suffix klein darunter
   (Woo wrappt den Hinweis bereits in <small class="woocommerce-price-suffix">) */
.woocommerce ul.products li.product .price {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 1.85rem;
	line-height: 1;
	color: var(--ink);
	padding: .85rem 1.5rem 0;
}
.woocommerce .price .woocommerce-price-suffix {
	display: block;
	font-family: var(--font-body);
	font-weight: 400;
	font-size: .68rem;
	letter-spacing: .04em;
	text-transform: none;
	color: var(--ink-soft);
	margin-top: .35rem;
}

/* "In den Warenkorb" — Atelier-Geometrie (sicherheitshalber explizit,
   falls Woo-Buttons die theme.json-Button-Styles nicht erben) */
.woocommerce ul.products li.product .button,
.woocommerce a.button.add_to_cart_button,
.woocommerce a.button.product_type_simple {
	margin: 1.1rem 1.5rem 1.5rem;
	align-self: flex-start;
	display: inline-block;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: .72rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	padding: .85em 1.5em;
	border-radius: 2px;
	border: 1px solid transparent;
	background: var(--accent);
	color: var(--accent-ink);
	transition: background .25s var(--ease), color .25s var(--ease);
}
.woocommerce ul.products li.product .button:hover,
.woocommerce a.button.add_to_cart_button:hover {
	background: #d4b87e;
	color: var(--accent-ink);
	opacity: 1;
}
.woocommerce ul.products li.product .added_to_cart {
	margin: 0 1.5rem 1.5rem;
	font-size: .72rem;
	letter-spacing: .1em;
	text-transform: uppercase;
}

/* Premium+-Block (store-tweaks; laedt Inline-CSS → body-Praefix fuer Spezifitaet)
   Ersetzt den schwarzen Standard-Kasten durch goldenen Linksrand + Goldfond. */
body .stx-premium-block {
	border-left: 2px solid var(--accent) !important;
	background: rgba(194, 163, 107, .07) !important;
	border-radius: 0 !important;
	padding: .75rem 1rem;
	margin: .85rem 1.5rem 0;
	font-size: .84rem;
	line-height: 1.5;
	color: var(--ink-soft) !important;
}
body .stx-premium-block strong {
	display: block;
	font-weight: 700;
	color: var(--ink) !important;
	letter-spacing: .01em;
}
body .stx-premium-block .stx-premium-sub { color: var(--ink-soft) !important; font-size: .8rem; margin-top: .25rem; }

/* Kurzbeschreibung im Loop (store-tweaks .stx-shortdesc) → wie .card__desc */
.woocommerce ul.products li.product .stx-shortdesc {
	color: var(--ink-soft);
	font-size: .92rem;
	line-height: 1.55;
	opacity: 1;
	padding: .85rem 1.5rem 0;
}
.woocommerce ul.products li.product .stx-shortdesc p { margin: 0 0 .4rem; }

/* Aktions-Band (store-tweaks .stx-banner) → Atelier-Band wie Prototyp */
body .stx-banner {
	max-width: 1280px;
	margin: 0 auto 3rem;
	padding: 1.4rem 2rem;
	background: var(--surface);
	border: 1px solid var(--accent);
	border-radius: 0;
	text-align: center;
	color: var(--ink-soft);
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 1.2rem;
	flex-wrap: wrap;
}
body .stx-banner .stx-banner__inner {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 1.2rem;
	flex-wrap: wrap;
	text-align: center;
}
body .stx-banner h2,
body .stx-banner h3,
body .stx-banner strong,
body .stx-banner .stx-banner__headline {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 1.45rem;
	line-height: 1.2;
	color: var(--ink);
}
body .stx-banner .stx-banner__subline {
	color: var(--ink-soft);
	font-size: .92rem;
	opacity: 1;
}

/* Rest-Lila von WooCommerce auf Akzent ziehen */
.woocommerce span.onsale {
	background: var(--accent);
	color: var(--accent-ink);
	border-radius: 999px;
	font-weight: 700;
}
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-noreviews {
	border-top-color: var(--accent);
	background: var(--surface);
	color: var(--ink);
}
.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before { color: var(--accent); }
.woocommerce .star-rating span::before,
.woocommerce p.stars a { color: var(--accent); }

/* ---------- Trust-Band (functions.php, woocommerce_after_main_content) ------ */
.trust {
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	background: var(--bg-2);
}
.trust__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 2.6rem 2rem;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
}
.trust__item .k {
	color: var(--accent);
	font-size: .66rem;
	font-weight: 700;
	letter-spacing: .22em;
	text-transform: uppercase;
	display: block;
	margin-bottom: .55rem;
}
.trust__item h3 {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 1.2rem;
	margin-bottom: .35rem;
	color: var(--ink);
}
.trust__item p {
	color: var(--ink-soft);
	font-size: .86rem;
	line-height: 1.55;
}

/* ===========================================================================
   PRODUKTSEITE (Single) — klassisches Woo-Markup (.woocommerce div.product)
   =========================================================================== */

/* Breadcrumb — dezent */
.woocommerce .woocommerce-breadcrumb {
	max-width: 1280px;
	margin: 0 auto;
	padding: 1.6rem 2rem .4rem;
	font-size: .74rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--ink-soft);
}
.woocommerce .woocommerce-breadcrumb a { color: var(--ink-soft); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--accent); }

/* Galerie + Zusammenfassung als 7/5-Raster, Tabs/Verwandtes volle Breite */
.woocommerce div.product {
	max-width: 1280px;
	margin: 0 auto;
	padding: 1.6rem 2rem 4rem;
	display: grid;
	grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
	column-gap: 3rem;
	row-gap: 2.5rem;
	align-items: start;
}
.woocommerce div.product .woocommerce-product-gallery {
	grid-column: 1;
	width: auto !important;
	margin: 0;
	float: none;
}
.woocommerce div.product .summary {
	grid-column: 2;
	margin: 0;
	width: auto;
	float: none;
}
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .product_meta,
.woocommerce div.product .related,
.woocommerce div.product .upsells {
	grid-column: 1 / -1;
}
.woocommerce div.product .woocommerce-product-gallery img { border: 1px solid var(--line); }

/* Titel */
.woocommerce div.product .product_title {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: clamp(2.1rem, 3.6vw, 2.9rem);
	line-height: 1.08;
	color: var(--ink);
	margin: .3rem 0 1rem;
}

/* Lead / Kurzbeschreibung */
.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--ink-soft);
	font-size: .98rem;
	margin-bottom: 1.4rem;
}

/* Preisbox — Haarlinien oben/unten, Cormorant gross */
.woocommerce div.product .summary > .price,
.woocommerce div.product p.price {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 2.6rem;
	line-height: 1;
	color: var(--ink);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	padding: 1.3rem 0;
	margin: 0 0 1.4rem;
}

/* Stripe/Klarna BNPL-Hinweis: Inhalt ist ein Cross-Origin-iframe mit
   color-scheme:light — innen nicht stylebar. Nur der aeussere Container
   wird gestaltet; die inneren Inline-!important-Styles von Stripe
   (negative Margins) werden durch das Padding hier aufgefangen. */
.single-product #payment-method-message.StripeElement {
	display: block;
	box-sizing: border-box;
	margin: 0 0 1.4rem;
	padding: 0.7rem 0.9rem;
	background: #f1e9da;
	border: 1px solid var(--line);
	border-left: 2px solid var(--accent);
	border-radius: 2px;
	overflow: hidden;
	--wc-bnpl-margin-bottom: 0px;
}

/* Mengen-Feld + "In den Warenkorb" */
.woocommerce div.product form.cart { margin-bottom: 1rem; display: flex; gap: .8rem; flex-wrap: wrap; align-items: stretch; }
.woocommerce div.product form.cart .quantity {
	display: flex;
	align-items: center;
	border: 1px solid var(--line);
	border-radius: 2px;
}
.woocommerce div.product form.cart .quantity input.qty {
	width: 3rem;
	text-align: center;
	background: none;
	border: none;
	color: var(--ink);
	font-family: var(--font-body);
	font-size: .95rem;
}
.woocommerce div.product form.cart .button {
	flex: 1;
	min-width: 220px;
	background: var(--accent);
	color: var(--accent-ink);
	font-family: var(--font-body);
	font-weight: 600;
	font-size: .82rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	padding: 1.05em 1.9em;
	border-radius: 2px;
	border: 1px solid transparent;
	transition: background .25s var(--ease);
}
.woocommerce div.product form.cart .button:hover { background: #d4b87e; color: var(--accent-ink); opacity: 1; }

/* Produkt-Meta — ruhig */
.woocommerce div.product .product_meta {
	margin-top: 1.6rem;
	font-size: .84rem;
	color: var(--ink-soft);
	line-height: 1.9;
}
.woocommerce div.product .product_meta a { color: var(--accent); }

/* Rueckweg-Block (functions.php, .df-serie-link) — wie Prototyp .serie-link */
.df-serie-link {
	display: block;
	border: 1px solid var(--line);
	background: var(--surface);
	padding: 1rem 1.2rem;
	margin: 1.5rem 0 0;
	font-size: .86rem;
	color: var(--ink);
	transition: border-color .25s var(--ease);
}
.df-serie-link:hover { border-color: var(--accent); opacity: 1; }
.df-serie-link strong { color: var(--accent); font-weight: 600; }
.df-serie-link small { display: block; color: var(--ink-soft); margin-top: .2rem; font-size: .78rem; }

/* Trust-Box Produktseite */
.df-product-trust {
	margin: 1.5rem 0 0;
	padding: 1rem 1.2rem 1.1rem;
	border: 1px solid var(--line);
	border-left: 2px solid var(--accent);
	background: var(--surface);
	font-size: .86rem;
	line-height: 1.5;
}
.df-product-trust__title {
	display: block;
	margin-bottom: .65rem;
	color: var(--accent);
	font-size: .66rem;
	font-weight: 700;
	letter-spacing: .22em;
	text-transform: uppercase;
}
.df-product-trust__list {
	display: grid;
	gap: .55rem;
	margin: 0;
	padding: 0;
	list-style: none;
}
.df-product-trust__list li { display: grid; gap: .1rem; margin: 0; }
.df-product-trust__list strong { color: var(--ink); font-weight: 600; }
.df-product-trust__list span { color: var(--ink-soft); font-size: .8rem; }

/* Beschreibungs-Tab als ruhige Prosa-Sektion */
.woocommerce div.product .woocommerce-tabs {
	border-top: 1px solid var(--line);
	padding-top: 2.4rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
	margin: 0 0 1.4rem;
	padding: 0;
	list-style: none;
	display: flex;
	gap: 1.4rem;
	flex-wrap: wrap;
}
.woocommerce div.product .woocommerce-tabs ul.tabs:has(> li:only-child) { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: none;
	border: none;
	border-radius: 0;
	padding: 0;
	margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	color: var(--ink-soft);
	font-size: .72rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover { color: var(--accent); }
.woocommerce div.product .woocommerce-tabs .panel {
	max-width: 68ch;
	color: var(--ink-soft);
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 1.9rem;
	color: var(--ink);
	margin-bottom: 1rem;
}
.woocommerce div.product .woocommerce-tabs .panel p { margin-bottom: 1rem; font-size: .96rem; }

/* "Aehnliche Produkte" / Upsells — Karten-Optik aus Phase 3 erbt via ul.products */
.woocommerce div.product .related > h2,
.woocommerce div.product .upsells > h2 {
	font-family: var(--font-head);
	font-weight: 500;
	font-size: 1.9rem;
	color: var(--ink);
	margin-bottom: 1.6rem;
}

/* ===========================================================================
   CART / CHECKOUT (Block-basiert: wc-block-components-*)
   Erben viel aus theme.json; hier nur das Block-Spezifische auf Tokens ziehen.
   =========================================================================== */

/* Layout-Container */
.wc-block-cart,
.wc-block-checkout,
.woocommerce-cart .wp-block-woocommerce-cart,
.woocommerce-checkout .wp-block-woocommerce-checkout {
	max-width: 1280px;
	margin: 0 auto;
	color: var(--ink);
}

/* Ueberschriften in Cormorant */
.wc-block-cart h1,
.wc-block-checkout h1,
.wc-block-components-title,
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-title {
	font-family: var(--font-head);
	font-weight: 500;
	color: var(--ink);
}

/* Totals-Karte auf --surface */
.wc-block-cart__sidebar > .wc-block-components-totals-wrapper,
.wc-block-cart__sidebar .wc-block-components-sidebar,
.wp-block-woocommerce-checkout-totals-block,
.wp-block-woocommerce-cart-order-summary-block {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: 0;
	padding: 1.5rem 1.6rem;
}

/* Totals-Zeilen */
.wc-block-components-totals-item,
.wc-block-components-totals-item__label,
.wc-block-components-totals-item__value,
.wc-block-components-totals-footer-item {
	color: var(--ink);
}
.wc-block-components-totals-item__description,
.wc-block-components-totals-coupon__content { color: var(--ink-soft); }
.wc-block-components-totals-footer-item { border-top-color: var(--line); }

/* Produktnamen / Metadaten / Summen */
.wc-block-components-product-name,
.wc-block-cart-item__total,
.wc-block-components-order-summary-item__total { color: var(--ink); }
.wc-block-components-product-metadata,
.wc-block-components-order-summary-item__description { color: var(--ink-soft); }
.wc-block-components-product-name:hover { color: var(--accent); }

/* Trenner / Tabellen-Linien */
.wc-block-cart-items__row,
.wc-block-components-order-summary-item,
.wc-block-checkout__main hr,
.wc-block-components-totals-item--order-total {
	border-color: var(--line);
}

/* Eingabefelder */
.wc-block-components-text-input input,
.wc-block-components-text-input input[type="text"],
.wc-block-components-text-input input[type="email"],
.wc-block-components-text-input input[type="tel"],
.wc-block-components-select select,
.wc-block-components-textarea {
	background: var(--bg-2);
	color: var(--ink);
	border: 1px solid var(--line);
	border-radius: 2px;
}
.wc-block-components-text-input label,
.wc-block-components-checkout-step__description,
.wc-block-components-form .wc-block-components-text-input label {
	color: var(--ink-soft);
}
.wc-block-components-text-input input:focus,
.wc-block-components-select select:focus {
	border-color: var(--accent);
	outline: none;
	box-shadow: none;
}

/* Mengen-Selektor im Block-Cart */
.wc-block-components-quantity-selector {
	border: 1px solid var(--line);
	border-radius: 2px;
}
.wc-block-components-quantity-selector__input,
.wc-block-components-quantity-selector__button {
	color: var(--ink);
	background: none;
}

/* Buttons (Weiter zur Kasse / Bestellung absenden) auf Akzent */
.wc-block-components-button.contained,
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button {
	background: var(--accent);
	color: var(--accent-ink);
	border-radius: 2px;
	font-family: var(--font-body);
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	transition: background .25s var(--ease);
}
.wc-block-components-button.contained:hover,
.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover {
	background: #d4b87e;
	color: var(--accent-ink);
	opacity: 1;
}
.wc-block-components-button:not(.contained) { color: var(--accent); }

/* §19-Hinweis aus df-legal-notices — auf dunklem Grund lesbar machen.
   #df-ku-note traegt einen Inline-Style (color:#666) → !important noetig.
   Deckt JS-Injektion (#df-ku-note) und Legacy-PHP-Hooks (.df-ku-note) ab. */
#df-ku-note,
.df-ku-note,
.df-ku-note th {
	color: var(--ink-soft) !important;
	border-top-color: var(--line) !important;
}

/* ===========================================================================
   QA — Fokus-Stile
   =========================================================================== */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.chip:focus-visible,
.wc-block-components-button:focus-visible,
.woocommerce a.button:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
}

/* ===========================================================================
   RESPONSIVE
   =========================================================================== */
@media (max-width: 1000px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 920px) {
	.woocommerce div.product { grid-template-columns: 1fr; gap: 2rem; }
	.woocommerce div.product .woocommerce-product-gallery,
	.woocommerce div.product .summary { grid-column: 1; }
}
@media (max-width: 900px) {
	.trust__inner { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.topbar__inner { padding: .8rem 1.2rem; }
	.site-footer { padding-left: 1.2rem; padding-right: 1.2rem; }
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: 1fr; padding: 0 1.2rem 3rem; }
	.woocommerce-products-header,
	.filter { padding-left: 1.2rem; padding-right: 1.2rem; }
	.woocommerce .woocommerce-breadcrumb,
	.woocommerce div.product { padding-left: 1.2rem; padding-right: 1.2rem; }
}
@media (max-width: 520px) {
	.trust__inner { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
	.wc-block-cart,
	.wc-block-checkout { padding-left: 1.2rem; padding-right: 1.2rem; }
}

/* ===========================================================================
   F1 — Konsolidierung auf den klassischen Render-Pfad
   (Classic-Template-Block; woo-blocks.css entfaellt, store.css ist die Wahrheit)
   =========================================================================== */

/* Klassischer Result-Count entfaellt — die Filter-Zeile zeigt die Anzahl */
.woocommerce-result-count { display: none; }

/* Kuratierte Galerie: Sortierung vorerst aus — Reihenfolge ist Kuration.
   Reaktivieren, wenn der Katalog waechst (siehe README-TODO). */
.woocommerce-ordering { display: none; }

/* Sortier-Dropdown (klassischer Pfad) — Optik bleibt fuer die Reaktivierung */
.woocommerce-ordering { float: none; margin: 0 0 1.2rem; }
.woocommerce-ordering select.orderby {
	background: var(--bg-2);
	color: var(--ink-soft);
	border: 1px solid var(--line);
	border-radius: 2px;
	padding: .6rem 2.2rem .6rem .75rem;
	font-family: var(--font-body);
	font-size: .78rem;
}
.woocommerce-ordering select.orderby:focus { border-color: var(--accent); outline: 0; }

/* Ordering-Zeile in den 1280er-Rahmen setzen */
.woocommerce-shop form.woocommerce-ordering,
.post-type-archive-product form.woocommerce-ordering {
	max-width: 1280px;
	margin: 0 auto 1.2rem;
	padding: 0 2rem;
	display: flex;
	justify-content: flex-end;
}

/* Preis-Suffix (§19) generisch — unabhaengig vom Eltern-Markup */
.woocommerce-price-suffix {
	display: block;
	font-family: var(--font-body);
	font-weight: 400;
	font-size: .68rem;
	letter-spacing: .04em;
	text-transform: none;
	color: var(--ink-soft);
	margin-top: .35rem;
}

/* Eyebrow ueber dem Produkttitel (klassischer Pfad) */
.woocommerce div.product .product_title::before {
	content: "Content-Paket";
	display: block;
	margin-bottom: .5rem;
	font-family: var(--font-body);
	font-size: .66rem;
	font-weight: 600;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--accent);
}

/* Lange Titel nicht hart umbrechen */
.woocommerce div.product .product_title,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	overflow-wrap: normal;
	word-break: normal;
	hyphens: manual;
}

/* Premium+-Eckbadge (functions.php, woocommerce_before_shop_loop_item_title) */
.woocommerce ul.products li.product { position: relative; }
.df-card-badge {
	position: absolute;
	top: .9rem;
	right: .9rem;
	z-index: 2;
	padding: .32em .95em;
	border: 1px solid var(--accent);
	border-radius: 999px;
	background: rgba(13, 11, 10, .78);
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	color: var(--accent);
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	pointer-events: none;
}

/* ===========================================================================
   QA — Reduzierte Bewegung
   =========================================================================== */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		transition: none !important;
		animation: none !important;
		scroll-behavior: auto !important;
	}
}
