
.newsletter .primary {
    background-color: #003A70!important;
    color: #FFFFFF;
}
.page-header .search-area .minisearch .actions button {
    background-color: #003A70!important;
}
/**
.sticky-header ul a { 
    color: #222223!important;
}
.sticky-header ul a:hover { 
    color: #003A70!important;
    background: #FFFFFF;
}
.sticky-header ul a:active { 
    color: #003A70!important;
    background: #FFF;
}
.sticky-header ul a:link { 
    background: #ffffff;
}
**/
.payment-icon {
	filter: invert(0)!important;
}
.header-main .header-left {
    height: 120px!important;
}

@media only screen and (max-width: 768px) {
	#myDIV {
		display: none;
	}
	.header-center {
		display: none!important;
	}
	.header-left {
		width: 100%!important;
	}
}
.minicart-items-wrapper  {
      max-height: 400px !important;
     }

/* Grundlegendes Styling für das Popup */
        .gpsr-popup-overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.5);
            display: none;
            justify-content: center;
            align-items: center;
            z-index: 1000;
        }

        .gpsr-popup-content {
            background: #fff;
            border-radius: 8px;
            width: 90%;
            max-width: 600px;
            padding: 20px;
            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
        }

        .gpsr-popup-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .gpsr-popup-header h2 {
            margin: 0;
            font-size: 1.5em;
        }

        .gpsr-close-btn {
            cursor: pointer;
            background: none;
            border: none;
            font-size: 1.5em;
        }

        .gpsr-tabs {
            display: flex;
            margin-top: 20px;
            border-bottom: 2px solid #ccc;
        }

        .gpsr-tab {
            flex: 1;
            text-align: center;
            padding: 10px;
            cursor: pointer;
            font-weight: bold;
            border-bottom: 2px solid transparent;
        }

        .gpsr-tab.active {
            border-color: #6965b5;
            color: #6965b5;
        }

        .gpsr-tab-content {
            display: none;
            margin-top: 20px;
        }

        .gpsr-tab-content.active {
            display: block;
        }

        .gpsr-highlight {
            background: #f9f9f9;
            padding: 10px;
            border: 1px solid #ccc;
            border-radius: 4px;
            margin-top: 10px;
        }

        .gpsr-product-images img {
            min-width: auto;
            height: 200px;
            margin: 10px 0;
        }
#gpsr-openPopup {
    color: #6965b5;
    transition: margin-left 0.2s ease;
}
#gpsr-openPopup:hover {
    color: #2195D1;
    margin-left: 1px;
}
.gpsr-title {
    color: #777777;
    font-style: normal;
    font-weight: 400;
    font-size: 12px;
    text-transform: uppercase;
}
.gpsr-product-images-container {
    overflow-x: auto;
    white-space: nowrap;
    padding: 10px 0;
}

.gpsr-product-images img {
    width: auto; /* Adjust image size */
    height: 300px;
    margin-right: 10px;
    cursor: pointer;
    display: inline-block;
    transition: transform 0.3s ease;
}

.gpsr-product-images img:hover {
    transform: scale(1.1);
}

/* Modal styles */
.gpsr-modal {
    display: none; /* Hidden by default */
    position: fixed;
    z-index: 100000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.8);
}

.gpsr-modal-content {
    margin: auto;
    display: block;
    max-width: 90%;
    max-height: 90%;
    animation: fadeIn 0.3s;
}

.gpsr-close {
    position: absolute;
    top: 10px;
    right: 25px;
    color: white;
    font-size: 30px;
    font-weight: bold;
    cursor: pointer;
    transition: color 0.3s ease;
}

