body {
    background-color: #ffffff !important;
    font-family: 'Open Sans', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;    
    font-style: normal;
    font-weight: 400;
    overflow-x: hidden; /* besser als komplett hidden */
}

a.nice-deco::before, a.nice-deco::after {
 display: none;
}

a, 
a:hover, 
a:active {
  text-decoration: none !important;
}

a {
    text-decoration: none !important;
    color: #111;

    transition:
        color 0.2s ease,
        opacity 0.2s ease;
}

a:hover {
    color: #000;
    opacity: 0.7;
}

a:active {
    opacity: 0.5;
}

/* inter-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/inter-v20-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* inter-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/inter-v20-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* inter-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/inter-v20-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* open-sans-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/open-sans-v44-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/open-sans-v44-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-500italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 500;
  src: url('../fonts/open-sans-v44-latin-500italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* Headlines */

h1 {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif !important;
}

h2 {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif !important;
  font-weight: 400;
  font-size: 2.2rem;
  line-height: 2.6rem;
  letter-spacing: -0.02em;
}

.main-headliner {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif !important;
font-weight: normal;
font-size: 2.2rem !important;
color: #272727;
width: 100%;
margin: 0 auto;
margin-bottom: 20px;

  line-height: 2.8rem !important;

}

.intro-text {
    font-size: 16px;
    letter-spacing: .01em;
    line-height: 1.3;
    width: 53%;
    margin: 0 auto;
}

@media (min-width: 768px) {
.main-headliner {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif !important;
  font-weight: 500;
  font-size: 48px;
  color: #272727;
  width: 70%;
  margin-bottom: 20px;
}
}

/* =========================
   🖥️ Desktop / große Bildschirme
   ========================= */
@media (min-width: 1200px) {
.main-headliner {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif !important;
  font-weight: 500;
  font-size: 2.4rem !important;
  line-height: 2.6rem !important;
  color: #272727;
  width: 42%;
  margin-bottom: 20px;
}
}


@media (min-width: 1300px) {
    .container {
        max-width: 100%;
    }
}

/* CONTAINER SIZES */

.full-size-container {
width:100vw;
margin-left:calc(50% - 50vw);   
}

.mid-size-content {
    width: 90% !important;
    margin: 0 auto;
}

.mid-size-content p {
    font-size: 16px;
}

.mid-size-container {
    width: 90% !important;
    margin: 0 auto;
}


.mid-size-content {
    display: flex !important;
    align-items: center !important;
}

.product-detail-container {
    width: 90% !important;
    margin: 0 auto;
}

.register-container {
    width: 90% !important;
    margin: 0 auto;
 }

.login-container {
    width: 90% !important;
    margin: 0 auto;
 }

.account-container {
    width: 90% !important;
    margin: 0 auto;
 }

.contact-container {
    width: 90% !important;
    margin: 0 auto;
 }

.cart-container {
    width: 90% !important;
    margin: 0 auto;
 }

.checkout-container { 
    width: 90% !important;
    margin: 0 auto;
}

.cms-page-container {
    max-width: 100%;
    margin: 0 auto;
}

.cms-page-container .container {
      max-width: 100% !important;
    margin: 0 auto;
}

.breadcrumb-container {

width: 90% !important;
}

/* Logo */

.navbar-brand img {
    max-width: 12vw !important;
    object-fit: contain;
}

/* TOP BAR */
/* Header */
.container-fluid-xl {
}

.container, .container-fluid, .container-xl, .container-lg, .container-md, .container-sm {
    width: 100%;
    padding-right: 0;
    padding-left: 0;
    margin-right: auto;
    margin-left: auto;
}

#header-top-bar, header {
    height: 30px;

    background-color: #000000 !important;
    color: #525252;
    text-transform: uppercase;
}

#header-top-bar a:not(.dropdown-item):not(.btn), header a:not(.dropdown-item):not(.btn) {
    text-decoration: none;
    color: #ffffff;
}

#jtl-nav-wrapper {
    position: relative;
    min-height: 68vh;
   overflow: visible !important;}

/* =========================================
   HERO BACKGROUND
========================================= */

.header-hero {
    position: absolute;
    inset: 0;
    z-index: 0;

    background: url('/templates/NOVAChild/img/dachtraeger-profi-header-thule.png') center center / cover no-repeat;
}

.header-hero__overlay {
    position: absolute;
    inset: 0;

    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.78) 0%,
            rgba(255, 255, 255, 0.62) 10%,
            rgba(255, 255, 255, 0.38) 22%,
            rgba(255, 255, 255, 0.14) 38%,
            rgba(0, 0, 0, 0.08) 58%,
            rgba(0, 0, 0, 0.22) 100%
        ),

        linear-gradient(
            90deg,
            rgba(0, 0, 0, 0.26) 0%,
            rgba(0, 0, 0, 0.14) 28%,
            rgba(0, 0, 0, 0.04) 60%,
            rgba(0, 0, 0, 0.00) 100%
        );

    pointer-events: none;
}



.header-hero__text {
    font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
    position: absolute;
    bottom: 20px;
    left: 1.3%;
    width: 40%;

    color: #fff;
    font-size: 4.2rem;
    font-weight: normal;
    line-height: 4.8rem;
    z-index: 2;


}

@media (max-width: 991px) {

    .header-hero__text {
        width: 90%;

        left: 5%;
        bottom: 24px;

        font-size: clamp(1.8rem, 7vw, 3rem);
        line-height: 1.1;

        text-align: left;
    }

}

/* =========================================
   HEADER CONTENT + NAV
========================================= */


.header-inner {
    position: relative;
    isolation: isolate;

    display: flex !important;
    align-items: center;
    flex-wrap: nowrap !important;

    background: transparent !important;
    border-bottom: 0 !important;
    box-shadow: none !important;
}

.header-inner::before {
    content: "";

    position: absolute;
    inset: 0;
    z-index: -1;

    background: rgba(255, 255, 255, 0.34);

    backdrop-filter: blur(22px) saturate(180%);
    -webkit-backdrop-filter: blur(22px) saturate(180%);

    -webkit-mask-image: linear-gradient(
        to bottom,
        #000 0%,
        #000 45%,
        rgba(0,0,0,0.55) 72%,
        transparent 100%
    );
    mask-image: linear-gradient(
        to bottom,
        #000 0%,
        #000 45%,
        rgba(0,0,0,0.55) 72%,
        transparent 100%
    );

    pointer-events: none;
}

/* =========================================
   TRANSPARENZ
========================================= */

#jtl-nav-wrapper,
#jtl-nav-wrapper .container-fluid,
#jtl-nav-wrapper .navbar,
#jtl-nav-wrapper .toggler-logo-wrapper {
    background: transparent !important;
}

/* =========================================
   TEXT WEISS
========================================= */

#jtl-nav-wrapper a,
#jtl-nav-wrapper span,
#jtl-nav-wrapper .nav-link {
	color: #1f2937  !important;
	font-weight: 600 !important;
	font-size: 1.1em;
        font-stretch: 90%;
        line-height: 1.4;
}

#jtl-nav-wrapper .navbar-toggler-icon {
    filter: invert(1);
}

/* =========================================
   CONTENT ABSTAND
========================================= */
.lg-min-w-lg {
	min-width: 100%;
}

#main-wrapper {
    margin-top: 8vh;
}


.dropdown-menu {
        min-width: 300px;
        overflow: visible !important;
	font-size: 0.7375rem !important;
    	color: #070707 !important;
	text-decoration: none !important;
}

@media (min-width: 992px) {
    header .submenu-headline-toplevel {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
        font-size: 1rem;
        border: none;
    }
}


/* =========================================================
   MODERN GLASSY NAVIGATION / MEGA MENU
========================================================= */


/* ---------------------------------------------------------
   NAV WRAPPER GLASS EFFECT
--------------------------------------------------------- */

#jtl-nav-wrapper.hover-active,
#jtl-nav-wrapper.hover-active .container-fluid,
#jtl-nav-wrapper.hover-active .navbar,
#jtl-nav-wrapper.hover-active .toggler-logo-wrapper {
    background: rgba(255, 255, 255, 0.25) !important;

    backdrop-filter: blur(20px) saturate(160%);
    -webkit-backdrop-filter: blur(20px) saturate(160%);
}


/* ---------------------------------------------------------
   NAVIGATION CENTER
--------------------------------------------------------- */

@media (min-width: 992px) {

    header #mainNavigation {
        display: flex !important;
        justify-content: center;

        width: 100% !important;
    }

    header #mainNavigation .navbar-nav {
        margin: 0 auto !important;

        justify-content: center;

        width: 100% !important;
    }
}


/* ---------------------------------------------------------
   NAVIGATION LINKS
--------------------------------------------------------- */

#jtl-nav-wrapper a,
#jtl-nav-wrapper span,
#jtl-nav-wrapper .nav-link {
    color: #000000 !important;

    font-weight: 600 !important;

    font-size: 1.1em;

    font-stretch: 90%;

    line-height: 1 !important;
}


/* ---------------------------------------------------------
   ACTIVE MENU ITEMS
--------------------------------------------------------- */

header .navbar-nav > .nav-item.active > .nav-link,
header .navbar-nav > .nav-item > .nav-link.active,
header .navbar-nav > .nav-item.show > .nav-link,
#jtl-nav-wrapper .nav-item.active > .nav-link,
#jtl-nav-wrapper .nav-link.active,
#jtl-nav-wrapper .nav-item.show > .nav-link {
    font-weight: 700 !important;
}


/* ---------------------------------------------------------
   TOP LEVEL NAV HOVER
--------------------------------------------------------- */

@media (min-width: 992px) {

    header .navbar-nav > .nav-item > .nav-link {
        position: relative;

        font-weight: 400;

        transition: font-weight .15s ease;
    }

    header .navbar-nav > .nav-item:hover > .nav-link,
    header .navbar-nav > .nav-item.active > .nav-link,
    header .navbar-nav > .nav-item > .nav-link.active,
    header .navbar-nav > .nav-item.show > .nav-link {
        font-weight: 700 !important;
    }

    header .navbar-nav > .nav-item > .nav-link::before {
        display: none !important;

        content: none !important;
    }
}


/* ---------------------------------------------------------
   GLASSY MEGA MENU
--------------------------------------------------------- */

@media (min-width: 992px) {

    .dropdown-menu[id^="category-dropdown-"] {
        width: min(1180px, calc(100vw - 80px)) !important;

        left: 50% !important;
        transform: translateX(-50%) !important;

        background: rgba(255,255,255,0.64) !important;

        backdrop-filter: blur(30px) saturate(180%);
        -webkit-backdrop-filter: blur(30px) saturate(180%);

        border: 1px solid rgba(255,255,255,0.55) !important;

        border-radius: 34px !important;

        box-shadow:
            0 24px 80px rgba(0,0,0,0.16),
            inset 0 1px 1px rgba(255,255,255,0.65);

        padding: 34px !important;

        overflow: hidden !important;
    }

    .dropdown-menu[id^="category-dropdown-"] .dropdown-body,
    .dropdown-menu[id^="category-dropdown-"] .subcategory-wrapper {
        background: transparent !important;

        padding: 0 !important;
    }


    /* ---------------------------------------------------------
       GRID
    --------------------------------------------------------- */

    .dropdown-menu[id^="category-dropdown-"] .row.nav {
        display: grid !important;

        grid-template-columns: repeat(4, minmax(0, 1fr));

        gap: 0 34px !important;

        margin: 0 !important;

        justify-content: initial !important;
    }

    .dropdown-menu[id^="category-dropdown-"] .col,
    .dropdown-menu[id^="category-dropdown-"] .nav-item-lg-m {
        width: auto !important;
        max-width: none !important;

        flex: none !important;

        padding: 0 !important;
        margin: 0 !important;
    }

    .dropdown-menu[id^="category-dropdown-"] .nav-item {
        display: block !important;

        margin: 0 !important;

        background: transparent !important;
    }


    /* ---------------------------------------------------------
       CLEAN SUBMENU LINKS
    --------------------------------------------------------- */

    .dropdown-menu[id^="category-dropdown-"] .categories-recursive-link,
    .dropdown-menu[id^="category-dropdown-"] .nav-link {
        display: flex !important;

        align-items: center;
        justify-content: space-between !important;

        width: 100%;

        min-height: 54px !important;
        height: auto !important;

        padding: 15px 4px !important;

        background: transparent !important;
        background-color: transparent !important;

        border: 0 !important;

        border-bottom: 1px solid rgba(7,16,20,0.10) !important;

        border-radius: 0 !important;

        box-shadow: none !important;

        color: #071014 !important;

        text-align: left !important;
        text-decoration: none !important;

        transform: none !important;

        opacity: 1 !important;

        transition:
            color .22s ease,
            border-color .22s ease,
            opacity .22s ease;
    }


    /* ---------------------------------------------------------
       HOVER / ACTIVE
    --------------------------------------------------------- */

    .dropdown-menu[id^="category-dropdown-"] .categories-recursive-link:hover,
    .dropdown-menu[id^="category-dropdown-"] .categories-recursive-link:focus,
    .dropdown-menu[id^="category-dropdown-"] .categories-recursive-link:active,
    .dropdown-menu[id^="category-dropdown-"] .categories-recursive-link.active,
    .dropdown-menu[id^="category-dropdown-"] .categories-recursive-link.show,

    .dropdown-menu[id^="category-dropdown-"] .nav-link:hover,
    .dropdown-menu[id^="category-dropdown-"] .nav-link:focus,
    .dropdown-menu[id^="category-dropdown-"] .nav-link:active,
    .dropdown-menu[id^="category-dropdown-"] .nav-link.active,
    .dropdown-menu[id^="category-dropdown-"] .nav-link.show {
        background: transparent !important;
        background-color: transparent !important;

        border-bottom-color: rgba(7,16,20,0.26) !important;

        color: #7db928 !important;

        box-shadow: none !important;

        transform: none !important;

        opacity: 1 !important;
    }


    /* ---------------------------------------------------------
       TEXT
    --------------------------------------------------------- */

    .dropdown-menu[id^="category-dropdown-"] .text-truncate {
        display: block !important;

        width: 100%;

        white-space: normal !important;

        overflow: visible !important;

        text-overflow: unset !important;

        color: inherit !important;

        text-align: left !important;

        font-size: 15px;

        font-weight: 650;

        line-height: 1.3;

        letter-spacing: -0.015em;
    }

    .dropdown-menu[id^="category-dropdown-"] .dropdown-toggle::after {
        margin-left: 12px;

        opacity: .35;

        transition: opacity .2s ease;
    }

    .dropdown-menu[id^="category-dropdown-"] .nav-link:hover.dropdown-toggle::after {
        opacity: .7;
    }
}


/* ---------------------------------------------------------
   REMOVE / HIDE NESTED DROPDOWN INSIDE MEGA MENU
--------------------------------------------------------- */

@media (min-width: 992px) {

    .dropdown-menu[id^="category-dropdown-"] .categories-recursive-dropdown {
        display: none !important;
    }
}


/* ---------------------------------------------------------
   RESPONSIVE MEGA MENU GRID
--------------------------------------------------------- */

@media (min-width: 992px) and (max-width: 1199px) {

    .dropdown-menu[id^="category-dropdown-"] .row.nav {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}


/* ---------------------------------------------------------
   SPACING
--------------------------------------------------------- */

.toggler-logo-wrapper {
    padding-left: 20px;
}

#shop-nav {
    padding-right: 20px;
}

.subcategory-wrapper {
    padding-left: 20px;
    padding-right: 20px;
}




















/* containers */

.fade-in {
  opacity: 0;
  transition: all 2s ease;
}

.fade-in.visible {
  opacity: 1;
}

#content-wrapper.has-left-sidebar {
    margin-top: 60px;
    width: 100%;
}

#content-wrapper {
    margin-top: 60px;
}

.container-fluid-xl {
    	max-width: 100%;
}


.align-items-lg-end {
        align-items: center !important;
    }

#main-wrapper {
    margin-top: 8vh;
    width: 100%;
    margin: 0 auto;
}

#main-wrapper.aside-active {
  width: 90%;
  margin: 0 auto;
}

.contact-box {
    position: relative;

    width: 100vw;
    margin-left: calc(50% - 50vw);

    background-color: #000;

    background-image:
        linear-gradient(
            rgba(0,0,0,.45),
            rgba(0,0,0,.45)
        ),
        url('/templates/NOVAChild/img/dachtraeger-profi-contact.png');

    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;

    overflow: hidden;
}

.contact-box-text {
  width: 80%;
  color: #ffffff;
  opacity: 0.75;
}

.contact-box h2 {
  color: #ffffff;
}

/* Footer */
.productlist-filter-headline {
    font-size: 16px;
    color: #ffffff;
    opacity: 0.75;
}

#copyright {
    background-color: #000000;
    color: #f5f7fa;
    margin-top: 1rem;
}

.row#footer-boxes {
    display: flex;
    flex-wrap: wrap;
    width: 90%;
    margin: 0 auto;
}

.footnote-vat {
    width: 90%;
    margin: 0 auto;

}

/* Top Bar Links */
/* Topbar Wrapper */
.topbar-main {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Standard Links */
.topbar-main .nav-link,
.topbar-main .nav-link.nav-link-custom,
.topbar-main .dropdown-toggle {
    color: #ffffff;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.02em;
    line-height: 1.3;
    padding: 4px 8px;
    text-decoration: none;
    opacity: 0.85;
    transition: opacity 0.2s ease;
}

/* Hover FIX (verhindert schwarz) */
.topbar-main .nav-link:hover,
.topbar-main .nav-link:focus,
.topbar-main .nav-link.nav-link-custom:hover,
.topbar-main .nav-link.nav-link-custom:focus,
.topbar-main .dropdown-toggle:hover,
.topbar-main .dropdown-toggle:focus {
    color: #ffffff !important;
    opacity: 1;
    text-decoration: none;
}

/* Allgemeine Absicherung gegen Theme */
.topbar-main a:hover,
.topbar-main a:focus {
    color: #ffffff !important;
}

/* Dropdown Menü */
.topbar-main .dropdown-menu {
    background: #111;
    border: none;
    border-radius: 8px;
    padding: 6px 0;
    min-width: 80px;
    box-shadow: 0 8px 20px rgba(0,0,0,0.2);
}

/* Dropdown Items */
.topbar-main .dropdown-item {
    color: #ffffff;
    font-size: 13px;
    padding: 6px 14px;
    opacity: 0.8;
    background: transparent;
    transition: opacity 0.2s ease, background 0.2s ease;
}

/* Dropdown Hover */
.topbar-main .dropdown-item:hover,
.topbar-main .dropdown-item:focus {
    color: #ffffff !important;
    background: rgba(255,255,255,0.05) !important;
    opacity: 1;
}

/* Aktiver Zustand */
.topbar-main .dropdown-item.active {
    color: #ffffff !important;
    opacity: 1;
    font-weight: 500;
}

/* Divider softer machen */
.topbar-main.nav-dividers .nav-item + .nav-item::before {
    opacity: 0.2;
}

.nav-dividers .nav-item::after {
    content: none !important;
}

/* Footer Links */
.box-nav-item .nav-link,
.nav.flex-column .nav-link {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
  color: #1f2937 !important !important;
  font-weight: 500;
  letter-spacing: 0.2px;
  text-decoration: none !important;
  display: inline-block;
}

.box-nav-item .nav-link:hover,
.box-nav-item .nav-link:focus,
.nav.flex-column .nav-link:hover,
.nav.flex-column .nav-link:focus {
  color: #000000 !important;
  text-decoration: none !important;
}

.box-nav-item .nav-link:active,
.nav.flex-column .nav-link:active {
  color: #fff !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.box-nav-item .nav-item,
.nav.flex-column .nav-item {
  margin-bottom: -6px;
}







/* links product archive  sidebar */

.nav-panel .nav .nav {
    padding-left: 0;
}

/* komplette Breite für Linien */
.box-categories .nav-panel,
.box-categories .nav,
.box-categories .nav-item,
.box-categories .nav-link {
    width: 100%;
}

/* Linie durchgehend über komplette Sidebar-Breite */
.box-categories .nav-item {
    border-bottom: 1px solid #e5e7eb !important;
}

/* Link clean */
.box-categories .nav-link {
    display: flex !important;
    align-items: center;
    justify-content: space-between;

    width: 100% !important;
    padding: 16px 0 !important;

    border: 0 !important;
    background: transparent !important;

    color: #000 !important;
    text-decoration: none !important;
}

/* collapse Hintergrund weg */
.box-categories .dropdown .collapse,
.box-linkgroup .dropdown .collapse {
    background: transparent !important;
}

/* linker Rahmen weg */
.box-categories,
.box-categories * {
    border-left: 0 !important;
    box-shadow: none !important;
}

/* Hover */
.box-categories .nav-link:hover {
    color: #000000;
    background: transparent !important;
}

/* Linien sauber: keine Doppel-/Dreifach-Borders */

/* alle alten Link-Linien raus */
.box-categories .nav-link,
.box-linkgroup .nav-link {
    border-bottom: 0 !important;
}

/* nur direkte Listenelemente bekommen Linie */
.box-categories .nav-panel .nav-item {
    border-bottom: 1px solid #e5e7eb !important;
}

/* Collapse selbst ohne Linie/Hintergrund */
.box-categories .snippets-categories-collapse,
.box-categories .dropdown .collapse,
.box-linkgroup .dropdown .collapse {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* letzter Unterpunkt ohne zusätzliche Abschlusslinie */
.box-categories .snippets-categories-collapse > .nav > .nav-item:last-child {
    border-bottom: 0 !important;
}

/* aktive/geöffnete Parent-Zeile nicht doppelt */
.box-categories .nav-item.dropdown.active > .nav-link,
.box-categories .nav-item.dropdown > .nav-link {
    border-bottom: 0 !important;
}

/* Abstand unten vom Collapse minimal entfernen */
.box-categories .snippets-categories-collapse {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}















/* search */

.search-wrapper .input-group {
    border-radius: 22px;
    overflow: hidden;
    background-color: #ffffff !important;

}

.twitter-typeahead {
border-radius: 8px;
}

#search-header {
    border: none;
    box-shadow: none;
}

.search-wrapper .btn {
    border-radius: 8px;
}

.form-control:disabled,
.form-control[readonly] {
    background-color: #e9ecef;
    border-radius: 22px 0 0 22px;
}







/* Buttons */
.btn-white {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: auto !important;

    padding: 10px 18px !important;

    background: #ffffff !important;
    color: #111111 !important;

    border: 1px solid #e5e5e5 !important;
    border-radius: 999px !important;

    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1 !important;

    text-decoration: none !important;

    transition: background .2s ease, border-color .2s ease !important;
}

.btn-white:hover {
    background: #f5f5f5 !important;
    border-color: #dcdcdc !important;

    color: #111111 !important;
}


.btn-black {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: auto !important;

    padding: 10px 18px !important;

    background: #111111 !important;
    color: #ffffff !important;

    border: 1px solid #1f1f1f !important;
    border-radius: 999px !important;

    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1 !important;

    text-decoration: none !important;

    transition: background .2s ease, border-color .2s ease !important;
}

.btn-black:hover {
    background: #1c1c1c !important;
    border-color: #2a2a2a !important;

    color: #ffffff !important;
}



.btn-secondary {
    color: #f5f7fa;
    background-color: #ffffff;
    border: none;
}

.btn-secondary:hover {
    color: #cccccc; 
    background-color: #ffffff;
}


.btn.btn-secondary .fas {
  color: #fff !important;
}

.btn.btn-secondary:hover .fas {
  color: #fff !important;
}







/* SLIDER */

.ss-slider {
  --gap: 1.75rem;
  --items-desktop: 3;
  --items-tablet: 2;
  --items-mobile: 1;

  position: relative;
  width: 100%;
  margin: 0 auto;
}

.ss-slider__viewport {
  overflow: hidden;
  width: 100%;
  height: auto; }

.ss-slider__track {
  display: flex;
  gap: var(--gap);
  list-style: none;
  margin: 0;
  padding: 0;
  transition: transform 0.6s ease;
  will-change: transform;
}


.ss-slider__item {
  position: relative;
  overflow: hidden;
  flex: 0 0 calc((100% - (var(--gap) * 2)) / 3);
  aspect-ratio: 1 / 1; }

.ss-slider__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 0px 0px 40px 60px;
  background: linear-gradient(to top, rgba(0,0,0,0.5), transparent 60%);
}

.ss-slider__title {
  color: #fff;
  font-size: 28px;
  font-weight: normal;
  text-transform: uppercase;
}

.ss-slider__link,
.ss-slider__item img {
  display: block;
  width: 100%;
  height: 100%;
}

.ss-slider__item img {
  object-fit: cover;
}

.ss-slider__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.85);
  color: #111;
  cursor: pointer;
  z-index: 5;
  font-size: 22px;
  line-height: 1;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.ss-slider__btn:hover {
  opacity: 1;
}

