/*
Theme Name: Botiga Druwids Child
Theme URI: https://fliegenpilz-bestellen.de
Template: botiga
Author: Heart Warrior UG
Author URI: https://druwids.de
Description: Premium/Boutique-Kindtheme für fliegenpilz-bestellen.de — Anthrazit + Champagne-Gold, viel Whitespace, Playfair Display + Inter.
Version: 2.4.0
License: GNU General Public License v2 or later
Text Domain: botiga-druwids-child
*/

/* =========================================================================
   1. Design-Tokens (Premium / Boutique)
   ========================================================================= */
:root {
    --druwids-anthracite:    #1a1a1a;
    --druwids-anthracite-90: #2c2c2c;
    --druwids-gold:          #b89968;
    --druwids-gold-hover:    #a37f4f;
    --druwids-gold-soft:     rgba(184, 153, 104, 0.12);
    --druwids-accent-red:    #8b3a3a;
    --druwids-cream:         #fafafa;
    --druwids-white:         #ffffff;
    --druwids-border:        #ececec;
    --druwids-muted:         #6b6b6b;

    --druwids-font-heading: "Playfair Display", "Cormorant Garamond", Georgia, serif;
    --druwids-font-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

    --druwids-section-y-desktop: clamp(4rem, 6vw, 7rem);
    --druwids-section-y-mobile:  clamp(2.5rem, 8vw, 4rem);
    --druwids-container-max:     1280px;

    --druwids-radius:        4px;
    --druwids-radius-lg:     6px;
    --druwids-shadow-card:   0 1px 2px rgba(26,26,26,0.04), 0 8px 24px rgba(26,26,26,0.06);
    --druwids-shadow-hover:  0 4px 8px rgba(26,26,26,0.06), 0 16px 40px rgba(26,26,26,0.12);
    --druwids-transition:    220ms cubic-bezier(.2,.7,.2,1);
}

/* =========================================================================
   2. Typografie
   ========================================================================= */
body,
.site,
.entry-content,
input, textarea, select, button {
    font-family: var(--druwids-font-body);
    color: var(--druwids-anthracite-90);
    font-feature-settings: "ss01", "cv11";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    font-size: 17px;
    line-height: 1.65;
}

h1, h2, h3, h4, h5, h6,
.entry-title,
.product_title,
.woocommerce-loop-product__title,
.widget-title {
    font-family: var(--druwids-font-heading);
    color: var(--druwids-anthracite);
    font-weight: 700;
    letter-spacing: -0.005em;
    line-height: 1.18;
}

h1, .entry-title { font-size: clamp(2.1rem, 3.4vw, 3.25rem); }
h2 { font-size: clamp(1.6rem, 2.4vw, 2.25rem); }
h3 { font-size: clamp(1.25rem, 1.6vw, 1.5rem); }

.entry-content p,
.woocommerce-Tabs-panel p {
    max-width: 68ch;
}

::selection {
    background: var(--druwids-gold);
    color: var(--druwids-white);
}

/* =========================================================================
   3. Container & Whitespace
   ========================================================================= */
.site-content,
.botiga-container,
.container {
    max-width: var(--druwids-container-max);
}

.site-main > article,
.site-main > .page,
.wp-site-blocks > main > section,
.entry-content > .wp-block-group {
    padding-top:    var(--druwids-section-y-mobile);
    padding-bottom: var(--druwids-section-y-mobile);
}

@media (min-width: 1024px) {
    .site-main > article,
    .site-main > .page,
    .wp-site-blocks > main > section,
    .entry-content > .wp-block-group {
        padding-top:    var(--druwids-section-y-desktop);
        padding-bottom: var(--druwids-section-y-desktop);
    }
}

/* =========================================================================
   4. Header / Logo / Navigation
   ========================================================================= */

/* --- 4a. Top-Bar (USP-Streifen, eigene Implementation via botiga_before_header) --- */
.druwids-topbar {
    display: none;
    background-color: var(--druwids-anthracite);
    color: rgba(255,255,255,0.92);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    padding: 0.6rem 1.25rem;
    text-align: center;
}

@media (min-width: 768px) {
    .druwids-topbar { display: block; }
}

.druwids-topbar__inner {
    max-width: var(--druwids-container-max);
    margin: 0 auto;
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.55rem 1.15rem;
}

.druwids-topbar__item {
    white-space: nowrap;
}

.druwids-topbar__sep {
    color: var(--druwids-gold);
    opacity: 0.7;
    user-select: none;
}

/* --- 4b. Header-Container --- */
.site-header,
.bhfb-header {
    border-bottom: 1px solid var(--druwids-border);
    background-color: var(--druwids-white);
}

