/* ============================================================================
   Edition Fichter — Theme-Glue (WordPress/WooCommerce + Layout-Utilities)
   Ergänzt assets/css/design.css (Design-System aus dem Handoff).
============================================================================ */

/* ---- A11y / Basis ---- */
.ef-skip { position:absolute; left:-9999px; top:0; background:var(--ef-ink); color:#fff; padding:12px 18px; z-index:1000; border-radius:0 0 8px 0; font-family:var(--ef-font-ui); font-size:13px; }
.ef-skip:focus { left:0; }
:focus-visible { outline:2px solid var(--ef-amber); outline-offset:2px; }
.ef-main { display:block; }
img { height:auto; }

/* ---- Header ---- */
.ef-header { position:relative; z-index:20; }
.ef-header__right { display:flex; gap:14px; align-items:center; }
.ef-search { margin:0; }
.ef-search input[type="search"] { border:0; background:transparent; outline:none; width:100%; font-family:var(--ef-font-body); font-size:13px; color:var(--ef-ink); }
.ef-search input::placeholder { color:var(--ef-muted-soft); }
.ef-cartpill { display:inline-flex; align-items:center; gap:8px; cursor:pointer; color:var(--ef-amber-bright); padding:9px 16px; font-size:13px; }
.ef-cartpill__ico { flex:none; }
.ef-cart-total { color:var(--ef-amber-bright); font-weight:700; letter-spacing:.3px; }
.ef-logo { cursor:pointer; }
.ef-logo__img { height:40px !important; width:auto !important; max-width:220px; display:block; }

/* Burger (nur mobil) */
.ef-burger { display:none; width:40px; height:40px; border:1px solid var(--ef-line); background:var(--ef-paper); border-radius:10px; cursor:pointer; flex-direction:column; justify-content:center; align-items:center; gap:4px; padding:0; }
.ef-burger span { display:block; width:18px; height:2px; background:var(--ef-ink); border-radius:2px; }

/* ---- Kontrast: Gold-Labels etwas dunkler (WCAG AA) ---- */
:root { --ef-label: #8f6b0e; }

/* ---- Ticker (Home) — animierte Laufschrift ---- */
.ef-ticker { overflow:hidden; }
.ef-ticker__track { display:flex; width:max-content; animation:ef-marquee 48s linear infinite; }
.ef-ticker__group { display:flex; gap:44px; padding-right:44px; flex:none; }
.ef-ticker:hover .ef-ticker__track { animation-play-state:paused; }
@keyframes ef-marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .ef-ticker__track { animation:none; } }

/* ---- Section / Page-Utilities ---- */
.ef-two-col { display:grid; }
.ef-richtext p { margin:0 0 1.1em; }
.ef-richtext h2, .ef-richtext h3 { font-family:var(--ef-font-ui); letter-spacing:-.3px; color:var(--ef-ink); margin:1.6em 0 .5em; }
.ef-richtext h2 { font-size:22px; } .ef-richtext h3 { font-size:17px; text-transform:uppercase; letter-spacing:1px; font-weight:700; }
.ef-richtext a { color:var(--ef-label); text-decoration:underline; text-underline-offset:2px; }
.ef-richtext ul, .ef-richtext ol { padding-left:1.2em; margin:0 0 1.1em; }
.ef-richtext li { margin:.3em 0; }

/* ---- Newsletter-Band (dunkel) — WPForms robust einkleiden ---- */
.ef-newsletter__text { color:#fff; }
.ef-newsletter__form .wpforms-form { margin:0; }
.ef-newsletter__form .wpforms-field { padding:0 0 14px !important; }
.ef-newsletter__form .wpforms-field-label,
.ef-newsletter__form .wpforms-field-label-inline { color:#e6ddca !important; font-family:var(--ef-font-ui) !important; font-weight:600 !important; font-size:11px !important; letter-spacing:.9px !important; text-transform:uppercase !important; }
.ef-newsletter__form .wpforms-required-label { color:var(--ef-amber-bright) !important; }
.ef-newsletter__form input[type="text"],
.ef-newsletter__form input[type="email"],
.ef-newsletter__form .wpforms-field input {
    background:var(--ef-dark-raise) !important; border:1px solid #3d382f !important; border-radius:var(--ef-r-pill) !important;
    padding:14px 20px !important; color:#fff !important; font-family:var(--ef-font-body) !important; font-size:14px !important; width:100% !important; box-shadow:none !important;
}
.ef-newsletter__form input::placeholder { color:var(--ef-muted-soft) !important; }
.ef-newsletter__form input:focus { border-color:var(--ef-amber) !important; outline:none !important; }
.ef-newsletter__form .wpforms-submit,
.ef-newsletter__form button[type="submit"] {
    background:var(--ef-amber) !important; color:var(--ef-ink) !important; border:0 !important; border-radius:var(--ef-r-pill) !important;
    padding:15px 30px !important; font-family:var(--ef-font-ui) !important; font-weight:700 !important; font-size:13px !important; letter-spacing:.8px !important; text-transform:uppercase !important; cursor:pointer !important; box-shadow:none !important;
}
.ef-newsletter__form .wpforms-submit:hover { transform:translateY(-1px); }

/* ---- „Vertrag widerrufen" (Plugin-Link) als echter Button ---- */
.eu-owb-order-withdraw-from-contract-button { margin:20px 0; }
.eu-owb-order-withdraw-from-contract-button a,
.eu-owb-order-withdraw-from-contract-button .button,
a.eu-owb-order-withdraw-from-contract-button-link {
    display:inline-flex !important; align-items:center; gap:8px; background:var(--ef-ink) !important; color:#fff !important;
    font-family:var(--ef-font-ui) !important; font-weight:700 !important; font-size:13px !important; letter-spacing:.8px !important; text-transform:uppercase !important;
    padding:15px 30px !important; border-radius:var(--ef-r-pill) !important; border:0 !important; text-decoration:none !important;
}

/* ---- Footer ---- */
.ef-footer__brand { max-width:300px; }
.ef-footer__brand a { color:var(--ef-label); }
.ef-footer__col a { color:var(--ef-body); }
.ef-footer__col a:hover { color:var(--ef-ink); }
.ef-footer__legal { display:flex; gap:16px; }
.ef-footer__legal a:hover, .ef-footer__cols a:hover { color:var(--ef-ink); }

/* ---- Mobile-Menü-Overlay ---- */
.ef-menu[hidden] { display:none; }
.ef-menu__top { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.ef-menu__top .ef-logo__word { color:#fff; }
.ef-menu__close { background:none; border:0; color:#fff; font-size:34px; line-height:1; cursor:pointer; padding:0 6px; }

/* ============================================================================
   WooCommerce — Grundangleichung an das Design
============================================================================ */
.woocommerce-notices-wrapper:empty { display:none; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
    background:var(--ef-tint) !important; border:0 !important; border-left:3px solid var(--ef-amber) !important; border-radius:0 10px 10px 0;
    padding:16px 22px; font-family:var(--ef-font-body); font-size:14px; color:var(--ef-body); list-style:none; margin:0 0 24px;
    display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}
.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before { content:none !important; }
.woocommerce-error { border-left-color:#b3403a !important; }
.woocommerce-message a.button, .woocommerce-info a.button { margin-left:auto; background:var(--ef-ink); color:#fff; border-radius:var(--ef-r-pill); padding:11px 22px; font-family:var(--ef-font-ui); font-size:12px; text-transform:uppercase; letter-spacing:.5px; }

/* WooCommerce Buttons -> ef-btn Look */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce #respond input#submit,
.woocommerce a.button.alt, .woocommerce button.button.alt {
    display:inline-flex; align-items:center; gap:8px; background:var(--ef-ink); color:#fff;
    font-family:var(--ef-font-ui); font-weight:700; font-size:13px; letter-spacing:.8px; text-transform:uppercase;
    padding:15px 30px; border-radius:var(--ef-r-pill); border:0; cursor:pointer; transition:transform .15s;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover { transform:translateY(-1px); }
.woocommerce .button.alt { background:var(--ef-amber); color:var(--ef-ink); }

/* WooCommerce Formularfelder -> ef-input Look */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce .select2-container--default .select2-selection--single,
.woocommerce form .form-row select {
    background:var(--ef-paper); border:1px solid var(--ef-line); border-radius:var(--ef-r-input);
    padding:14px 16px; font-family:var(--ef-font-body); font-size:14px; color:var(--ef-ink); line-height:1.3;
}
.woocommerce form .form-row label { font-family:var(--ef-font-ui); font-weight:600; font-size:11px; letter-spacing:.8px; text-transform:uppercase; color:var(--ef-muted); }
.woocommerce .price, .woocommerce div.product p.price, .woocommerce div.product span.price { font-family:var(--ef-font-ui); font-weight:700; color:var(--ef-ink); }

/* Standard-WooCommerce-Produktgitter neutralisieren (wir nutzen ef-grid in Templates) */
.woocommerce ul.products { margin:0; padding:0; list-style:none; }
.woocommerce ul.products::before, .woocommerce ul.products::after { content:none; }

/* ============================================================================
   PRODUKTKARTEN — Cover-Blend (weißer Hintergrund weg) + einheitliche Ausrichtung
============================================================================ */
/* Cover: freigestellte Mockups (transparente PNG) bzw. flache Scans — voll & unbeschnitten, ohne Schatten */
.ef-card__cover img { filter:none; }
.ef-card__cover { padding:4px; }
/* Karten gleich hoch, Trennlinie + Fuß immer unten -> kein Zeilensprung */
.ef-grid > .ef-card, .ef-grid--3 > .ef-card { height:100%; }
.ef-card { justify-content:flex-start; }
.ef-card__title { min-height:0; }
.ef-card__rule { margin-top:auto; }

/* Hero-Cover: frei schwebend auf Amber (kein weißer Kasten mehr) */
.ef-hero__cover-frame { background:transparent; padding:0; box-shadow:none; align-self:center; margin:14px 0; display:flex; justify-content:center; width:100%; }
.ef-cover-hero { width:auto; max-width:min(78%,300px); height:auto; max-height:400px; object-fit:contain; filter:none; }

/* Produktdetail-Bühne: Cover ohne Kasten/Schatten im Amber-Panel */
.ef-stage-cover { background:transparent; padding:0; box-shadow:none; }

/* ============================================================================
   SHOP / KATALOG
============================================================================ */
.ef-shop-head { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:20px; margin-top:16px; }
.ef-shop-head__title { display:flex; align-items:baseline; gap:20px; }
.ef-shop-head__count { font-family:var(--ef-font-body); font-size:15px; color:var(--ef-muted-soft); }
.ef-shop-head__sort { display:flex; align-items:center; gap:10px; }
.ef-shop-head__sort .ef-label { color:var(--ef-muted); }
.ef-shop-head__sort select, .woocommerce-ordering select {
    -webkit-appearance:none; appearance:none; background:var(--ef-paper); border:1px solid var(--ef-line);
    border-radius:22px; padding:10px 34px 10px 16px; font-family:var(--ef-font-ui); font-weight:600; font-size:12px;
    letter-spacing:.5px; text-transform:uppercase; color:var(--ef-ink); cursor:pointer;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23b98a12' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 15px center;
}
.woocommerce-ordering { margin:0; }

.ef-shop { grid-template-columns:220px 1fr; gap:44px; padding-top:6px; padding-bottom:20px; }
.ef-side-h { font-family:var(--ef-font-ui); font-weight:700; font-size:12px; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:16px; }
.ef-cat-nav a { display:flex; justify-content:space-between; align-items:center; }
.ef-cat-count { color:var(--ef-muted-soft); }
.ef-cat-nav a.is-active .ef-cat-count { color:var(--ef-amber-bright); }
.ef-price-range__track { height:3px; background:#e2d8c4; border-radius:2px; position:relative; margin:14px 4px 12px; }
.ef-price-range__fill { position:absolute; left:6%; right:18%; top:0; height:3px; background:var(--ef-amber); border-radius:2px; }
.ef-price-range__knob { position:absolute; top:-4.5px; width:12px; height:12px; background:var(--ef-ink); border-radius:50%; }
.ef-price-range__labels { display:flex; justify-content:space-between; font-family:var(--ef-font-ui); font-weight:500; font-size:12px; color:var(--ef-muted-soft); }
.ef-chips { display:flex; flex-wrap:wrap; gap:8px; }

.ef-pagination { display:flex; justify-content:center; padding:30px 0 20px; }
.ef-pagination ul, .ef-pagination .page-numbers { list-style:none; display:flex; gap:8px; padding:0; margin:0; }
.ef-pagination li { list-style:none; }
.ef-pagination .page-numbers:not(ul) { width:38px; height:38px; display:flex; align-items:center; justify-content:center; border:1px solid var(--ef-line); border-radius:9px; font-family:var(--ef-font-ui); font-weight:600; font-size:14px; color:var(--ef-body); }
.ef-pagination .page-numbers.current { background:var(--ef-ink); color:#fff; border-color:var(--ef-ink); }

/* ============================================================================
   PRODUKTDETAIL
============================================================================ */
.ef-product { display:grid; grid-template-columns:.92fr 1.08fr; gap:56px; padding-top:26px; padding-bottom:10px; align-items:start; }
.ef-product__stage { position:relative; background:var(--ef-amber); border-radius:6px; padding:56px 48px 48px; display:flex; flex-direction:column; align-items:center; }
.ef-stage-eyebrow { align-self:flex-start; font-family:var(--ef-font-ui); font-weight:600; font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--ef-amber-ink); margin-bottom:26px; }
.ef-product__stage { padding:36px 36px 32px; }
.ef-stage-cover { display:flex; justify-content:center; width:100%; }
.ef-stage-img { width:auto; max-width:92%; height:auto; max-height:600px; object-fit:contain; filter:none; }
.ef-thumbs { display:flex; gap:10px; margin-top:34px; }
.ef-thumb { width:44px; height:58px; background:#fff; border-radius:3px; display:flex; align-items:center; justify-content:center; padding:5px; }
.ef-thumb.is-active { border:2px solid var(--ef-ink-deep); }
.ef-thumb img { max-width:100%; max-height:100%; object-fit:contain; }

.ef-product__title { font-family:var(--ef-font-serif); font-weight:500; font-size:42px; line-height:1.12; margin:0 0 8px; }
.ef-product__sub { font-family:var(--ef-font-body); font-size:15px; color:var(--ef-muted-soft); margin-bottom:26px; }
.ef-product__pricerow { display:flex; align-items:baseline; gap:14px; margin-bottom:22px; flex-wrap:wrap; }
.ef-product__price { font-family:var(--ef-font-ui); font-weight:700; font-size:32px; }
.ef-product__price .amount, .ef-product__price bdi { font-weight:700; }
.ef-product__tax { font-family:var(--ef-font-body); font-size:13px; color:var(--ef-muted-soft); }
.ef-stock { margin-left:auto; font-family:var(--ef-font-ui); font-weight:600; font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--ef-success); display:flex; align-items:center; gap:7px; }
.ef-stock--out { color:var(--ef-muted-soft); }
.ef-stock__dot { width:8px; height:8px; border-radius:50%; background:currentColor; }
.ef-product__lead { max-width:520px; margin:0 0 28px; }
.ef-add { display:flex; gap:12px; align-items:center; margin-bottom:30px; flex-wrap:wrap; }
.ef-add .quantity { display:flex; }
.ef-add .ef-stepper input.qty { width:32px; text-align:center; border:0; background:transparent; font:inherit; -moz-appearance:textfield; }
.ef-add .ef-stepper input.qty::-webkit-outer-spin-button, .ef-add .ef-stepper input.qty::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.ef-add__btn { flex:1; justify-content:center; min-width:200px; }
.ef-wish { width:52px; height:52px; display:flex; align-items:center; justify-content:center; border:1px solid var(--ef-line); background:var(--ef-paper); border-radius:50%; font-size:18px; color:var(--ef-muted-soft); cursor:pointer; }
.ef-meta { display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--ef-line); margin:0; }
.ef-meta__row { display:flex; justify-content:space-between; gap:12px; padding:13px 0; border-bottom:1px solid var(--ef-line-soft); }
.ef-meta__row:nth-child(odd) { padding-right:28px; }
.ef-meta dt { font-family:var(--ef-font-ui); font-weight:600; font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--ef-muted); margin:0; }
.ef-meta dd { font-family:var(--ef-font-body); font-size:14px; color:var(--ef-ink); margin:0; text-align:right; }

/* ============================================================================
   WARENKORB
============================================================================ */
.ef-cart { grid-template-columns:1fr 360px; gap:44px; align-items:start; padding-bottom:20px; }
.ef-cart__head, .ef-cart__row { display:grid; grid-template-columns:2.4fr 1fr 1fr .3fr; gap:16px; align-items:center; }
.ef-cart__head { font-family:var(--ef-font-ui); font-weight:700; font-size:11px; letter-spacing:1.2px; text-transform:uppercase; color:var(--ef-muted-soft); padding-bottom:14px; border-bottom:1px solid var(--ef-line); }
.ef-cart__head .c { text-align:center; } .ef-cart__head .r { text-align:right; }
.ef-cart__row { padding:22px 0; border-bottom:1px solid var(--ef-line); }
.ef-cart__prod { display:flex; align-items:center; gap:18px; }
.ef-cart__thumb { width:60px; height:80px; background:#fff; border:1px solid var(--ef-line-soft); border-radius:3px; display:flex; align-items:center; justify-content:center; padding:6px; flex:none; }
.ef-cart__thumb img { max-width:100%; max-height:100%; object-fit:contain; }
.ef-cart__author { font-size:10px; margin-bottom:5px; }
.ef-cart__name { font-size:17px; line-height:1.25; }
.ef-cart__qty { justify-self:center; }
.ef-cart__qty .ef-stepper { padding:9px 16px; gap:14px; }
.ef-cart__qty .ef-stepper input.qty { width:26px; text-align:center; border:0; background:transparent; font:inherit; -moz-appearance:textfield; }
.ef-cart__qty .ef-stepper input.qty::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.ef-cart__price { font-family:var(--ef-font-ui); font-weight:700; font-size:17px; text-align:right; }
.ef-cart__remove a { color:#b0a894; font-size:20px; }
.ef-cart__remove { text-align:right; }
.ef-cart__actions { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; margin-top:26px; }
.ef-cart__continue { font-family:var(--ef-font-ui); font-weight:600; font-size:12px; letter-spacing:.8px; text-transform:uppercase; color:var(--ef-muted); }
.ef-cart__actions-right { display:flex; gap:12px; align-items:center; }
.ef-coupon { display:flex; gap:8px; }
.ef-coupon input { background:var(--ef-paper); border:1px solid var(--ef-line); border-radius:var(--ef-r-pill); padding:11px 16px; font-family:var(--ef-font-body); font-size:13px; }
.ef-cart__actions .button { padding:12px 20px; font-size:12px; }
.ef-cart__update { background:transparent; border:1px solid var(--ef-line); color:var(--ef-ink); font-family:var(--ef-font-ui); font-weight:600; font-size:12px; letter-spacing:.8px; text-transform:uppercase; padding:12px 22px; border-radius:var(--ef-r-pill); cursor:pointer; }
.ef-cart__update:hover { border-color:var(--ef-ink); }
.ef-coupon .button { background:var(--ef-ink); }

.ef-summary { position:sticky; top:20px; }
.ef-summary__checkout { margin-top:8px; }
.ef-summary__pay { display:flex; align-items:center; justify-content:center; gap:10px; margin-top:20px; font-family:var(--ef-font-ui); font-weight:500; font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--ef-muted-soft); }
.ef-srow--shipping { display:block; }
.ef-srow--shipping ul { list-style:none; margin:6px 0 0; padding:0; }
.ef-srow--shipping label { color:var(--ef-dark-text); }
.ef-summary .shipping-calculator-button { color:var(--ef-amber-bright); }

.ef-reassure { display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--ef-line); border-radius:12px; overflow:hidden; margin-bottom:44px; }
.ef-reassure__col { padding:22px 26px; border-right:1px solid var(--ef-line); }
.ef-reassure__col:last-child { border-right:0; }
.ef-reassure__h { font-family:var(--ef-font-ui); font-weight:700; font-size:12px; letter-spacing:.8px; text-transform:uppercase; margin-bottom:6px; }
.ef-reassure__s { font-family:var(--ef-font-body); font-size:13px; color:var(--ef-muted-soft); }

.woocommerce-cart .cart-empty, .woocommerce-checkout .woocommerce-info { font-size:15px; }

/* ============================================================================
   KASSE / CHECKOUT
============================================================================ */
.ef-checkout { grid-template-columns:1fr 380px; gap:44px; align-items:start; }
.ef-checkout__forms .col2-set { display:block; }
.ef-checkout__forms h3 { font-family:var(--ef-font-ui); font-weight:700; font-size:18px; letter-spacing:-.2px; margin:0 0 18px; padding-top:8px; }
.ef-checkout__forms h3::before { content:""; }
.ef-checkout__forms .woocommerce-billing-fields, .ef-checkout__forms .woocommerce-shipping-fields, .ef-checkout__forms .woocommerce-additional-fields { background:var(--ef-paper); border:1px solid var(--ef-line); border-radius:var(--ef-r-card); padding:26px 28px; margin-bottom:22px; }
.ef-checkout__forms .form-row { margin-bottom:14px; }
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus { outline:none; border-color:var(--ef-ink); }
.ef-checkout__forms .select2-container .select2-selection--single { height:auto; }

/* Dunkle Bestellübersicht */
.ef-order { position:sticky; top:20px; }
.ef-order .shop_table { width:100%; border-collapse:collapse; margin-bottom:6px; }
.ef-order .shop_table th, .ef-order .shop_table td { padding:9px 0; text-align:left; font-family:var(--ef-font-body); font-size:14px; color:var(--ef-dark-text); border:0; }
.ef-order .shop_table td.product-total, .ef-order .shop_table th.product-total, .ef-order .shop_table .amount { text-align:right; color:#fff; }
.ef-order .shop_table thead th { font-family:var(--ef-font-ui); font-weight:700; font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--ef-dark-muted); border-bottom:1px solid var(--ef-dark-line); }
.ef-order .shop_table .cart_item td { border-bottom:1px solid var(--ef-dark-line); }
.ef-order .shop_table tfoot th { color:var(--ef-dark-text); font-family:var(--ef-font-body); font-weight:400; font-size:14px; padding:8px 0; }
.ef-order .shop_table tfoot .order-total th { font-family:var(--ef-font-ui); font-weight:600; font-size:15px; color:#fff; }
.ef-order .shop_table tfoot .order-total td .amount { font-family:var(--ef-font-ui); font-weight:700; font-size:24px; color:var(--ef-amber-bright); }
.ef-order .product-name { color:#fff; }
.ef-order .product-quantity { color:var(--ef-dark-muted); }
.ef-order #payment { background:transparent; border-radius:0; margin-top:8px; }
.ef-order #payment ul.payment_methods { border:0; padding:0; margin:0 0 8px; list-style:none; }
.ef-order #payment ul.payment_methods li { background:var(--ef-dark-raise); border:1px solid #3d382f; border-radius:11px; padding:14px 16px; margin-bottom:8px; color:var(--ef-dark-text); }
.ef-order #payment ul.payment_methods li label { color:#fff; font-family:var(--ef-font-body); font-weight:500; }
.ef-order #payment .payment_box { background:transparent; color:var(--ef-dark-muted); font-size:13px; padding:8px 2px 0; }
.ef-order #payment .payment_box::before { display:none; }
.ef-order #payment .woocommerce-terms-and-conditions-wrapper { color:var(--ef-dark-text); font-size:13px; margin:10px 0; }
.ef-order #payment a { color:var(--ef-amber-bright); }
.ef-order #place_order { display:flex; justify-content:center; width:100%; background:var(--ef-amber); color:var(--ef-ink); border-radius:var(--ef-r-pill); padding:16px; font-family:var(--ef-font-ui); font-weight:700; font-size:13px; letter-spacing:.8px; text-transform:uppercase; margin-top:10px; }
.ef-order .woocommerce-privacy-policy-text { color:var(--ef-dark-muted); font-size:12px; margin-top:12px; }
.ef-order .woocommerce-privacy-policy-text a { color:var(--ef-amber-bright); }

/* Coupon-Toggle auf der Kasse */
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info { background:var(--ef-tint); }

/* ============================================================================
   INFO-/RECHTSSEITEN
============================================================================ */
.ef-info { grid-template-columns:230px 1fr; gap:44px; align-items:start; padding-bottom:20px; }
.ef-info__ask { margin-top:26px; }
.ef-info__ask strong { font-family:var(--ef-font-ui); }
.ef-info__ask-link { display:inline-block; margin-top:10px; }
.ef-info__article { max-width:680px; }
.ef-info__article h1:first-child, .ef-info__article > h2:first-child { margin-top:0; }

/* ============================================================================
   KONTAKT
============================================================================ */
.ef-contact { grid-template-columns:.85fr 1.15fr; gap:44px; align-items:start; padding-bottom:20px; }
.ef-contact__card { border-radius:16px; padding:36px 34px; }
.ef-contact__row { display:flex; gap:16px; align-items:flex-start; padding:14px 0; border-bottom:1px solid var(--ef-dark-line); }
.ef-contact__ico { width:40px; height:40px; flex:none; background:var(--ef-dark-raise); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--ef-amber-bright); }
.ef-contact__label { display:block; font-family:var(--ef-font-ui); font-weight:600; font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--ef-amber-bright); margin-bottom:3px; }
.ef-contact__val { font-family:var(--ef-font-body); font-size:15px; color:#fff; line-height:1.5; }
.ef-contact__val a { color:#fff; }
.ef-contact__hours { padding-top:18px; font-family:var(--ef-font-body); font-size:14px; color:var(--ef-dark-text); }
.ef-contact__form { padding-top:6px; }
.ef-contact__form > .ef-richtext > h2:first-child { margin-top:0; font-family:var(--ef-font-ui); font-size:26px; }
.ef-contact__form .wpforms-form { max-width:none; }
.ef-contact__form .wpforms-field { padding:0 0 16px !important; }
.ef-contact__form input[type="text"], .ef-contact__form input[type="email"], .ef-contact__form textarea, .ef-contact__form .wpforms-field input {
    background:var(--ef-paper) !important; border:1px solid var(--ef-line) !important; border-radius:var(--ef-r-input) !important; padding:14px 16px !important; font-family:var(--ef-font-body) !important; font-size:15px !important; width:100% !important; color:var(--ef-ink) !important; box-shadow:none !important;
}
.ef-contact__form input:focus, .ef-contact__form textarea:focus { border-color:var(--ef-ink) !important; outline:none !important; }
.ef-contact__form .wpforms-field-label, .ef-contact__form .wpforms-field-label-inline { font-family:var(--ef-font-ui) !important; font-weight:600 !important; font-size:11px !important; letter-spacing:.8px !important; text-transform:uppercase !important; color:var(--ef-muted) !important; }
.ef-contact__form .wpforms-required-label { color:#b3403a !important; }
.ef-contact__form .wpforms-field-description, .ef-contact__form .wpforms-gdpr-text { color:var(--ef-muted-soft); }
.ef-contact__form a { color:var(--ef-label); }
.ef-contact__form .wpforms-submit, .ef-contact__form button[type="submit"] {
    background:var(--ef-ink) !important; color:#fff !important; border:0 !important; border-radius:var(--ef-r-pill) !important; padding:15px 32px !important; font-family:var(--ef-font-ui) !important; font-weight:700 !important; font-size:13px !important; letter-spacing:.8px !important; text-transform:uppercase !important; cursor:pointer !important; box-shadow:none !important;
}
.ef-contact__form .wpforms-submit:hover { transform:translateY(-1px); }

/* ============================================================================
   PRODUKTDETAIL — Ergänzungen (Autor, Zoom, Blick ins Buch, Lightbox)
============================================================================ */
.ef-product__author { font-family:var(--ef-font-ui); font-weight:600; font-size:13px; letter-spacing:1.6px; text-transform:uppercase; color:var(--ef-label); margin-bottom:14px; }
.ef-product__author a { color:var(--ef-label); }
.ef-product__author a:hover { color:var(--ef-ink); text-decoration:underline; text-underline-offset:3px; }
.ef-meta dd a { color:var(--ef-ink); text-decoration:underline; text-underline-offset:2px; text-decoration-color:var(--ef-line); }
.ef-meta dd a:hover { text-decoration-color:var(--ef-amber); }

/* Cover-Bühne als Zoom-Button */
button.ef-stage-cover { border:0; cursor:zoom-in; width:100%; position:relative; }
.ef-zoom__hint { position:absolute; top:14px; right:14px; width:30px; height:30px; border-radius:50%; background:rgba(27,26,23,.6); color:#fff; display:flex; align-items:center; justify-content:center; font-size:18px; opacity:0; transition:opacity .2s; }
button.ef-stage-cover:hover .ef-zoom__hint { opacity:1; }
button.ef-thumb { border:0; cursor:pointer; }

/* „Blick ins Buch" — hervorgehobener Button */
.ef-lookinside { display:inline-flex; align-items:center; gap:9px; background:var(--ef-tint); border:1.5px solid var(--ef-amber); color:var(--ef-amber-ink); border-radius:var(--ef-r-pill); padding:11px 22px; font-family:var(--ef-font-ui); font-weight:700; font-size:12px; letter-spacing:.6px; text-transform:uppercase; margin-bottom:26px; }
.ef-lookinside:hover { background:var(--ef-amber); color:var(--ef-ink); }

/* Lightbox */
.ef-lightbox { position:fixed; inset:0; z-index:200; background:rgba(23,21,15,.92); display:flex; align-items:center; justify-content:center; padding:40px; }
.ef-lightbox[hidden] { display:none; }
.ef-lightbox__img { max-width:min(720px,90vw); max-height:88vh; width:auto; height:auto; object-fit:contain; box-shadow:0 30px 80px rgba(0,0,0,.5); border-radius:4px; }
.ef-lightbox__close { position:absolute; top:24px; right:28px; background:none; border:0; color:#fff; font-size:40px; line-height:1; cursor:pointer; }

/* <picture>-Wrapper (WebP) transparent für Layout halten */
.ef-card__cover picture, .ef-stage-cover picture, .ef-hero__cover-frame picture, .ef-thumb picture { display:contents; }

/* ============================================================================
   BLICK INS BUCH (DearFlip)
============================================================================ */
.ef-flipbook-sec { max-width:none; }
.ef-flipbook { background:var(--ef-tint); border:1px solid var(--ef-line); border-radius:14px; padding:22px; }
.ef-flipbook .df-container, .ef-flipbook ._df_book { margin:0 auto; }
.ef-flipbook__hint { margin-top:14px; font-family:var(--ef-font-ui); font-size:12px; letter-spacing:.4px; color:var(--ef-muted); text-align:center; }
@media (max-width:900px){ .ef-flipbook { padding:12px; } }
/* DearFlip-Steuerung sichtbar machen: Buttons (v.a. Schließen-X) sind sonst grau/weiß auf weiß */
.df-ui-btn { color:#fff !important; background:rgba(27,26,23,.82) !important; border-radius:8px !important; }
.df-ui-btn:hover { background:#1b1a17 !important; }
.df-ui-btn.df-ui-close, .df-ui-close { color:#fff !important; background:#1b1a17 !important; border-radius:50% !important; width:40px !important; height:40px !important; opacity:1 !important; }
.df-ui-btn.disabled, .df-ui-btn[class*="disab"] { opacity:.4 !important; }

/* ============================================================================
   PREISFILTER (funktional)
============================================================================ */
.ef-pricefilter { margin-top:2px; }
.ef-pricefilter__row { display:flex; gap:10px; }
.ef-pricefilter__field { flex:1; display:flex; flex-direction:column; gap:5px; font-family:var(--ef-font-ui); font-size:10px; font-weight:600; letter-spacing:.8px; text-transform:uppercase; color:var(--ef-muted); }
.ef-pricefilter__field input { width:100%; background:var(--ef-paper); border:1px solid var(--ef-line); border-radius:var(--ef-r-input); padding:9px 11px; font-family:var(--ef-font-body); font-size:15px; color:var(--ef-ink); -moz-appearance:textfield; }
.ef-pricefilter__field input::-webkit-outer-spin-button, .ef-pricefilter__field input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.ef-pricefilter__field input:focus { border-color:var(--ef-ink); outline:none; }
.ef-pricefilter__actions { display:flex; align-items:center; gap:14px; margin-top:12px; }
.ef-pricefilter__btn { padding:10px 22px; font-size:12px; }
.ef-pricefilter__reset { font-family:var(--ef-font-ui); font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--ef-muted); text-decoration:underline; text-underline-offset:2px; }
.ef-pricefilter__reset:hover { color:var(--ef-ink); }

/* ============================================================================
   SUCHE
============================================================================ */
.ef-searchlist { list-style:none; margin:0; padding:0; border-top:1px solid var(--ef-line); max-width:720px; }
.ef-searchlist li { border-bottom:1px solid var(--ef-line); }
.ef-searchlist a { display:block; padding:15px 2px; font-family:var(--ef-font-serif,var(--ef-font-body)); font-size:19px; color:var(--ef-ink); }
.ef-searchlist a:hover { color:var(--ef-amber-ink); padding-left:8px; transition:padding .15s; }
.ef-noresult .ef-searchform { display:flex; gap:10px; margin-top:22px; }
.ef-noresult .ef-searchform input { flex:1; background:var(--ef-paper); border:1px solid var(--ef-line); border-radius:var(--ef-r-input); padding:13px 16px; font-family:var(--ef-font-body); font-size:15px; color:var(--ef-ink); }
.ef-noresult .ef-searchform input:focus { border-color:var(--ef-ink); outline:none; }

/* ============================================================================
   MEIN KONTO (WooCommerce myaccount — kein Template-Override, nur Styling)
============================================================================ */
/* Eingeloggtes Dashboard: Navigation + Inhalt nebeneinander */
body.logged-in.woocommerce-account .ef-main .woocommerce { display:grid; grid-template-columns:230px 1fr; gap:48px; align-items:start; }
/* Ausgeloggt: Login + Registrierung zweispaltig */
.woocommerce-account .ef-main .u-columns.col2-set { display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:start; }
.woocommerce-account .ef-main .col2-set h2 { font-family:var(--ef-font-serif,var(--ef-font-body)); font-size:24px; margin:0 0 18px; }
.woocommerce-MyAccount-navigation ul { list-style:none; margin:0; padding:0; border-top:1px solid var(--ef-line); }
.woocommerce-MyAccount-navigation li { border-bottom:1px solid var(--ef-line); }
.woocommerce-MyAccount-navigation li a { display:block; padding:13px 4px; font-family:var(--ef-font-ui); font-weight:600; font-size:12px; letter-spacing:.9px; text-transform:uppercase; color:var(--ef-muted); }
.woocommerce-MyAccount-navigation li.is-active a, .woocommerce-MyAccount-navigation li a:hover { color:var(--ef-ink); }
.woocommerce-MyAccount-navigation li.is-active { border-left:2px solid var(--ef-amber); }
.woocommerce-MyAccount-navigation li.is-active a { padding-left:12px; }
.woocommerce-MyAccount-content { min-width:0; }
.woocommerce-MyAccount-content p { color:var(--ef-muted-soft); }
/* Formulare (Login/Register/Adressen) */
.ef-main .woocommerce form .form-row { display:flex; flex-direction:column; gap:6px; margin:0 0 18px; }
.ef-main .woocommerce form label { font-family:var(--ef-font-ui); font-weight:600; font-size:11px; letter-spacing:.8px; text-transform:uppercase; color:var(--ef-muted); }
.ef-main .woocommerce form .woocommerce-Input, .ef-main .woocommerce form input.input-text, .ef-main .woocommerce form input[type="text"], .ef-main .woocommerce form input[type="email"], .ef-main .woocommerce form input[type="password"], .ef-main .woocommerce form input[type="tel"], .ef-main .woocommerce form select {
    background:var(--ef-paper); border:1px solid var(--ef-line); border-radius:var(--ef-r-input); padding:13px 15px; font-family:var(--ef-font-body); font-size:15px; color:var(--ef-ink); width:100%; box-shadow:none; }
.ef-main .woocommerce form input:focus, .ef-main .woocommerce form select:focus { border-color:var(--ef-ink); outline:none; }
.ef-main .woocommerce .woocommerce-form-login__rememberme, .ef-main .woocommerce form .woocommerce-form__label-for-checkbox { flex-direction:row; align-items:center; gap:8px; text-transform:none; letter-spacing:0; font-weight:400; color:var(--ef-muted-soft); }
.ef-main .woocommerce .button, .ef-main .woocommerce button.button, .ef-main .woocommerce input.button, .ef-main .woocommerce .woocommerce-Button {
    background:var(--ef-ink); color:#fff; border:0; border-radius:var(--ef-r-pill); padding:14px 30px; font-family:var(--ef-font-ui); font-weight:700; font-size:12px; letter-spacing:.8px; text-transform:uppercase; cursor:pointer; box-shadow:none; }
.ef-main .woocommerce .button:hover { transform:translateY(-1px); }
.woocommerce-account .woocommerce-form-login__submit { margin-top:4px; }
.ef-main .woocommerce .lost_password a { color:var(--ef-label); font-size:13px; }
/* Tabellen (Bestellungen, Adressen) */
.ef-main .woocommerce table.shop_table, .ef-main .woocommerce table.woocommerce-orders-table, .ef-main .woocommerce table.woocommerce-table { width:100%; border-collapse:collapse; }
.ef-main .woocommerce table.shop_table th { font-family:var(--ef-font-ui); font-weight:600; font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--ef-muted); text-align:left; padding:12px 10px; border-bottom:1px solid var(--ef-line); }
.ef-main .woocommerce table.shop_table td { padding:14px 10px; border-bottom:1px solid var(--ef-line); font-size:15px; color:var(--ef-ink); }
.ef-main .woocommerce .woocommerce-Address { border:1px solid var(--ef-line); border-radius:12px; padding:20px 22px; margin-top:12px; }
.ef-main .woocommerce .woocommerce-Address address { font-style:normal; color:var(--ef-ink); line-height:1.6; }
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Message, .woocommerce-account .woocommerce-info { background:var(--ef-tint); border:0; border-left:3px solid var(--ef-amber); border-radius:8px; padding:14px 18px; color:var(--ef-ink); box-shadow:none; }
.woocommerce-account .woocommerce-info::before { content:none; }

/* ============================================================================
   404
============================================================================ */
.ef-404 { text-align:center; padding-top:56px; padding-bottom:64px; }
.ef-404__num { font-family:var(--ef-font-ui); font-weight:700; font-size:92px; letter-spacing:2px; color:var(--ef-amber); line-height:1; margin-bottom:6px; }
.ef-404__search { max-width:460px; margin:0 auto 22px; display:flex; gap:10px; }
.ef-404__search input { flex:1; min-width:0; background:var(--ef-paper); border:1px solid var(--ef-line); border-radius:var(--ef-r-input); padding:13px 16px; font-family:var(--ef-font-body); font-size:15px; color:var(--ef-ink); }
.ef-404__search input:focus { border-color:var(--ef-ink); outline:none; }
.ef-404__links { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ============================================================================
   COOKIE-HINWEIS (eigene Lösung, kein Plugin)
============================================================================ */
.ef-cookie { position:fixed; left:0; right:0; bottom:0; z-index:140; background:var(--ef-ink-deep); box-shadow:0 -10px 30px rgba(0,0,0,.28); }
.ef-cookie[hidden] { display:none; }
.ef-cookie__inner { max-width:var(--ef-maxw); margin:0 auto; padding:15px 24px; display:flex; align-items:center; gap:26px; }
.ef-cookie__text { margin:0; font-family:var(--ef-font-body); font-size:13.5px; line-height:1.55; color:#e8e2d4; }
.ef-cookie__text strong { color:#fff; }
.ef-cookie__text a { color:var(--ef-amber-bright); text-decoration:underline; text-underline-offset:2px; }
.ef-cookie__actions { flex:none; }
.ef-cookie__ok { padding:12px 28px; font-size:12px; white-space:nowrap; }
@media (max-width:900px){
    .ef-cookie__inner { flex-direction:column; align-items:stretch; gap:12px; padding:15px 20px calc(15px + env(safe-area-inset-bottom)); }
    .ef-cookie__ok { width:100%; }
}

/* ============================================================================
   MOBILE KAUF-LEISTE
============================================================================ */
.ef-buybar { display:none; }

/* ============================================================================
   Responsive
============================================================================ */
@media (max-width: 900px) {
    body.logged-in.woocommerce-account .ef-main .woocommerce { grid-template-columns:1fr; gap:24px; }
    .woocommerce-account .ef-main .u-columns.col2-set { grid-template-columns:1fr; gap:32px; }
    /* Mobile Kauf-Leiste */
    .ef-buybar { display:flex; position:fixed; left:0; right:0; bottom:0; z-index:120; align-items:center; gap:14px; padding:11px 16px calc(11px + env(safe-area-inset-bottom)); background:rgba(253,251,247,.96); backdrop-filter:blur(8px); border-top:1px solid var(--ef-line); box-shadow:0 -8px 24px rgba(27,26,23,.08); }
    .ef-buybar[hidden] { display:none; }
    .ef-buybar__info { display:flex; flex-direction:column; min-width:0; flex:1; }
    .ef-buybar__title { font-family:var(--ef-font-ui); font-size:11px; font-weight:600; letter-spacing:.6px; text-transform:uppercase; color:var(--ef-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .ef-buybar__price { font-family:var(--ef-font-serif,var(--ef-font-body)); font-size:19px; color:var(--ef-ink); }
    .ef-buybar__price .amount { font-weight:600; }
    .ef-buybar__btn { flex:none; padding:13px 20px; font-size:12px; white-space:nowrap; }
    /* Platz, damit die fixe Leiste nichts überdeckt */
    body.single-product .ef-footer { padding-bottom:84px; }
    .ef-burger { display:flex; }
    .ef-header__right { gap:10px; }
    .ef-section { padding:30px 20px; }
    /* Nicht-Section-Container (.ef-page ohne Innenabstand) brauchen mobil einen Seitenrand */
    .ef-shop, .ef-product, .ef-contact, .ef-info, .ef-cart, .ef-checkout { padding-left:20px; padding-right:20px; }
    /* Sortier-Dropdown darf nicht überlaufen (sonst horizontaler Scroll) */
    .ef-shop-head__sort { width:100%; }
    .ef-shop-head__sort .woocommerce-ordering { flex:1; min-width:0; margin:0; }
    .ef-shop-head__sort select, .woocommerce-ordering select { width:100%; min-width:0; max-width:100%; }
    /* Karten-Fuß umbrechen, damit Preis + „Mehr lesen" nicht quetschen */
    .ef-card__foot { flex-wrap:wrap; row-gap:6px; }
    .ef-footer__cols { flex-direction:column; }
    .ef-shop, .ef-product { grid-template-columns:1fr; gap:28px; }
    .ef-product__stage { padding:24px 20px; max-width:440px; margin:0 auto; }
    .ef-stage-img { max-width:100%; max-height:460px; }
    .ef-product__title { font-size:30px; }
    .ef-add__btn { min-width:0; }
    .ef-shop__side { order:2; }
    .ef-pagehead { padding-left:20px; padding-right:20px; }
    .ef-cart, .ef-checkout { grid-template-columns:1fr; gap:28px; }
    .ef-cart__head { display:none; }
    .ef-cart__row { grid-template-columns:1fr auto; grid-template-areas:"prod remove" "qty price"; gap:12px 16px; }
    .ef-cart__prod { grid-area:prod; } .ef-cart__remove { grid-area:remove; } .ef-cart__qty { grid-area:qty; justify-self:start; } .ef-cart__price { grid-area:price; align-self:center; }
    .ef-reassure { grid-template-columns:1fr; }
    .ef-reassure__col { border-right:0; border-bottom:1px solid var(--ef-line); }
    .ef-reassure__col:last-child { border-bottom:0; }
    .ef-summary, .ef-order { position:static; }
    .ef-h1 { font-size:32px; }
    /* Produktdetail mobil */
    .ef-meta { grid-template-columns:1fr; }
    .ef-meta__row:nth-child(odd) { padding-right:0; }
    .ef-product__pricerow { align-items:flex-start; }
    .ef-product__pricerow .ef-stock { margin-left:0; width:100%; margin-top:4px; }
    .ef-product__price { font-size:28px; }
    .ef-add { flex-wrap:wrap; }
    .ef-add__btn { order:3; width:100%; flex:1 0 100%; }
    .ef-lightbox { padding:16px; }
    .ef-info { grid-template-columns:1fr; }
    .ef-contact__card { padding:26px 22px; }
    /* Info-Sidebar mobil: kompakter oben */
    .ef-info__side { margin-bottom:8px; }
}
