/*
Theme Name: extragroup Shop
Version: 1.0
Description: IFrame-optimiertes WooCommerce-Theme für shop.extragroup.de. Kein Header, kein Footer – für Einbettung per IFrame in p696832.webspaceconfig.de.
Author: extragroup GmbH
Text Domain: extragroup-shop
*/

/* ============================================================
   CSS-Variablen (Design-System passend zu p696832.webspaceconfig.de)
   ============================================================ */
:root {
    --color-primary:      #190023;
    --color-accent:       rgb(216, 59, 62);
    --color-accent-dark:  rgb(197, 54, 56);
    --color-bg:           #f4f3ee;
    --color-white:        #ffffff;
    --color-text:         #1a1a1a;
    --color-text-muted:   #6b6b6b;
    --color-border:       #e0ddd6;
    --color-btn:          #32373c;
    --color-btn-hover:    #1a1e22;
    --font-sans:          -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --radius-sm:          4px;
    --radius-md:          8px;
    --radius-lg:          16px;
    --radius-pill:        9999px;
    --max-width:          1140px;
    --spacing-xs:         0.5rem;
    --spacing-sm:         1rem;
    --spacing-md:         1.5rem;
    --spacing-lg:         2.5rem;
    --spacing-xl:         4rem;
}

/* ============================================================
   Reset & Box-Sizing
   ============================================================ */
*, *::before, *::after {
    box-sizing: border-box;
}

html, body {
    margin: 0;
    padding: 0;
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: 18px;
    line-height: 1.6;
    -webkit-text-size-adjust: 100%;
}

/* IFrame-spezifisch: kein horizontaler Overflow */
body {
    overflow-x: hidden;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: var(--color-accent);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

/* ============================================================
   Layout
   ============================================================ */
#page {
    width: 100%;
}

#main.site-main {
    padding: var(--spacing-lg) var(--spacing-sm);
}

.container,
.site-main > * {
    max-width: var(--max-width);
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}

/* ============================================================
   Typografie
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-sans);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-primary);
    margin-top: 0;
    margin-bottom: var(--spacing-sm);
}

h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.75rem, 4vw, 2.625rem); }
h3 { font-size: clamp(1.375rem, 3vw, 2rem); }
h4 { font-size: clamp(1.125rem, 2.5vw, 1.5rem); }
h5 { font-size: 1.25rem; }
h6 { font-size: 1.125rem; }

p {
    margin-top: 0;
    margin-bottom: var(--spacing-sm);
}

/* ============================================================
   Buttons
   ============================================================ */
.button,
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
a.button {
    display: inline-block;
    background: var(--color-btn);
    color: var(--color-white) !important;
    border: none;
    border-radius: var(--radius-pill);
    padding: 0.75em 1.75em;
    font-size: 1rem;
    font-family: var(--font-sans);
    font-weight: 600;
    cursor: pointer;
    text-decoration: none !important;
    transition: background 0.2s ease;
    line-height: 1.4;
    vertical-align: middle;
}

.button:hover,
button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
a.button:hover {
    background: var(--color-btn-hover);
    text-decoration: none !important;
}

/* Primär-Button (Akzentfarbe) */
.button.alt,
.button.wc-forward,
.single_add_to_cart_button,
.checkout-button,
#place_order {
    background: var(--color-accent) !important;
    color: var(--color-white) !important;
}

.button.alt:hover,
.button.wc-forward:hover,
.single_add_to_cart_button:hover,
.checkout-button:hover,
#place_order:hover {
    background: var(--color-accent-dark) !important;
}

/* ============================================================
   Formulare
   ============================================================ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="search"],
textarea,
select {
    width: 100%;
    padding: 0.65em 1em;
    font-size: 1rem;
    font-family: var(--font-sans);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-white);
    color: var(--color-text);
    transition: border-color 0.2s ease;
    appearance: none;
}

input:focus,
textarea:focus,
select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(25, 0, 35, 0.1);
}

label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.35em;
    font-size: 0.9rem;
}

/* ============================================================
   WooCommerce — Allgemein
   ============================================================ */

/* Woo-Breadcrumbs ausblenden (unnötig im IFrame) */
.woocommerce-breadcrumb {
    display: none !important;
}

/* Resultate-Zahl ausblenden */
.woocommerce-result-count {
    display: none;
}

/* Woo-Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 0.95rem;
}

.woocommerce-message {
    background: #d4edda;
    border-left: 4px solid #28a745;
    color: #155724;
}

.woocommerce-info {
    background: #d1ecf1;
    border-left: 4px solid #17a2b8;
    color: #0c5460;
}

.woocommerce-error {
    background: #f8d7da;
    border-left: 4px solid var(--color-accent);
    color: #721c24;
    list-style: none;
    padding-left: var(--spacing-md);
}

/* ============================================================
   WooCommerce — Produktliste (Kategorie/Archiv + Ähnliche Produkte)
   ============================================================ */