.gpsr-close:hover {
    color: #f00;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

.inkl-mwst {
    color: #777777;
    font-style: normal;
    font-weight: 400;
    font-size: 12px;
    text-transform: uppercase;
}

.dhl-icon {
    width: 150px;
    height: auto;
    margin-left: 50px;
    margin-top: 0px;
}
.dhl-bg {
    background: #FFFFFF; /* ffcc01 */
    border: 2px solid #ffcc01;
    min-height: 200px;
    padding-top: 25px;
    padding-left: 20px;
    padding-right: 20px;
}
.dhl-title {
    color: #d40511;
    font-size: 24px;
    font-weight: bolder;
}
.dhl-logo {
    position: relative;
    float: right;
    right: 20px;
    bottom: 20px;
} 
.dhl-col-pos {
    top: 25px;
    left: 25px;
}

.swatch-attribute-options {
    margin-top: 5px;
    margin-bottom: 15px;
}
.swatch-option.text {
    /* background: rgb(45,85,184); */
    background: #003A70;
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
}
.swatch-option {
    border-color: #333333;
    color: #ffffff!important;
}
.swatch-option.text.selected {
    background-color: #b51539!important;
    background: #b51539!important;

}

.product-item .rating-summary .rating-result > span:before {
    color: #FECA09!important;
}


.product-info-main p {
    font-size: 14px;
    font-weight: 400;
    letter-spacing: .005em;
    line-height: 1.9;
}

/* ########## Fields ######### */

.product-options-wrapper {
    padding-bottom: 30px;
}
/* Stil für die Input-Felder (Checkboxen) */
.product-options-wrapper .field .label span {
    margin-right: 10px;
    min-width: 72px;
    font-size: .8571em;
    text-transform: uppercase;
    font-weight: 400;
    line-height: 32px;
    white-space: nowrap;
    padding: 2px 0 8px;
    margin: 0;
}

/* Verstecke die Standard-Checkbox */
.product-options-wrapper .field.choice .checkbox {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 25px;  /* Breite der benutzerdefinierten Checkbox */
    height: 25px; /* Höhe der benutzerdefinierten Checkbox */
    background-color: #fff; /* Hintergrundfarbe */
    border: 2px solid #003A70; /* Randfarbe */
    border-radius: 4px; /* Abgerundete Ecken */
    position: relative;
    cursor: pointer;
    box-sizing: border-box;
    transition: transform 0.2s ease-in-out; /* Sanfter Übergang für die Puls-Effekt-Animation */
}

/* Benutzerdefinierte Darstellung für angekreuzte Checkbox */
.product-options-wrapper .field.choice .checkbox:checked {
    background-color: #b51539; /* Blau für angekreuzte Checkbox */
    border-color: #003A70; /* Gleiche Farbe für den Rand */
}

/* Häkchen für die angekreuzte Checkbox */
.product-options-wrapper .field.choice .checkbox:checked::after {
    content: '✔';  /* Unicode-Häkchen */
    font-size: 30px;
    color: white;
    position: absolute;
    top: -10px;
    left: 2px;
}

/* Stil für das Label, das den Text umgibt */
.product-options-wrapper .field.choice .label {
    font-size: 14px;
    letter-spacing: .005em;
    line-height: 1.9;
    font-weight: 600;
}

/* Optional: Vergrößern der Labels und Hinzufügen von Abständen */
.product-options-wrapper .field.choice {
    margin-bottom: 0px;  /* Abstand zwischen den Feldern */
}

/* Stil für den Preistext */
.product-options-wrapper .field.choice .price-wrapper {
    font-size: 14px;
    font-weight: 400;
    letter-spacing: .005em;
    line-height: 1.9;
    transition: color 2s ease-in-out; /* Übergang für die Farbe des Preises */
}

/* Stil für den Preis, wenn die Checkbox angeklickt wurde */
.product-options-wrapper .field.choice .checkbox:checked + .label .price-wrapper {
    color: #28a745; /* Grüne Farbe für den Preis */
}

/* Rückkehr zur ursprünglichen Farbe nach 2 Sekunden */
.product-options-wrapper .field.choice .checkbox:checked + .label .price-wrapper {
    animation: revertPriceColor 2s forwards;
}


/* Stil für den Preis, wenn die Checkbox angeklickt wurde */
.product-options-wrapper .field.choice .checkbox:checked + .product-info-price .price {
    color: #28a745!important; /* Grüne Farbe für den Preis */
}

/* Rückkehr zur ursprünglichen Farbe nach 2 Sekunden */
.product-options-wrapper .field.choice .checkbox:checked + .product-info-price .price {
    animation: revertPriceColor 2s forwards;
}

/* Pulse-Effekt bei Klick auf die Checkbox (wenn sie gecheckt ist) */
.product-options-wrapper .field.choice .checkbox:checked {
    animation: pulse 0.6s ease-in-out; /* Aktiviert die Puls-Animation für angekreuzte Checkbox */
}

/* Keyframes für den Pulse-Effekt */
@keyframes pulse {
    0% {
        transform: scale(1); /* Ursprüngliche Größe */
    }
    50% {
        transform: scale(1.2); /* Vergrößern auf 120% */
    }
    100% {
        transform: scale(1); /* Zurück zur ursprünglichen Größe */
    }
}

/* Animation, um den Preis wieder auf die ursprüngliche Farbe zu setzen */
@keyframes revertPriceColor {
    0% {
        color: #28a745; /* Grüne Farbe */
    }
    100% {
        color: inherit; /* Zurück zur Originalfarbe */
    }
}


/** ############## Icons für Options ################ **/

/* Icon für 60 ml */
#options_16_2 + label::before {
    content: "";
    display: inline-block;
    width: 14px;
    height: 25px;
    background-image: url("https://www.funnylens.de/media/wysiwyg/icons/icon-kombiloesung-60-bunt.svg");
    background-size: contain;
    background-repeat: no-repeat;
    margin-right: 2px; /* Abstand zur Checkbox */
    margin-left: 3px;
    vertical-align: middle;
}

