/**
 * CarGirlSociety - WooCommerce + Germanized Styling
 *
 * Alle Selektoren nutzen die Theme-Design-Tokens (--cgs-c-*), die sich
 * automatisch an Dark/Light-Mode anpassen.
 */

/* ==========================================================================
   Shop-Wrapper
   ========================================================================== */

.cgs-wc-wrapper {
	/* padding-block: clamp(2rem, 5vw, 4rem); */
}

/* Shop-Header */
.woocommerce-products-header__title.page-title {
	font-family: var(--cgs-font-display);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	margin-block: 0 0.5rem;
}

.woocommerce-result-count {
	color: var(--cgs-c-text-muted);
	font-size: 0.875rem;
}

.woocommerce-ordering select {
	min-width: 220px;
}

/* ==========================================================================
   Produkt-Grid
   ========================================================================== */

.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid;
	grid-template-columns: repeat(var(--cgs-shop-cols, 3), minmax(0, 1fr));
	gap: clamp(1rem, 2.5vw, 2rem);
	margin: 0;
	padding: 0;
	list-style: none;
}
@media (max-width: 1024px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (max-width: 560px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: 1fr;
	}
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	position: relative;
	background: var(--cgs-c-bg-elevated);
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-lg);
	padding: 1rem;
	margin: 0;
	width: auto !important;
	float: none !important;
	transition: transform var(--cgs-dur) var(--cgs-ease),
	            border-color var(--cgs-dur) var(--cgs-ease),
	            box-shadow var(--cgs-dur) var(--cgs-ease);
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-3px);
	border-color: var(--cgs-c-border-hover);
	box-shadow: var(--cgs-shadow-md);
}

.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
	border-radius: var(--cgs-radius-md);
	background: var(--cgs-c-bg-overlay);
	margin-bottom: 1rem;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--cgs-font-display);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--cgs-c-text);
	padding: 0;
	margin: 0 0 0.25rem;
	line-height: 1.3;
}

.woocommerce ul.products li.product .price {
	color: var(--cgs-c-primary);
	font-weight: 700;
	font-size: 1.125rem;
	margin: 0.5rem 0;
}

.woocommerce ul.products li.product .price del {
	color: var(--cgs-c-text-faint);
	font-weight: 400;
	font-size: 0.9rem;
	margin-right: 0.375rem;
}
.woocommerce ul.products li.product .price ins {
	background: transparent;
	text-decoration: none;
	color: var(--cgs-c-accent);
	font-weight: 800;
}

/* Sale-Badge */
.woocommerce span.onsale,
.cgs-onsale {
	position: absolute;
	top: 1rem;
	left: 1rem;
	background: linear-gradient(135deg, var(--cgs-c-primary), var(--cgs-c-accent));
	color: #fff;
	border: 0;
	border-radius: var(--cgs-radius-pill);
	font-family: var(--cgs-font-body);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	padding: 0.25rem 0.625rem;
	min-height: 0;
	line-height: 1.4;
	margin: 0;
	box-shadow: var(--cgs-shadow-sm);
	z-index: 2;
}

/* Attribute-Swatches (Sticker-Farbvarianten) */
.woocommerce ul.products li.product .variations {
	display: flex;
	flex-wrap: wrap;
	gap: 0.375rem;
	margin-top: 0.75rem;
}
.woocommerce ul.products li.product .variations .variation-chip {
	padding: 0.25rem 0.625rem;
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-pill);
	font-size: 0.75rem;
	color: var(--cgs-c-text-muted);
}

/* Add-to-cart Button in Loop */
.woocommerce ul.products li.product .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	background: var(--cgs-c-primary) !important;
	color: #fff !important;
	border: 0;
	border-radius: var(--cgs-radius-pill);
	padding: 0.625rem 1.25rem;
	font-weight: 600;
	font-size: 0.875rem;
	letter-spacing: 0.02em;
	transition: background var(--cgs-dur) var(--cgs-ease),
	            box-shadow var(--cgs-dur) var(--cgs-ease);
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .button:focus-visible {
	background: var(--cgs-c-primary-hover) !important;
	box-shadow: var(--cgs-glow);
}
.woocommerce ul.products li.product .added_to_cart {
	display: inline-block;
	margin-top: 0.375rem;
	font-size: 0.8125rem;
	color: var(--cgs-c-success);
}

.woocommerce .product-category mark.count {
    color: var(--wp--preset--color--text);
}

/* ==========================================================================
   Einzelprodukt
   ========================================================================== */