.ss-slider__btn--prev {
  left: 12px;
}

.ss-slider__btn--next {
  right: 12px;
}

/* Tablet */
@media (max-width: 991px) {
  .ss-slider__item {
    flex: 0 0 calc((100% - var(--gap)) / 2);
  }
}

/* Mobile */
@media (max-width: 699px) {
  .ss-slider__item {
    flex: 0 0 100%;
  }
}

/* Slider Full Width */
.ss-slider--fullwidth {
  position: relative;
  width: 100%;
  margin: 0 auto;
}

/* echter Fullwidth über Container hinaus */
.ss-slider--fullwidth {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}

.ss-slider--fullwidth .ss-slider__viewport {
  overflow: hidden;
  width: 100%;
  height: auto;
}

.ss-slider--fullwidth .ss-slider__track {
  display: flex;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  transition: transform 0.6s ease;
  will-change: transform;
}

.ss-slider--fullwidth .ss-slider__item {
  position: relative;
  overflow: hidden;
  flex: 0 0 100%;
  width: 100%;
  aspect-ratio: 16 / 6;
}

.ss-slider--fullwidth .ss-slider__link,
.ss-slider--fullwidth .ss-slider__item img {
  display: block;
  width: 100%;
  height: 100%;
}

.ss-slider--fullwidth .ss-slider__item img {
  object-fit: cover;
}

.ss-slider--fullwidth .ss-slider__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 20px;
  background: linear-gradient(to top, rgba(0,0,0,0.5), transparent 60%);
}

.ss-slider--fullwidth .ss-slider__title {
  color: #fff;
  font-size: 28px;
  font-weight: 600;
  text-transform: uppercase;
  margin: 0;
}

.ss-slider.full-width .ss-slider__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;

    display: flex;
    align-items: center;     /* vertikal */
    justify-content: center; /* horizontal */

    text-align: center;
}

.ss-slider.full-width .ss-slider__title {
    margin: 0;
    color: #fff; /* optional je nach Bild */
}

/* Buttons */
.ss-slider--fullwidth .ss-slider__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.85);
  color: #111;
  cursor: pointer;
  z-index: 5;
  font-size: 22px;
  line-height: 1;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.ss-slider--fullwidth .ss-slider__btn--prev {
  left: 20px;
}

.ss-slider--fullwidth .ss-slider__btn--next {
  right: 20px;
}

/* Tablet */
@media (max-width: 991px) {
  .ss-slider--fullwidth .ss-slider__item {
    aspect-ratio: 16 / 8;
  }

  .ss-slider--fullwidth .ss-slider__title {
    font-size: 20px;
  }
}

/* Mobile */
@media (max-width: 699px) {
  .ss-slider--fullwidth .ss-slider__item {
    aspect-ratio: 4 / 3;
  }

  .ss-slider--fullwidth .ss-slider__title {
    font-size: 16px;
  }

  .ss-slider--fullwidth .ss-slider__overlay {
    padding: 16px;
  }
}








/* Numbers */

/* Wrapper */
.benefits-wrapper {
  display: flex;
}

/* Einzelne Box */
.benefits-box {
  flex: 1;
  display: flex;
  align-items: center;      /* vertikal mittig */
  justify-content: center;  /* Inhalt als Einheit mittig */
  gap: 12px;
  padding: 20px;
  border-right: 1px solid #D9D9D9;
  text-align: left;
}

/* Letzte Box ohne Border */
.benefits-box:last-child {
  border-right: none;
}

/* Icon */
.benefits-icon {
  font-size: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px; /* sorgt für saubere Ausrichtung */
}

/* Content */
.benefits-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* Titel */
.benefits-title {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 16px;
  color: #000;
}

/* Text */
.benefits-text {
  font-size: 14px;
  color: #555;
}


@media (max-width: 768px) {
  .benefits-wrapper {
    flex-direction: column;
  }

  .benefits-box {
    justify-content: flex-start;
    border-right: none;
    border-bottom: 1px solid #D9D9D9;
  }

  .benefits-box:last-child {
    border-bottom: none;
  }
}














/* Tables */

.table.table-sm.table-striped.table-bordered-outline {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 4px 18px rgba(0,0,0,.04);
}

.table.table-sm.table-striped.table-bordered-outline tbody tr {
    transition: background .2s ease;
}

.table.table-sm.table-striped.table-bordered-outline tbody tr:not(:last-child) td {
    border-bottom: 1px solid #f1f1f1;
}

.table.table-sm.table-striped.table-bordered-outline tbody tr:hover {
    background: #fafafa;
}

.table.table-sm.table-striped.table-bordered-outline td {
    padding: 16px 20px;
    vertical-align: middle;
    border: none;
    font-size: 15px;
    color: #222;
}

.table.table-sm.table-striped.table-bordered-outline td.h6 {
    font-size: 14px;
    font-weight: 600;
    color: #666;
    width: 40%;
    white-space: nowrap;
}

.table.table-sm.table-striped.table-bordered-outline td.weight-unit {
    font-weight: 500;
    color: #050505;
}

.table.table-sm.table-striped.table-bordered-outline tbody tr:nth-child(even) {
    background: #fcfcfc;
}

@media (max-width: 768px) {
    .table.table-sm.table-striped.table-bordered-outline td {
        padding: 14px 16px;
        font-size: 14px;
    }

    .table.table-sm.table-striped.table-bordered-outline td.h6 {
        width: 45%;
    }
}





/* Timetable */

/* Titel */
.opening-title {
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 10px;
    color: #fff;
}

/* Container */
.opening-hours {
    max-width: 320px;
    background: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    border-radius: 14px;
    padding: 14px 16px;

    color: #fff;
    font-size: 14px;
    letter-spacing: 0.02em;

}

/* Zeilen */
.opening-hours .row {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 12px;

    padding: 4px 0;
}

/* Tage links */
.opening-hours .day {
    opacity: 0.7;
}

/* Zeiten rechts */
.opening-hours .time {
    line-height: 1.4;
}

/* Zeilen-Trennung (optional nice) */
.opening-hours .row:not(:last-child) {
    border-bottom: 1px solid rgba(255,255,255,0.08);
    margin-bottom: 4px;
    padding-bottom: 6px;
}
/* sidebox */

#sidebox127 .footer-contact {
    margin: 0 0 12px 0;
    color: #ffffff;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.02em;
    line-height: 1.45;
    opacity: 0.75; /* dezenter als Zeiten */

}

#sidebox127 .footer-contact strong {
    display: inline-block;
    font-weight: 500;
    color: #ffffff;
}

#sidebox127 .footer-contact--meta {
    margin-bottom: 0;
}

/* Info Links */

.productlist-filter-headline {
  border: none !important;
}

hr {
    margin-top: 1rem;
    margin-bottom: 1rem;
    border: 0;
    border-top: none !important;
}



/* Headline (Desktop) */
#box123 .productlist-filter-headline {
    color: #ffffff;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.03em;
    margin-bottom: 10px;
}

/* Mobile Toggle */
#box123 .box-normal-link {
    color: #ffffff;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-decoration: none;
    display: block;
    margin-bottom: 10px;
}

/* Navigation Liste */
#box123 .nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin: 0;
    padding: 0;
}

/* List Items */
#box123 .nav-item {
    margin: 0;
    padding: 0;
    list-style: none;
}

/* links */

/* Links */
#footer #box123 .nav-link {
    color: #ffffff !important;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.02em;
    line-height: 1.35;
    padding: 3px 0;
    text-decoration: none;
    display: inline-block;
    opacity: 0.85;
    transition: opacity 0.2s ease;
}

/* Hover */
#footer #box123 .nav-link:hover,
#footer #box123 .nav-link:focus {
    color: #ffffff;
    opacity: 1;
    text-decoration: none;
}

#footer a:not(.btn):hover {
    color: #e7e7e7;
}

/* Subtile Linie */
#footer #box123 .nav-link::after {
    content: "";
    display: block;
    width: 0;
    margin-top: 3px;
}

#footer #box123 .nav-link:hover::after,
#footer #box123 .nav-link:focus::after {
    width: 100%;
}


/* Wrapper / Navigation */
#footer #crd-cllps-122 .nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin: 0;
    padding: 0;
}

/* List Items */
#footer #crd-cllps-122 .nav-item {
    margin: 0;
    padding: 0;
    list-style: none;
}

/* Links */
#footer #crd-cllps-122 .nav-link {
    color: #ffffff !important;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.02em;
    line-height: 1.35;
    padding: 3px 0;
    text-decoration: none;
    display: inline-block;
    opacity: 0.85;
    transition: opacity 0.2s ease;
}

/* Hover */
#footer #crd-cllps-122 .nav-link:hover,
#footer #crd-cllps-122 .nav-link:focus {
    color: #ffffff;
    opacity: 1;
    text-decoration: none;
}

/* Linie */
#footer #crd-cllps-122 .nav-link::after {
    content: "";
    display: block;
    width: 0;
    margin-top: 3px;
}

#footer #crd-cllps-122 .nav-link:hover::after,
#footer #crd-cllps-122 .nav-link:focus::after {
    width: 100%;
}

/* Headline */
#footer #crd-cllps-122 h1,
#footer #crd-cllps-122 h2,
#footer #crd-cllps-122 h3 {
    color: #ffffff;
    font-size: 16px;
    font-weight: 500;
    margin-bottom: 10px;
    letter-spacing: 0.03em;
}

.footer-content {
  font-size: 14px; 
  letter-spacing: 0.02em;
  line-height: 2;
}

.footer-content a {
  display: block;
  font-size: 14px; 
}

.footer-content a {
    display: block;
    font-size: 14px;
    color: #ffffff;
    text-decoration: none;
    margin-bottom: 6px;
    transition: all 0.25s ease;
}

.footer-content a:hover {
    color: rgba(255, 255, 255, 0.7);
}

.footer-content {
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}

@media (max-width: 768px) {
    .footer-content a {
        font-size: 14px;
        margin-bottom: 4px;
    }
}

h4 {
  font-size: 22px;
  color: #ffffff;

}

/* Breadcrumb */
/* Breadcrumb modern & clean */

@media (min-width: 992px) {
    .breadcrumb-wrapper {
	width: 100%;
        border: none !important;
    }
}

#breadcrumb .breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0;
    padding: 10px 0;
    background: transparent;
}

#breadcrumb .breadcrumb-item {
    display: inline-flex;
    align-items: center;
    max-width: 260px;
    padding: 7px 14px;
    border-radius: 999px;
    background: #f2f2f2;
    color: #555;
    font-size: 13px;
    line-height: 1.2;
    transition: all .2s ease;
}

#breadcrumb .breadcrumb-item + .breadcrumb-item {
    margin-left: 0;
}

#breadcrumb .breadcrumb-link {
    color: inherit !important;
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

#breadcrumb .breadcrumb-item:hover {
    background: #e7e7e7;
    color: #222;
}

#breadcrumb .breadcrumb-item.active,
#breadcrumb .breadcrumb-item.last {
    background: #2f2f2f;
    color: #fff;
    font-weight: 700;
}

#breadcrumb .breadcrumb-item::before,
#breadcrumb .breadcrumb-item::after,
#breadcrumb .breadcrumb-item + .breadcrumb-item::before {
    content: none !important;
    display: none !important;
}

/* Zurück zur Liste etwas dezenter */
#breadcrumb .breadcrumb-backtolist {
    background: #ffffff;
    color: #444 !important;
    border: 1px solid #ddd;
}

#breadcrumb .breadcrumb-backtolist::before {
    content: "←";
    margin-right: 6px;
    font-weight: 600;
}

#breadcrumb .breadcrumb-backtolist:hover {
    background: #f7f7f7;
    border-color: #cfcfcf;
}

/* Optional: unnötigen Produkt-Doppelpunkt ausblenden */
#breadcrumb .breadcrumb-arrow {
    display: none;
}

/* Mobile kompakter */
@media (max-width: 767px) {
    #breadcrumb .breadcrumb {
        gap: 6px;
        padding: 8px 0;
    }

    #breadcrumb .breadcrumb-item {
        max-width: 180px;
        padding: 6px 11px;
        font-size: 12px;
    }
}

/* Erstmal Off */

.currency-dropdown, 
.language-dropdown {
  display: none;
}
  
.topbar-main {
    width: 100%;
    display: flex;
}

.topbar-main .nav-item:last-child {
    margin-left: auto;
}



/* Bundles */

.partslist-top {
    margin: 24px 0 20px;
}

.partslist-top .slick-slider-other {
    margin: 0;
}

.partslist-top .slick-slider-other .h2 {
    margin: 0 0 14px;
    font-size: 1.25rem;
    line-height: 1.3;
    font-weight: 600;
    color: #222;
}

/* alles untereinander */
.partslist-top .slick-track {
    width: 100% !important;
    transform: none !important;
    display: flex !important;
    flex-direction: column;
    gap: 0;
}

.partslist-top .slick-list {
    overflow: visible;
}

.partslist-top .product-wrapper.product-wrapper-product {
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

/* ruhige Zeilenoptik */
.partslist-top .product-wrapper.product-wrapper-product > a {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid #e6e6e6;
    transition: background 0.2s ease, transform 0.2s ease;
}

.partslist-top .product-wrapper.product-wrapper-product:last-child > a {
    border-bottom: 0;
}

/* dezenter Hover */
.partslist-top .product-wrapper.product-wrapper-product > a:hover {
    background: #fafafa;
}

/* kleines Bild links */
.partslist-top .item-slider.productbox-image,
.partslist-top .item-slider.productbox-image .inner {
    width: 40px;
    min-width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.partslist-top .product-image {
    width: 40px;
    height: 40px;
    max-width: 40px;
    max-height: 40px;
    object-fit: contain;
}

/* Text */
.partslist-top .item-slider-desc {
    flex: 1;
    margin: 0;
    text-align: left;
    line-height: 1.4;
    font-size: 0;
    color: #222;
}

.partslist-top .item-slider-desc span[itemprop="name"] {
    font-size: 1rem;
    font-weight: 500;
    color: #222;
}

/* Anzahl und Preis ausblenden */
.partslist-top .item-slider-price {
    display: none !important;
}

/* Slider-Controls ausblenden */
.partslist-top .slick-arrow,
.partslist-top .slick-dots {
    display: none !important;
}

.partslist-top .square.square-image::before {
    display: none;
}

.partslist-top .square.square-image {
    padding-top: 0;
}

.partslist-top {
    width: 100%;
    max-width: 100%;
    margin: 24px 0 20px;
    padding: 0;
}

.partslist-top .slick-slider-other,
.partslist-top .slick-list,
.partslist-top .slick-track,
.partslist-top .carousel {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
}

/* falls die Produktboxen seitlich noch extra Abstand haben */
.partslist-top .product-wrapper.product-wrapper-product {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
}

/* die Zeile selbst bündig halten */
.partslist-top .product-wrapper.product-wrapper-product > a {
    width: 100%;
    box-sizing: border-box;
    padding-left: 0;
    padding-right: 0;
}

/* Product Detail - More Info */

/* =========================
   Product Tabs – Clean Reiter Style
   ========================= */

.tab-navigation {
    margin-top: 28px;
    width: 100%;
}

/* Tabs Wrapper */
.tab-navigation .nav-tabs {
    border-bottom: none !important;
    gap: 20px;
    padding: 0;
    background: transparent;
}

/* Tab Items */
.tab-navigation .nav-tabs .nav-item {
    margin-bottom: -1px;
}

/* Tab Links */
.tab-navigation .nav-tabs .nav-link {
    border: none;
    border-radius: 0;
    padding: 12px 4px;
    color: #777;
    background: transparent;
    font-size: 15px;
    font-weight: 500;
    position: relative;
    transition: all .2s ease;
}

/* Hover (ohne Linie) */
.tab-navigation .nav-tabs .nav-link:hover {
    color: #111;
}

/* Active */
.tab-navigation .nav-tabs .nav-link.active {
    color: #000;
    font-weight: 700;
}

/* ALLE Linien entfernen */
.tab-navigation .nav-tabs .nav-link::after,
.tab-navigation .nav-tabs .nav-link:hover::after,
.tab-navigation .nav-tabs .nav-link.active::after {
    display: none !important;
    content: none !important;
}

/* =========================
   Dropdown Tab FIX (original Verhalten, kein Bubble-Look)
   ========================= */

.tab-navigation .tab-drop {
    display: list-item !important;
    margin-left: auto;
}

.tab-navigation .tab-drop .nav-link {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 12px 4px !important;
    color: #777;
    font-size: 15px;
    font-weight: 500;
    position: relative;
}

/* Hover */
.tab-navigation .tab-drop .nav-link:hover {
    color: #111;
}

/* Active/Open */
.tab-navigation .tab-drop.show .nav-link {
    color: #000;
    font-weight: 700;
}

/* auch hier Linien killen */
.tab-navigation .tab-drop .nav-link::after {
    display: none !important;
}

/* Dropdown Menü clean */
.tab-navigation .tab-drop .dropdown-menu {
    padding: 6px;
    border: 1px solid #e5e5e5;
    border-radius: 12px;
    box-shadow: 0 12px 28px rgba(0,0,0,.08);
}

.tab-navigation .tab-drop .dropdown-item,
.tab-navigation .tab-drop .dropdown-menu .nav-link {
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 14px;
    color: #555;
}

.tab-navigation .tab-drop .dropdown-item:hover,
.tab-navigation .tab-drop .dropdown-menu .nav-link:hover {
    background: #f5f5f5;
    color: #111;
}

/* =========================
   Content Box
   ========================= */

.tab-navigation .tab-content {
    margin-top: 18px;
    padding: 24px;
    background: #ffffff;
    border: 1px solid #ececec;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .04);
}

/* Description */
.tab-navigation .desc {
    color: #333;
    font-size: 15px;
    line-height: 1.7;
}

#result-wrapper .desc {
    margin-bottom: 2rem;

}

#result-wrapper .title {
    margin-bottom: 0;
}

/* Tabelle */
.tab-navigation .product-attributes {
    margin-top: 22px;
}

.tab-navigation .product-attributes table {
    margin-bottom: 0;
    border: none;
}

