/* ===============================
   START Globale Design Variables
   =============================== */

:root {
    /* Brand */
    --c-primary: #990099;
    --c-accent: #EF886A;

    /* Neutrals */
    --c-white: #ffffff;
    --c-muted: #909090;
    --c-bg-soft: #FCFCFC;

    /* Borders */
    --c-border-subtle: rgba(173, 176, 182, 0.3);

    /* Radii / sizes */
    --r-1: 6px;
    --h-input: 30px;
    --h-qty: 28px;
    --h-control: 34px;

    /* Typography */
    --fz-sm: 13px;
    --lh-base: 1.2;

    /* Buttons */
    --btn-pad: 0.6em 1.4em;
    --btn-disabled-opacity: 0.4;

    /* Gradients */
    --g-primary: linear-gradient(to right, var(--c-primary), var(--c-accent));
    --g-primary-rev: linear-gradient(to right, var(--c-accent), var(--c-primary));
}

/* ==============================
   ENDE Globale Design Variables
   ============================== */

/* =========================
   START Generelle Settings
   ========================= */

/* 1) reCAPTCHA Bade ausblenden */
.grecaptcha-badge {
    opacity: 0;
}

/* 2) H1 wie H4 stylen */
.bn-h1-to-h4-style {
    font-family: "Open Sans", sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 26px;
    margin: 0 0 1rem 0;
}

/* 3) H2 wie H4 stylen */
.bn-h2-to-h4-style {
    font-family: "Open Sans", sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 26px;
    margin: 0 0 1rem 0;
}

/* 4) Hinweisbox (Service-Info) */
.bn-note {
    margin-top: 1.8em;
    margin-bottom: 1.3em;
    padding: 0.9em 1em;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-left: 4px solid var(--c-primary);
    background: rgba(0, 0, 0, 0.02);
    border-radius: 10px;
    font-size: 0.95em;
    line-height: 1.45;
}

.bn-note strong {
    font-weight: 600;
}

/* ========================
   ENDE Generelle Settings
   ======================== */

/* ===================================
   START Globale WooCommerce Settings
   =================================== */

/* 1) Generell: Abstand nach der Währung */
.woocommerce-Price-currencySymbol {
    margin-right: 3px;
}

/* 2) Mini-Cart: Remove als runder Button */
.wc-shopping-cart .cart_list .remove {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;

    line-height: 1;
    color: var(--c-white) !important;

    background: var(--c-primary) !important;
    border-radius: 50%;
    border: none;
    text-decoration: none !important;
}

/* 3) Mini-Cart: Remove als runder Button - Hover */
.wc-shopping-cart .cart_list .remove:hover {
    background: var(--c-accent) !important;
    color: var(--c-white) !important;
}

/* 4) Mini-Cart: Produktname-Link Hover */
.wc-shopping-cart .cart_list.product_list_widget li a:not(.remove):hover {
    color: var(--c-primary) !important;
    text-decoration: none !important;
    background: none !important;
    background-image: none !important;
    -webkit-text-fill-color: var(--c-primary) !important;
}

/* 5) Related Products – Produkttitel Hover */
.related-product .product-title:hover {
    background-image: none !important;
    color: var(--c-primary) !important;
}

/* 6) WooCommerce Buttons Grundzustand */
.single_add_to_cart_button,
.dt-wc-btn.wc-cart-button.button,
.checkout-button.button,
.woocommerce button.button,
.woocommerce .return-to-shop a.button.wc-backward {
    display: inline-block !important;
    appearance: none !important;
    -webkit-appearance: none !important;

    padding: var(--btn-pad) !important;
    border-radius: var(--r-1) !important;

    border: none !important;
    box-shadow: none !important;
    font-weight: 600;
    line-height: var(--lh-base);
    box-sizing: border-box !important;
    font-size: var(--fz-sm) !important;
    min-height: 20px !important;
    vertical-align: middle !important;
    justify-content: center !important;
    align-items: center !important;
    display: flex !important;
    text-align: center !important;
}

/* 7) WooCommerce Buttons — Hover */
.single_add_to_cart_button:hover,
.dt-wc-btn.wc-cart-button.button:hover,
.checkout-button.button:hover,
.woocommerce .order-again a.button:hover,
a.woocommerce-MyAccount-downloads-file.button.alt:hover,
.woocommerce button.button:hover,
.woocommerce .return-to-shop a.button.wc-backward:hover,
.wc-shopping-cart .button.view-cart:hover,
.wc-shopping-cart .button.checkout:hover {
    background-image: var(--g-primary-rev) !important;
}

/* ==================================
   ENDE Globale WooCommerce Settings
   ================================== */

/* =================================
   START Latepoint Buchungsformular
   ================================= */

#customer_custom_fields_cf_oojzvstw.os-form-control {
    min-height: calc(1.5em * 5) !important;
}

input#customer_first_name.required.os-form-control:focus,
input#customer_last_name.required.os-form-control:focus,
input#customer_email.required.os-form-control:focus,
textarea#customer_notes.os-form-control:focus,
textarea#customer_custom_fields_cf_oojzvstw.os-form-control:focus,
select#booking_custom_fields_cf_qlei1bsh.required.os-form-control:focus {
    border-color: var(--c-primary) !important;
}