/* Botiga hardcodet container-fluid — wir constrainen den Header-Inhalt
   auf max-width 1320px, sodass Cart/Account-Icons nicht am Rand kleben
   und Logo + Hamburger auf Mobile etwas Luft zum Rand bekommen. */
.bhfb-header .bhfb-row-wrapper > .container-fluid {
    max-width: 1320px;
    margin: 0 auto;
    padding-left: clamp(1rem, 3vw, 2.25rem);
    padding-right: clamp(1rem, 3vw, 2.25rem);
}

/* Mobile: Spalten-Padding leicht erhöht für Atem zwischen Hamburger/Logo/Icons */
@media (max-width: 991px) {
    .bhfb-header .bhfb-row > .bhfb-column {
        padding-left: 0.4rem;
        padding-right: 0.4rem;
    }
}

/* --- 4c. Sticky-Header (BHFB-Klassen: 'is-sticky' wird per JS getoggelt) --- */
.bhfb-header.has-sticky-header.is-sticky {
    box-shadow: 0 1px 0 var(--druwids-border), 0 8px 24px rgba(26,26,26,0.06);
    background-color: rgba(255,255,255,0.98);
    backdrop-filter: saturate(140%) blur(6px);
    -webkit-backdrop-filter: saturate(140%) blur(6px);
}

/* Logo-Größen-Regeln entfernt — wird vollständig über den Customizer
   gesteuert (Customize → Header → Logo Size). */

/* Body-Class beim Sticky: dezente kompensatorische Spacing-Korrektur falls nötig */
body.sticky-header-active .druwids-topbar {
    /* bleibt unscrolled an Position 0 — Header übernimmt fixed-positioning */
}

.bhfb-header .main-navigation a,
.bhfb-header .main-navigation .menu-item > a,
.bhfb-mobile_offcanvas .main-navigation a {
    color: var(--druwids-anthracite);
    font-weight: 500;
    letter-spacing: 0.02em;
    transition: color var(--druwids-transition);
}

.bhfb-header .main-navigation a:hover,
.bhfb-header .main-navigation .current-menu-item > a,
.bhfb-header .main-navigation .current_page_item > a,
.bhfb-mobile_offcanvas .main-navigation a:hover {
    color: var(--druwids-gold);
}

.bhfb-header .main-navigation a:focus-visible {
    outline: 2px solid var(--druwids-gold);
    outline-offset: 4px;
    border-radius: 2px;
}

/* =========================================================================
   5. Buttons (Primary Anthrazit, Secondary Gold-Outline)
   ========================================================================= */
.wp-block-button__link,
.button,
button[type="submit"],
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt {
    background-color: var(--druwids-anthracite);
    color: var(--druwids-white);
    border: 1px solid var(--druwids-anthracite);
    border-radius: var(--druwids-radius);
    padding: 0.85em 1.75em;
    font-family: var(--druwids-font-body);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.85rem;
    min-height: 44px;
    cursor: pointer;
    transition: background-color var(--druwids-transition),
                color var(--druwids-transition),
                border-color var(--druwids-transition),
                transform var(--druwids-transition),
                box-shadow var(--druwids-transition);
}

.wp-block-button__link:hover,
.button:hover,
button[type="submit"]:hover,
input[type="submit"]:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover {
    background-color: var(--druwids-gold);
    border-color: var(--druwids-gold);
    color: var(--druwids-white);
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(184,153,104,0.25);
}