.woocommerce div.product {
	display: grid;
	grid-template-columns: auto;
	gap: clamp(1.5rem, 4vw, 3.5rem);
}
@media (max-width: 880px) {
	.woocommerce div.product {
		grid-template-columns: 1fr;
	}
}

.woocommerce div.product div.images,
.woocommerce div.product div.summary {
	width: auto !important;
	float: none !important;
	margin: 0 !important;
}

.woocommerce div.product .woocommerce-product-gallery__image img {
	border-radius: var(--cgs-radius-lg);
	background: var(--cgs-c-bg-elevated);
}

.woocommerce div.product .product_title {
	font-family: var(--cgs-font-display);
	font-weight: 700;
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	letter-spacing: -0.02em;
	margin-bottom: 0.75rem;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--cgs-c-primary);
	font-weight: 700;
	font-size: 1.75rem;
}

.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--cgs-c-text-muted);
	margin-block: 1rem;
	line-height: 1.7;
}

/* Quantity + Add to Cart */
.woocommerce div.product form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
	margin-block: 1.5rem;
}
.woocommerce .quantity {
	display: inline-flex;
	align-items: center;
	background: var(--cgs-c-input-bg);
	border: 1.5px solid var(--cgs-c-input-border);
	border-radius: var(--cgs-radius-pill);
	overflow: hidden;
}
.woocommerce .quantity input.qty {
	width: 72px;
	text-align: center;
	background: transparent;
	border: 0;
	padding: 0.625rem 0.5rem;
}
.woocommerce .quantity input.qty:focus {
	box-shadow: none;
}

.woocommerce div.product form.cart .button,
.woocommerce div.product .single_add_to_cart_button {
	background: linear-gradient(135deg, var(--cgs-c-primary), var(--cgs-c-accent)) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: var(--cgs-radius-pill);
	padding: 0.9rem 2rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	box-shadow: var(--cgs-shadow-sm);
}
.woocommerce div.product .single_add_to_cart_button:hover {
	filter: brightness(1.08);
	box-shadow: var(--cgs-glow);
}

/* Variation-Select */
.woocommerce .variations td {
	background: transparent !important;
	border: 0 !important;
	padding: 0.5rem 0 !important;
}
.woocommerce .variations label {
	font-weight: 600;
}
.woocommerce .reset_variations {
	margin-left: 0.5rem;
	font-size: 0.8125rem;
	color: var(--cgs-c-text-faint);
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	border: 0;
	padding: 0;
	margin: 2rem 0 1rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
	display: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent;
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-pill);
	padding: 0;
	margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: inline-block;
	padding: 0.5rem 1.125rem;
	color: var(--cgs-c-text-muted);
	font-size: 0.875rem;
	font-weight: 500;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	background: var(--cgs-c-primary);
	border-color: var(--cgs-c-primary);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: #fff;
}

.woocommerce div.product .woocommerce-tabs .panel {
	margin: 1rem 0 2rem;
	padding: 1.5rem;
	background: var(--cgs-c-bg-elevated);
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-md);
}

/* ==========================================================================
   Germanized-Elemente
   ========================================================================== */

/* Lieferzeit + Versandkosten */
.cgs-gzd,
.wc-gzd-additional-info {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	color: var(--cgs-c-text-muted);
	font-size: 0.8125rem;
}
.cgs-gzd__delivery::before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--cgs-c-success);
	box-shadow: 0 0 6px var(--cgs-c-success);
}
.cgs-gzd__shipping {
	color: var(--cgs-c-text-faint);
}
.cgs-gzd__unit {
	color: var(--cgs-c-text-faint);
	font-size: 0.75rem;
}

.price-unit-container .price-unit {
	color: var(--cgs-c-text-faint);
	font-size: 0.8125rem;
}

.wc-gzd-additional-info {
	display: block;
	margin-top: 0.25rem;
}

/* AGB-/Widerrufs-Checkboxen im Checkout */
.cgs-has-gzd .wc-gzd-checkbox-placeholder,
.cgs-has-gzd .woocommerce-terms-and-conditions-wrapper,
.cgs-has-gzd .wc-gzd-legal-checkboxes {
	padding: 1rem 1.25rem;
	background: var(--cgs-c-bg-overlay);
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-md);
	margin-block: 0.75rem;
}

.cgs-has-gzd .form-row.form-row-checkbox label,
.cgs-has-gzd .wc-terms-and-conditions label {
	display: flex;
	align-items: flex-start;
	gap: 0.625rem;
	font-size: 0.875rem;
	line-height: 1.5;
	color: var(--cgs-c-text);
	cursor: pointer;
}