.tab-navigation .product-attributes td {
    border-top: 1px solid #f0f0f0;
    padding: 10px 0;
}

.tab-navigation .product-attributes td:first-child {
    color: #666;
    font-weight: 600;
}

.tab-navigation .product-attributes td:last-child {
    font-weight: 700;
}

/* =========================
   Mobile
   ========================= */

@media (max-width: 767px) {

    .tab-navigation .nav-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        gap: 16px;
    }

    .tab-navigation .nav-tabs::-webkit-scrollbar {
        display: none;
    }

    .tab-navigation .nav-tabs .nav-link {
        white-space: nowrap;
        font-size: 14px;
    }

    .tab-navigation .tab-content {
        padding: 18px;
    }
}



/* Formulare */

.form-control {
    border-radius: 99px !important;
margin-bottom: 12px !important;
}

.d-flex .form-control {
    border-radius: 22px !important;
}





/* Form Plugin */
/* Form Plugin – Modern Dark Glass */
/* Search Result – Premium Look */

#result-wrapper {
    width: 100%;
    margin: 70px auto 90px;
    padding: 0 24px;
    text-align: left;
    background: transparent;
    border: 0;
    box-shadow: none;
}

#result-wrapper > * {
    position: relative;
}

#result-wrapper h1 {
   margin: 0 0 14px;
   font-size: clamp(28px, 3.2vw, 48px);
   line-height: .95;
   font-weight: 500;
   color: #050505;
}

#result-wrapper .alert.alert-info {
    max-width: 560px;
    margin: 0 auto 34px;
    padding-top: 60px;
    border: 0;
    background: transparent;
    color: rgba(0,0,0,.55);
    font-size: 15px;    
    text-align: center;
    line-height: 1.65;
    box-shadow: none;
}

/* Search Pill */

#suche2 {
    max-width: 560px;
    margin: 0 auto;
    padding: 10px;
    border-radius: 999px;

    background: rgba(255,255,255,.82);
    border: 1px solid rgba(0,0,0,.06);

    box-shadow:
        0 24px 70px rgba(0,0,0,.10),
        0 8px 22px rgba(0,0,0,.05),
        inset 0 1px 0 rgba(255,255,255,.9);

    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
}

#suche2 fieldset {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    padding: 0;
    border: 0;
}

#suche2 .form-group {
    flex: 1;
    margin: 0;
}

#suche2 .d-flex {
    display: block !important;
}

#suche2 label {
    display: none;
}

#searchkey,
#searchkey.form-control {
    width: 100%;
    height: 48px;
    padding: 0 18px;
    border: 0 !important;
    border-radius: 999px;
    background: transparent !important;
    color: #111;
    font-size: 15px;
    box-shadow: none !important;
}

#searchkey:focus,
#searchkey.form-control:focus {
    outline: none;
    border: 0 !important;
    box-shadow: none !important;
}


/* Form Plugin – Premium Dark Glass */

.custom-offer-box {
    width: 100% !important;
    max-width: 1220px;
    margin: 120px auto 0;
    padding: clamp(24px, 4vw, 48px);
    border-radius: 30px;
    text-align: left;
    position: relative;
    overflow: hidden;

    background:
        radial-gradient(circle at top left, rgba(255,255,255,.14), transparent 34%),
        radial-gradient(circle at bottom right, rgba(255,255,255,.07), transparent 38%),
        linear-gradient(135deg, #050505 0%, #111 56%, #050505 100%);

    border: 1px solid rgba(255,255,255,.12);

    box-shadow:
        0 40px 120px rgba(0,0,0,.18),
        0 12px 36px rgba(0,0,0,.08),
        inset 0 1px 0 rgba(255,255,255,.08);
}

.custom-offer-box::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .2;
    background-image: url("https://www.transparenttextures.com/patterns/noise.png");
    mix-blend-mode: overlay;
}

.custom-offer-content {
    position: relative;
    z-index: 1;
    display: flex;
    gap: clamp(32px, 5vw, 72px);
    align-items: stretch;
}

.custom-offer-text {
    flex: 0 0 34%;
    padding-top: 12px;
}

.custom-offer-text h2 {
    margin: 0 0 14px;
    font-size: clamp(34px, 4vw, 56px);
    line-height: .95;
    letter-spacing: -0.055em;
    font-weight: 700;
    color: rgba(255,255,255,.9);
}

.custom-offer-text p {
    max-width: 420px;
    margin: 0;
    color: rgba(255,255,255,.58);
    font-size: 15px;
    line-height: 1.7;
}

.custom-offer-form {
    flex: 1;
    padding: clamp(24px, 3vw, 42px);
    border-radius: 26px;
    position: relative;
    overflow: hidden;

    background: rgba(255,255,255,.055);
    backdrop-filter: blur(24px) saturate(140%);
    -webkit-backdrop-filter: blur(24px) saturate(140%);

    border: 1px solid rgba(255,255,255,.12);

    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.12),
        0 20px 50px rgba(0,0,0,.18);
}

.custom-offer-form::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .14;
    background-image: url("https://www.transparenttextures.com/patterns/noise.png");
}

.custom-offer-form > * {
    position: relative;
    z-index: 1;
}

.custom-offer-form .form-group {
    margin-bottom: 0px;
}

.custom-offer-form label {
    margin-bottom: 8px;
    font-size: 13px;
    font-weight: 500;
    color: rgba(255,255,255,.56);
}

.custom-offer-form .form-control,
.custom-offer-form select,
.custom-offer-form textarea {
    min-height: 46px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.92);
    color: #111;

    box-shadow:
        inset 0 1px 2px rgba(0,0,0,.06),
        0 8px 20px rgba(0,0,0,.08);
}

.custom-offer-form .form-control:focus,
.custom-offer-form select:focus,
.custom-offer-form textarea:focus {
    outline: none;
    border-color: rgba(255,255,255,.75);
    box-shadow:
        0 0 0 4px rgba(255,255,255,.12),
        0 12px 28px rgba(0,0,0,.16);
}

.custom-offer-form textarea,
#offer-nachricht,
#offer-nachricht.form-control {
    min-height: 120px;
    border-radius: 22px !important;
    resize: vertical;
}

.custom-offer-form .form-check,
.custom-offer-form .custom-control {
    color: rgba(255,255,255,.56);
    font-size: 13px;
}

.custom-offer-form button,
.custom-offer-form .btn {
    margin-top: 8px;
    border-radius: 999px;
    padding: 10px 22px;
    font-weight: 700;
    border: 0;
    background: #fff;
    color: #111;

    box-shadow:
        0 12px 28px rgba(0,0,0,.2),
        inset 0 1px 0 rgba(255,255,255,.8);

    transition: transform .2s ease, box-shadow .2s ease;
}

.custom-offer-form button:hover,
.custom-offer-form .btn:hover {
    transform: translateY(-2px);
    box-shadow:
        0 18px 38px rgba(0,0,0,.28),
        inset 0 1px 0 rgba(255,255,255,.85);
}

.offer-hp {
    position: absolute !important;
    left: -10000px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

/* Mobile */

@media (max-width: 991px) {
    #result-wrapper {
        margin: 48px auto 64px;
    }

    #suche2 {
        max-width: 100%;
        border-radius: 24px;
    }

    #suche2 fieldset {
        flex-direction: column;
        gap: 10px;
    }

    #suche2 .form-group,
    #suche2 button,
    #suche2 .btn {
        width: 100%;
    }

    .custom-offer-content {
        flex-direction: column;
        gap: 28px;
    }

    .custom-offer-text,
    .custom-offer-form {
        width: 100%;
        flex: none;
    }

    .custom-offer-text h2 {
        font-size: 40px;
    }
}














/* Toggles */

.dropdown-toggle {
border-radius: 99px !important;
}

.btn-group > .btn:not(:last-child):not(.dropdown-toggle):not([data-toggle=collapse]:not(.navbar-toggler)), .btn-group > .btn-group:not(:last-child) > .btn {
    border-top-left-radius: 99px !important;
    border-bottom-left-radius: 99px !important;
}

.btn-group > .btn:not(:first-child), .btn-group > .btn-group:not(:first-child) > .btn {
    border-top-right-radius: 99px !important;
    border-bottom-right-radius: 99px !important;
}

/* Pagination */

.page-item.active .page-link,
.page-item.active .page-text {
    font-weight: 800 !important; 
} 

.page-item.active .page-link::after,
.page-item.active .page-text::after {
    content: none;
}

.fa-long-arrow-alt-right {
    --fa: "\f105" !important; 
    font: var(--fa-font-solid);

}

.fa-long-arrow-alt-left {
    --fa: "\f104" !important;
    font: var(--fa-font-solid);
}












/* Warenkorb Header clean fix */
#jtl-nav-wrapper .cart-icon-dropdown .nav-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
}

#jtl-nav-wrapper .cart-icon-dropdown .cart-icon-dropdown-icon {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 24px !important;
    height: 24px !important;
    font-size: 21px !important;
    line-height: 1 !important;
}

/* Mengen-Kreis */
#jtl-nav-wrapper .cart-icon-dropdown .cart-icon-dropdown-icon .fa-sup {
    position: absolute !important;
    top: -8px !important;
    right: -10px !important;
    left: auto !important;
    bottom: auto !important;

    min-width: 17px !important;
    height: 17px !important;
    padding: 0 5px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    border-radius: 999px !important;
    background: #000 !important;
    color: #fff !important;

    font-size: 10px !important;
    font-weight: 700 !important;
    line-height: 1 !important;

    transform: none !important;
    z-index: 2 !important;
}

/* Preis */
#jtl-nav-wrapper .cart-icon-dropdown .cart-icon-dropdown-price {
    color: #000 !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
}







/* Mengen Buttons */

/* Linke Seite */
.input-group > .input-group-prepend > .btn,
.input-group > .input-group-prepend > .input-group-text {
    border-top-left-radius: 99px !important;
    border-bottom-left-radius: 99px !important;
}

/* Rechte Seite */
.input-group > .input-group-append > .btn,
.input-group > .input-group-append > .input-group-text {
    border-top-right-radius: 99px !important;
    border-bottom-right-radius: 99px !important;
}


.input-group-text {
    border: none !important;
    background-color: transparent !important;
}






/* FIX: Produktbild-Lightbox über Tabs */
#image_wrapper,
.product-detail-image,
.gallery-with-action-main {
    position: relative;
    z-index: 20;
}

/* Wenn Galerie/Fullscreen aktiv ist */
#image_wrapper:hover,
#image_wrapper:focus-within,
.gallery-with-action-main:hover,
.gallery-with-action-main:focus-within {
    z-index: 9999 !important;
}

/* Tabs dürfen nie über der Galerie liegen */
.tab-navigation {
    position: relative;
    z-index: 0 !important;
}



/* Bage Abstand im Variation */

.badge-not-available {
    margin-left: 10px;
}

.cart-icon-dropdown-price {
    display: none !important;
}









/* =========================================================
   CLEAN PRODUCT GRID
   ========================================================= */

#result-wrapper {
    width: 100%;
    max-width: 1440px;
    margin: 40px auto 70px;
    padding: 0 32px;
    background: transparent;
    border: 0;
    box-shadow: none;
}

/* GRID */

#product-list.product-list.layout-gallery {
    margin: 0 !important;
    row-gap: 0 !important;
    column-gap: 0 !important;
}

#product-list .product-wrapper,
#product-list .product-wrapper[style] {
    padding: 0 !important;
    margin: 0 !important;
    height: auto !important;
    display: flex;
}






/* PRODUCT BOX */

#product-list .productbox {
    width: 100%;
    height: 340px !important;
    min-height: 340px !important;
    max-height: 340px !important;

    border-right: 1px solid #ececec;
    border-bottom: 1px solid #ececec;
    border-top: 0 !important;
    border-left: 0;

    border-radius: 0;
    background: #ffffff;
    overflow: hidden;

    box-shadow: none !important;
    margin: 0 !important;

    transition: background-color .18s ease !important;
}

#product-list .product-wrapper:first-child .productbox,
#product-list .product-wrapper:nth-child(4n+1) .productbox {
    border-left: 1px solid #ececec !important;
}

#product-list .productbox:hover {
    background: #f7f7f7 !important;
    transform: none !important;
    box-shadow: none !important;
}

#product-list .productbox:focus,
#product-list .productbox:active,
#product-list .productbox-inner,
#product-list .productbox:hover .productbox-inner {
    transform: none !important;
    box-shadow: none !important;
}

/* INNER */

#product-list .productbox-inner {
    height: 100% !important;
    padding: 28px 22px 24px !important;
    display: flex;
    flex-direction: column;
    background: transparent;
}

#product-list .productbox .row {
    margin: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
}

#product-list .productbox .col {
    padding: 0;
}

/* IMAGE */

#product-list .productbox-image.square::before,
#product-list .square::before {
    display: none !important;
    content: none !important;
}

#product-list .productbox-images {
    position: relative;
    width: 100%;
    height: 175px !important;
    min-height: 175px !important;
    max-height: 175px !important;
    margin-bottom: 16px;
    background: transparent;
    overflow: hidden;
}

#product-list .productbox-images > a {
    position: relative;
    display: block !important;
    width: 100%;
    height: 175px !important;
    opacity: 1 !important;
}

/* beide Bild-Wrapper übereinander */

#product-list .productbox-images .productbox-image.square,
#product-list .productbox-images .first-wrapper,
#product-list .productbox-images .second-wrapper {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 175px !important;
    min-height: 175px !important;
    max-height: 175px !important;
    overflow: hidden;
    background: transparent;
}

#product-list .productbox-images .productbox-image.square > .inner {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    padding: 0 12px !important;
}

/* Bild 1: standardmäßig sichtbar */

#product-list .productbox-images .first-wrapper {
    z-index: 2 !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    transition: opacity .3s ease, visibility .3s ease;
}

/* Bild 2: standardmäßig versteckt */

#product-list .productbox-images .second-wrapper {
    z-index: 1 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    display: block !important;
    transition: opacity .3s ease, visibility .3s ease;
}

/* Hover: erstes Bild ausblenden */

#product-list .productbox:hover .productbox-images .first-wrapper {
    opacity: 0 !important;
    visibility: hidden !important;
}

/* Hover: zweites Bild einblenden */

#product-list .productbox:hover .productbox-images .second-wrapper {
    z-index: 3 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Fallback für Artikel ohne zweites Bild */

#product-list .productbox-images .first-wrapper:only-child,
#product-list .productbox:hover .productbox-images .first-wrapper:only-child {
    opacity: 1 !important;
    visibility: visible !important;
}

/* Bild sauber zentrieren */

#product-list .square-image .inner img,
#product-list .productbox-image.square .inner img {
    display: block !important;
    position: absolute !important;

    left: 50% !important;
    top: 50% !important;

    transform: translate(-50%, -50%) !important;

    width: auto !important;
    height: auto !important;

    max-width: calc(100% - 24px) !important;
    max-height: 165px !important;

    object-fit: contain !important;
    object-position: center !important;

    margin: 0 !important;
}

/* TITLE */

#product-list .productbox-title {
    margin-top: 18px;
    min-height: 42px;
    max-height: 42px;
    overflow: hidden;
    text-align: center;
}

#product-list .productbox-title a {
    display: block;
    color: #2d2d2d;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.3;
    text-decoration: none;
}

#product-list .productbox-title a:hover {
    color: #2d2d2d;
}

/* PRICE */

#product-list .price_wrapper {
    margin-top: 18px !important;
    padding-top: 0 !important;
    text-align: center;
}

#product-list .productbox-price {
    color: #6b7280;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0;
    margin: 0;
}

#product-list .productbox-price span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
}

/* REMOVE UNWANTED */

#product-list .productbox-ribbon,
#product-list .footnote-reference,
#product-list .price-note {
    display: none !important;
}

.ribbon-3::before,
.ribbon-7::before,
.ribbon-8::before {
    border: none !important;
}

/* MOBILE */

@media (max-width: 991px) {

    #result-wrapper {
        padding: 0 14px;
        margin: 24px auto 50px;
    }

    #product-list .productbox {
        height: 290px !important;
        min-height: 290px !important;
        max-height: 290px !important;
    }

    #product-list .product-wrapper:nth-child(2n+1) .productbox {
        border-left: 1px solid #ececec !important;
    }

    #product-list .productbox-inner {
        padding: 18px 14px 16px !important;
    }

    #product-list .productbox-images,
    #product-list .productbox-images > a,
    #product-list .productbox-images .productbox-image.square,
    #product-list .productbox-images .first-wrapper,
    #product-list .productbox-images .second-wrapper {
        height: 130px !important;
        min-height: 130px !important;
        max-height: 130px !important;
    }

    #product-list .square-image .inner img,
    #product-list .productbox-image.square .inner img {
        max-height: 120px !important;
    }

    #product-list .productbox-title {
        min-height: 36px;
        max-height: 36px;
        margin-top: 14px;
    }

    #product-list .productbox-title a {
        font-size: 14px;
    }

    #product-list .price_wrapper {
        margin-top: 14px !important;
    }

    #product-list .productbox-price {
        font-size: 12px;
    }
}

/* MOBILE TOUCH FIX */

@media (max-width: 991px) {

    #product-list .productbox,
    #product-list .productbox:hover,
    #product-list .productbox:focus,
    #product-list .productbox:active,
    #product-list .productbox.productbox-hover:hover,
    #product-list .productbox.productbox-hover:focus,
    #product-list .productbox.productbox-hover:active {
        background: #ffffff !important;
        transform: none !important;
        box-shadow: none !important;
    }

    #product-list .productbox-inner,
    #product-list .productbox:hover .productbox-inner,
    #product-list .productbox:focus .productbox-inner,
    #product-list .productbox:active .productbox-inner {
        background: transparent !important;
        transform: none !important;
        box-shadow: none !important;
    }

    #product-list .productbox:hover .productbox-images .first-wrapper {
        opacity: 1 !important;
        visibility: visible !important;
    }

    #product-list .productbox:hover .productbox-images .second-wrapper {
        opacity: 0 !important;
        visibility: hidden !important;
    }
}


.list-gallery img.second {
    opacity: 1 !important;
    transition: opacity 0.35s linear;
}










/* =========================================================
   OPC PRODUCT STREAM 
   ========================================================= */

.product-list.opc-ProductStream,
.opc-ProductStream-gallery {
    margin: 0 -12px !important;
    row-gap: 24px;
}

/* Inline margin-right:80px entfernen */
.product-list.opc-ProductStream[style],
.opc-ProductStream-gallery[style] {
    margin-right: -12px !important;
}

/* =========================================================
   GRID
   ========================================================= */

.product-list.opc-ProductStream .product-wrapper,
.opc-ProductStream-gallery .product-wrapper {
    padding: 0 12px;
    margin-bottom: 24px !important;
    height: auto !important;
}

.product-list.opc-ProductStream .product-wrapper[style],
.opc-ProductStream-gallery .product-wrapper[style] {
    height: auto !important;
}

/* =========================================================
   PRODUCT CARD
   ========================================================= */

.product-list.opc-ProductStream .productbox,
.opc-ProductStream-gallery .productbox {
    position: relative;
    height: 100%;
    border-radius: 18px;
    border: 1px solid #edf1f5;
    background: #ffffff;
    overflow: hidden;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 8px 24px rgba(15, 23, 42, 0.06);
    transition: none !important;
}

.product-list.opc-ProductStream .productbox.thumbnail,
.opc-ProductStream-gallery .productbox.thumbnail {
    padding: 0;
    border: 1px solid #edf1f5;
    background: #ffffff;
}

.product-list.opc-ProductStream .productbox-inner,
.opc-ProductStream-gallery .productbox-inner {
    position: relative;
    height: 100%;
    padding: 14px;
    background: #ffffff;
}

/* Entfernt aggressiven Hover */
.product-list.opc-ProductStream .productbox.productbox-hover .productbox-inner::before,
.opc-ProductStream-gallery .productbox.productbox-hover .productbox-inner::before {
    display: none !important;
}

.product-list.opc-ProductStream .productbox:hover,
.product-list.opc-ProductStream .productbox:focus,
.product-list.opc-ProductStream .productbox:active,
.opc-ProductStream-gallery .productbox:hover,
.opc-ProductStream-gallery .productbox:focus,
.opc-ProductStream-gallery .productbox:active {
    transform: none !important;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 8px 24px rgba(15, 23, 42, 0.06) !important;
}

/* =========================================================
   IMAGE AREA
   ========================================================= */

.product-list.opc-ProductStream .productbox-images,
.opc-ProductStream-gallery .productbox-images {
    border-radius: 14px;
    overflow: hidden;
    background: #ffffff;
}

.product-list.opc-ProductStream .productbox-image.square,
.opc-ProductStream-gallery .productbox-image.square {
    background: #ffffff;
    border-radius: 14px;
}

.product-list.opc-ProductStream .productbox-image.square .inner,
.opc-ProductStream-gallery .productbox-image.square .inner {
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    min-height: 180px;
}

.product-list.opc-ProductStream .productbox-image img,
.opc-ProductStream-gallery .productbox-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: none !important;
}

/* Kein Bild Placeholder */
.product-list.opc-ProductStream img[src*="keinBild.gif"],
.opc-ProductStream-gallery img[src*="keinBild.gif"] {
    width: 100%;
    height: 100%;
    opacity: 0.35;
    object-fit: contain;
}

/* =========================================================
   RIBBON
   ========================================================= */