.wp-block-button.is-style-outline .wp-block-button__link,
.button.outline,
.woocommerce .button.outline {
    background: transparent;
    color: var(--druwids-gold);
    border: 1px solid var(--druwids-gold);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover,
.button.outline:hover {
    background: var(--druwids-gold);
    color: var(--druwids-white);
}

button:focus-visible,
.button:focus-visible,
.wp-block-button__link:focus-visible {
    outline: 2px solid var(--druwids-gold);
    outline-offset: 3px;
}

/* =========================================================================
   6. Produkt-Karten (Shop Loop)
   ========================================================================= */
.woocommerce ul.products li.product,
ul.products li.product {
    background: var(--druwids-white);
    border: 1px solid var(--druwids-border);
    border-radius: var(--druwids-radius-lg);
    padding: 1.25rem 1.25rem 1.5rem;
    transition: box-shadow var(--druwids-transition),
                transform var(--druwids-transition),
                border-color var(--druwids-transition);
}

.woocommerce ul.products li.product:hover,
ul.products li.product:hover {
    border-color: transparent;
    box-shadow: var(--druwids-shadow-hover);
    transform: translateY(-2px);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 1.05rem;
    margin: 0.75rem 0 0.4rem;
}

.woocommerce ul.products li.product .price {
    color: var(--druwids-anthracite);
    font-weight: 600;
    font-size: 1.05rem;
}

.woocommerce ul.products li.product .price del {
    color: var(--druwids-muted);
}

.woocommerce ul.products li.product .price ins {
    background: transparent;
    color: var(--druwids-accent-red);
    font-weight: 700;
}

.woocommerce ul.products li.product img {
    border-radius: var(--druwids-radius);
    transition: transform 350ms cubic-bezier(.2,.7,.2,1);
}

.woocommerce ul.products li.product:hover img {
    transform: scale(1.02);
}

/* Sale-Badge — Champagne-Gold statt knallrot */
.woocommerce span.onsale {
    background: var(--druwids-gold);
    color: var(--druwids-white);
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    padding: 0.35em 0.9em;
    min-width: auto;
    min-height: auto;
    line-height: 1.4;
}

/* =========================================================================
   7. Single Product
   ========================================================================= */
.single-product .product_title {
    margin-bottom: 0.5rem;
}

.single-product .price {
    color: var(--druwids-anthracite);
    font-family: var(--druwids-font-heading);
    font-size: 1.75rem;
}

.single-product .woocommerce-product-gallery {
    background: var(--druwids-cream);
    padding: 1.5rem;
    border-radius: var(--druwids-radius-lg);
}

/* =========================================================================
   8. Footer — hell (Cream + Anthrazit-Text, Gold-Akzente)
   ========================================================================= */
.site-footer,
.bhfb-footer,
.botiga-footer-widgets-area {
    background-color: var(--druwids-cream);
    color: var(--druwids-anthracite-90);
    border-top: 1px solid var(--druwids-border);
}

/* Footer-Main-Row: ausreichend Top-Padding zwischen Footer-Beginn und Widgets */
.bhfb-footer .bhfb-row-wrapper.bhfb-main_footer_row {
    padding-top: clamp(3rem, 6vw, 5rem) !important;
    padding-bottom: clamp(2rem, 4vw, 3.5rem) !important;
}

.site-footer h1, .site-footer h2, .site-footer h3,
.site-footer h4, .site-footer h5, .site-footer h6,
.site-footer .widget-title,
.botiga-footer-widgets-area .widget-title {
    color: var(--druwids-anthracite);
    font-family: var(--druwids-font-heading);
    font-size: 1.125rem !important;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 1.25rem;
    position: relative;
    padding-bottom: 0.75rem;
}

.site-footer .widget-title::after,
.botiga-footer-widgets-area .widget-title::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 28px;
    height: 1px;
    background-color: var(--druwids-gold);
}

.site-footer a,
.botiga-footer-widgets-area a {
    color: var(--druwids-anthracite);
    text-decoration: none;
    transition: color var(--druwids-transition);
}

.site-footer a:hover,
.botiga-footer-widgets-area a:hover {
    color: var(--druwids-gold);
}

/* --- 8a. Brand-Spalte --- */
.druwids-footer__logo {
    display: block;
    max-width: 260px;
    height: auto;
    margin-bottom: 1.5rem;
}

.druwids-footer__claim {
    font-size: 0.95rem;
    line-height: 1.65;
    max-width: 32ch;
    margin: 0 0 1.25rem;
    color: var(--druwids-anthracite-90);
}

.druwids-footer__address {
    font-size: 0.9rem;
    line-height: 1.65;
    margin: 0 0 1.25rem;
    color: var(--druwids-anthracite-90);
}

.druwids-footer__address strong {
    color: var(--druwids-anthracite);
    font-weight: 700;
}

.druwids-footer__disclaimer {
    font-size: 0.82rem;
    color: var(--druwids-muted);
    font-style: italic;
    line-height: 1.55;
}

/* --- 8b. Link-Listen (Rechtliches/Service) --- */
.druwids-footer__menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.druwids-footer__menu li {
    margin: 0 0 0.55rem;
    line-height: 1.45;
}

.druwids-footer__menu a {
    font-size: 0.92rem;
    color: var(--druwids-anthracite-90);
    display: inline-block;
    padding: 2px 0;
    border-bottom: 1px solid transparent;
    transition: color var(--druwids-transition), border-color var(--druwids-transition);
}

.druwids-footer__menu a:hover {
    color: var(--druwids-gold);
    border-bottom-color: var(--druwids-gold);
}

/* § 312k BGB — Widerrufslink in der Rechtliches-Spalte hervorheben */
.druwids-footer__menu .druwids-footer__menu-revoke {
    color: var(--druwids-gold-hover);
    font-weight: 600;
}

.druwids-footer__menu .druwids-footer__menu-revoke:hover {
    color: var(--druwids-anthracite);
    border-bottom-color: var(--druwids-gold);
}

/* --- 8c. Kontakt/Newsletter-Spalte --- */
.druwids-footer__contact-line {
    font-size: 0.92rem;
    margin: 0 0 1.5rem;
    line-height: 1.55;
}