/* Seiten-Titel der Shop-Archiv-Seite */
.woocommerce-products-header__title {
    font-size: clamp(1.75rem, 3vw, 2.625rem);
    color: var(--color-primary);
    margin-bottom: var(--spacing-lg);
}

/* Produkt-Grid — WooCommerce columns-* Klassen komplett überschreiben */
ul.products,
ul.products.columns-1,
ul.products.columns-2,
ul.products.columns-3,
ul.products.columns-4,
ul.products.columns-5,
ul.products.columns-6 {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 var(--spacing-xl) !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 1.5rem !important;
    /* WooCommerce float-Layout zurücksetzen */
    float: none !important;
    clear: both !important;
    width: 100% !important;
}

@media (max-width: 900px) {
    ul.products,
    ul.products.columns-1,
    ul.products.columns-2,
    ul.products.columns-3,
    ul.products.columns-4,
    ul.products.columns-5,
    ul.products.columns-6 {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 580px) {
    ul.products,
    ul.products.columns-1,
    ul.products.columns-2,
    ul.products.columns-3,
    ul.products.columns-4,
    ul.products.columns-5,
    ul.products.columns-6 {
        grid-template-columns: 1fr !important;
    }
}

/* Produktkarte — WooCommerce float/width zurücksetzen */
ul.products li.product {
    background: var(--color-white) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    transition: box-shadow 0.2s ease, transform 0.2s ease !important;
    /* WooCommerce float/width überschreiben */
    float: none !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    clear: none !important;
}

ul.products li.product:hover {
    box-shadow: 0 8px 24px rgba(25, 0, 35, 0.1);
    transform: translateY(-2px);
}

ul.products li.product a {
    text-decoration: none;
    color: inherit;
}

ul.products li.product img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
}

ul.products li.product .woocommerce-loop-product__link {
    display: block;
    text-decoration: none;
    color: inherit;
}

ul.products li.product .woocommerce-loop-product__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-primary);
    padding: var(--spacing-sm) var(--spacing-sm) 0.25rem;
    margin: 0;
}

ul.products li.product .price {
    padding: 0 var(--spacing-sm) 0.5rem;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-accent);
    display: block;
}

ul.products li.product .price del {
    color: var(--color-text-muted);
    font-weight: 400;
    font-size: 0.9em;
    margin-right: 0.4em;
}

/* "Ähnliche Produkte" und "Upsell"-Sektion */
.related.products,
.upsells.products {
    grid-column: 1 / -1;
    margin-top: var(--spacing-xl);
}

.related.products > h2,
.upsells.products > h2 {
    font-size: clamp(1.375rem, 2.5vw, 1.75rem);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-xs);
    border-bottom: 2px solid var(--color-border);
}

/* Button in Produktkarte */
ul.products li.product .button,
ul.products li.product .add_to_cart_button {
    display: block;
    margin: auto var(--spacing-sm) var(--spacing-sm);
    text-align: center;
    width: calc(100% - 2 * var(--spacing-sm));
}

/* ============================================================
   WooCommerce — Einzelprodukt
   ============================================================ */
.woocommerce div.product {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    align-items: start;
    margin-bottom: var(--spacing-xl);
}

/* Ähnliche Produkte + Tabs über volle Breite */
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related.products,
.woocommerce div.product .upsells.products {
    grid-column: 1 / -1;
}

@media (max-width: 700px) {
    .woocommerce div.product {
        grid-template-columns: 1fr;
    }
}

/* Produktbild (linke Spalte) */
.woocommerce div.product .woocommerce-product-gallery {
    position: sticky;
    top: 1rem;
}

.woocommerce div.product .woocommerce-product-gallery__image img {
    border-radius: var(--radius-lg);
    width: 100%;
}

/* Produkt-Info (rechte Spalte) */
.woocommerce div.product .summary {
    padding: 0;
}

.woocommerce div.product .summary .product_title {
    font-size: clamp(1.5rem, 3.5vw, 2.25rem);
    margin-bottom: var(--spacing-sm);
}

.woocommerce div.product .summary .price {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-accent);
    margin-bottom: var(--spacing-md);
}

.woocommerce div.product .summary .price del {
    font-size: 1.2rem;
    color: var(--color-text-muted);
    font-weight: 400;
}

/* Kurzbeschreibung */
.woocommerce div.product .woocommerce-product-details__short-description {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
    font-size: 1rem;
}

/* Variationen-Tabelle (z.B. "Kundenart") */
.woocommerce div.product .variations {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--spacing-md);
    table-layout: fixed;
}

.woocommerce div.product .variations th,
.woocommerce div.product .variations td {
    padding: 0.5rem 0;
    text-align: left;
    vertical-align: middle;
}

.woocommerce div.product .variations th.label {
    width: 8rem;
    font-weight: 600;
    color: var(--color-primary);
    white-space: nowrap;
    padding-right: 1rem;
}