.product-list.opc-ProductStream .productbox-ribbon,
.opc-ProductStream-gallery .productbox-ribbon {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 5;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    line-height: 1;
    box-shadow: none;
    border: 0;
}

/* Auf Lager */
.product-list.opc-ProductStream .ribbon-8,
.opc-ProductStream-gallery .ribbon-8 {
    background: #1fa463;
    color: #ffffff;
}

/* Ausverkauft */
.product-list.opc-ProductStream .ribbon-7,
.opc-ProductStream-gallery .ribbon-7 {
    background: #c7ced6;
    color: #ffffff;
}







/* Ribbon: normaler Zustand */
.product-list.opc-ProductStream .productbox-ribbon,
.opc-ProductStream-gallery .productbox-ribbon,
.productbox-ribbon.ribbon {
    top: 14px !important;
    left: 14px !important;
    transform: none !important;
    transition: none !important;
}

/* Ribbon: Hover/Focus Zustand identisch */
.productbox.productbox-hover:hover .productbox-ribbon.ribbon,
.productbox.productbox-hover:focus .productbox-ribbon.ribbon,
.productbox.productbox-hover.focus .productbox-ribbon.ribbon {
    top: 14px !important;
    left: 14px !important;
    transform: none !important;
    transition: none !important;
}

/* Desktop Override ebenfalls neutralisieren */
@media (min-width: 768px) {
    .productbox.productbox-hover:hover .productbox-ribbon.ribbon,
    .productbox.productbox-hover:focus .productbox-ribbon.ribbon,
    .productbox.productbox-hover.focus .productbox-ribbon.ribbon {
        top: 14px !important;
        left: 14px !important;
        transform: none !important;
        transition: none !important;
    }
}






/* Ribbon Farben */
.product-list.opc-ProductStream .ribbon-7,
.opc-ProductStream-gallery .ribbon-7 {
    background: #c7ced6;
    color: #ffffff;
}

.ribbon-7 {
    background-color: #b90000;
    color: #e1e7f0;
}
/* =========================================================
   QUICK ACTIONS
   ========================================================= */

.product-list.opc-ProductStream .productbox-quick-actions,
.opc-ProductStream-gallery .productbox-quick-actions {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 10;
}

.product-list.opc-ProductStream .product-actions,
.opc-ProductStream-gallery .product-actions {
    gap: 8px;
}

.product-list.opc-ProductStream .product-actions .btn,
.opc-ProductStream-gallery .product-actions .btn {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border-radius: 999px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    color: #374151;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 4px 12px rgba(15, 23, 42, 0.06);
    transition: none !important;
}

.product-list.opc-ProductStream .product-actions .btn:hover,
.product-list.opc-ProductStream .product-actions .btn:focus,
.opc-ProductStream-gallery .product-actions .btn:hover,
.opc-ProductStream-gallery .product-actions .btn:focus {
    background: #ffffff !important;
    color: #111827 !important;
    border-color: #d1d5db !important;
    transform: none !important;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 4px 12px rgba(15, 23, 42, 0.06) !important;
}

/* =========================================================
   TITLE
   ========================================================= */

.product-list.opc-ProductStream .productbox-title,
.opc-ProductStream-gallery .productbox-title {
    margin-top: 16px;
    min-height: 44px;
}

.product-list.opc-ProductStream .productbox-title a,
.opc-ProductStream-gallery .productbox-title a {
    display: block;
    color: #1f2937;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.45;
    text-decoration: none;
    transition: none !important;
}

.product-list.opc-ProductStream .productbox-title a:hover,
.opc-ProductStream-gallery .productbox-title a:hover {
    color: #111827;
    text-decoration: none;
}

/* =========================================================
   PRICE
   ========================================================= */

.product-list.opc-ProductStream .price_wrapper,
.opc-ProductStream-gallery .price_wrapper {
    margin-top: 10px;
}

.product-list.opc-ProductStream .productbox-price,
.opc-ProductStream-gallery .productbox-price {
    color: #111827;
    font-size: 20px;
    font-weight: 800;
    line-height: 1.2;
}

.product-list.opc-ProductStream .productbox-price span,
.opc-ProductStream-gallery .productbox-price span {
    display: flex;
    align-items: flex-start;
    gap: 2px;
}

.product-list.opc-ProductStream .footnote-reference,
.opc-ProductStream-gallery .footnote-reference {
    font-size: 11px;
    color: #94a3b8;
    position: relative;
    top: 1px;
}

/* =========================================================
   CLEANUP
   ========================================================= */

.product-list.opc-ProductStream .price-note,
.opc-ProductStream-gallery .price-note {
    display: none;
}

.product-list.opc-ProductStream .productbox .row,
.opc-ProductStream-gallery .productbox .row {
    margin: 0;
}

.product-list.opc-ProductStream .productbox .col,
.opc-ProductStream-gallery .productbox .col {
    padding: 0;
}

/* =========================================================
   MOBILE
   ========================================================= */

@media (max-width: 991px) {

    .product-list.opc-ProductStream,
    .opc-ProductStream-gallery {
        margin: 0 -7px !important;
        row-gap: 14px;
    }

    .product-list.opc-ProductStream .product-wrapper,
    .opc-ProductStream-gallery .product-wrapper {
        padding: 0 7px;
        margin-bottom: 14px !important;
    }

    .product-list.opc-ProductStream .productbox-inner,
    .opc-ProductStream-gallery .productbox-inner {
        padding: 10px;
    }

    .product-list.opc-ProductStream .productbox-image.square .inner,
    .opc-ProductStream-gallery .productbox-image.square .inner {
        min-height: 130px;
        padding: 14px;
    }

    .product-list.opc-ProductStream .productbox-title,
    .opc-ProductStream-gallery .productbox-title {
        min-height: 38px;
        margin-top: 12px;
    }

    .product-list.opc-ProductStream .productbox-title a,
    .opc-ProductStream-gallery .productbox-title a {
        font-size: 12px;
        line-height: 1.35;
    }

    .product-list.opc-ProductStream .productbox-price,
    .opc-ProductStream-gallery .productbox-price {
        font-size: 17px;
    }

    .product-list.opc-ProductStream .productbox-ribbon,
    .opc-ProductStream-gallery .productbox-ribbon {
        top: 10px;
        left: 10px;
        font-size: 9px;
        padding: 5px 8px;
    }

    .product-list.opc-ProductStream .productbox-quick-actions,
    .opc-ProductStream-gallery .productbox-quick-actions {
        display: none !important;
    }
}








/* =========================================================
   SS RANDOM PRODUCTS
   ========================================================= */

.ss-random-products {
    margin: 0 -12px !important;
}

.ss-random-products .row {
    row-gap: 24px;
}

/* Grid */
.ss-random-products .col-6,
.ss-random-products .col-md-3 {
    padding: 0 12px;
    margin-bottom: 24px;
}

/* Card */
.ss-random-products__card {
    height: 100%;
    border-radius: 18px;
    border: 1px solid #edf1f5;
    background: #ffffff;
    overflow: hidden;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 8px 24px rgba(15, 23, 42, 0.06);
    padding: 14px;
}

/* Image Area */
.ss-random-products__image-link {
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    min-height: 180px;
    border-radius: 14px;
    background: #ffffff;
    overflow: hidden;
    text-decoration: none;
}

.ss-random-products__image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: none !important;
}

/* Kein Bild Placeholder */
.ss-random-products__image[src*="keinBild.gif"] {
    opacity: 0.35;
}

/* Content */
.ss-random-products__content {
    margin-top: 16px;
}

/* Title */
.ss-random-products__title {
    display: block;
    min-height: 44px;
    color: #1f2937;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.45;
    text-decoration: none;
    transition: none !important;
}

.ss-random-products__title:hover {
    color: #111827;
    text-decoration: none;
}

/* Price */
.ss-random-products__price {
    margin-top: 10px;
    color: #111827;
    font-size: 20px;
    font-weight: 800;
    line-height: 1.2;
}

/* Fallback: Array ausblenden */
.ss-random-products__price:has(*) {
    display: block;
}

.ss-random-products__price {
    word-break: break-word;
}

/* =========================================================
   MOBILE
   ========================================================= */

@media (max-width: 991px) {

    .ss-random-products {
        margin: 0 -7px !important;
    }

    .ss-random-products .row {
        row-gap: 14px;
    }

    .ss-random-products .col-6,
    .ss-random-products .col-md-3 {
        padding: 0 7px;
        margin-bottom: 14px;
    }

    .ss-random-products__card {
        padding: 10px;
    }

    .ss-random-products__image-link {
        min-height: 130px;
        padding: 14px;
    }

    .ss-random-products__content {
        margin-top: 12px;
    }

    .ss-random-products__title {
        min-height: 38px;
        font-size: 12px;
        line-height: 1.35;
    }

    .ss-random-products__price {
        font-size: 17px;
    }
}











/* =========================================================
   CLEAN INPUTS
   ========================================================= */

input,
textarea,
select,
.form-control {
    background: #ffffff !important;
    box-shadow: none !important;
    transition: all 0.15s ease;
}

/* Focus */
input:focus,
textarea:focus,
select:focus,
.form-control:focus,
.form-control:focus-visible {
    outline: none !important;
    box-shadow: none !important;
    background: #ffffff !important;
}

/* Hover optional */
input:hover,
textarea:hover,
select:hover,
.form-control:hover {
}

/* Placeholder */
input::placeholder,
textarea::placeholder {
    color: #9aa4b2;
}

/* Disabled */
input:disabled,
textarea:disabled,
select:disabled {
    background: #f5f7fa !important;
    opacity: 0.7;
}





/* Fav + Account Dropdown */

/* =========================================================
   Account Dropdown — Modern Glassmorphism Style
========================================================= */

header .nav-right .dropdown-menu {
    position: absolute;

    min-width: 320px;
    padding: 10px;
    margin-top: 12px;

    border: 1px solid rgba(255, 255, 255, 0.55);
    border-radius: 20px;

    background: rgba(255, 255, 255, 0.74) !important;

    backdrop-filter: blur(22px) saturate(180%);
    -webkit-backdrop-filter: blur(22px) saturate(180%);

    box-shadow:
        0 20px 50px rgba(0, 0, 0, 0.14),
        0 4px 18px rgba(0, 0, 0, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.75);

    overflow: hidden !important;

    color: #111 !important;

    animation: dropdownFade 0.18s ease;
}

/* Smooth opening */
@keyframes dropdownFade {
    from {
        opacity: 0;
        transform: translateY(6px) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Wrapper */
#account-dropdown-menu {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* =========================================================
   Dropdown Items
========================================================= */

header .nav-right .dropdown-menu .dropdown-item {
    display: flex;
    align-items: center;

    min-height: 46px;
    padding: 11px 15px;

    border-radius: 14px;

    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.3;

    color: #181818 !important;
    text-decoration: none !important;

    background: transparent;

    transition:
        background-color 0.18s ease,
        color 0.18s ease,
        transform 0.18s ease,
        opacity 0.18s ease;
}

/* Hover */
header .nav-right .dropdown-menu .dropdown-item:hover {
    background: rgba(0, 0, 0, 0.055);
    color: #000 !important;

    transform: translateX(2px);

    text-decoration: none !important;
}

/* Active */
header .nav-right .dropdown-menu .dropdown-item:active {
    background: rgba(0, 0, 0, 0.09);
    transform: translateX(1px) scale(0.99);
}

/* Focus */
header .nav-right .dropdown-menu .dropdown-item:focus-visible {
    outline: none;
    background: rgba(0, 0, 0, 0.06);
}

/* =========================================================
   Divider
========================================================= */

header .nav-right .dropdown-menu .dropdown-divider {
    margin: 8px 4px;

    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

/* =========================================================
   Logout Item
========================================================= */

header .nav-right .dropdown-menu .account-icon-dropdown-logout {
    color: #181818 !important;
}

header .nav-right .dropdown-menu .account-icon-dropdown-logout:hover {
    background: rgba(0, 0, 0, 0.055) !important;
    color: #000 !important;
}

header .nav-right .dropdown-menu .account-icon-dropdown-logout:active {
    background: rgba(0, 0, 0, 0.09) !important;
}

/* =========================================================
   Mobile
========================================================= */

@media (max-width: 767px) {

    header .nav-right .dropdown-menu {
        min-width: 280px;
        border-radius: 18px;
        padding: 8px;
    }

    header .nav-right .dropdown-menu .dropdown-item {
        min-height: 44px;
        padding: 10px 13px;

        font-size: 0.875rem;
    }
}
















/* Startseite */
.page-start .header-inner {
    min-height: 700px;
}

/* Alle anderen Seiten */
body:not(.page-start) .header-inner {
    min-height: 90px;
}






/* Startseite groß */
#jtl-nav-wrapper.home-header {
    min-height: 76vh;
}

/* Unterseiten klein */
#jtl-nav-wrapper.sub-header {
    min-height: 120px;
}

/* Header-Inhalt normal */
#jtl-nav-wrapper.sub-header .header-inner {
    min-height: 120px;
}

/* Hero nur Startseite */
#jtl-nav-wrapper.home-header .header-hero {
    display: block;
}

#jtl-nav-wrapper.sub-header .header-hero {
    display: none;
}










/* INPUT GROUP */

.search-wrapper .input-group {

    display: flex !important;
    align-items: center;

    flex-wrap: nowrap !important;

    background: rgba(255,255,255,0.34) !important;

    backdrop-filter: blur(22px) saturate(180%);
    -webkit-backdrop-filter: blur(22px) saturate(180%);

    border: 1px solid rgba(255,255,255,0.45);

    border-radius: 999px;

    overflow: hidden;

    box-shadow:
        inset 0 1px 1px rgba(255,255,255,0.35),
        0 0 0 1px rgba(0,0,0,0.03);
}


/* TYPEAHEAD FIX */

.search-wrapper .twitter-typeahead {

    flex: 1 1 auto !important;

    width: auto !important;

    min-width: 0;
}


/* INPUT */

#search-header,
.search-wrapper .form-control,
.search-wrapper .tt-input,
.search-wrapper .tt-hint {

    height: auto;

    border: none !important;

    background: transparent !important;

    box-shadow: none !important;

    padding-left: 22px;

    display: flex;
    align-items: center;
}


/* BUTTON */

.search-wrapper .input-group-append {

    display: flex;
    align-items: center;

    margin-right: 10px;
}

.search-wrapper .btn {

    width: 42px;
    height: 42px;

    display: flex;
    align-items: center;
    justify-content: center;

    border: none !important;

    background: transparent !important;

    box-shadow: none !important;
}


/* ICON */

.search-wrapper .btn .fas {
    color: #000 !important;
}









/* Newsletter */












/* Account */

/* =========================================================
   CHECKOUT SUMMARY CLEAN
   OHNE STEP STYLING
========================================================= */

/* =========================================================
   PAGE
========================================================= */

#checkout {
    padding-top: 24px !important;
    padding-bottom: 32px !important;
}

.checkout-confirmation h1 {
    font-size: 34px !important;
    line-height: 1.05 !important;

    font-weight: 800 !important;
    letter-spacing: -0.04em !important;

    color: #111111 !important;

    margin-bottom: 24px !important;
}

/* =========================================================
   GRID SPACING
========================================================= */

.checkout-confirmation .row {
    row-gap: 18px !important;
}

/* =========================================================
   CARDS
========================================================= */

.checkout-confirmation .card,
#panel-submit-order .card {
    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 24px !important;

    box-shadow: none !important;
    overflow: hidden !important;
}

/* =========================================================
   CARD HEADER
========================================================= */

.checkout-confirmation .card-header,
#panel-submit-order .card-header {
    background: transparent !important;

    border-bottom: 1px solid #f1f1f1 !important;

    padding: 20px 24px !important;
}

.checkout-confirmation-heading {
    font-size: 20px !important;
    line-height: 1.1 !important;

    font-weight: 750 !important;
    letter-spacing: -0.03em !important;

    color: #111111 !important;
}

/* =========================================================
   CARD BODY
========================================================= */

.checkout-confirmation .card-body,
#panel-submit-order .card-body {
    padding: 24px !important;
}

/* =========================================================
   CHANGE BUTTON
========================================================= */

.checkout-confirmation .btn-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;

    padding: 7px 14px !important;

    border-radius: 999px !important;

    background: #ffffff !important;

    border: 1px solid #e5e5e5 !important;

    color: #111111 !important;

    text-decoration: none !important;

    font-size: 13px !important;
    font-weight: 650 !important;
}

.checkout-confirmation .btn-link:hover {
    background: #f5f5f5 !important;
}

/* =========================================================
   ADDRESS LISTS
========================================================= */

.inc-billing-address,
.inc-delivery-address {
    margin: 0 !important;
}

.inc-billing-address li,
.inc-delivery-address li {
    margin-bottom: 2px !important;

    color: #555555 !important;

    font-size: 14px !important;
    line-height: 1.45 !important;
}

.checkout-confirmation .title {
    display: inline-block !important;

    margin-bottom: 8px !important;

    color: #111111 !important;

    font-size: 15px !important;
    font-weight: 700 !important;
}

/* =========================================================
   COMMENT
========================================================= */

.checkout-confirmation-comment {
    min-height: 110px !important;

    border-radius: 16px !important;
    border: 1px solid #e5e5e5 !important;

    padding: 16px !important;

    font-size: 14px !important;

    box-shadow: none !important;

    resize: vertical !important;
}

.checkout-confirmation-comment:focus {
    border-color: #111111 !important;
    box-shadow: none !important;
}

/* =========================================================
   LEGAL NOTICE
========================================================= */

.checkout-confirmation-legal-notice {
    margin-top: 22px !important;
    margin-bottom: 10px !important;

    font-size: 14px !important;
    line-height: 1.5 !important;

    color: #555555 !important;
}

.checkout-confirmation-legal-notice a {
    color: #111111 !important;
    font-weight: 650 !important;
}

/* =========================================================
   PRODUCT CARD
========================================================= */

.card-products .card-body {
    padding: 20px 24px !important;
}

/* Header Row */
.checkout-items-header {
    margin-bottom: 6px !important;

    color: #777777 !important;

    font-size: 13px !important;
    font-weight: 650 !important;
}

.checkout-items-header-hr {
    margin: 12px 0 20px !important;
}

/* =========================================================
   PRODUCT ITEM
========================================================= */

.checkout-items-item {
    align-items: center !important;
}

/* Image */

.checkout-items-item-image-wrapper a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    padding: 12px !important;

    background: #fafafa !important;

    border-radius: 18px !important;
}

.checkout-items-item-image-wrapper img {
    border-radius: 12px !important;
}

/* Title */

.checkout-items-item-main p {
    margin-bottom: 8px !important;
}

.checkout-items-item-main a {
    color: #111111 !important;

    text-decoration: none !important;

    font-size: 16px !important;
    line-height: 1.35 !important;

    font-weight: 650 !important;
}

.checkout-items-item-main a:hover {
    color: #444444 !important;
}

/* Meta */

.checkout-items-item-main ul {
    margin-bottom: 0 !important;
}

.checkout-items-item-main li {
    margin-bottom: 3px !important;

    color: #777777 !important;

    font-size: 13px !important;
}

/* Price Columns */

.checkout-items-item-vat,
.checkout-items-item-price-single,
.checkout-items-item-quantity,
.checkout-items-item .price-col {
    font-size: 14px !important;
    color: #444444 !important;
}

.price_overall {
    font-size: 16px !important;
    font-weight: 750 !important;

    color: #111111 !important;
}

/* =========================================================
   DIVIDERS
========================================================= */

.checkout-items-item hr,
.checkout-confirmation hr {
    border: 0 !important;
    border-top: 1px solid #efefef !important;

    margin: 18px 0 !important;
}

/* =========================================================
   TOTALS
========================================================= */

.checkout-items-total {
    margin-left: auto !important;

    background: #fafafa !important;

    border: 1px solid #ececec !important;
    border-radius: 20px !important;

    padding: 18px !important;
}

.tax_label {
    color: #777777 !important;
    font-size: 14px !important;
}

.price_label {
    color: #111111 !important;
}

.total-sum {
    font-size: 28px !important;
    line-height: 1 !important;

    font-weight: 800 !important;
    letter-spacing: -0.04em !important;

    color: #111111 !important;
}

/* =========================================================
   BUTTON ROW
========================================================= */

.checkout-button-row {
    margin-top: 24px !important;
    row-gap: 14px !important;
}

.checkout-button-row .btn {
    height: 48px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    border-radius: 14px !important;

    font-size: 14px !important;
    font-weight: 650 !important;

    box-shadow: none !important;

    transition:
        background .2s ease,
        border-color .2s ease !important;
}

/* Primary */

.checkout-button-row .btn-primary {
    background: #111111 !important;
    border: 1px solid #111111 !important;

    color: #ffffff !important;
}

.checkout-button-row .btn-primary:hover {
    background: #222222 !important;
    border-color: #222222 !important;
}

/* Secondary */

.checkout-button-row .btn-outline-primary {
    background: #ffffff !important;

    border: 1px solid #e5e5e5 !important;

    color: #111111 !important;
}

.checkout-button-row .btn-outline-primary:hover {
    background: #f5f5f5 !important;
    border-color: #dcdcdc !important;

    color: #111111 !important;
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 991px) {

    .checkout-confirmation h1 {
        font-size: 28px !important;
    }

    .checkout-confirmation .card-body,
    .checkout-confirmation .card-header,
    .card-products .card-body {
        padding: 20px !important;
    }

    .checkout-items-total {
        margin-top: 18px !important;
    }

    .checkout-button-row .btn {
        width: 100% !important;
    }
}