.druwids-footer__contact {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.druwids-footer__contact li {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
    margin: 0 0 0.4rem;
    font-size: 0.92rem;
    line-height: 1.5;
}

.druwids-footer__contact-label {
    flex: 0 0 auto;
    min-width: 54px;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--druwids-gold-hover);
    font-weight: 700;
    white-space: nowrap;
}

.druwids-footer__contact a {
    color: var(--druwids-anthracite);
    border-bottom: 1px solid transparent;
    transition: color var(--druwids-transition), border-color var(--druwids-transition);
}

.druwids-footer__contact a:hover {
    color: var(--druwids-gold);
    border-bottom-color: var(--druwids-gold);
}

.druwids-footer__newsletter {
    padding: 1.1rem 1.25rem;
    border: 1px solid var(--druwids-gold);
    border-radius: var(--druwids-radius);
    background: rgba(184,153,104,0.10);
}

.druwids-footer__newsletter-title {
    color: var(--druwids-anthracite);
    font-family: var(--druwids-font-heading);
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    margin: 0 0 0.5rem;
}

.druwids-footer__newsletter-hint {
    font-size: 0.9rem;
    margin: 0 0 0.85rem;
    color: var(--druwids-anthracite-90);
    line-height: 1.55;
}

/* MailPoet-Form im Footer — Premium-Look */
.druwids-footer__newsletter .mailpoet_form {
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    margin: 0 !important;
}

.druwids-footer__newsletter .mailpoet_paragraph {
    margin: 0 0 0.55rem !important;
}

.druwids-footer__newsletter .mailpoet_form input[type="email"],
.druwids-footer__newsletter .mailpoet_text {
    width: 100% !important;
    padding: 0.7em 0.9em !important;
    font-size: 0.92rem !important;
    background: var(--druwids-white) !important;
    border: 1px solid var(--druwids-border) !important;
    border-radius: var(--druwids-radius) !important;
    color: var(--druwids-anthracite) !important;
    box-sizing: border-box !important;
}

.druwids-footer__newsletter .mailpoet_form input[type="email"]:focus,
.druwids-footer__newsletter .mailpoet_text:focus {
    border-color: var(--druwids-gold) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(184,153,104,0.18) !important;
}

.druwids-footer__newsletter .mailpoet_submit,
.druwids-footer__newsletter .mailpoet_form input[type="submit"] {
    width: 100% !important;
    background: var(--druwids-anthracite) !important;
    color: var(--druwids-white) !important;
    border: 1px solid var(--druwids-anthracite) !important;
    border-radius: var(--druwids-radius) !important;
    padding: 0.75em 1.5em !important;
    font-weight: 600 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    font-size: 0.8rem !important;
    cursor: pointer !important;
    transition: all var(--druwids-transition);
    margin-top: 0.4rem !important;
}

.druwids-footer__newsletter .mailpoet_submit:hover,
.druwids-footer__newsletter .mailpoet_form input[type="submit"]:hover {
    background: var(--druwids-gold) !important;
    border-color: var(--druwids-gold) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(184,153,104,0.25);
}

.druwids-footer__newsletter .mailpoet_validate_success {
    color: #2d5a3d !important;
    font-size: 0.85rem;
    margin-top: 0.6rem;
    line-height: 1.4;
}

.druwids-footer__newsletter .mailpoet_validate_error {
    color: var(--druwids-accent-red) !important;
    font-size: 0.85rem;
    margin-top: 0.6rem;
}

.druwids-newsletter-intro {
    font-size: 0.88rem;
    line-height: 1.55;
    margin: 0 0 0.85rem !important;
    color: var(--druwids-anthracite-90);
}

/* --- 8d. Spacing zwischen Widgets, Copyright-Row sauber abgesetzt --- */
.botiga-footer-widgets-area .widget,
.site-footer .widget {
    margin-bottom: 0;
}

.bhfb-footer .bhfb-row-wrapper:last-child {
    border-top: 1px solid var(--druwids-border);
    background: rgba(0,0,0,0.02);
}

/* Copyright/Bottom-Row */
.bhfb-component-copyright,
.site-info,
.botiga-credits {
    font-size: 0.82rem;
    color: var(--druwids-muted);
    letter-spacing: 0.02em;
}

.botiga-credits a {
    color: var(--druwids-anthracite-90) !important;
}

.botiga-credits a:hover {
    color: var(--druwids-gold) !important;
}

/* =========================================================================
   9a. Widerrufs-Button (§ 312k BGB — sichtbar & klar erkennbar)
   ========================================================================= */