.woocommerce div.product .variations td.value {
    width: auto;
}

/* Select-Feld volle Breite, kein Abschneiden */
.woocommerce div.product .variations td.value select,
.woocommerce div.product table.variations select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    min-width: 200px;
    padding: 0.6em 2em 0.6em 0.8em;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-white);
    color: var(--color-text);
    font-size: 1rem;
    appearance: none;
    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 fill='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.8em center;
    cursor: pointer;
}

.woocommerce div.product .variations td.value select:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(25, 0, 35, 0.1);
}

/* Reset-Link "Optionen löschen" */
.woocommerce div.product .reset_variations {
    display: inline-block;
    margin-top: 0.4rem;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    text-decoration: underline;
}

/* In den Warenkorb */
.woocommerce div.product form.cart {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-lg);
}

.woocommerce div.product form.cart .qty {
    width: 80px;
    text-align: center;
    padding: 0.6em;
    border-radius: var(--radius-md);
}

.woocommerce div.product form.cart .single_add_to_cart_button {
    flex: 1;
    min-width: 200px;
    text-align: center;
    font-size: 1.1rem;
    padding: 0.8em 2em;
}

/* Produkt-Tabs */
.woocommerce-tabs {
    grid-column: 1 / -1;
    border-top: 1px solid var(--color-border);
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
}

.woocommerce-tabs ul.tabs {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-md);
    display: flex;
    gap: 0.5rem;
    border-bottom: 2px solid var(--color-border);
}

.woocommerce-tabs ul.tabs li {
    margin: 0;
}

.woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 0.6em 1.2em;
    font-weight: 600;
    color: var(--color-text-muted);
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    text-decoration: none;
    transition: color 0.2s, border-color 0.2s;
}

.woocommerce-tabs ul.tabs li.active a {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.woocommerce-tabs .panel {
    padding: var(--spacing-md) 0;
}

/* ============================================================
   WooCommerce — Warenkorb
   ============================================================ */
.woocommerce-cart table.cart {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--spacing-lg);
}

.woocommerce-cart table.cart th,
.woocommerce-cart table.cart td {
    padding: 0.85rem var(--spacing-sm);
    text-align: left;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}

.woocommerce-cart table.cart th {
    background: var(--color-bg);
    font-weight: 700;
    color: var(--color-primary);
}

.woocommerce-cart .cart-collaterals {
    margin-top: var(--spacing-lg);
}

.woocommerce-cart .cart_totals h2 {
    font-size: 1.5rem;
    margin-bottom: var(--spacing-sm);
}

.woocommerce-cart .cart_totals table {
    width: 100%;
    border-collapse: collapse;
}

.woocommerce-cart .cart_totals table tr {
    border-bottom: 1px solid var(--color-border);
}

.woocommerce-cart .cart_totals table td,
.woocommerce-cart .cart_totals table th {
    padding: 0.65rem;
}

.woocommerce-cart .cart_totals table .order-total th,
.woocommerce-cart .cart_totals table .order-total td {
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--color-primary);
}

/* ============================================================
   WooCommerce — Checkout
   ============================================================ */
.woocommerce-checkout #customer_details {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

@media (max-width: 700px) {
    .woocommerce-checkout #customer_details {
        grid-template-columns: 1fr;
    }
}

.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout h3#order_review_heading {
    font-size: 1.375rem;
    margin-bottom: var(--spacing-md);
    color: var(--color-primary);
}

.woocommerce-checkout .woocommerce-checkout-review-order {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.woocommerce form .form-row {
    margin-bottom: var(--spacing-sm);
}

.woocommerce form .form-row label {
    display: block;
    margin-bottom: 0.35em;
    font-weight: 600;
    font-size: 0.9rem;
}

.woocommerce form .form-row .required {
    color: var(--color-accent);
}

/* Bezahlmethoden */
.woocommerce-checkout #payment {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

#place_order {
    width: 100%;
    font-size: 1.15rem;
    padding: 1em 2em;
}

/* ============================================================
   WooCommerce — Mein Konto
   ============================================================ */
.woocommerce-account .woocommerce-MyAccount-navigation {
    float: none;
    width: 100%;
    margin-bottom: var(--spacing-md);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation li a {
    display: inline-block;
    padding: 0.5em 1em;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    color: var(--color-text);
    font-size: 0.9rem;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
    background: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
}

/* ============================================================
   Seiten (page.php / index.php Fallback)
   ============================================================ */
.entry-content {
    max-width: var(--max-width);
    margin: 0 auto;
}

.entry-content h1 {
    margin-bottom: var(--spacing-lg);
    border-bottom: 3px solid var(--color-accent);
    padding-bottom: var(--spacing-sm);
    display: inline-block;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 768px) {
    #main.site-main {
        padding: var(--spacing-md) var(--spacing-xs);
    }
}