/* Icon für Avizor 100 ml */
#options_4768_2 + label::before {
    content: "";
    display: inline-block;
    width: 14px;
    height: 25px;
    background-image: url("https://www.funnylens.de/media/wysiwyg/icons/icon-kombiloesung-100-bunt.svg");
    background-size: contain;
    background-repeat: no-repeat;
    margin-right: 2px; /* Abstand zur Checkbox */
    margin-left: 3px;
    vertical-align: middle;
}

/* Icon für 350 ml */
#options_16_3 + label::before {
    content: "";
    display: inline-block;
    width: 14px;
    height: 25px;
    background-image: url("https://www.funnylens.de/media/wysiwyg/icons/icon-kombiloesung-350-bunt.svg");
    background-size: contain;
    background-repeat: no-repeat;
    margin-right: 2px; /* Abstand zur Checkbox */
    margin-left: 3px;
    vertical-align: middle;
}

/* Icon für Augentropfen */
#options_17_2 + label::before {
    content: "";
    display: inline-block;
    width: 14px;
    height: 25px;
    background-image: url("https://www.funnylens.de/media/wysiwyg/icons/icon-augentropfen.svg");
    background-size: contain;
    background-repeat: no-repeat;
    margin-right: 2px; /* Abstand zur Checkbox */
    margin-left: 3px;
    vertical-align: middle;
}




.product-description-p a {
    color: #5883a5;
    font-weight: 500;
}
.product-description-p h2,
.product-description-p h3,
.product-description-p h4,
.product-description-p h5 {
    font-weight: 600;
}

.product-description-p h3 {
    marign-bottom: 0px;
    margin-top: 50px!important;
}
.product-description-p a:hover {
    color: #74B0E2;
    text-decoration: underline;
}
.product-description-p ul {
    padding-left: 28px!important;
}

.product-description-p ul li {
  list-style-type: none; /* Entfernt die Standard-Aufzählungszeichen */
  padding-left: 20px; /* Fügt Platz für das benutzerdefinierte Bullet hinzu */
  position: relative; /* Ermöglicht das Hinzufügen von absolut positionierten Elementen */
}

.product-description-p ul li::before {
  content: "•"; /* Fügt das Bullet Point-Zeichen hinzu */
  font-size: 24px; /* Ändert die Größe des Bullet Points */
  color: #003A70; /* Setzt die Farbe des Bullet Points */
  position: absolute; /* Positioniert das Bullet an einer bestimmten Stelle */
  left: 0; /* Setzt die Position des Bullets ganz links */
  top: 0; /* Setzt die Position des Bullets nach oben ausgerichtet */
}


.mollie-payment-icon {
width: 45px!important;
}


.custom-html {
    padding-left: 20px;
    padding-right: 20px;
}


/* #### MOBILE ANPASSUNGEN #### */
@media only screen and (max-width: 768px) {

    .porto-ibanner-layer {
      left: 15% !important; /* Überschreibt das inline-Style */
      right: 15% !important; /* Überschreibt das inline-Style */
    }
    .owl-next, .owl-prev {
        box-shadow: none!important;
    }
    .header-main .header-left {
        height: 0px!important;
    }
    .header-main .right { 
        height: 0px!important; 
    }
    .type22 { 
        padding-top: 0px;
    }

    .header.welcome {
    display: none;
    }
    .section-items .active {
        -webkit-box-shadow: inset 0px 0px 5px 0px rgba(0,0,0,0.25); 
        box-shadow: inset 0px 0px 5px 0px rgba(0,0,0,0.25);
    }
    .search-area {
        width: 25%!important; 
    }
}