.druwids-revoke {
    margin: 2.5rem 0 0;
    padding: 1.75rem 1.5rem;
    border: 1px solid var(--druwids-border);
    border-left: 3px solid var(--druwids-gold);
    background: var(--druwids-cream);
    border-radius: var(--druwids-radius);
}

.druwids-revoke__title {
    margin: 0 0 0.6rem;
    font-size: 1.2rem;
}

.druwids-revoke__text {
    margin: 0 0 1.1rem;
    font-size: 0.95rem;
    color: var(--druwids-anthracite-90);
}

.druwids-revoke__cta {
    margin: 0;
}

.druwids-revoke-button {
    display: inline-block;
    background-color: var(--druwids-anthracite);
    color: var(--druwids-white);
    text-decoration: none;
    border: 1px solid var(--druwids-anthracite);
    border-radius: var(--druwids-radius);
    padding: 0.85em 2em;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.85rem;
    line-height: 1.2;
    min-height: 44px;
    transition: background-color var(--druwids-transition),
                color var(--druwids-transition),
                border-color var(--druwids-transition),
                transform var(--druwids-transition),
                box-shadow var(--druwids-transition);
}

.druwids-revoke-button:hover,
.druwids-revoke-button:focus-visible {
    background-color: var(--druwids-gold);
    border-color: var(--druwids-gold);
    color: var(--druwids-white);
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(184,153,104,0.25);
    text-decoration: none;
}

.druwids-revoke-button--primary {
    font-size: 0.95rem;
    padding: 1em 2.4em;
}

.druwids-revoke-page__intro {
    font-size: 1.05rem;
    line-height: 1.7;
    margin-bottom: 2rem;
}

.druwids-revoke-page ol li {
    margin-bottom: 0.5rem;
}

.druwids-revoke-page__cta {
    margin: 2rem 0;
}

.druwids-revoke-page__hint {
    margin-top: 2rem;
    font-size: 0.9rem;
    color: var(--druwids-muted);
}

.druwids-revoke-page address {
    background: var(--druwids-cream);
    padding: 1rem 1.25rem;
    border-left: 3px solid var(--druwids-gold);
    border-radius: var(--druwids-radius);
    font-style: normal;
    line-height: 1.6;
    margin: 0.5rem 0 1.25rem;
}

/* =========================================================================
   9. Amanita-Compliance-Box
   ========================================================================= */
.amanita-disclaimer {
    border-left: 3px solid var(--druwids-gold);
    background: var(--druwids-gold-soft);
    padding: 1.1rem 1.4rem;
    border-radius: var(--druwids-radius);
    font-size: 0.92rem;
    color: var(--druwids-anthracite-90);
    margin: 1.75rem 0;
}

/* =========================================================================
   9aa. Latest-Posts-Blog-Listing (Wissenswertes-Page)
   ========================================================================= */
.druwids-blog-list {
    margin: 2.5rem 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.druwids-blog-list > li,
.wp-block-latest-posts.druwids-blog-list > li {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 1.75rem;
    align-items: start;
    padding: 1.75rem 0;
    border-bottom: 1px solid var(--druwids-border);
    margin: 0 !important;
}

.druwids-blog-list > li:first-child {
    padding-top: 0;
}

.druwids-blog-list > li:last-child {
    border-bottom: none;
}

.druwids-blog-list .wp-block-latest-posts__featured-image {
    margin: 0 !important;
    width: 100%;
}

.druwids-blog-list .wp-block-latest-posts__featured-image a {
    display: block;
    overflow: hidden;
    border-radius: var(--druwids-radius-lg);
}

.druwids-blog-list .wp-block-latest-posts__featured-image img {
    width: 100%;
    height: auto;
    aspect-ratio: 280 / 190;
    object-fit: cover;
    transition: transform 400ms ease;
}

.druwids-blog-list > li:hover .wp-block-latest-posts__featured-image img {
    transform: scale(1.03);
}

.druwids-blog-list .wp-block-latest-posts__post-title {
    display: block;
    font-family: var(--druwids-font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.25;
    color: var(--druwids-anthracite);
    margin: 0 0 0.5rem;
    text-decoration: none;
    transition: color var(--druwids-transition);
}

.druwids-blog-list .wp-block-latest-posts__post-title:hover {
    color: var(--druwids-gold);
}

.druwids-blog-list .wp-block-latest-posts__post-date {
    display: block;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--druwids-gold-hover);
    margin-bottom: 0.75rem;
}

.druwids-blog-list .wp-block-latest-posts__post-excerpt {
    font-size: 1rem;
    line-height: 1.6;
    color: var(--druwids-anthracite-90);
    margin: 0;
}

@media (max-width: 767px) {
    .druwids-blog-list > li,
    .wp-block-latest-posts.druwids-blog-list > li {
        grid-template-columns: 1fr;
        gap: 1rem;
        padding: 1.5rem 0;
    }
}

/* Empty-State wenn noch keine Beiträge da sind */
.druwids-blog-list:empty::after,
.wp-block-latest-posts.druwids-blog-list:empty::after {
    content: "Bald folgen hier Artikel zu Wildsammlung, Verarbeitung und Tradition rund um Amanita-Pilze.";
    display: block;
    padding: 3rem 1.5rem;
    text-align: center;
    color: var(--druwids-muted);
    font-style: italic;
    background: var(--druwids-cream);
    border-radius: var(--druwids-radius-lg);
    margin: 2rem 0;
}

/* =========================================================================
   9b. Contact Form 7 — Premium-Look
   ========================================================================= */
.wpcf7 {
    max-width: 580px;
}

.druwids-form-row {
    margin-bottom: 1.25rem;
}

.druwids-form-row label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--druwids-anthracite);
    margin-bottom: 0.4rem;
}