/* ================================
   ENDE Latepoint Buchungsformular
   ================================ */

/* ======================
   START WPBakery Tweaks
   ====================== */

/* WPBakery Button: Textfarbe in allen States erzwingen */
.vc_btn3-container .vc_btn3.vc_general,
.vc_btn3-container .vc_btn3.vc_general:focus,
.vc_btn3-container .vc_btn3.vc_general:active,
.vc_btn3-container .vc_btn3.vc_general:focus-visible {
    color: var(--c-white) !important;
}

/* WPBakery Button: Textfarbe in allen States erzwingen (Text in einem span) */
.vc_btn3-container .vc_btn3.vc_general span,
.vc_btn3-container .vc_btn3.vc_general:focus span,
.vc_btn3-container .vc_btn3.vc_general:active span,
.vc_btn3-container .vc_btn3.vc_general:focus-visible span {
    color: var(--c-white) !important;
}

/* WPBakery Button: Iconfarbe in allen States erzwingen */
.vc_btn3-container .vc_btn3.vc_general .vc_btn3-icon {
    color: var(--c-white) !important;
    fill: var(--c-white) !important;
}

/* WPBakery Button: immer gleichen Border */
.vc_btn3-container .vc_btn3.vc_general {
    border-style: solid !important;
    border-width: 1px !important;
    border-color: transparent !important;
    /* unsichtbar, aber vorhanden */
}

/* WPBakery Button: immer gleichen Border (Fokus / Hover) */
.vc_btn3-container .vc_btn3.vc_general:focus,
.vc_btn3-container .vc_btn3.vc_general:focus-visible,
.vc_btn3-container .vc_btn3.vc_general:active,
.vc_btn3-container .vc_btn3.vc_general:hover {
    border-width: 1px !important;
    border-color: transparent !important;
}

.vc_btn3-container .vc_btn3.vc_general {
    box-sizing: border-box !important;
}

/* ======================
   ENDE WPBakery Tweaks
   ====================== */

/* ====================
   START Search Widget
   ==================== */

/* Mini Search – Grundzustand */
.searchform.mini-widget-searchform input[type="search"],
.searchform.mini-widget-searchform input[type="text"] {
    border-radius: var(--r-1) !important;
    border: 1px solid var(--c-border-subtle) !important;
    background-color: var(--c-bg-soft) !important;
}

/* Mini Search – Fokus */
.searchform.mini-widget-searchform input[type="search"]:focus,
.searchform.mini-widget-searchform input[type="text"]:focus {
    border-color: var(--c-primary) !important;
}

/* Mini Search Icon – Grundzustand */
.searchform.mini-widget-searchform a.search-icon i::before {
    color: var(--c-muted) !important;
}

/* Mini Search Icon – Hover */
.searchform.mini-widget-searchform a.search-icon:hover i::before {
    color: var(--c-primary) !important;
}

/* Wrapper positionieren */
.mini-search .searchform {
  position: relative;
}

/* Input rechts Platz schaffen (damit nichts überlappt) */
.mini-search .searchform .field.searchform-s {
  padding-right: 52px !important;
  box-sizing: border-box;
}

/* Such-Icon als echter 48x48-Klickbereich positionieren */
.mini-search .searchform a.search-icon {
  position: absolute;
  right: 6px;                     
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;

  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
}

/* Icon selbst nicht “verziehen” */
.mini-search .searchform a.search-icon i {
  line-height: 1;
}

/* dezenter Fokus */
.mini-search .searchform a.search-icon:focus-visible {
  outline: 2px solid rgba(0,0,0,0.25);
  outline-offset: 2px;
}

/* ===================
   ENDE Search Widget
   =================== */

/* ================
   START Complianz
   ================ */

/* 1) Complianz Accept Button — Gradient */
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-accept {
    background-image: var(--g-primary) !important;
    background-color: transparent !important;

    border: none !important;
    border-color: transparent !important;
    box-shadow: none !important;

    color: var(--c-white) !important;
}

/* 2) Complianz Accept Button Hover — Verlauf umkehren */
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-accept:hover,
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-accept:focus {
    background-image: var(--g-primary-rev) !important;
    border: none !important;
    border-color: transparent !important;
    box-shadow: none !important;
}

/* ================
   ENDE Complianz
   ================ */

/* ===================
   START Mobile Fixes
   =================== */

/* 1) Mobile Horizontal Scrolling Fix */
@media (max-width: 1024px) {

    html,
    body {
        overflow-x: clip;
    }

    /* Fallback */
    @supports not (overflow: clip) {

        html,
        body {
            overflow-x: hidden;
        }
    }
}

/* 2) Tablets & iPad Landscape mode Scrolling Fix */
@media (orientation: landscape) and (max-width: 1366px) {

    html,
    body {
        overflow-x: clip;
    }

    /* Fallback */
    @supports not (overflow: clip) {

        html,
        body {
            overflow-x: hidden;
        }
    }
}

/* 3) Floating "Manage consent" Button von Complianz auf mobilen Geräten und Tablets ausblenden */
@media (hover: none) and (pointer: coarse) and (min-width: 768px) and (max-width: 1400px) {
    #cmplz-manage-consent {
        display: none !important;
    }
}

/* ==================
   ENDe Mobile Fixes
   ================== */