.account-head-data .account-head-data-credit {
    text-align: center;
    font-weight: 700;
    border: 1px solid rgb(0, 0, 0);
    border-radius: 99px;
}

.btn-outline-secondary {
    border-color: rgb(108, 112, 115);
    background-color: transparent;
    color: rgb(40, 40, 48) !important;
    border-radius: 99px;
}

.btn-outline-secondary:hover {
    background-color: transparent !important;
}

.btn-outline-danger {
    color: #b90000;
    border-color: #b90000;
    border-radius: 99px;
}

.btn-outline-primary {
    border-color: rgb(0, 0, 0);
    background-color: transparent;
    color: #525252;
    position: relative;
    overflow: hidden;
    border-radius: 99px;
}









/* Checkout */

.order-completed {
    max-width: 760px;
    margin: 3rem auto 5rem;

    background: #fff;

    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 32px;

    padding: clamp(1.5rem, 4vw, 3rem);

    box-shadow:
        0 24px 70px rgba(15, 23, 42, .08);

    text-align: center;
}

.order-completed .checkout-paymentmodules-alert {
    font-size: 1.05rem;
    line-height: 1.8;

    color: #334155;

    margin-bottom: 2rem;
}

.order-completed .checkout-paymentmodules-alert::before {
    content: "✓";

    width: 84px;
    height: 84px;

    display: flex;
    align-items: center;
    justify-content: center;

    margin: 0 auto 1.5rem;

    border-radius: 999px;

    background:
        linear-gradient(
            135deg,
            #ecfdf5 0%,
            #f7fffb 100%
        );

    border: 1px solid #bbf7d0;

    color: #16a34a;

    font-size: 2rem;
    font-weight: 800;

    box-shadow:
        0 16px 40px rgba(22, 163, 74, .12);
}

.order-completed .payment-method-module-ids {
    margin: 0 auto 2rem;

    padding: 1.25rem 1.5rem;

    max-width: 520px;

    background: #f8fafc;

    border: 1px solid #e2e8f0;
    border-radius: 22px;

    text-align: left;
}

.order-completed .payment-method-module-ids li {
    color: #475569;
    line-height: 1.7;
    margin-bottom: .5rem;

    &:last-child {
        margin-bottom: 0;
    }
}

.order-completed .payment-method-module-ids strong {
    color: #0f172a;
}

.order-completed .row {
    justify-content: center;
}

.order-completed .col-md-4,
.order-completed .col-lg-3,
.order-completed .col-xl-2 {
    flex: 0 0 auto;
    max-width: 320px;
}

.order-completed .btn-primary {
    width: 100%;

    min-height: auto;

    border-radius: 999px;

    font-weight: 800;
    letter-spacing: .01em;

    box-shadow:
        0 16px 34px rgba(15, 23, 42, .18);

    transition: all .18s ease;

    &:hover {
        transform: translateY(-1px);

        box-shadow:
            0 20px 42px rgba(15, 23, 42, .22);
    }
}

/* versand zahlungsart */

/* =========================================================
   SHIPPING + PAYMENT PAGE CLEAN
   OHNE STEP STYLING
========================================================= */

#checkout h1 {
    font-size: 34px !important;
    line-height: 1.05 !important;

    font-weight: 800 !important;
    letter-spacing: -0.04em !important;

    color: #111111 !important;

    margin-bottom: 28px !important;
}

/* =========================================================
   MAIN CARD
========================================================= */

.checkout-shipping-form {
    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 26px !important;

    padding: 30px !important;

    box-shadow: none !important;
}

/* =========================================================
   FIELDSETS
========================================================= */

#checkout-shipping-payment,
#fieldset-payment {
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

#fieldset-payment {
    margin-top: 34px !important;
}

/* =========================================================
   HEADLINES
========================================================= */

.checkout-shipping-form .h2 {
    font-size: 23px !important;
    line-height: 1.1 !important;

    font-weight: 750 !important;
    letter-spacing: -0.03em !important;

    color: #111111 !important;

    margin-bottom: 14px !important;
}

/* =========================================================
   CHANGE ADDRESS
========================================================= */

.checkout-shipping-form-change {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;

    gap: 14px !important;

    padding: 14px 16px !important;

    background: #fafafa !important;

    border: 1px solid #efefef !important;
    border-radius: 16px !important;

    font-size: 14px !important;
    color: #444444 !important;
}

.checkout-shipping-form-change .btn-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;

    padding: 7px 13px !important;

    background: #ffffff !important;

    border: 1px solid #e5e5e5 !important;
    border-radius: 999px !important;

    color: #111111 !important;

    text-decoration: none !important;

    font-size: 13px !important;
    font-weight: 650 !important;
}

.checkout-shipping-form-change .btn-link:hover {
    background: #f5f5f5 !important;
}

/* =========================================================
   DIVIDER
========================================================= */

.checkout-shipping-form hr {
    border: 0 !important;
    border-top: 1px solid #efefef !important;

    margin: 24px 0 !important;
}

/* =========================================================
   SHIPPING METHOD CARD
========================================================= */

.checkout-shipping-form-options .custom-control {
    margin-bottom: 12px !important;
}

.checkout-shipping-form-options .custom-control-label {
    display: block !important;

    width: 100% !important;

    padding: 16px 18px !important;

    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 18px !important;

    cursor: pointer !important;

    transition:
        border-color .2s ease,
        background .2s ease !important;
}

.checkout-shipping-form-options .custom-control-label:hover {
    background: #fafafa !important;
    border-color: #dddddd !important;
}

.checkout-shipping-form-options .custom-control-input:checked ~ .custom-control-label {
    border-color: #111111 !important;
    background: #fcfcfc !important;
}

/* Shipping Content */

.checkout-shipping-form-options .content {
    align-items: center !important;
}

.checkout-shipping-form-options .title {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;

    font-size: 15px !important;
    font-weight: 650 !important;

    color: #111111 !important;
}

.checkout-shipping-form-options .price-col {
    text-align: right !important;

    font-size: 15px !important;
    font-weight: 750 !important;

    color: #111111 !important;
}

/* =========================================================
   PAYMENT METHODS
========================================================= */

.checkout-payment-options {
    margin-top: 4px !important;
}

.checkout-payment-method {
    margin-bottom: 2px !important;
    padding: 0 !important;
}

.checkout-payment-method .custom-control {
    width: 100% !important;
    margin: 0 !important;
}

.checkout-payment-method .custom-control-label {
    display: block !important;

    width: 100% !important;

    padding: 4px 0 4px 34px !important;

    background: transparent !important;

    border: none !important;
    border-radius: 0 !important;

    box-shadow: none !important;

    cursor: pointer !important;
}

.checkout-payment-method .custom-control-label:hover,
.checkout-payment-method .custom-control-input:checked ~ .custom-control-label {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Payment Content */

.checkout-payment-method .content {
    display: flex !important;
    flex-direction: column !important;

    gap: 1px !important;
}

.checkout-payment-method .title {
    font-size: 15px !important;
    font-weight: 650 !important;

    color: #111111 !important;
}

.checkout-payment-method-note {
    margin-top: 2px !important;
}

.checkout-payment-method-note small {
    color: #777777 !important;

    font-size: 12px !important;
    line-height: 1.3 !important;
}

/* Logos */

.checkout-payment-method img {
    max-height: 26px !important;
    width: auto !important;
}

/* =========================================================
   RADIOS
========================================================= */

.custom-radio .custom-control-label::before,
.checkout-payment-method .custom-control-label::before,
.checkout-shipping-form-options .custom-control-label::before {
    width: 18px !important;
    height: 18px !important;

    border: 1px solid #d0d0d0 !important;

    background: #ffffff !important;

    box-shadow: none !important;
}

/* Payment radio exact align */

.checkout-payment-method .custom-control-label::before,
.checkout-payment-method .custom-control-label::after {
    top: 14px !important;
    transform: none !important;
}

/* Shipping radio centered */

.checkout-shipping-form-options .custom-control-label::before,
.checkout-shipping-form-options .custom-control-label::after {
    top: 50% !important;
    transform: translateY(-50%) !important;
}

.custom-control-input:checked ~ .custom-control-label::before {
    background: #111111 !important;
    border-color: #111111 !important;
}

/* =========================================================
   PAYPAL BANNER
========================================================= */

#ppc-orderProcess-instalment-banner {
    margin-top: 8px !important;
}

/* =========================================================
   BUTTON ROW
========================================================= */

.checkout-button-row {
    margin-top: 30px !important;
    row-gap: 14px !important;
}

.checkout-button-row .btn {
    height: 48px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    border-radius: 14px !important;

    font-size: 14px !important;
    font-weight: 650 !important;

    box-shadow: none !important;

    transition:
        background .2s ease,
        border-color .2s ease !important;
}

/* Primary */

.checkout-button-row .btn-primary {
    background: #111111 !important;
    border: 1px solid #111111 !important;

    color: #ffffff !important;
}

.checkout-button-row .btn-primary:hover {
    background: #222222 !important;
    border-color: #222222 !important;
}

/* Secondary */

.checkout-button-row .btn-outline-primary {
    background: #ffffff !important;

    border: 1px solid #e5e5e5 !important;

    color: #111111 !important;
}

.checkout-button-row .btn-outline-primary:hover {
    background: #f5f5f5 !important;
    border-color: #dcdcdc !important;

    color: #111111 !important;
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 991px) {

    .checkout-shipping-form {
        padding: 22px !important;
        border-radius: 22px !important;
    }

    #checkout h1 {
        font-size: 28px !important;
    }

    .checkout-shipping-form .h2 {
        font-size: 21px !important;
    }

    .checkout-shipping-form-change {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    .checkout-shipping-form-options .price-col {
        text-align: left !important;
        margin-top: 8px !important;
    }

    .checkout-button-row .btn {
        width: 100% !important;
    }
}


.checkout-shipping-form-options {
    background: #f7f7f7;
    border-radius: 12px;
    padding: 16px;
    border: 1px solid #e5e7eb;

    .custom-control {
        width: 100%;
        margin: 0;
    }

    .custom-control-label {
        width: 100%;
        padding: 12px 16px;
        background: #fff;
        border: 1px solid #e5e7eb;
        border-radius: 10px;
        cursor: pointer;
        transition: 0.2s ease;
    }

    .custom-control-label:hover {
        background: #fafafa;
    }

    .custom-control-input:checked ~ .custom-control-label {
        border-color: #d1d5db;
        background: #fcfcfc;
    }

    .form-row.content {
        align-items: center;
    }

    .title {
        display: flex;
        align-items: center;
        gap: 10px;
        font-weight: 600;

        img {
            max-height: 24px;
            width: auto;
        }
    }

    .price-col {
        text-align: right;
        font-weight: 600;
    }
}










#order-additional-payment {
width: 40%;
}

.stepper .step-active .step-content::after {
    display: none;
}

.wishlist-button .wishlist-button-inner .wishlist-button-text {
    text-decoration: none;
}

.cart-items-body .cart-items-delete .cart-items-delete-button {
    padding: 0;
    text-decoration: none;
    white-space: nowrap;
}

.stepper .badge {
    width: 1.5625rem;
    height: 1.5625rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-right: 6px;
    margin-left: 4px;
}

.card-gray {
    background: #f5f7fa;
    border: 0;
    margin-bottom: 40px;
}

.card-products .card-header .btn {
    background: #f5f7fa;
    padding: 0.9375rem 1.875rem;
    border-radius: 99px;
}

.stepper {
    align-items: center;
    border: 1px solid #ebebeb;
    margin-bottom: 40px;
    background: #f5f7fa;
    overflow: hidden;
    border-radius: 99px;
}


/* Buttons */

    .btn-outline-primary:hover {
        background-color: #000000;
        color: #ffffff;
    }



.form-counter {
    border-radius: 99px;
}

.btn-primary {
	color: #ffffff;
	background-color: #000000;
	border: 1 px solid #000000;
	border-radius: 99px;
	padding: 6px 18px 6px 18px;
}

.btn-secondary {
	color: #ffffff;
	background-color: #ffffff;
	border: 1 px solid #000000;
	border-radius: 99px;
	padding: 6px 18px 6px 18px;
}

.btn-secondary:hover {
    color: #000000;
    background-color: #ffffff;
}

#suche2 button,
#suche2 .btn,
#suche2 .btn-primary {
    flex: 0 0 auto;
    min-width: 150px;
    height: 48px;
    padding: 0 24px;
    border-radius: 999px;
    border: 0 !important;

    background: #050505 !important;
    color: #fffff !important;
    font-size: 14px;
    font-weight: 700;

    box-shadow:
        0 12px 26px rgba(0,0,0,.22),
        inset 0 1px 0 rgba(255,255,255,.16);

    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

#suche2 button:hover,
#suche2 .btn:hover,
#suche2 .btn-primary:hover {
    transform: translateY(-1px);
    background: #1a1a1a !important;
    box-shadow:
        0 18px 36px rgba(0,0,0,.26),
        inset 0 1px 0 rgba(255,255,255,.18);
}

/* Warenkorb Button */

/* Add to cart Button schwarz */
.btn-primary {
    background: #000000 !important;
    border-color: #000000 !important;
    color: #ffffff !important;
}

/* Hover */
.btn-primary:hover {
    background: #111 !important;
    border-color: #111 !important;
    color: #fff !important;
}

/* Active / Click */
.btn-primary:active,
.btn-primary:focus {
    background: #000 !important;
    border-color: #000 !important;
    box-shadow: none !important;
}

.btn-outline-secondary:focus, .btn-outline-secondary.focus {
    box-shadow: none;
}

.btn-outline-secondary:not(:disabled):not(.disabled):active:focus, .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-secondary.dropdown-toggle:focus, .show > .btn-outline-secondary[data-toggle=collapse]:focus:not(.navbar-toggler) {
    box-shadow: none;
}




@media (min-width: 992px) {
    #content-wrapper:not(.has-fluid) {
        padding-top: 0 !important;
    }
}

@media (min-width: 992px) {
    main section {
        padding: 0;
    }
}

.landing-page {
    margin-bottom: 26px;
}







.header-hero__overlay::before {
    content: "";
    position: absolute;
    inset: 0;

    background:
        radial-gradient(
            ellipse at 9% 13%,
            rgba(255,255,255,0.72) 0%,
            rgba(255,255,255,0.50) 14%,
            rgba(255,255,255,0.24) 28%,
            rgba(255,255,255,0.08) 42%,
            rgba(255,255,255,0.00) 62%
        );

    pointer-events: none;
}

















/* Icons Payment Provider */


.checkout-shipping-form-options {
    & .title {
        img {
            max-height: auto;
            width: 10% !important;
        }
    }
}

.img-fluid {
    max-width: 60%;
    height: auto;
}












#image_wrapper #gallery .slick-slide > div {
    display: flex !important;
    justify-content: center;
}

#image_wrapper #gallery .square-image {
    width: 80% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

#image_wrapper #gallery .square-image .inner {
    display: flex;
    align-items: center;
    justify-content: center;
}

#image_wrapper #gallery .product-image {
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: contain;
}











h1, h2, h3, h4, h5, h6, .h1, .h2, .product-matrix .product-matrix-title, .h3, .sidepanel-left .box-normal .box-normal-link, .h4, .h5, .h6 {
   font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif !important;

}




#tab-link-description {
   font-size: 1.5rem  !important; 
   font-weight: 400 !important;
    line-height: 1.2  !important;
    color: #525252  !important;
}













#pushed-success.pushed-success-toast {
    display: flex;
    align-items: center;
    justify-content: center;

    gap: .75rem;

    width: fit-content;
    max-width: 420px;

    padding: .85rem 1rem;
    margin: 1rem auto 2rem;

    border: 1px solid #e7efe7;
    border-radius: 14px;

    background: #fff;
    color: #222;

    box-shadow:
        0 8px 24px rgba(0,0,0,.06);

    backdrop-filter: blur(8px);

    text-align: left;
}

#pushed-success .pushed-success-icon {
    width: 30px;
    height: 30px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 999px;

    background: #1C871E;
    color: #fff;

    font-size: .8rem;

    flex-shrink: 0;
}

#pushed-success .pushed-success-content {
    display: flex;
    flex-direction: column;
    align-items: center;

    line-height: 1.2;
}

#pushed-success .pushed-success-content strong {
    font-size: .92rem;
    font-weight: 700;
}

#pushed-success .pushed-success-content span {
    font-size: .82rem;
    color: #777;
}
















#new_customer {
  max-width: 1100px;
  margin: 0 auto 4rem;
  padding: 2rem 1rem;

  h1 {
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 800;
    margin-bottom: 2rem;
    letter-spacing: -0.03em;
  }

  .register-form {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 28px;
    padding: clamp(1.25rem, 3vw, 2.5rem);
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.08);
  }

  fieldset,
  .register-form-account {
    margin-bottom: 2rem;
  }

  hr {
    display: none;
  }

  .h3 {
    font-size: 1rem;
    font-weight: 800;
    color: #111827;
    margin-bottom: 1rem;
    padding: .75rem 1rem;
    background: #f8fafc;
    border-radius: 16px;
  }

  .form-row {
    row-gap: 1rem;
  }

  .form-group {
    margin-bottom: 1rem;

    .d-flex {
      position: relative;
    }
  }

  .form-control,
  .custom-select {
    min-height: 54px;
    border-radius: 16px;
    border: 1px solid #dbe3ec;
    background-color: #f8fafc !important;
    padding: 1.15rem 1rem .55rem;
    font-size: .95rem;
    transition: all .18s ease;

    &:focus {
      background-color: #fff !important;
      border-color: #0f172a;
      box-shadow: 0 0 0 4px rgba(15, 23, 42, .08);
    }
  }

  label.col-form-label {
    font-size: .78rem;
    font-weight: 700;
    color: #64748b;
    margin-bottom: .35rem;

    .optional {
      font-weight: 500;
      color: #94a3b8;
    }
  }

  .required-info {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    color: #64748b;
    padding: .9rem 1rem;
    border-radius: 16px;
    margin-bottom: 1.5rem;
    font-size: .9rem;
  }

  .required-star {
    color: #ef4444;
  }

  .has-error {
    .form-control,
    .custom-select {
      border-color: #ef4444;
      background-color: #fff7f7 !important;
    }
  }

  .form-error-msg {
    margin-top: .45rem;
    color: #dc2626;
    font-size: .82rem;
    font-weight: 600;
  }

  .checkout-button-row {
    align-items: center;
    gap: 1rem;
    margin-top: 2rem;
  }

  .checkout-register-form-buttons-privacy {
    font-size: .88rem;
    color: #64748b;

    a {
      color: #0f172a;
      font-weight: 700;
      text-decoration: underline;
      text-underline-offset: 3px;
    }
  }

  .btn-primary {
    min-height: 56px;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .01em;
    box-shadow: 0 14px 30px rgba(15, 23, 42, .18);
  }
}

@media (min-width: 768px) {
  #new_customer {
    .col-md-4 > .h3 {
      position: sticky;
      top: 2rem;
    }
  }
}

@media (max-width: 767.98px) {
  #new_customer {
    padding: 1rem;

    .register-form {
      border-radius: 22px;
      padding: 1rem;
    }

    .h3 {
      margin-top: 1rem;
    }
  }
}







/* forgot password */
.account-password-heading,
.account-password {
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

.account-password-heading {
  padding: 3rem 1rem 1rem;
  text-align: center;

  h1 {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    margin: 0;
    color: #0f172a;
  }
}

.account-password {
  padding: 0 1rem 4rem;

  .row {
    justify-content: center;
  }

  .col-lg-8 {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .alert-info {
    border: 1px solid #dbeafe;
    background: #eff6ff;
    color: #1e3a8a;
    border-radius: 18px;
    padding: 1rem 1.15rem;
    font-size: .95rem;
    line-height: 1.5;
    box-shadow: none;

    i {
      margin-right: .5rem;
      color: #2563eb;
    }
  }

  form#passwort_vergessen {
    margin-top: 1.25rem;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 28px;
    padding: clamp(1.25rem, 4vw, 2.25rem);
    box-shadow: 0 24px 70px rgba(15, 23, 42, .08);
  }

  .required-info {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    color: #64748b;
    padding: .85rem 1rem;
    border-radius: 16px;
    margin-bottom: 1.5rem;
    font-size: .88rem;
  }

  .required-star {
    color: #ef4444;
  }

  fieldset {
    margin: 0;
    padding: 0;
    border: 0;
  }

  legend {
    font-size: 1.15rem;
    font-weight: 800;
    color: #111827;
    margin-bottom: 1rem;
    padding: 0;
  }

  hr {
    display: none;
  }

  .form-group {
    margin-bottom: 1.4rem;

    .d-flex {
      position: relative;
    }
  }

  .form-control {
    min-height: 56px;
    border-radius: 16px;
    border: 1px solid #dbe3ec;
    background-color: #f8fafc !important;
    padding: 1.15rem 1rem .55rem;
    font-size: .96rem;
    transition: all .18s ease;

    &:focus {
      background-color: #fff !important;
      border-color: #0f172a;
      box-shadow: 0 0 0 4px rgba(15, 23, 42, .08);
    }
  }

  label.col-form-label {
    font-size: .8rem;
    font-weight: 700;
    color: #64748b;
    margin-bottom: .35rem;
  }

  .btn-primary {
    width: 100%;
    min-height: 58px;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .01em;
    box-shadow: 0 16px 34px rgba(15, 23, 42, .18);
    transition: all .18s ease;

    &:hover {
      transform: translateY(-1px);
      box-shadow: 0 20px 42px rgba(15, 23, 42, .22);
    }
  }
}

@media (max-width: 575.98px) {
  .account-password-heading {
    padding-top: 2rem;
  }

  .account-password {
    form#passwort_vergessen {
      border-radius: 22px;
      padding: 1.15rem;
    }

    .alert-info {
      border-radius: 16px;
    }
  }
}