.druwids-form-req {
    color: var(--druwids-gold-hover);
    margin-left: 2px;
}

.wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-acceptance) {
    width: 100%;
    padding: 0.75em 0.95em;
    font-family: var(--druwids-font-body);
    font-size: 1rem;
    color: var(--druwids-anthracite);
    background: var(--druwids-white);
    border: 1px solid var(--druwids-border);
    border-radius: var(--druwids-radius);
    transition: border-color var(--druwids-transition), box-shadow var(--druwids-transition);
    box-sizing: border-box;
}

.wpcf7-form-control:focus {
    border-color: var(--druwids-gold);
    outline: none;
    box-shadow: 0 0 0 3px rgba(184,153,104,0.18);
}

.wpcf7-textarea {
    min-height: 140px;
    resize: vertical;
}

.druwids-form-consent {
    font-size: 0.88rem;
    line-height: 1.5;
    color: var(--druwids-anthracite-90);
}

.druwids-form-consent .wpcf7-list-item {
    margin: 0;
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
}

.druwids-form-consent input[type="checkbox"] {
    margin-top: 0.25rem;
    width: 18px;
    height: 18px;
    accent-color: var(--druwids-gold);
}

.druwids-form-consent .wpcf7-list-item-label {
    flex: 1;
}

.druwids-form-submit input[type="submit"],
.druwids-form-submit .wpcf7-submit {
    width: auto;
    background-color: var(--druwids-anthracite);
    color: var(--druwids-white);
    border: 1px solid var(--druwids-anthracite);
    border-radius: var(--druwids-radius);
    padding: 0.85em 2.2em;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.85rem;
    cursor: pointer;
    min-height: 44px;
}

.druwids-form-submit input[type="submit"]:hover,
.druwids-form-submit .wpcf7-submit:hover {
    background: var(--druwids-gold);
    border-color: var(--druwids-gold);
    color: var(--druwids-white);
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(184,153,104,0.25);
}

.wpcf7 form .wpcf7-response-output {
    margin: 1rem 0 0;
    padding: 0.85rem 1rem;
    border-radius: var(--druwids-radius);
    font-size: 0.92rem;
    line-height: 1.5;
}

.wpcf7 form.sent .wpcf7-response-output {
    background: rgba(45, 90, 61, 0.08);
    border: 1px solid rgba(45, 90, 61, 0.35);
    color: #2d5a3d;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output {
    background: rgba(139, 58, 58, 0.08);
    border: 1px solid var(--druwids-accent-red);
    color: var(--druwids-accent-red);
}

.wpcf7-not-valid-tip {
    color: var(--druwids-accent-red);
    font-size: 0.85rem;
    margin-top: 0.25rem;
}

.wpcf7-spinner {
    margin: 0 0 0 0.5rem;
}

.druwids-muted {
    color: var(--druwids-muted);
    font-size: 0.85rem;
}

/* =========================================================================
   9c. Startseite — Hero / USPs / Kategorie-Karten / Story
   ========================================================================= */

/* --- Hero (background-image basiert, von functions.php gerendert) --- */
.druwids-hero {
    position: relative;
    overflow: hidden;
    text-align: center;
    color: #ffffff !important;
    aspect-ratio: 1920 / 1100;
    margin: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: block;
    /* Full-width-Ausbruch aus Botigas .container.content-wrapper */
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    max-width: 100vw;
}

@media (max-width: 767px) {
    .druwids-hero {
        aspect-ratio: 1080 / 1350;
    }
}

.druwids-hero__overlay {
    position: absolute;
    inset: 0;
    background: rgba(26,26,26,0.4);
    z-index: 1;
    pointer-events: none;
    display: block;
}

.druwids-hero__inner {
    position: relative;
    z-index: 2;
    max-width: 880px;
    margin: 0 auto;
    padding: 2rem 1.5rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    color: #ffffff;
}

