/*
Theme Name: TT5 GuterStoff
Theme URI: 
Author: GuterStoff fair organic basics
Author URI: 
Description: The GuterStoff child of twenty twenty-five theme
Requires at least: 6.9
Tested up to: 6.9
Requires PHP: 5.7
Version: 4.7 (spacer stuff line 107 to 117 added)
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Template: twentytwentyfive
Text Domain: tt5-guterstoff
*/

/* ==========================================================================
   1. GLOBAL & HEADER
   ========================================================================== */

html {
    scroll-behavior: smooth;
    scroll-padding-top: 120px; /* Hier die Höhe Ihres Menüs eintragen */
}

strong, b { font-weight: 800 !important; }

.wp-block-group.is-position-sticky {
    background-color: var(--wp--preset--color--base);
    z-index: 1000;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.05);
    max-width: 100% !important;
}

.wp-block-group.is-nowrap.is-layout-flex {
    box-sizing: border-box !important;
    padding-right: 1rem !important; 
    padding-left: 1rem !important;
}

@media (min-width: 600px) {
    .wp-block-group.is-nowrap.is-layout-flex {
        padding-right: 3.5rem !important;
        padding-left: var(--wp--preset--spacing--30) !important;
    }
}

.wp-block-site-logo img {
    width: 100% !important; 
    max-width: 304px !important;
    height: auto !important;
    display: block;
}


/* ==========================================================================
   2. NAVIGATION & MODAL
   ========================================================================== */

.wp-block-navigation__responsive-container.is-menu-open {
    background-color: var(--wp--preset--color--base) !important;
    padding: 100px 2rem 2rem 2rem !important;
    z-index: 10000 !important;
}

.wp-block-navigation__responsive-container-open,
.wp-block-navigation .wp-block-navigation__responsive-container-close {
    width: 44px !important;
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important; 
    border: 0 !important; 
    border-radius: 8px !important;
    transition: all 0.2s ease-in-out !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container-close {
    position: fixed !important; 
    left: 2rem !important;
    top: 2rem !important;
    z-index: 10001 !important;
    background-color: var(--wp--preset--color--base) !important;
}

@media (min-width: 782px) {
    .wp-block-navigation__responsive-container-content {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important; 
        gap: 0 4rem !important;
        max-width: 1000px;
        align-items: start;
    }
    .wp-block-navigation__responsive-container-content .wp-block-spacer { display: none !important; }
}

.wp-block-navigation__container.is-responsive {
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    /* Reduced gap for tighter mobile layout */
    gap: 0.8rem !important; 
    align-items: flex-start !important;
}

/* Force menu spacers to a small, consistent height on mobile */
.wp-block-navigation__responsive-container-content .wp-block-spacer {
    height: 20px !important; /* Adjust this to your preferred gap size */
}

/* On desktop, we keep them hidden as they are redundant to the grid gap */
@media (min-width: 782px) {
    .wp-block-navigation__responsive-container-content .wp-block-spacer { 
        display: none !important; 
    }
}

/* Mobile-specific font weight for menu items */
@media (max-width: 781px) {
    .wp-block-navigation-item__content {
        font-weight: 500 !important;
    }
}

/* ==========================================================================
   3. CONTACT FORM 7
   ========================================================================== */

.wpcf7 label { display: block; margin-bottom: 0.25rem; font-weight: 500; }
.wpcf7 p { margin-bottom: 1rem; }

.wpcf7 input:not([type="submit"]):not([type="checkbox"]),
.wpcf7 textarea,
.wpcf7 select {
    width: 100%;
    padding: 0.85rem 1rem; 
    border: 1px solid var(--wp--preset--color--accent-4);
    border-radius: 8px;
    background-color: var(--wp--preset--color--base);
    color: var(--wp--preset--color--contrast);
    font-family: inherit;
    font-size: var(--wp--preset--font-size--medium, 1rem);
    box-sizing: border-box;
}

.wpcf7-acceptance label {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px;
    cursor: pointer;
}

.wpcf7-acceptance input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    flex-shrink: 0 !important;
    margin: 3px 0 0 0 !important;
    cursor: pointer;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem; 
    margin-bottom: 1rem; 
}

.form-grid br { display: none; }

form.sent div.wpcf7-response-output {
    background-color: #f0fdf4;
    border-color: var(--wp--preset--color--success) !important;
    color: #15803d; 
}

span.wpcf7-not-valid-tip {
    font-size: 0.85rem;
    color: var(--wp--preset--color--alert);
    margin-top: 0.25rem;
    display: block;
    font-weight: 500;
}

/* ==========================================================================
   4. GLOBAL BUTTONS
   ========================================================================== */

.wp-block-button__link,
.woocommerce a.button,
.woocommerce button.button,
.wp-block-search__button,
.wc-block-product-filters__apply,
.wc-block-product-filters__open-overlay,
.wpcf7-submit,
.wpcf7-file {
    background-color: transparent !important;
    border: 1px solid var(--wp--preset--color--accent-5) !important;
    color: var(--wp--preset--color--accent-5) !important;
    border-radius: 8px !important;
    font-weight: 500 !important;
    transition: all 0.2s ease-in-out !important;
    padding: 0.7rem 1.5rem !important;
    line-height: 1.4 !important;
    cursor: pointer;
}

.wp-block-button__link:hover, .woocommerce a.button:hover, .woocommerce button.button:hover,
.wpcf7-submit:hover, .wpcf7-file:hover {
    background-color: var(--wp--preset--color--accent-1) !important;
    border-color: var(--wp--preset--color--contrast) !important;
    color: var(--wp--preset--color--contrast) !important;
    transform: translateY(-1px);
}

/* ==========================================================================
   5. COMPONENTS & WOOCOMMERCE
   ========================================================================== */

.wp-block-group.is-style-gs-card,
.wp-block-group.unisex-size-info {
    background-color: var(--wp--preset--color--accent-1) !important;
    border: 1px solid var(--wp--preset--color--contrast) !important;
    border-radius: 8px !important;
    padding: var(--wp--preset--spacing--20) !important;
    height: 100%; 
}

.wp-block-group.unisex-size-info { margin-bottom: 1.5rem; }

.wc-block-product-filters__open-overlay { display: inline-flex !important; align-items: center; gap: 0.5rem; }
@media (min-width: 600px) { .wc-block-product-filters__open-overlay { display: none !important; } }

.wp-block-woocommerce-product-filters:has(.wp-block-woocommerce-product-filter-active:not([hidden])) .wc-block-product-filters__open-overlay span { display: none; }
.wp-block-woocommerce-product-filters:has(.wp-block-woocommerce-product-filter-active:not([hidden])) .wc-block-product-filters__open-overlay::after { content: "Aktive Filter..."; }

.wc-block-components-product-sale-badge {
    background-color: rgba(255, 255, 255, 0.65) !important; 
    backdrop-filter: blur(2px);
    border: 1px solid var(--wp--preset--color--contrast) !important;
}