@media(max-width:767px){
  .logo {
    max-width: 100%!important;
    z-index: auto;
}
}
@media(max-width:785px){
  .logo {
    max-width: 100%!important;
    z-index: auto;
}
}



.grand.totals.excl {
    display: none;
}

.columns .sidebar-additional {
padding: 0 0 0 0!important;
}

.stickycart {
  display: none;
}
.sticky-header .stickycart {
  display: block !important;
}

.product-item-name a {
    display: -webkit-box;
    -webkit-line-clamp: 2;          /* Max. 2 Zeilen */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal !important; /* 'initial' oder 'normal' erlaubt Umbrüche */
}

.baseprice {
    font-weight: normal;
    font-size: 12px;
    color: #777777;
}


.catalog-category-view .page-title-wrapper {
    display: block!important;
}

 .block-category-list{
    display: none;
}

.infinite-loader .btn-load-more {
color: #ffffff!important;
background-color: #003A70!important;
}

.price-label{
    display:inline-block!important;
}


/* Auf mobilen Geräten: Desktop-Bilder ausblenden, mobile einblenden */
@media only screen and (max-width: 768px) {
.amprot-input-block {
max-width: 100%!important;
}
}
.amprot-input-block {
max-width: 50%;
}

/* ########## Fields für neues Markup ######### */

.amprot-field-container {
    padding-bottom: 0px;
}

/* Label-Überschrift (Kontaktlinsenflüssigkeit) */
.amprot-field .amprot-label {
    margin-right: 10px;
    min-width: 72px;
    font-size: .8571em;
    text-transform: uppercase;
    font-weight: 400;
    line-height: 32px;
    white-space: nowrap;
    padding: 2px 0 8px;
    margin: 0;
    display: inline-block;
}

/* Verstecke Standard-Checkbox */
.amprot-checkbox-block .amprot-input.amprot-checkbox-option {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 25px;
    height: 25px;
    background-color: #fff;
    border: 2px solid #003A70;
    border-radius: 4px;
    position: relative;
    cursor: pointer;
    box-sizing: border-box;
    transition: transform 0.2s ease-in-out;
}

/* Gecheckte Checkbox */
.amprot-checkbox-block .amprot-input.amprot-checkbox-option:checked {
    background-color: #BFCCFF;
    border-color: #003A70;
    animation: pulse 0.6s ease-in-out;
}

/* Häkchen */
.amprot-checkbox-block .amprot-input.amprot-checkbox-option:checked::after {
    content: '✔';
    font-size: 30px;
    color: #fff;
    position: absolute;
    top: -10px;
    left: 2px;
}
.amprot-radio-block>.amprot-input:checked~.amprot-text, .amprot-checkbox-block>.amprot-input:checked~.amprot-text {
    color: #0e1025;
    font-weight: 400;
}
/* Text Label */
.amprot-checkbox-block .amprot-text {
    font-size: 14px;
    letter-spacing: .005em;
    line-height: 1.9;
    font-weight: 400;
    cursor: pointer;
    color: #777777;
}

/* Preistext */
.amprot-checkbox-block .price-wrapper {
    font-size: 14px;
    font-weight: 400;
    letter-spacing: .005em;
    line-height: 1.9;
    transition: color 2s ease-in-out;
}
.amprot-field.-checkable .amprot-label {
    margin: 10px 0 0px 0;
}

/* Preisfarbe grün beim Anklicken */
.amprot-checkbox-block .amprot-input.amprot-checkbox-option:checked + .amprot-text .price-wrapper {
    color: #28a745;
    animation: revertPriceColor 2s forwards;
}

/* Pulse-Effekt */
@keyframes pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); }
}

/* Animation Preis zurück */
@keyframes revertPriceColor {
    0% { color: #28a745; }
    100% { color: inherit; }
}

@media (max-width: 991px)
.page-header.type22 .side-megamenu.navigation li.level0.staticwidth > .submenu {
background-color: #FFFFFF !important;
}

.review-date { display: none; }


/* Standardmäßig mobile Elemente ausblenden */
.mobile-only {
  display: none!important;
}

/* Auf mobilen Geräten: Desktop-Bilder ausblenden, mobile einblenden */
@media only screen and (max-width: 767px) {
  .desktop-only {
    display: none !important;
  }
  .mobile-only {
    display: block !important;
    width: 100%;
    height: auto;
  }

  /* Ganze Slides ausblenden */
  .hide-on-mobile {
    display: none !important;
  }
}