.druwids-hero__title {
    color: #ffffff !important;
    font-family: var(--druwids-font-heading) !important;
    font-weight: 700 !important;
    line-height: 1.1 !important;
    font-size: clamp(2.2rem, 5vw, 4rem) !important;
    margin: 0 0 1rem !important;
}

.druwids-hero__subtitle {
    color: rgba(255,255,255,0.92) !important;
    font-size: clamp(1rem, 1.6vw, 1.2rem) !important;
    letter-spacing: 0.04em !important;
    margin: 0 0 2.25rem !important;
}

.druwids-hero__cta .wp-block-button__link {
    background-color: var(--druwids-anthracite) !important;
    color: #ffffff !important;
    border: 1px solid var(--druwids-anthracite) !important;
}

.druwids-hero__cta .wp-block-button__link:hover {
    background-color: var(--druwids-gold) !important;
    border-color: var(--druwids-gold) !important;
}

/* Hero klebt direkt am Header — alle Botiga/WP-Wrapper auf Home auf padding 0 */
body.home .container.content-wrapper,
body.home .content-wrapper > .row.main-row,
body.home .row.main-row,
body.home #primary.site-main,
body.home .site-main,
body.home .site-main > article,
body.home .entry-content,
body.home .entry-content > .wp-block-cover:first-child {
    padding-top: 0 !important;
    margin-top: 0 !important;
}


.druwids-hero__title {
    margin: 0 0 1rem !important;
    line-height: 1.1 !important;
    font-size: clamp(2.2rem, 5vw, 4rem) !important;
}

.druwids-hero__subtitle {
    font-size: clamp(1rem, 1.6vw, 1.2rem);
    letter-spacing: 0.04em;
    margin: 0 0 2.25rem !important;
    color: rgba(255,255,255,0.88) !important;
}

/* --- USP-Streifen unter Hero --- */
.druwids-usps {
    padding: clamp(2.5rem, 5vw, 4.5rem) 1.5rem;
    background: var(--druwids-cream);
    border-bottom: 1px solid var(--druwids-border);
}

.druwids-usps .wp-block-column {
    text-align: center;
    padding: 0 0.75rem;
}

.druwids-usp-h {
    font-size: 1.1rem !important;
    margin-bottom: 0.5rem !important;
}

/* --- Kategorie-Karten --- */
.druwids-categories {
    padding: clamp(3rem, 6vw, 5.5rem) 1.5rem;
}

.druwids-section-lead {
    max-width: 56ch;
    margin: 0 auto 3rem !important;
    color: var(--druwids-muted);
    font-size: 1.05rem;
    line-height: 1.6;
}

/* 3-Spalten-Grid auf Desktop, 1-col auf Mobile */
.druwids-categories__grid.wp-block-columns {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

@media (max-width: 767px) {
    .druwids-categories__grid.wp-block-columns {
        grid-template-columns: 1fr;
    }
}

.druwids-categories__grid > .wp-block-column.druwids-cat-card {
    flex: unset !important;
    width: 100% !important;
    margin: 0 !important;
}

.druwids-cat-card {
    background: var(--druwids-white);
    border: 1px solid var(--druwids-border);
    border-radius: var(--druwids-radius-lg);
    padding: 0 0 2rem !important;
    text-align: center;
    overflow: hidden;
    transition: box-shadow var(--druwids-transition),
                transform var(--druwids-transition),
                border-color var(--druwids-transition);
}

.druwids-cat-card:hover {
    border-color: transparent;
    box-shadow: var(--druwids-shadow-hover);
    transform: translateY(-3px);
}

.druwids-cat-card__media {
    display: block;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    margin-bottom: 1.75rem;
}

.druwids-cat-card__img,
.druwids-cat-card__media img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    display: block;
    transition: transform 500ms cubic-bezier(.2,.7,.2,1);
}

.druwids-cat-card:hover .druwids-cat-card__img,
.druwids-cat-card:hover .druwids-cat-card__media img {
    transform: scale(1.04);
}

.druwids-cat-card h3 {
    margin: 0 1.75rem 0.5rem;
    font-size: 1.45rem;
}

.druwids-cat-card p {
    color: var(--druwids-muted);
    font-size: 0.95rem;
    line-height: 1.55;
    margin: 0 1.75rem 1.5rem;
    min-height: 3em;
}

.druwids-cat-card .wp-block-buttons {
    padding: 0 1.75rem;
}

/* --- Bestseller-Block --- */
.druwids-bestseller {
    padding: clamp(3rem, 6vw, 5.5rem) 1.5rem;
    background: var(--druwids-white);
    border-top: 1px solid var(--druwids-border);
}

.druwids-bestseller ul.products {
    margin: 0 0 2.5rem !important;
}