.cgs-has-gzd input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	border: 1.5px solid var(--cgs-c-input-border);
	border-radius: 4px;
	background: var(--cgs-c-input-bg);
	margin-top: 2px;
	cursor: pointer;
	transition: background var(--cgs-dur) var(--cgs-ease),
	            border-color var(--cgs-dur) var(--cgs-ease);
	position: relative;
}
.cgs-has-gzd input[type="checkbox"]:checked {
	background: var(--cgs-c-primary);
	border-color: var(--cgs-c-primary);
}
.cgs-has-gzd input[type="checkbox"]:checked::after {
	content: "";
	position: absolute;
	left: 5px;
	top: 1px;
	width: 5px;
	height: 10px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}
.cgs-has-gzd input[type="checkbox"]:focus-visible {
	outline: 2px solid var(--cgs-c-primary);
	outline-offset: 2px;
}

/* MwSt-Hinweis im Cart */
.woocommerce .cart-subtotal,
.woocommerce .shipping-total,
.woocommerce .order-total {
	font-size: 0.9375rem;
}
.woocommerce .order-total {
	font-weight: 700;
	font-size: 1.0625rem;
}
.tax_label,
.includes_tax,
.amount + small,
.woocommerce-Price-taxLabel {
	color: var(--cgs-c-text-faint);
	font-size: 0.75rem;
	margin-left: 0.25rem;
}

/* ==========================================================================
   Cart
   ========================================================================== */

.woocommerce-cart table.shop_table,
.woocommerce table.shop_table {
	background: var(--cgs-c-bg-elevated);
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-lg);
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
	width: 100%;
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	padding: 1rem;
	border-top: 1px solid var(--cgs-c-border);
	background: transparent;
}
.woocommerce table.shop_table thead th {
	border-top: 0;
	background: var(--cgs-c-bg-overlay);
	color: var(--cgs-c-text-muted);
	font-weight: 600;
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.woocommerce-cart .cart-collaterals .cart_totals {
	background: var(--cgs-c-bg-elevated);
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-lg);
	padding: 1.5rem;
}
.woocommerce-cart .cart_totals h2 {
	font-family: var(--cgs-font-display);
	font-size: 1.25rem;
	margin-top: 0;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	display: block;
	text-align: center;
	background: linear-gradient(135deg, var(--cgs-c-primary), var(--cgs-c-accent)) !important;
	color: #fff !important;
	padding: 1rem 1.5rem;
	border-radius: var(--cgs-radius-pill);
	font-weight: 700;
	text-transform: none;
	letter-spacing: 0.02em;
	border: 0;
}

/* Coupon */
.woocommerce-cart form.woocommerce-cart-form .coupon {
	display: flex;
	gap: 0.5rem;
}
.woocommerce-cart form.woocommerce-cart-form .coupon input.input-text {
	max-width: 220px;
}

/* ==========================================================================
   Checkout
   ========================================================================== */

.woocommerce-checkout .col-1,
.woocommerce-checkout .col-2 {
	float: none !important;
	width: auto !important;
}
.woocommerce-checkout form.checkout {
	display: grid;
	grid-template-columns: unset;
	gap: clamp(1.5rem, 4vw, 3rem);
}
@media (max-width: 880px) {
	.woocommerce-checkout form.checkout {
		grid-template-columns: 1fr;
	}
}
.woocommerce-checkout #customer_details {
	grid-column: 1;
}
.woocommerce-checkout #order_review,
.woocommerce-checkout #order_review_heading {
	grid-column: 2;
}
@media (max-width: 880px) {
	.woocommerce-checkout #customer_details,
	.woocommerce-checkout #order_review,
	.woocommerce-checkout #order_review_heading {
		grid-column: 1;
	}
}

.woocommerce-checkout h3,
.woocommerce-checkout h2 {
	font-family: var(--cgs-font-display);
	font-weight: 700;
	margin-top: 0;
}

.woocommerce-checkout .form-row {
	margin-block: 0.75rem;
}
.woocommerce-checkout #order_review {
	background: var(--cgs-c-bg-elevated);
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-lg);
	padding: 1.5rem;
	position: sticky;
	top: 100px;
	align-self: start;
}

.woocommerce-checkout #place_order {
	width: 100%;
	background: linear-gradient(135deg, var(--cgs-c-primary), var(--cgs-c-accent)) !important;
	color: #fff !important;
	padding: 1rem 1.5rem;
	border: 0;
	border-radius: var(--cgs-radius-pill);
	font-weight: 700;
	letter-spacing: 0.02em;
	box-shadow: var(--cgs-shadow-sm);
	margin-top: 0.5rem;
}
.woocommerce-checkout #place_order:hover {
	filter: brightness(1.08);
	box-shadow: var(--cgs-glow);
}