.account-password form#passwort_vergessen {
    max-width: 640px;
    margin: 1.5rem auto 0;
}

.account-password .alert.alert-wrapper.alert-info,
.account-password form#passwort_vergessen {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}


/* Alert Success */
#alert-list .alert.alert-success,
.alert.alert-wrapper.alert-success[data-key="newPasswordWasGenerated"] {
    display: flex !important;
    align-items: flex-start;
    gap: .85rem;

    max-width: 640px;
    width: auto;
    margin: 0 auto 1.5rem !important;

    background: linear-gradient(135deg, #ecfdf5 0%, #f7fffb 100%) !important;
    border: 1px solid #bbf7d0 !important;
    border-left: 4px solid #16a34a !important;

    border-radius: 20px !important;
    padding: 1rem 3rem 1rem 1.15rem !important;

    color: #166534 !important;
    font-size: .95rem;
    line-height: 1.6;

    box-shadow: 0 10px 30px rgba(22, 163, 74, .08);
    position: relative;
}


#alert-list .alert.alert-danger,
.alert.alert-wrapper.alert-danger[data-key="accountLocked"] {
    display: flex !important;
    align-items: flex-start;
    gap: .85rem;

    max-width: 640px;
    width: auto;

    margin: 0 auto 1.5rem !important;

    background: linear-gradient(
        135deg,
        #fef2f2 0%,
        #fff8f8 100%
    ) !important;

    border: 1px solid #fecaca !important;
    border-left: 4px solid #dc2626 !important;

    border-radius: 20px !important;

    padding: 1rem 3rem 1rem 1.15rem !important;

    color: #991b1b !important;

    font-size: .95rem;
    line-height: 1.6;

    box-shadow:
        0 10px 30px rgba(220, 38, 38, .08);

    position: relative;
}

#alert-list .alert.alert-danger i,
.alert.alert-wrapper.alert-danger[data-key="accountLocked"] i {
    color: #dc2626 !important;
    margin-top: .2rem;
    flex-shrink: 0;
}

#alert-list .alert.alert-danger .close,
.alert.alert-wrapper.alert-danger[data-key="accountLocked"] .close {
    display: none;
}

#alert-list .alert.alert-danger .sr-only,
.alert.alert-wrapper.alert-danger[data-key="accountLocked"] .sr-only {
    display: none;
}




/* login */


#account {
    max-width: 1200px;
    margin: 0 auto;
    padding: 3rem 1rem 5rem;

    h1 {
        text-align: center;
        font-size: clamp(2rem, 4vw, 3rem);
        font-weight: 800;
        letter-spacing: -.04em;
        margin-bottom: 2.5rem;
        color: #0f172a;
    }

    .login-form {
        justify-content: center;
    }

    .col-sm-8.col-lg-6 {
        flex: 0 0 100%;
        max-width: 640px;
    }

    form#login_form {
        background: #fff;
        border: 1px solid rgba(15, 23, 42, .08);
        border-radius: 28px;
        padding: clamp(1.25rem, 4vw, 2.5rem);

        box-shadow:
            0 24px 70px rgba(15, 23, 42, .08);
    }

    legend {
        font-size: 1.2rem;
        font-weight: 800;
        color: #111827;
        margin-bottom: 1rem;
    }

    .required-info {
        background: #f8fafc;
        border: 1px solid #e2e8f0;
        color: #64748b;

        padding: .9rem 1rem;
        border-radius: 16px;

        margin-bottom: 1.5rem;

        font-size: .88rem;
    }

    .required-star {
        color: #ef4444;
    }

    .form-group {
        margin-bottom: 1.15rem;
    }

    .form-control {
        min-height: 56px;

        border-radius: 16px;
        border: 1px solid #dbe3ec;

        background: #f8fafc !important;

        padding: 1.15rem 1rem .55rem;

        font-size: .96rem;

        transition: all .18s ease;

        &:focus {
            background: #fff !important;
            border-color: #0f172a;

            box-shadow:
                0 0 0 4px rgba(15, 23, 42, .08);
        }
    }

    label.col-form-label {
        font-size: .8rem;
        font-weight: 700;
        color: #64748b;
        margin-bottom: .35rem;
    }

    .login-form-submit {
        margin-top: 1.5rem;
        margin-bottom: 1.5rem;
    }

    .btn-primary {
        width: 100%;
        min-height: 58px;

        border-radius: 999px;

        font-weight: 800;
        letter-spacing: .01em;

        box-shadow:
            0 16px 34px rgba(15, 23, 42, .18);

        transition: all .18s ease;

        &:hover {
            transform: translateY(-1px);

            box-shadow:
                0 20px 42px rgba(15, 23, 42, .22);
        }
    }

    .register-wrapper,
    .resetpw-wrapper {
        display: block;
        text-align: center;

        color: #64748b;

        font-size: .92rem;

        margin-top: 1rem;

        a {
            color: #0f172a;
            font-weight: 700;

            text-decoration: none;

            &:hover {
                text-decoration: underline;
            }
        }
    }

    .resetpw-wrapper {
        margin-top: .7rem;

        .fa {
            margin-right: .35rem;
            opacity: .7;
        }
    }
}

/* alert */
#alert-list .alert.alert-info[data-key="changepasswordSuccess"] {
    display: flex;
    align-items: flex-start;
    gap: .85rem;

    max-width: 640px;
    width: auto;

    margin: 0 auto 1.5rem !important;

    background: linear-gradient(
        135deg,
        #eff6ff 0%,
        #f8fbff 100%
    ) !important;

    border: 1px solid #dbeafe !important;
    border-left: 4px solid #2563eb !important;

    border-radius: 20px !important;

    padding: 1rem 1.15rem !important;

    color: #1e3a8a !important;

    font-size: .95rem;
    line-height: 1.6;

    box-shadow:
        0 10px 30px rgba(37, 99, 235, .06);

    position: relative;
}

#alert-list .alert.alert-info[data-key="changepasswordSuccess"] i {
    color: #2563eb !important;
    margin-top: .2rem;
    flex-shrink: 0;
}

#alert-list .alert.alert-info[data-key="changepasswordSuccess"] .close,
#alert-list .alert.alert-info[data-key="changepasswordSuccess"] .sr-only {
    display: none;
}






/* Widerruf */

#online-revocation-form {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;

    .container {
        max-width: 860px;
        margin: 0 auto;
        padding: 3rem 1rem 5rem;
    }

    form.withdrawal-form {
        background: #fff;

        border: 1px solid rgba(15, 23, 42, .08);
        border-radius: 28px;

        padding: clamp(1.25rem, 4vw, 2.5rem);

        box-shadow:
            0 24px 70px rgba(15, 23, 42, .08);

        margin-bottom: 2rem;
    }

    .row {
        row-gap: .4rem;
    }

    .form-group {
        margin-bottom: 1rem;
    }

    .form-control {
        min-height: 56px;

        border-radius: 16px;
        border: 1px solid #dbe3ec;

        background: #f8fafc !important;

        padding: 1.15rem 1rem .55rem;

        font-size: .96rem;

        transition: all .18s ease;

        &:focus {
            background: #fff !important;

            border-color: #0f172a;

            box-shadow:
                0 0 0 4px rgba(15, 23, 42, .08);
        }
    }

    textarea.form-control {
        min-height: 160px;
        resize: vertical;
        padding-top: 1rem;
    }

    label.col-form-label {
        font-size: .8rem;
        font-weight: 700;
        color: #64748b;
        margin-bottom: .35rem;
    }

    .form-text.text-muted {
        color: #94a3b8 !important;
        font-size: .8rem;
        margin-bottom: .5rem;
    }

    .btn-primary {
        width: 100%;
        min-height: 58px;

        border-radius: 999px;

        font-weight: 800;
        letter-spacing: .01em;

        box-shadow:
            0 16px 34px rgba(15, 23, 42, .18);

        transition: all .18s ease;

        &:hover {
            transform: translateY(-1px);

            box-shadow:
                0 20px 42px rgba(15, 23, 42, .22);
        }
    }

    hr.my-4 {
        border: 0;
        height: 1px;

        background:
            linear-gradient(
                to right,
                transparent,
                #e2e8f0,
                transparent
            );

        margin: 2rem 0;
    }

    p {
        color: #475569;
        line-height: 1.7;
        font-size: .95rem;
    }
}

#online-revocation-form .withdrawal-form,
#online-revocation-form hr.my-4,
#online-revocation-form p {
    max-width: 740px;
    margin-left: auto;
    margin-right: auto;
}




/* Rechts pages */


#content {
	width: 90%;
	margin: 0 auto;
}


















/* product fancy carts */

/* =========================================================
   MODERN DARK CATEGORY CARDS
========================================================= */

.content-cats-small {
    margin-top: 28px;

    row-gap: 18px;
}


/* ---------------------------------------------------------
   CARD
--------------------------------------------------------- */

.content-cats-small .sub-categories {
    height: 100%;

    background: rgba(15, 15, 15, 0.92);

    border: 1px solid rgba(255,255,255,0.06);

    border-radius: 22px;

    box-shadow:
        0 8px 24px rgba(0,0,0,0.10);

    overflow: hidden;

    transition:
        border-color .2s ease,
        background .2s ease;
}

.content-cats-small .sub-categories:hover {
    border-color: rgba(125,185,40,0.25);

    background: rgba(18,18,18,0.96);
}


/* ---------------------------------------------------------
   INNER
--------------------------------------------------------- */

.content-cats-small .sub-categories > div {
    height: 100%;

    padding: 22px;

    display: flex;
    flex-direction: column;
}


/* ---------------------------------------------------------
   TITLE
--------------------------------------------------------- */

.content-cats-small .caption {
    margin-bottom: 10px;
}

.content-cats-small .caption a {
    display: inline-flex;
    align-items: center;

    color: #ffffff !important;

    font-size: 17px;
    font-weight: 700;

    line-height: 1.25;

    letter-spacing: -0.02em;

    text-decoration: none !important;

    transition: color .2s ease;
}

.content-cats-small .caption a:hover {
    color: #7db928 !important;
}


/* ---------------------------------------------------------
   DESCRIPTION
--------------------------------------------------------- */

.content-cats-small .item_desc {
    margin: 0;

    color: rgba(255,255,255,0.62) !important;

    font-size: 14px;
    font-weight: 450;

    line-height: 1.55;

    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;

    overflow: hidden;
}


/* ---------------------------------------------------------
   DIVIDER
--------------------------------------------------------- */

.content-cats-small .sub-categories hr {
    margin: 18px 0 12px;

    border: 0;

    border-top: 1px solid rgba(255,255,255,0.08);

    opacity: 1;
}


/* ---------------------------------------------------------
   SUB LINKS
--------------------------------------------------------- */

.content-cats-small .sub-categories ul {
    margin: auto 0 0;

    padding: 0;

    list-style: none;
}

.content-cats-small .sub-categories li {
    margin: 0;
    padding: 0;
}

.content-cats-small .sub-categories li a {
    display: flex;
    align-items: center;
    justify-content: space-between;

    padding: 11px 0;

    color: rgba(255,255,255,0.72) !important;

    font-size: 14px;
    font-weight: 600;

    line-height: 1.3;

    text-decoration: none !important;

    border-top: 1px solid rgba(255,255,255,0.06);

    transition:
        color .2s ease,
        border-color .2s ease;
}

.content-cats-small .sub-categories li a:hover {
    color: #7db928 !important;

    border-color: rgba(125,185,40,0.24);
}


/* ---------------------------------------------------------
   SUBTLE ARROW
--------------------------------------------------------- */

.content-cats-small .caption a::after {
    content: "›";

    margin-left: 8px;

    color: #7db928;

    font-size: 18px;
    font-weight: 500;

    opacity: .55;

    transition:
        opacity .2s ease,
        transform .2s ease;
}

.content-cats-small .caption a:hover::after {
    opacity: 1;

    transform: translateX(2px);
}


/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 991px) {

    .content-cats-small {
        row-gap: 14px;
    }

    .content-cats-small .sub-categories {
        border-radius: 18px;
    }

    .content-cats-small .sub-categories > div {
        padding: 18px;
    }

    .content-cats-small .caption a {
        font-size: 16px;
    }
}






















/* Check out */

/* Warenkorb modern clean */
.basket_wrapper {
    background: #ffffff;
    border: 1px solid #ececec;
    border-radius: 18px;
    padding: 24px;
}

.cart-items-header {
    color: #777777 !important;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.cart-items-body {
    align-items: center;
    padding: 20px 0;
}

.cart-items-image a {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f7f7f7;
    border-radius: 16px;
    padding: 14px;
}

.cart-items-image img {
    border-radius: 12px;
}

.cart-items-name {
    color: #111111 !important;
    font-weight: 650;
    font-size: 16px;
    line-height: 1.35;
    text-decoration: none !important;
}

.cart-items-name:hover {
    color: #444444 !important;
}

.cart-items-single-price,
.cart-items-price {
    font-size: 15px;
    color: #222222;
}

.cart-items-price-text {
    display: block;
    margin-bottom: 4px;
    color: #777777;
    font-size: 12px;
    font-weight: 600;
}

/* Menge */
.qty-wrapper .input-group {
    width: fit-content;
    border: 1px solid #e5e5e5;
    border-radius: 999px;
    overflow: hidden;
    background: #ffffff;
}

.qty-wrapper .btn,
.qty-wrapper .quantity {
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
}

.qty-wrapper .btn {
    width: 38px;
    color: #111111 !important;
}

.qty-wrapper .quantity {
    max-width: 54px;
    text-align: center;
    font-weight: 600;
}

/* Meta Infos */
.cart-items-body ul {
    margin-top: 14px;
    margin-bottom: 0;
    color: #777777;
    font-size: 13px;
}

.cart-items-body ul li {
    margin-bottom: 4px;
}

.cart-items-delete {
    margin-top: 12px;
}

.cart-items-delete .btn-link {
    color: #777777 !important;
    text-decoration: none !important;
    font-size: 13px;
}

.cart-items-delete .btn-link:hover {
    color: #111111 !important;
}

/* Bestellübersicht */
.cart-summary {
    background: #ffffff;
    border: 1px solid #ececec;
    border-radius: 18px;
    padding: 24px;
}

.cart-summary .card {
    border: 1px solid #ececec;
    border-radius: 16px;
    background: #fafafa;
}

.cart-summary .card-header {
    background: transparent;
    border-bottom: none;
    color: #666666;
    font-size: 14px;
}

.basket-summary .card-body {
    padding: 20px;
}

.basket-summary-total {
    margin-top: 12px;
    padding-top: 16px;
    border-top: 1px solid #e8e8e8;
}

.total-sum {
    font-size: 20px;
    color: #111111;
}

/* Checkout Button */
#cart-checkout-btn {
    display: flex !important;
    justify-content: center;
    width: 100%;
    margin-top: 18px;
    border-radius: 999px !important;
    padding: 13px 22px !important;
    font-weight: 650 !important;
}

/* Mobile */
@media (max-width: 991px) {
    .basket_wrapper,
    .cart-summary {
        padding: 18px;
        border-radius: 16px;
    }

    .cart-items-body {
        row-gap: 14px;
    }

    .cart-items-image a {
        padding: 10px;
    }
}



/* =========================================================
   REGISTER / LOGIN LAYOUT
========================================================= */

#register-customer {
    margin-top: 20px !important;
    row-gap: 28px !important;
}

#register-customer > [class*="col"] {
    min-width: 0 !important;
}

/* =========================================================
   LEFT LOGIN CARD
========================================================= */

.checkout-existing-customer .card {
    border: 1px solid #ececec !important;
    border-radius: 28px !important;
    background: #ffffff !important;

    box-shadow: none !important;
    overflow: hidden !important;
}

.checkout-existing-customer .card-body {
    padding: 34px !important;
}



.checkout-existing-customer .card-title.h3 {
    font-size: 30px !important;
    line-height: 1.1 !important;

    font-weight: 750 !important;
    letter-spacing: -0.03em !important;

    color: #111111 !important;

    margin-bottom: 28px !important;
}

/* =========================================================
   RIGHT REGISTER CARD
========================================================= */

.checkout-register-form {
    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 28px !important;

    padding: 38px !important;

    box-shadow: none !important;
}

.checkout-register-form fieldset {
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

.checkout-register-form h1 {
    font-size: 42px !important;
    line-height: 1.05 !important;

    font-weight: 800 !important;
    letter-spacing: -0.04em !important;

    color: #111111 !important;

    margin-bottom: 14px !important;
}

.checkout-register-form .required-info {
    margin-top: 14px !important;

    color: #777777 !important;
    font-size: 14px !important;
}

/* =========================================================
   SECTION HEADINGS
========================================================= */

.checkout-register-form .h3 {
    font-size: 22px !important;
    line-height: 1.1 !important;

    font-weight: 700 !important;
    letter-spacing: -0.02em !important;

    color: #111111 !important;

    margin-top: 4px !important;
}

/* =========================================================
   INPUTS
========================================================= */

.form-group {
    margin-bottom: 18px !important;
}

.form-control,
.custom-select,
.tt-input {
    height: auto;

    border-radius: 18px !important;
    border:none !important;

    background: transparent !important;

    box-shadow: none !important;

    padding: 0 18px !important;

    font-size: 15px !important;
    color: #111111 !important;

    transition:
        border-color .2s ease,
        background .2s ease !important;
}

.form-control:hover,
.custom-select:hover,
.tt-input:hover {
    border-color: #d8d8d8 !important;
}

.form-control:focus,
.custom-select:focus,
.tt-input:focus {
    border-color: #111111 !important;

    background: #ffffff !important;

    box-shadow: none !important;
}

/* =========================================================
   FLOATING LABELS
========================================================= */

.label-slide .form-group {
    position: relative !important;
}

.label-slide .col-form-label {
    position: absolute !important;

    top: -10px !important;
    left: 14px !important;

    padding: 0 8px !important;

    background: #ffffff !important;

    font-size: 12px !important;
    font-weight: 600 !important;

    color: #777777 !important;

    z-index: 5 !important;
}

/* =========================================================
   HR
========================================================= */

.checkout-register-form hr,
.checkout-existing-customer hr {
    border: 0 !important;
    border-top: 1px solid #f0f0f0 !important;

    margin: 34px 0 !important;
}

/* =========================================================
   ODER
========================================================= */

.checkout-existing-customer-hr {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    margin: 28px 0 !important;
}

.hr-sect {
    position: relative !important;

    font-size: 14px !important;
    font-weight: 600 !important;

    color: #999999 !important;
}

.hr-sect::before,
.hr-sect::after {
    content: "" !important;

    position: absolute !important;
    top: 50% !important;

    width: 80px !important;
    height: 1px !important;

    background: #ececec !important;
}

.hr-sect::before {
    right: calc(100% + 14px) !important;
}

.hr-sect::after {
    left: calc(100% + 14px) !important;
}

/* =========================================================
   CHECKBOXES
========================================================= */

.custom-control-label {
    font-weight: 550 !important;
    color: #222222 !important;
}

.custom-control-input:checked ~ .custom-control-label::before {
    background: #111111 !important;
    border-color: #111111 !important;
}

/* =========================================================
   BUTTONS
========================================================= */

.btn-primary {
    height: auto;

    border-radius: 999px !important;

    background: #111111 !important;
    border: 1px solid #111111 !important;

    color: #ffffff !important;

    font-size: 15px !important;
    font-weight: 650 !important;

    box-shadow: none !important;

    transition:
        background .2s ease,
        border-color .2s ease !important;
}

.btn-primary:hover {
    background: #222222 !important;
    border-color: #222222 !important;

    color: #ffffff !important;
}

.customer-login-buttons .btn-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    height: 58px !important;

    border-radius: 999px !important;

    background: #f5f5f5 !important;
    color: #111111 !important;

    text-decoration: none !important;
    font-weight: 600 !important;

    transition: background .2s ease !important;
}

.customer-login-buttons .btn-link:hover {
    background: #ececec !important;
    color: #111111 !important;
}

/* =========================================================
   PRIVACY LINK
========================================================= */

.checkout-register-form-buttons-privacy {
    margin-bottom: 20px !important;
}

.checkout-register-form-buttons-privacy a {
    color: #666666 !important;
    text-decoration: none !important;

    font-size: 14px !important;
}

.checkout-register-form-buttons-privacy a:hover {
    color: #111111 !important;
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 991px) {

    .checkout-register-form {
        padding: 24px !important;
        border-radius: 22px !important;
    }

    .checkout-existing-customer .card-body {
        padding: 24px !important;
    }

    .checkout-register-form h1 {
        font-size: 30px !important;
    }

    .checkout-existing-customer .card-title.h3 {
        font-size: 24px !important;
    }

    .btn-primary,
    .customer-login-buttons .btn-link {
        width: 100% !important;
    }
}



/* account */

/* =========================================================
   ACCOUNT DASHBOARD CLEAN CARDS
========================================================= */

.account-head-data {
    margin-bottom: 28px !important;
}

.account-head-data > .col:first-child {
    background: #ffffff !important;
    border: 1px solid #ececec !important;
    border-radius: 24px !important;
    padding: 28px !important;
    color: #555555 !important;
    font-size: 15px !important;
}