.druwids-bestseller .wp-block-buttons {
    margin-top: 1.5rem;
}

/* --- Story-Block --- */
.druwids-story {
    padding: clamp(3rem, 6vw, 5.5rem) 1.5rem;
}

.druwids-story__text {
    max-width: 62ch;
    margin: 0 auto 2rem !important;
    font-size: 1.1rem;
    line-height: 1.7;
}

/* --- SEO-Sektion direkt unter Compliance-Balken (vor Footer) --- */
.druwids-seo {
    padding: clamp(2.5rem, 5vw, 4.5rem) 1.5rem;
    background: var(--druwids-white);
    border-top: 1px solid var(--druwids-border);
}

.druwids-seo__grid {
    max-width: var(--druwids-container-max);
    margin: 0 auto;
    gap: clamp(1.5rem, 4vw, 3.5rem);
}

@media (min-width: 768px) {
    .druwids-seo__grid {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
    }
}

.druwids-seo__grid > .wp-block-column {
    margin: 0 !important;
    flex: unset;
}

.druwids-seo h2 {
    font-size: clamp(1.35rem, 2.4vw, 1.75rem);
    margin: 0 0 1rem;
    line-height: 1.25;
}

.druwids-seo p {
    font-size: 0.98rem;
    line-height: 1.7;
    margin: 0 0 1rem;
    color: var(--druwids-anthracite-90);
}

.druwids-seo p:last-child {
    margin-bottom: 0;
}

@media (max-width: 767px) {
    .druwids-seo__grid {
        display: block !important;
    }
    .druwids-seo__grid > .wp-block-column + .wp-block-column {
        margin-top: 2rem !important;
    }
}

/* --- Compliance-Footer-Block der Startseite --- */
.druwids-compliance {
    padding: 2.5rem 1.5rem;
    background: var(--druwids-anthracite);
}

.druwids-compliance__text {
    color: rgba(255,255,255,0.7);
    font-size: 0.9rem;
    max-width: 60ch;
    margin: 0 auto !important;
}

/* =========================================================================
   9d. Page-Titles ausblenden (Pages + Shop-Header)
        Pages: WP-Default `.entry-title.page-title` und der Wrapper `.entry-header`
        Shop:  WooCommerce-Products-Header
        Produkt-Detail: NICHT verstecken (Produktname ist SEO-relevant)
   ========================================================================= */
body.page .entry-header,
body.page .entry-title.page-title,
body.page-template-default .entry-header,
.woocommerce-products-header__title {
    display: none !important;
}

/* Leere woocommerce-products-header im main-Bereich entfernen
   (Botiga rendert eine zweite leere — frisst sonst Vertical-Space) */
.site-main > header.woocommerce-products-header:empty,
.site-main > header.woocommerce-products-header:not(:has(*)) {
    display: none !important;
}

/* Top-Block (oberhalb des Content-Wrappers) mit Shop-Description-Inhalt */
header.woocommerce-products-header > .container {
    padding-top: clamp(1.25rem, 2.5vw, 2rem);
    padding-bottom: clamp(1rem, 2vw, 1.5rem);
}

/* Page-Description-Wrapper (von WC bei archive_description() ausgegeben) */
.page-description {
    text-align: center;
    max-width: 72ch;
    margin: 0 auto;
    padding: 0 1rem;
}

/* Hauptüberschrift im Description-Block — Playfair, kräftig, groß */
h2.woocommerce-shop-page-description,
.page-description > h2,
.page-description > h2.wp-block-heading {
    font-family: var(--druwids-font-heading);
    font-size: clamp(1.65rem, 3.2vw, 2.4rem) !important;
    font-weight: 700;
    line-height: 1.2;
    color: var(--druwids-anthracite);
    margin: 0 0 1rem;
}

.page-description p {
    font-size: 1rem;
    line-height: 1.65;
    color: var(--druwids-anthracite-90);
    margin: 0 0 0.85rem;
}

.page-description p:last-child {
    margin-bottom: 0;
}

/* Kategorie-Term-Description (auf /produkt-kategorie/...) */
.term-description {
    text-align: center;
    max-width: 72ch;
    margin: 0 auto;
    padding: 0 1rem;
    font-size: 1rem;
    line-height: 1.65;
    color: var(--druwids-anthracite-90);
}

/* Etwas geringerer Top-Abstand fürs Grid auf Archive-Pages */
body.post-type-archive-product .site-main,
body.tax-product_cat .site-main,
body.woocommerce-page.archive .site-main {
    padding-top: clamp(0.5rem, 1.5vw, 1.25rem);
}

/* =========================================================================
   10. Reduced Motion
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        transition-duration: 0.001ms !important;
        animation-duration: 0.001ms !important;
    }
}