/* Zahlungsarten */
.woocommerce-checkout #payment {
	background: transparent;
	border-radius: 0;
}
.woocommerce-checkout #payment ul.payment_methods {
	background: var(--cgs-c-bg-overlay);
	border: 1px solid var(--cgs-c-border);
	border-radius: var(--cgs-radius-md);
	padding: 1rem;
	list-style: none;
	margin: 0;
}
.woocommerce-checkout #payment ul.payment_methods li {
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--cgs-c-border);
}
.woocommerce-checkout #payment ul.payment_methods li:last-child {
	border-bottom: 0;
}
.woocommerce-checkout #payment div.payment_box {
	background: var(--cgs-c-bg-elevated);
	border-radius: var(--cgs-radius-md);
	color: var(--cgs-c-text-muted);
	padding: 0.875rem 1rem;
	margin-top: 0.5rem;
	font-size: 0.875rem;
}
.woocommerce-checkout #payment div.payment_box::before {
	display: none;
}

.woocommerce-account .wp-block-post-title, .woocommerce-account main .woocommerce, .woocommerce-cart .wp-block-post-title, .woocommerce-cart main .woocommerce, .woocommerce-checkout .wp-block-post-title, .woocommerce-checkout main .woocommerce {
    max-width: 1400px;
}

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

.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notice {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 1rem 1.25rem;
	border-radius: var(--cgs-radius-md);
	border: 1px solid var(--cgs-c-border);
	background: var(--cgs-c-bg-elevated);
	color: var(--cgs-c-text);
	margin-block: 1rem;
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
	display: none;
}
.woocommerce-message {
	border-left: 3px solid var(--cgs-c-success);
}
.woocommerce-error {
	border-left: 3px solid var(--cgs-c-error);
	color: var(--cgs-c-error);
}
.woocommerce-info {
	border-left: 3px solid var(--cgs-c-primary);
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.woocommerce nav.woocommerce-pagination ul {
	display: inline-flex;
	gap: 0.375rem;
	border: 0;
}
.woocommerce nav.woocommerce-pagination ul li {
	border: 0;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-grid;
	place-items: center;
	min-width: 40px;
	height: 40px;
	padding: 0 0.75rem;
	border-radius: var(--cgs-radius-pill);
	background: var(--cgs-c-bg-elevated);
	border: 1px solid var(--cgs-c-border);
	color: var(--cgs-c-text);
	font-weight: 500;
	font-size: 0.875rem;
}
.woocommerce nav.woocommerce-pagination ul li a:hover {
	border-color: var(--cgs-c-primary);
	color: var(--cgs-c-primary);
}
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--cgs-c-primary);
	border-color: var(--cgs-c-primary);
	color: #fff;
}

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

.cgs-breadcrumbs,
.woocommerce-breadcrumb {
	color: var(--cgs-c-text-muted);
	font-size: 0.8125rem;
	margin-block: 1rem 1.5rem;
}
.cgs-breadcrumbs a,
.woocommerce-breadcrumb a {
	color: var(--cgs-c-text-muted);
}
.cgs-breadcrumbs a:hover,
.woocommerce-breadcrumb a:hover {
	color: var(--cgs-c-primary);
}
.cgs-breadcrumb-sep {
	margin-inline: 0.5rem;
	color: var(--cgs-c-text-faint);
}

/* ==========================================================================
   Mini-Cart / Cart-Item Image
   ==========================================================================
   WooCommerce rendert fuer Produkte, die nicht im Katalog sichtbar sind,
   ein zusaetzliches unverlinktes <img> direkt neben dem verlinkten <img>.
   Zur Laufzeit setzt die Interactivity-API das jeweils nicht passende
   Element per [hidden]. Einige Core-/Plugin-Regeln ueberschreiben
   [hidden] mit display: block, wodurch beide Bilder sichtbar sind.
*/
.wc-block-cart-item__image > img[hidden],
.wc-block-mini-cart-items .wc-block-cart-item__image > img[hidden],
.wc-block-cart-item__image a[hidden] {
	display: none !important;
}

.wc-block-cart-item__image {
	position: relative;
	width: 64px;
	min-width: 64px;
}
.wc-block-cart-item__image > img,
.wc-block-cart-item__image > a {
	display: block;
	width: 100%;
	height: auto;
}
.wc-block-cart-item__image > a > img {
	display: block;
	width: 100%;
	height: auto;
}