.account-head-data-credit {
    border: 1px solid #ececec !important;
    border-radius: 24px !important;
    background: #ffffff !important;
    box-shadow: none !important;
}

.account-head-data-credit .card-body {
    padding: 28px !important;
    font-weight: 650 !important;
    color: #111111 !important;
}

/* Card Grid */
.account-data-item {
    margin-bottom: 28px !important;
}

.account-data-item .card {
    height: 100% !important;

    border: 1px solid #ececec !important;
    border-radius: 28px !important;

    background: #ffffff !important;
    box-shadow: none !important;

    overflow: hidden !important;
}

/* Header */
.account-data-item .card-header {
    background: #ffffff !important;
    border-bottom: 1px solid #f0f0f0 !important;

    padding: 24px 26px !important;
}

.account-data-item .card-header h2,
.account-data-item .card-header .h3 {
    margin: 0 !important;

    font-size: 22px !important;
    line-height: 1.15 !important;

    font-weight: 750 !important;
    letter-spacing: -0.03em !important;
}

.account-data-item .card-header a {
    color: #111111 !important;
    text-decoration: none !important;
}

.account-data-item .card-header a:hover {
    color: #444444 !important;
}

/* "Alle anzeigen" */
.account-data-item .card-header .font-size-sm a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    padding: 8px 13px !important;

    background: #f5f5f5 !important;
    color: #111111 !important;

    border-radius: 999px !important;

    font-size: 13px !important;
    font-weight: 650 !important;

    text-decoration: none !important;
}

.account-data-item .card-header .font-size-sm a:hover {
    background: #ececec !important;
}

/* Body */
.account-data-item .card-body {
    padding: 26px !important;

    color: #555555 !important;
    font-size: 15px !important;
}

/* Tables inside cards */
.account-data-item .table-responsive {
    padding: 8px 0 !important;
}

.account-data-item table {
    margin: 0 !important;
}

.account-data-item table tr {
    transition: background .2s ease !important;
}

.account-data-item table tr:hover {
    background: #fafafa !important;
}

.account-data-item table td {
    padding: 18px 26px !important;

    border-top: 1px solid #f2f2f2 !important;

    color: #222222 !important;
    font-size: 14px !important;
}

.account-data-item table tr:first-child td {
    border-top: none !important;
}

.account-data-item small,
.account-data-item .text-muted-util {
    margin-top: 4px !important;
    color: #777777 !important;
    font-size: 13px !important;
}

/* Action icons */
.account-data-item table td a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: 36px !important;
    height: 36px !important;

    border-radius: 999px !important;

    background: #f5f5f5 !important;
    color: #111111 !important;

    text-decoration: none !important;
}

.account-data-item table td a:hover {
    background: #ececec !important;
}

/* Empty states */
.account-shipping-address .card-body,
.account-comparelist .card-body,
#my-wishlists .card-body {
    min-height: 170px !important;

    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;

    gap: 14px !important;
}

.account-data-item p {
    margin: 0 !important;
    color: #666666 !important;
}

/* Secondary outline buttons */
.account-data-item .btn-outline-secondary {
    border-radius: 999px !important;

    border: 1px solid #e5e5e5 !important;
    background: #ffffff !important;
    color: #111111 !important;

    padding: 10px 16px !important;

    font-size: 14px !important;
    font-weight: 650 !important;

    box-shadow: none !important;
}

.account-data-item .btn-outline-secondary:hover {
    background: #f5f5f5 !important;
    border-color: #dcdcdc !important;
    color: #111111 !important;
}

/* Bottom buttons */
.btn-row {
    margin-top: 12px !important;
    row-gap: 14px !important;
}

.btn-row .btn {
    border-radius: 999px !important;
    height: 52px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    gap: 9px !important;

    font-weight: 650 !important;
    box-shadow: none !important;
}

.btn-row .btn-outline-danger {
    border: 1px solid #f1d0d0 !important;
    background: #fffafa !important;
    color: #b42318 !important;
}

.btn-row .btn-outline-danger:hover {
    background: #fff0f0 !important;
    border-color: #e5b8b8 !important;
    color: #8f1d15 !important;
}

/* Mobile */
@media (max-width: 991px) {
    .account-head-data > .col:first-child,
    .account-head-data-credit,
    .account-data-item .card {
        border-radius: 22px !important;
    }

    .account-data-item .card-header {
        padding: 22px !important;
    }

    .account-data-item .card-body {
        padding: 22px !important;
    }

    .account-data-item table td {
        padding: 16px 22px !important;
    }

    .btn-row .btn {
        width: 100% !important;
    }
}



/* lieferadresse */

/* =========================================================
   SHIPPING ADDRESSES PAGE - CLEAN CARDS
========================================================= */

.shipping-address-form-wrapper,
.shipping-addresses-wrapper {
    margin-bottom: 28px !important;
}

/* =========================================================
   LEFT FORM CARD
========================================================= */

.shipping-address-form-wrapper form {
    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 28px !important;

    padding: 34px !important;

    box-shadow: none !important;
}

.shipping-address-form-wrapper {

    .form-group {
        margin-bottom: 1rem;
    }

    .row {
        row-gap: 1rem;
    }

    fieldset {
        padding: 1rem;
    }
}


.shipping-address-form-wrapper .required-info {
    margin-bottom: 24px !important;

    color: #777777 !important;
    font-size: 14px !important;
}

/* =========================================================
   RIGHT LIST CARD
========================================================= */

.shipping-addresses-wrapper .dataTables_wrapper {
    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 28px !important;

    padding: 28px !important;

    box-shadow: none !important;
}

/* =========================================================
   INPUTS / SELECTS
========================================================= */

.shipping-address-form-wrapper .form-group,
.shipping-addresses-wrapper .form-group {
    margin-bottom: 18px !important;
}

.shipping-address-form-wrapper .form-control,
.shipping-address-form-wrapper .custom-select,
.shipping-address-form-wrapper .tt-input,
.shipping-addresses-wrapper .form-control,
.shipping-addresses-wrapper .custom-select {
    height: 58px !important;

    border-radius: 18px !important;
    border: 1px solid #e7e7e7 !important;

    background: #ffffff !important;
    box-shadow: none !important;

    padding: 0 18px !important;

    font-size: 15px !important;
    color: #111111 !important;

    transition:
        border-color .2s ease,
        background .2s ease !important;
}

.shipping-address-form-wrapper .form-control:hover,
.shipping-address-form-wrapper .custom-select:hover,
.shipping-address-form-wrapper .tt-input:hover,
.shipping-addresses-wrapper .form-control:hover,
.shipping-addresses-wrapper .custom-select:hover {
    border-color: #d8d8d8 !important;
}

.shipping-address-form-wrapper .form-control:focus,
.shipping-address-form-wrapper .custom-select:focus,
.shipping-address-form-wrapper .tt-input:focus,
.shipping-addresses-wrapper .form-control:focus,
.shipping-addresses-wrapper .custom-select:focus {
    border-color: #111111 !important;
    background: #ffffff !important;
    box-shadow: none !important;
}

/* =========================================================
   FLOATING LABELS
========================================================= */

.shipping-address-form-wrapper .label-slide .form-group,
.shipping-address-form-wrapper.label-slide .form-group {
    position: relative !important;
}

.shipping-address-form-wrapper .col-form-label {
    position: absolute !important;

    top: -10px !important;
    left: 14px !important;

    padding: 0 8px !important;

    background: #ffffff !important;

    font-size: 12px !important;
    font-weight: 600 !important;

    color: #777777 !important;

    z-index: 5 !important;
}

/* =========================================================
   SECTION HEADING
========================================================= */

.shipping-address-form-wrapper .h3 {
    font-size: 22px !important;
    line-height: 1.1 !important;

    font-weight: 750 !important;
    letter-spacing: -0.02em !important;

    color: #111111 !important;

    margin-bottom: 20px !important;
}

/* =========================================================
   CHECKBOX
========================================================= */

.shipping-address-form-wrapper .custom-control-label {
    font-weight: 550 !important;
    color: #222222 !important;
}

.shipping-address-form-wrapper .custom-control-input:checked ~ .custom-control-label::before {
    background: #111111 !important;
    border-color: #111111 !important;
}

/* =========================================================
   HR
========================================================= */

.shipping-address-form-wrapper hr {
    border: 0 !important;
    border-top: 1px solid #f0f0f0 !important;

    margin: 34px 0 !important;
}

/* =========================================================
   BUTTON
========================================================= */

.shipping-address-form-wrapper .btn-primary {
    height: 58px !important;

    border-radius: 999px !important;

    background: #111111 !important;
    border: 1px solid #111111 !important;

    color: #ffffff !important;

    font-size: 15px !important;
    font-weight: 650 !important;

    box-shadow: none !important;

    transition:
        background .2s ease,
        border-color .2s ease !important;
}

.shipping-address-form-wrapper .btn-primary:hover {
    background: #222222 !important;
    border-color: #222222 !important;
    color: #ffffff !important;
}

/* =========================================================
   DATATABLE TOP CONTROLS
========================================================= */

.shipping-addresses-wrapper .dataTables_length label,
.shipping-addresses-wrapper .dataTables_filter label {
    width: 100% !important;

    color: #777777 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

.shipping-addresses-wrapper .dataTables_filter input {
    width: 100% !important;
}

.shipping-addresses-wrapper .dataTables_length select {
    width: auto !important;
    min-width: 90px !important;
    margin-right: 8px !important;
}

/* =========================================================
   DATATABLE TABLE
========================================================= */

.shipping-addresses-wrapper table {
    margin-top: 20px !important;
    margin-bottom: 0 !important;

    border-collapse: separate !important;
    border-spacing: 0 10px !important;
}

.shipping-addresses-wrapper table tbody tr {
    background: #fafafa !important;
    border-radius: 18px !important;
}

.shipping-addresses-wrapper table tbody td {
    padding: 18px 20px !important;

    border: 0 !important;

    color: #333333 !important;
    font-size: 14px !important;
}

.shipping-addresses-wrapper table tbody td:first-child {
    border-radius: 18px 0 0 18px !important;
}

.shipping-addresses-wrapper table tbody td:last-child {
    border-radius: 0 18px 18px 0 !important;
}

.shipping-addresses-wrapper .dataTables_empty {
    text-align: center !important;

    color: #777777 !important;
    background: #fafafa !important;

    border-radius: 18px !important;

    padding: 34px 20px !important;
}

/* =========================================================
   DATATABLE FOOTER
========================================================= */

.shipping-addresses-wrapper .dataTables_info {
    margin-top: 18px !important;

    color: #777777 !important;
    font-size: 13px !important;
}

.shipping-addresses-wrapper .pagination {
    margin-top: 18px !important;
    justify-content: flex-end !important;
}

.shipping-addresses-wrapper .page-link {
    border: 1px solid #e7e7e7 !important;
    background: #ffffff !important;
    color: #111111 !important;

    border-radius: 999px !important;

    margin-left: 8px !important;
    padding: 9px 14px !important;

    font-size: 13px !important;
    font-weight: 650 !important;

    box-shadow: none !important;
}

.shipping-addresses-wrapper .page-item.disabled .page-link {
    color: #aaaaaa !important;
    background: #f6f6f6 !important;
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 991px) {

    .shipping-address-form-wrapper form,
    .shipping-addresses-wrapper .dataTables_wrapper {
        padding: 24px !important;
        border-radius: 22px !important;
    }

    .shipping-addresses-wrapper .pagination {
        justify-content: flex-start !important;
    }

    .shipping-address-form-wrapper .btn-primary {
        width: 100% !important;
    }
}


/* personal data */


/* =========================================================
   ACCOUNT PERSONAL DATA FORM - CLEAN CARD
========================================================= */

.inc-billing-address-form {
    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 28px !important;

    padding: 38px !important;

    box-shadow: none !important;

    margin-bottom: 60px !important;
}

.inc-billing-address-form h1 {
    font-size: 42px !important;
    line-height: 1.05 !important;

    font-weight: 800 !important;
    letter-spacing: -0.04em !important;

    color: #111111 !important;

    margin-bottom: 14px !important;
}

.inc-billing-address-form .required-info {
    margin-top: 14px !important;
    margin-bottom: 26px !important;

    color: #777777 !important;
    font-size: 14px !important;
}

.inc-billing-address-form .h3 {
    font-size: 22px !important;
    line-height: 1.1 !important;

    font-weight: 750 !important;
    letter-spacing: -0.02em !important;

    color: #111111 !important;

    margin-top: 4px !important;
}

/* Inputs */
.inc-billing-address-form .form-group {
    margin-bottom: 18px !important;
}

.inc-billing-address-form .form-control,
.inc-billing-address-form .custom-select,
.inc-billing-address-form .tt-input {
    height: 58px !important;

    border-radius: 18px !important;
    border: 1px solid #e7e7e7 !important;

    background: #ffffff !important;
    box-shadow: none !important;

    padding: 0 18px !important;

    font-size: 15px !important;
    color: #111111 !important;

    transition:
        border-color .2s ease,
        background .2s ease !important;
}

.inc-billing-address-form .form-control:hover,
.inc-billing-address-form .custom-select:hover,
.inc-billing-address-form .tt-input:hover {
    border-color: #d8d8d8 !important;
}

.inc-billing-address-form .form-control:focus,
.inc-billing-address-form .custom-select:focus,
.inc-billing-address-form .tt-input:focus {
    border-color: #111111 !important;
    background: #ffffff !important;
    box-shadow: none !important;
}

/* Floating labels */
.inc-billing-address-form .form-group {
    position: relative !important;
}

.inc-billing-address-form .col-form-label {
    position: absolute !important;

    top: -10px !important;
    left: 14px !important;

    padding: 0 8px !important;

    background: #ffffff !important;

    font-size: 12px !important;
    font-weight: 600 !important;

    color: #777777 !important;

    z-index: 5 !important;
}

/* Typeahead fix */
.inc-billing-address-form .twitter-typeahead {
    width: 100% !important;
}

.inc-billing-address-form .tt-menu {
    width: 100% !important;

    margin-top: 8px !important;

    border: 1px solid #ececec !important;
    border-radius: 16px !important;

    background: #ffffff !important;

    overflow: hidden !important;
}

.inc-billing-address-form .tt-suggestion {
    padding: 12px 16px !important;

    font-size: 14px !important;
    color: #111111 !important;
}

.inc-billing-address-form .tt-suggestion:hover {
    background: #f5f5f5 !important;
}

/* HR */
.inc-billing-address-form hr {
    border: 0 !important;
    border-top: 1px solid #f0f0f0 !important;

    margin: 34px 0 !important;
}

/* Mobile */
@media (max-width: 991px) {
    .inc-billing-address-form {
        padding: 24px !important;
        border-radius: 22px !important;
    }

    .inc-billing-address-form h1 {
        font-size: 30px !important;
    }

    .inc-billing-address-form .h3 {
        margin-bottom: 18px !important;
    }
}

/* =========================================================
   KONTAKTDATEN SECTION
========================================================= */



fieldset:last-of-type .h3 {
    font-size: 22px !important;
    line-height: 1.1 !important;

    font-weight: 750 !important;
    letter-spacing: -0.02em !important;

    color: #111111 !important;

    margin-bottom: 20px !important;
}

fieldset:last-of-type .form-group {
    position: relative !important;
    margin-bottom: 18px !important;
}

fieldset:last-of-type .form-control,
fieldset:last-of-type .tt-input {
    height: 38px !important;

    border-radius: 18px !important;
    border: 1px solid #e7e7e7 !important;

    background: #ffffff !important;
    box-shadow: none !important;

    padding: 0 18px !important;

    font-size: 15px !important;
    color: #111111 !important;

    transition:
        border-color .2s ease,
        background .2s ease !important;
}

fieldset:last-of-type .form-control:hover,
fieldset:last-of-type .tt-input:hover {
    border-color: #d8d8d8 !important;
}

fieldset:last-of-type .form-control:focus,
fieldset:last-of-type .tt-input:focus {
    border-color: #111111 !important;
    background: #ffffff !important;

    box-shadow: none !important;
}

fieldset:last-of-type .col-form-label {
    position: absolute !important;

    top: -10px !important;
    left: 14px !important;

    padding: 0 8px !important;

    background: transparent !important;

    font-size: 12px !important;
    font-weight: 600 !important;

    color: #777777 !important;

    z-index: 5 !important;
}

/* orders */

/* =========================================================
   ORDERS PAGE CLEAN
========================================================= */

.account-orders-item {
    border: 1px solid #ececec !important;
    border-radius: 28px !important;

    background: #ffffff !important;

    box-shadow: none !important;
    overflow: hidden !important;

    transition:
        border-color .2s ease,
        background .2s ease !important;
}

.account-orders-item:hover {
    border-color: #dddddd !important;
    background: #fcfcfc !important;
}

.account-orders-item .card-header {
    background: transparent !important;
    border: 0 !important;

    padding: 26px 30px !important;
}

/* =========================================================
   GRID
========================================================= */

.account-orders-item .row {
    align-items: center !important;
}

/* =========================================================
   DATE
========================================================= */

.account-orders-item strong {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;

    font-size: 15px !important;
    font-weight: 700 !important;

    color: #111111 !important;
}

.account-orders-item strong i {
    color: #777777 !important;
}

/* =========================================================
   PRICE
========================================================= */

.account-orders-item .col-md-3.col-lg-2.order-4 {
    font-size: 17px !important;
    font-weight: 750 !important;

    color: #111111 !important;
}

/* =========================================================
   ORDER NUMBER
========================================================= */

.account-orders-item .col-md-3.col-lg-2.order-2 {
    font-size: 14px !important;
    font-weight: 650 !important;

    color: #777777 !important;
}

/* =========================================================
   STATUS
========================================================= */

.account-orders-item .col-md-8.col-lg-4.order-5 {
    display: flex !important;
    align-items: center !important;

    font-size: 14px !important;
    font-weight: 600 !important;

    color: #444444 !important;
}

/* =========================================================
   ACTION BUTTON
========================================================= */

.account-orders-item .text-right-util a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: 44px !important;
    height: 44px !important;

    border-radius: 999px !important;

    background: #f5f5f5 !important;
    color: #111111 !important;

    text-decoration: none !important;

    transition:
        background .2s ease,
        transform .2s ease !important;
}

.account-orders-item .text-right-util a:hover {
    background: #ececec !important;

    transform: translateY(-1px) !important;

    color: #111111 !important;
}

.account-orders-item .text-right-util i {
    font-size: 15px !important;
}

/* =========================================================
   ROW SPACING
========================================================= */

.row .account-orders-item {
    margin-bottom: 20px !important;
}

/* =========================================================
   PAGINATION / INFO
========================================================= */

.pagination-wrapper {
    margin-top: 26px !important;
    margin-bottom: 26px !important;
}

.pagination-entries {
    color: #777777 !important;

    font-size: 14px !important;
    font-weight: 600 !important;
}

/* =========================================================
   BACK BUTTON
========================================================= */

.btn-outline-primary {
    height: auto !important;

    border-radius: 999px !important;

    border: 1px solid #e5e5e5 !important;
    background: #ffffff !important;

    color: #111111 !important;

    font-size: 15px !important;
    font-weight: 650 !important;

    box-shadow: none !important;

    transition:
        background .2s ease,
        border-color .2s ease !important;
}

.btn-outline-primary:hover {
    background: #f5f5f5 !important;
    border-color: #dcdcdc !important;

    color: #111111 !important;
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 991px) {

    .account-orders-item .card-header {
        padding: 22px !important;
    }

    .account-orders-item .row {
        row-gap: 14px !important;
    }

    .account-orders-item .text-right-util {
        text-align: left !important;
    }

    .btn-outline-primary {
        width: 100% !important;
    }
}

/* orders */

/* =========================================================
   ORDER DETAILS PAGE CLEAN
========================================================= */

.order-details {
    border: 1px solid #ececec !important;
    border-radius: 30px !important;

    background: #ffffff !important;

    box-shadow: none !important;
    overflow: hidden !important;
}

/* =========================================================
   HEADER
========================================================= */

.order-details .card-header {
    background: #ffffff !important;

    border-bottom: 1px solid #f1f1f1 !important;

    padding: 28px 34px !important;
}

.order-details-date {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;

    font-size: 15px !important;
    font-weight: 650 !important;

    color: #111111 !important;
}

.order-details-date i,
.order-details-date span {
    color: #777777 !important;
}

.order-details-status {
    font-weight: 650 !important;
    color: #444444 !important;
}

/* =========================================================
   BODY
========================================================= */

.order-details .card-body {
    padding: 34px !important;
}

/* =========================================================
   LEFT INFO COLUMN
========================================================= */

.order-details-data {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;

    margin: 0 !important;
}

.order-details-data > li {
    color: #666666 !important;

    font-size: 14px !important;
    line-height: 1.5 !important;
}

.order-details-data-item {
    display: block !important;

    margin-top: 8px !important;

    color: #111111 !important;
    font-weight: 500 !important;
}

.order-details-data dl,
.order-details-data ul {
    margin: 0 !important;
}

.order-details-data dt {
    font-weight: 650 !important;
    color: #111111 !important;
}

.order-details-data dd {
    margin-top: 4px !important;
    color: #666666 !important;
}

/* Address */
.inc-billing-address {
    margin-top: 4px !important;
}

.inc-billing-address li {
    margin-bottom: 3px !important;
}

/* =========================================================
   RIGHT COLUMN
========================================================= */

.subheadline {
    display: inline-block !important;

    margin-bottom: 24px !important;

    font-size: 24px !important;
    line-height: 1.1 !important;

    font-weight: 750 !important;
    letter-spacing: -0.03em !important;

    color: #111111 !important;
}

/* =========================================================
   ORDER ITEMS
========================================================= */

.order-items {
    border: 1px solid #f0f0f0 !important;
    border-radius: 24px !important;

    background: #fafafa !important;

    padding: 26px !important;
}

.order-item {
    align-items: center !important;
}

/* Product image */
.order-item-image-wrapper a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    background: #ffffff !important;

    border-radius: 18px !important;

    padding: 14px !important;
}

.order-item-image-wrapper img {
    border-radius: 12px !important;
}

/* Product title */
.order-item a {
    color: #111111 !important;

    text-decoration: none !important;

    font-size: 16px !important;
    font-weight: 650 !important;
    line-height: 1.35 !important;
}

.order-item a:hover {
    color: #444444 !important;
}

/* Meta */
.item-detail-list {
    margin-top: 12px !important;
}

.item-detail-list li {
    margin-bottom: 4px !important;

    color: #777777 !important;

    font-size: 13px !important;
}

/* Qty / Prices */
.qty-col,
.price-col {
    font-size: 15px !important;
    color: #222222 !important;
}

.price_overall {
    font-size: 16px !important;
    font-weight: 750 !important;

    color: #111111 !important;
}

/* =========================================================
   DIVIDERS
========================================================= */

.order-items hr,
.order-details hr {
    border: 0 !important;
    border-top: 1px solid #ececec !important;

    margin: 26px 0 !important;
}

/* =========================================================
   TOTALS
========================================================= */

.order-items-total {
    margin-left: auto !important;

    background: #ffffff !important;

    border: 1px solid #ececec !important;
    border-radius: 22px !important;

    padding: 22px !important;
}

.tax_label {
    color: #777777 !important;
    font-size: 14px !important;
}

.price_label {
    color: #111111 !important;
}

.total-sum {
    font-size: 28px !important;
    line-height: 1 !important;

    font-weight: 800 !important;
    letter-spacing: -0.04em !important;

    color: #111111 !important;
}

/* =========================================================
   BACK BUTTON
========================================================= */

.btn-outline-primary {
    height: 54px !important;

    border-radius: 999px !important;

    border: 1px solid #e5e5e5 !important;
    background: #ffffff !important;

    color: #111111 !important;

    font-size: 15px !important;
    font-weight: 650 !important;

    box-shadow: none !important;

    transition:
        background .2s ease,
        border-color .2s ease !important;
}

.btn-outline-primary:hover {
    background: #f5f5f5 !important;
    border-color: #dcdcdc !important;

    color: #111111 !important;
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 991px) {

    .order-details .card-header,
    .order-details .card-body {
        padding: 24px !important;
    }

    .order-items {
        padding: 20px !important;
        border-radius: 20px !important;
    }

    .order-items-total {
        margin-top: 24px !important;
    }

    .order-item {
        row-gap: 16px !important;
    }

    .qty-col,
    .price-col {
        text-align: left !important;
    }

    .total-sum {
        font-size: 24px !important;
    }

    .btn-outline-primary {
        width: 100% !important;
    }
}

/* delete account */

/* =========================================================
   DELETE ACCOUNT PAGE - CLEAN / COMPACT
========================================================= */

#delete_account {
    background: #ffffff !important;
    border: 1px solid #ececec !important;
    border-radius: 24px !important;
    padding: 28px !important;
    box-shadow: none !important;
}

/* Alert */


.alert.alert-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    text-align: center;

    max-width: 640px;
    margin: 2rem auto !important;

    background: linear-gradient(
        135deg,
        #f8fafc 0%,
        #ffffff 100%
    ) !important;

    border: 1px solid #e2e8f0 !important;
    border-radius: 24px !important;

    padding: 2rem 1.5rem !important;

    color: #475569 !important;

    font-size: 1rem;
    line-height: 1.6;

    box-shadow:
        0 20px 50px rgba(15, 23, 42, .05);
}

.alert.alert-info .bubble.badge {
    width: 74px;
    height: 74px;

    border-radius: 999px;

    display: flex;
    align-items: center;
    justify-content: center;

    margin-bottom: 1rem;

    background: #fff !important;

    border: 1px solid #e2e8f0;

    box-shadow:
        0 10px 30px rgba(15, 23, 42, .06);
}

.alert.alert-info .bubble.badge i {
    font-size: 1.5rem;
    color: #0f172a;
}

.alert.alert-info br {
    display: none;
}

.alert.alert-info .sr-only,
.alert.alert-info .close {
    display: none;
}

#alert-list .alert.alert-warning,
.alert.alert-wrapper.alert-warning[data-key="orderAmountStock"] {
    display: flex !important;
    align-items: flex-start;
    gap: .85rem;

    max-width: 960px;
    width: auto;

    margin: 0 auto 1.5rem !important;

    background: linear-gradient(
        135deg,
        #fffbeb 0%,
        #fffdf5 100%
    ) !important;

    border: 1px solid #fde68a !important;
    border-left: 4px solid #f59e0b !important;

    border-radius: 20px !important;

    padding: 1rem 3rem 1rem 1.15rem !important;

    color: #92400e !important;

    font-size: .95rem;
    line-height: 1.65;

    box-shadow:
        0 10px 30px rgba(245, 158, 11, .08);

    position: relative;
}

#alert-list .alert.alert-warning i,
.alert.alert-wrapper.alert-warning[data-key="orderAmountStock"] i {
    color: #f59e0b !important;

    margin-top: .2rem;

    flex-shrink: 0;
}

#alert-list .alert.alert-warning .close,
.alert.alert-wrapper.alert-warning[data-key="orderAmountStock"] .close {
    display: none;
}

#alert-list .alert.alert-warning .sr-only,
.alert.alert-wrapper.alert-warning[data-key="orderAmountStock"] .sr-only {
    display: none;
}

#alert-list .alert.alert-warning ul,
.alert.alert-wrapper.alert-warning[data-key="orderAmountStock"] ul {
    margin: .75rem 0 .25rem 1.2rem;
    padding: 0;
}

#alert-list .alert.alert-warning li,
.alert.alert-wrapper.alert-warning[data-key="orderAmountStock"] li {
    margin-bottom: .35rem;
}

#alert-list .alert.alert-warning strong,
.alert.alert-wrapper.alert-warning[data-key="orderAmountStock"] strong {
    display: block;
    margin-top: .75rem;
    color: #78350f;
}



.alert-danger {
    min-height: auto !important;
    padding: 16px 22px !important;
    border-radius: 18px !important;

    background: #fff8f8 !important;
    border: 1px solid #f2d6d6 !important;

    color: #9f1d1d !important;
    font-size: 14px !important;
    font-weight: 600 !important;

    box-shadow: none !important;
    margin-bottom: 32px !important;
}

/* Input */
#delete_account .form-group {
    position: relative !important;
    margin-bottom: 0 !important;
}

#delete_account .form-control {
    height: 44px !important;
    max-width: 220px !important;

    border-radius: 14px !important;
    border: 1px solid #e5e5e5 !important;

    background-color: #ffffff !important;
    background-image: none !important;

    box-shadow: none !important;

    padding: 0 16px !important;

    font-size: 14px !important;
    color: #111111 !important;
}

#delete_account .form-control:focus {
    border-color: #111111 !important;
    box-shadow: none !important;
}

/* Label */
#delete_account .col-form-label {
    position: absolute !important;
    top: -10px !important;
    left: 14px !important;

    padding: 0 7px !important;

    background: #ffffff !important;

    font-size: 12px !important;
    font-weight: 600 !important;
    color: #777777 !important;

    z-index: 5 !important;
}

/* Layout */
#delete_account .row {
    align-items: center !important;
    row-gap: 18px !important;
}

/* Buttons */
#delete_account .btn {
    height: 44px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    padding: 0 22px !important;

    border-radius: 999px !important;

    font-size: 14px !important;
    font-weight: 650 !important;

    box-shadow: none !important;
    text-decoration: none !important;

    transition: background .2s ease, border-color .2s ease, color .2s ease !important;
}

#delete_account .btn-outline-primary {
    width: auto !important;
    min-width: 150px !important;

    background: #ffffff !important;
    border: 1px solid #e5e5e5 !important;

    color: #111111 !important;
}

#delete_account .btn-outline-primary:hover {
    background: #f5f5f5 !important;
    border-color: #dcdcdc !important;

    color: #111111 !important;
}

#delete_account .btn-danger {
    width: auto !important;
    min-width: 190px !important;

    background: #df2b24 !important;
    border: 1px solid #df2b24 !important;

    color: #ffffff !important;
}

#delete_account .btn-danger:hover {
    background: #c8241f !important;
    border-color: #c8241f !important;

    color: #ffffff !important;
}

/* Mobile */
@media (max-width: 991px) {
    #delete_account {
        padding: 22px !important;
        border-radius: 20px !important;
    }

    #delete_account .form-control {
        max-width: none !important;
        width: 100% !important;
    }

    #delete_account .btn {
        width: 100% !important;
    }
}





.row {
	margin-bottom: 8px;
}







form#suche2,
#content form#suche2 {
    max-width: 760px !important;
    margin: 0 auto !important;
    padding: 0 !important;
}

form#suche2 fieldset,
#content form#suche2 fieldset {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;

    border: 0 !important;
    padding: .75rem 1rem !important;
    margin: 0 !important;

    min-height: unset !important;
}

form#suche2 .form-group {
    flex: 1 1 auto !important;
    margin: 0 !important;
    padding: 0 !important;
}

form#suche2 .d-flex.flex-column-reverse {
    display: block !important;
}

form#suche2 label {
    display: none !important;
}

form#suche2 input#searchkey {
    height: 48px !important;
    min-height: 48px !important;
    padding: 0 1rem !important;
    margin: 0 !important;
}

form#suche2 .btn {
    height: 48px !important;
    min-height: 48px !important;
    padding: 0 1.6rem !important;
    margin: 0 !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}


















/* wishlist */

.container.snippets-wishlist {
    max-width: 1440px !important;

    margin: 0 auto;
    padding: 3rem 1.5rem 5rem;

    h1 {
        text-align: center;

        font-size: clamp(2.2rem, 4vw, 3.4rem);
        font-weight: 800;

        letter-spacing: -.04em;

        color: #0f172a;

        margin-bottom: 2.5rem;
    }
}

/* TOP ACTION BAR */

.wishlist-actions {
    align-items: center;

    gap: 1rem;

    margin-bottom: 2rem;

    padding: 1.25rem;

    background: #fff;

    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 24px;

    box-shadow:
        0 16px 50px rgba(15, 23, 42, .05);
}

.wishlist-options .btn,
.wishlist-dropdown-name .btn {
    border-radius: 16px !important;
    min-height: 48px;

    font-weight: 700;
}

#wishlist-search .input-group {
    overflow: hidden;

    border-radius: 18px;

    border: 1px solid #dbe3ec;

    background: #f8fafc;
}

#wishlist-search .form-control {
    border: 0 !important;
    background: transparent !important;

    min-height: 56px;

    box-shadow: none !important;
}

#wishlist-search .btn {
    border: 0 !important;

    min-width: 58px;

    background: transparent !important;
    color: #0f172a !important;
}

/* PRIVACY / COUNT */

.wishlist-privacy-count {
    align-items: center;

    margin-bottom: 2rem;

    padding: 1rem 1.25rem;

    border-radius: 20px;

    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.wishlist-count {
    font-weight: 700;
    color: #0f172a;
}

/* PRODUCT GRID */

.container.snippets-wishlist .product-list {
    row-gap: 2rem;
}

/* PRODUCT CARD */

.wishlist-item .productbox {
    height: 100%;

    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 28px;

    overflow: hidden;

    background: #fff;

    transition:
        transform .18s ease,
        box-shadow .18s ease;

    box-shadow:
        0 10px 30px rgba(15, 23, 42, .05);
}

.wishlist-item .productbox:hover {
    transform: translateY(-4px);

    box-shadow:
        0 24px 60px rgba(15, 23, 42, .10);
}

.wishlist-item .productbox-inner {
    padding: 1.25rem;
}

/* IMAGE */

.wishlist-item .productbox-image {
    margin-bottom: 1rem;
}

.wishlist-item .square-image {
    border-radius: 22px;
    overflow: hidden;

    background: #f8fafc;
}

/* DELETE BUTTON */

.wishlist-pos-delete {
    position: absolute;

    top: 1rem;
    right: 1rem;

    width: 38px;
    height: 38px;

    border-radius: 999px !important;

    background: rgba(255,255,255,.92) !important;

    display: flex !important;
    align-items: center;
    justify-content: center;

    box-shadow:
        0 8px 20px rgba(15, 23, 42, .08);

    z-index: 10;
}

.wishlist-pos-delete i {
    color: #ef4444;
}

/* TITLE */

.wishlist-item .productbox-title {
    display: block;

    font-size: 1rem;
    font-weight: 700;

    line-height: 1.45;

    color: #0f172a;

    margin-bottom: .9rem;

    text-decoration: none !important;
}

/* PRICE */

.wishlist-item .productbox-price {
    font-size: 1.4rem;
    font-weight: 800;

    color: #0f172a;

    margin-bottom: .35rem;
}

.wishlist-item .price-note {
    font-size: .8rem;
    color: #64748b;
}

/* DETAILS */

.product-characteristics {
    margin-top: 1rem;

    padding-top: 1rem;

    border-top: 1px solid #eef2f7;
}

.product-characteristics dt {
    color: #64748b;
    font-weight: 600;
}

.product-characteristics dd {
    color: #0f172a;
    font-weight: 700;
}

/* NOTE TEXTAREA */

.productbox-options textarea.form-control {
    border-radius: 18px;

    border: 1px solid #dbe3ec;

    background: #f8fafc !important;

    min-height: 110px;

    resize: vertical;

    margin-top: 1rem;
}

/* DELIVERY */

.delivery-status {
    margin-top: 1rem;
}

.signal_image {
    display: inline-flex;

    padding: .55rem .9rem;

    border-radius: 999px;

    font-size: .82rem;
    font-weight: 700;
}

.status-0 {
    background: #fef2f2;
    color: #991b1b;
}

/* QUANTITY */

.form-counter {
    overflow: hidden;

    border-radius: 16px;

    border: 1px solid #dbe3ec;
}

.form-counter .btn {
    min-width: 46px;
}

.form-counter .form-control {
    border: 0 !important;
    text-align: center;
}

/* CTA */

.productbox-actions {
    margin-top: 1rem;
}

.productbox-actions .btn-primary {
    min-height: 54px;

    border-radius: 16px;

    font-weight: 700;
}

/* STICKY BOTTOM */

.wishlist-all-to-cart {
    position: sticky;
    bottom: 1rem;

    margin-top: 2.5rem;

    display: flex;
    justify-content: center;

    z-index: 20;
}

.wishlist-all-to-cart .btn {
    min-height: 58px;

    padding: 0 2rem;

    border-radius: 999px;

    font-weight: 800;

    box-shadow:
        0 16px 40px rgba(15, 23, 42, .18);
}

#badge-wl-count.fa-sup {
    position: absolute !important;

    top: -8px !important;
    right: -10px !important;

    left: auto !important;
    bottom: auto !important;

    min-width: 17px !important;
    height: 17px !important;

    padding: 0 5px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    border-radius: 999px !important;

    background: #000 !important;
    color: #fff !important;

    font-size: 10px !important;
    font-weight: 700 !important;
    line-height: 1 !important;

    transform: none !important;

    z-index: 2 !important;
}




.search-wrapper .twitter-typeahead,
.search-wrapper .tt-input,
.search-wrapper .tt-hint {
    height: 44px !important;
    line-height: 44px !important;
}

.search-wrapper .tt-input,
.search-wrapper .tt-hint {
    padding: 0 1rem !important;
    display: flex !important;
    align-items: center !important;
}

.search-wrapper input#search-header {
    height: 44px !important;
    min-height: 44px !important;
    line-height: 44px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}



.navbar-toggler .navbar-toggler-icon,
.navbar-toggler .navbar-toggler-icon::before,
.navbar-toggler .navbar-toggler-icon::after {
    background: #000000 !important;
}




.label-slide .form-group:not(.exclude-from-label-slide):not(.checkbox) label:after {
    background: transparent !important;
    height: 0.125rem;
    top: 45%;
    z-index: -1;
}

.dropdown-body, .dropdown-footer {
    padding: 18px;
}

.account-icon-dropdown .dropdown-footer {
    background-color: transparent !important;
}


#jtl-nav-wrapper .wishlist-dropdown-footer a.btn.btn-primary {
    color: #fff !important;
}





legend {
    font-size: 0.8rem;
    font-weight: bolder;
    padding-bottom: 5px;
    margin: 10px 0 20px 0;
    border-bottom: solid 1px #ebebeb;
}


.label-slide .form-group label {
    position: static !important;
    transform: none !important;

    display: block;

    margin-bottom: .45rem !important;
}














#set-anfrage .set-anfrage-form input.form-control,
#set-anfrage .set-anfrage-form select.form-control,
#set-anfrage .set-anfrage-form select.custom-select,
#set-anfrage .set-anfrage-form textarea.form-control {
    border: 2px solid #ffffff !important;
    background: #ffffff !important;
    color: #111111 !important;
    border-radius: 999px !important;
    min-height: 54px !important;
    padding: 0 22px !important;
}

#set-anfrage .set-anfrage-form textarea.form-control {
    border-radius: 28px !important;
    min-height: 160px !important;
    padding-top: 18px !important;
}

#set-anfrage .set-anfrage-form label {
    color: #ffffff !important;
    margin-bottom: 8px !important;
}




.label-slide .form-group:not(.exclude-from-label-slide):not(.checkbox) label {
    display: block;
    background: transparent !important;
    position: absolute;
    cursor: text;
    top: 0;
    font-size: 0.7525rem;
    margin: 0;
    padding: 0 0.3125rem;
    transform: translateY(-50%);
    transition: all 0.2s ease-in-out;
    left: 0.9375rem;
    z-index: 10;
    line-height: 1.3;
    pointer-events: none;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    max-width: calc(100% - 2 * 0.9375rem);
}













.carousel-thumbnails .slick-slide {

border: none !important;
}









.form-control,
.custom-select,
.tt-input {
    height: auto;
    border-radius: 18px !important;
    border: 1px solid #d9dee7 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 12px 18px !important;
    font-size: 15px !important;
    color: #111111 !important;
    transition: border-color .2s ease, background .2s ease !important;
}

.form-control:focus,
.custom-select:focus,
.tt-input:focus {
    border-color: #111111 !important;
    box-shadow: 0 0 0 4px rgba(0, 0, 0, .04) !important;
}









.form-group {
    margin-bottom: 0 !important;
}




.faqs {
width: 50%;
margin: 0 auto;
}






/* =========================================================
   Dachträger Profi - Clean Minimal FAQ Accordion
========================================================= */

.opc-Accordion {
  max-width: 960px;
  margin: 40px auto;
  display: grid;
  gap: 14px;

  /* überall runde Kanten */
  &,
  .opc-Accordion-group,
  .card-header,
  .opc-Accordion-collapse,
  .card-body,
  .opc-Accordion-head {
    border-radius: 22px;
  }

  .opc-Accordion-group {
    border: 1px solid #eceef3;
    overflow: hidden;
    background: #f7f8fb;
    transition: all 0.25s ease;

    &:hover {
      border-color: #dde2ea;
      transform: translateY(-1px);
    }
  }

  .card-header {
    padding: 0;
    border: 0;
    background: transparent;
  }

  .opc-Accordion-head {
    width: 100%;
    padding: 24px 28px;
    position: relative;

    border: 0;
    background: transparent;
    color: #1c2430;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.4;
    text-align: left;
    text-decoration: none;
    box-shadow: none !important;
    transition: all 0.2s ease;

    &:focus {
      outline: none;
      text-decoration: none;
    }

    &:hover {
      color: #000;
    }

    /* Original Pfeil/Icon */
    .icon,
    svg {
      position: absolute;
      right: 16px;
      top: 50%;
      transform: translateY(-50%);
      width: 42px;
      height: 42px;
      padding: 12px;
      border-radius: 50%;
      background: #fff;
      border: 1px solid #e7eaf0;
      transition: all 0.25s ease;
    }

    &[aria-expanded="true"] {
      .icon,
      svg {
        background: #eef1f5;
      }
    }

    &:hover {
      .icon,
      svg {
        transform: translateY(-50%) scale(1.05);
      }
    }
  }

  .opc-Accordion-collapse {
    background: #f7f8fb;

    /* unten weich abrunden */
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  .card-body {
    padding: 0 28px 28px;
    color: #5f6b7a;
    font-size: 15px;
    line-height: 1.8;

    p {
      margin: 0;
      max-width: 760px;
    }
  }

  .collapse,
  .collapsing {
    transition: height 0.28s ease;
  }

  /* Mobile */
  @media (max-width: 768px) {
    gap: 10px;
    margin: 28px 0;

    &,
    .opc-Accordion-group,
    .opc-Accordion-head,
    .opc-Accordion-collapse,
    .card-body {
      border-radius: 18px;
    }

    .opc-Accordion-head {
      padding: 20px;
      font-size: 16px;

      .icon,
      svg {
        width: 38px;
        height: 38px;
        padding: 10px;
        right: 14px;
      }
    }

    .card-body {
      padding: 0 20px 22px;
      font-size: 14px;
      line-height: 1.7;
    }
  }
}