/*
Theme Name:   Bolli Theme
Theme URL:
Description:  Bolli Theme
Author:       Bernardo Bär
Author URL:
Template:     storefront
Version:      1.0.0
Tags:
Text Domain:  bolli_theme
*/

@import url("assets/css/style.css");

@font-face {
    font-family: 'Lora';
    src: url('assets/fonts/Lora-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'Lora';
    src: url('assets/fonts/Lora-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Lora';
    src: url('assets/fonts/Lora-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'Lora';
    src: url('assets/fonts/Lora-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Nunito';
    src: url('assets/fonts/Nunito-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'Nunito';
    src: url('assets/fonts/Nunito-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Nunito';
    src: url('assets/fonts/Nunito-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'Nunito';
    src: url('assets/fonts/Nunito-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}

/* globale Auswahl-Farbe */
::selection {
  background: #d30b22;  
  color: #820614;  
}

/* für Firefox extra */
::-moz-selection {
  background: #d30b22;
  color: #820614;
}
.cf7-hidden { 
    display: none; 
}
#musterkarten-group .wpcf7-checkbox .wpcf7-list-item {
  display: block;
  margin: 0;
  outline: none !important;
}
#musterkarten-group .wpcf7-checkbox .wpcf7-list-item input:focus {
    outline: none !important;
    border: none !important;
    border-color: transparent !important;
    box-shadow: none !important;
}

#musterkarten-group .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 6px;
}
#musterkarten-group span.wpcf7-list-item-label {
     
     margin: 0 !important;
     padding: 0 !important;
 }


body {
    font-family: 'Nunito';
    font-weight: 400;
}


.banner {
    align-items: center;
    display: flex;

    margin-left: auto;
    margin-right: auto;
    width: 100%;

    padding: 10px;

    background-color: #d30b22;
    color: white;
}

.banner .inner {
    align-items: center;
    justify-content: space-between;
    align-self: center !important;
    height: auto;

    display: flex;

    margin-left: auto;
    margin-right: auto;

    width: 90%;
    max-width: 1100px;
}

.site-header {
    box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.2);
    padding: 0;
}

.site-header > .col-full {
    display: flex;

    width: 90%;
    max-width: unset;
    border-bottom: 1px solid rgba(221, 222, 223, 0.5);

    align-items: center;
    padding: 20px;
}

.site-header .site-branding {
    display: flex;
    justify-content: center;
}

.widget_product_search form:not(.wp-block-search) input[type=search] {
    padding-left: 15px;
}

.header-icons {
    display: flex;
    gap: 20px;

    align-items: center;

    width: 21.7391304348%;
    justify-content: end;
}

.trp_language_switcher_shortcode, .trp-language-switcher {
    max-width: 112px;
}

.site-header-account {
    min-width: 30px;
}

.site-header-cart {
    margin-top: 10px;
}

.site-header-cart .cart-contents::after {
    content: unset;
}

.site-header-cart .cart-contents {
    padding: unset;
}

.site-header-cart .widget_shopping_cart {
    position: absolute;
    width: 330px;
    transform: translate(-300px, 15px);
    top: 20px;
    background-color: transparent;
    z-index: 20;
}

.site-header-cart .widget_shopping_cart > div {
    background-color: white;
    margin-top: 20px;
    border: 1px solid #dddedf;
}

.site-header-cart .widget_shopping_cart .buttons, .site-header-cart .widget_shopping_cart .total {
    background-color: white;
}

.site-header-cart .widget_shopping_cart .product_list_widget li a.remove {
    text-indent: unset;
    right: 0;
    left: unset;

    position: absolute;
}

.site-header-cart .widget_shopping_cart .product_list_widget img {
    float: left;
    width: 60px;
    min-width: 60px;
    max-width: 60px;
    height: auto;
    object-fit: cover;
    border-radius: 10px;
    margin-left: 0;
    margin-right: 15px;
}

.widget_shopping_cart p.total {
    border-bottom: none;
}

.site-header-cart .widget_shopping_cart li > a, .site-header-cart .widget_shopping_cart li > a:hover, .site-header-cart .widget_shopping_cart li dt, .site-header-cart .widget_shopping_cart li dd {
    color: #d30b22;
    font-size: 17px;
    font-weight: 700;
    line-height: 26px;
}

.site-header-cart .widget_shopping_cart li dl.variation {
    display: flex;
}

.site-header-cart .widget_shopping_cart li .quantity {
    font-size: 16px;
    line-height: 24px;
}

.woocommerce-mini-cart__total.total {
    display: flex;
    justify-content: space-between;
    font-size: 16px;
    line-height: 24px;
    font-weight: 700;
}


.site-header .custom-logo-link {
    display: inline-block;
}

.site-search, .site-branding {
    margin-bottom: 0;
}

.site-search .search-field {
    width: 100%;
    border-width: 1px;
    border-color: #dddedf;
    background-color: unset;
    border-style: solid;

    box-shadow: unset;
}

input[type="search"]:focus {
    outline-color: #d30b22;
    background-color: unset;
}

.woocommerce-products-header {
    display: none;
}

.products-filter {
    width: 100%;
    display: flex;
    gap: 20px;
}

.products-count {
    width: 100%;
}

.site-content {
    padding-bottom: 30px;
}

.site-content > .col-full, .storefront-breadcrumb > .col-full {
    max-width: 1100px;
}

.storefront-breadcrumb {
    margin: 0;
    padding: 40px 0;
}

ul.products li.product .woocommerce-loop-product__link img {
    width: 100%;
    aspect-ratio: 1 / 1; /* keeps square images */
    object-fit: cover;
    display: block;

    margin-bottom: 0;
}

ul.products li.product img.sale {
    pointer-events: none;

    position: absolute;
    top: -10px;
    left: -10px;
}

ul.products li.product img.variable {
    pointer-events: none;

    position: absolute;
    top: -10px;
    right: -10px;
}

.products-filter .filter {
    position: relative;

    padding: 35px 10px 10px;
    border: 1px solid #e3e3e3;
    background-color: #ffffff;
    border-radius: 6px;
}

.products-filter .filter .css-filter {
    position: absolute;
    top: -10px;
    left: -10px;
}

.products-filter .filter h4 {
    color: #1a1a1a;
    font-weight: 600;
}

.iksm-terms-tree {
    width: 280px;
}

.woocommerce-breadcrumb {
    font-size: 18px;
}

.woocommerce-breadcrumb a:first-of-type::before {
    content: unset;
}

.woocommerce-breadcrumb .breadcrumb-separator {
    text-indent: unset;
}

.woocommerce-breadcrumb .breadcrumb-separator::after {
    content: unset;
}

.woocommerce-breadcrumb a {
    text-decoration: unset;
    color: #d30b22;
}

.woocommerce-result-count {
    font-size: 18px;
    color: #414141;

    margin-bottom: 20px;
}

.products .product .product-number {
    font-size: 18px;
    color: #4d4d4d;
}

.products .product .designation1 {
    font-weight: 600;
}

.product .price .amount {
    font-weight: 600;
    color: #2f2f2f;

    font-size: 18px;
}

.storefront-sorting {
    display: flex;
    justify-content: center;
}

.woocommerce-pagination .next::after {
    content: unset;
}

.woocommerce-pagination .prev::after {
    content: unset;
}

.woocommerce-pagination .next, .woocommerce-pagination .prev {
    text-indent: unset;
}

.woocommerce-pagination .page-numbers li .page-numbers:not(.current) {
    color: #d30b22;
}

.woocommerce-pagination .page-numbers li .page-numbers {
    background-color: unset;
    font-size: 18px;
}

.woocommerce-pagination .page-numbers li .page-numbers.current {
    background-color: unset;
    color: #2f2f2f;
}

div.hr.bottom {
    height: 1px;
    width: 100%;
    border-bottom: 1px solid #ececec;
}

div.hr.right {
    height: 450px;
    width: 1px;
    border-right: 1px solid #ececec;
}

.main-navigation ul li:has(.mega-menu) {
    position: unset;
}

.mega-menu {
    display: flex;
    position: absolute;
    width: 100vw;

    padding: 30px 5%;
    background-color: white;
    justify-content: space-evenly;
    border-top: 1px solid #ececec;
    border-bottom: 1px solid #ececec;
    box-shadow: 0 5px 10px 0 rgba(0, 0, 0, .2);
}

.mega-menu .section .item {
    padding-top: 10px;
    padding-left: 20px;
    padding-right: 20px;
}

.mega-menu .section .item .content {
    display: flex;
    position: relative;
}

.mega-menu .section .item .all {
    font-weight: 600;
}

.mega-menu .section .item h3 {
    white-space: nowrap;
    margin-left: 15px;

    font-weight: 600;
}

.mega-menu .section .item .content > div {
    position: absolute;
    left: -35px;
}

.woocommerce-active .site-header .main-navigation {
    margin-right: 0;
    width: 100%;
}

.main-navigation ul.menu, .main-navigation ul.nav-menu {
    display: flex;
    justify-content: center;
}

.site-main {
    display: flex;
    justify-content: center;
}

.main-navigation ul.menu > li > a, .main-navigation ul.nav-menu > li > a {
    padding: 1em;
}

.product .summary {
    position: relative;

    border: 1px solid #e9e7e7;
    border-radius: 4px;

    background-color: #f9f9f9;

    padding: 20px;
}

.product .summary .css-filter {
    position: absolute;
    top: -10px;
    left: -10px;
}

.product .summary .product-number {
    font-size: 18px;
    color: #4d4d4d;
}

.product .summary .product_title .designation1 {
    font-weight: 500;
    font-size: 25px;
    color: #d30b22;
}

.product .summary .product_title .designation2 {
    font-weight: 400;
    font-size: 25px;
    color: #d30b22;
}

.single-product div.product {
    overflow: visible;
}

.woocommerce-variation-add-to-cart {
    display: flex;
    flex-direction: column;
}

.product .summary form.cart {
    display: flex;
    flex-direction: column;
}

.product .summary .variations tr {
    display: flex;
    justify-content: space-between;
}

.product .summary .variations td.value {
    display: flex;
    flex-direction: column;
    flex: 1;
    margin-left: 50px;
}

.single-product div.product table.variations select {
    max-width: unset;
    appearance: none;
    -webkit-appearance: none;
    background-color: transparent;
    background-image: linear-gradient(45deg, transparent 50%, gray 0), linear-gradient(135deg, gray 50%, transparent 0);
    background-position: calc(100% - 20px) calc(50% + 2px), calc(100% - 16px) calc(50% + 2px);
    background-repeat: no-repeat;
    background-size: 4px 4px, 4px 4px;
    border-radius: 0;
    border-style: solid;
    border-width: 1px;
    box-shadow: none;
    color: currentcolor;
    font-size: inherit;
    line-height: 40px;
    outline: none;
    padding: 0 12px;
    width: 100%;
    border-color: #dddedf;
}

a.reset_variations::before {
    content: unset;
}

a.reset_variations {
    color: #d30b22;
}

.product .summary .quantity-unit {
    display: flex;
    align-items: center;
}

.product .summary .quantity {
    border: 1px solid #d30b22;
    display: flex;
    align-items: center;

    border-radius: 3px;
    background-color: #fff;
}

.product .description {
    text-align: left;
    display: inline-block;
    width: 100%;
    margin-top: 50px;
    margin-bottom: 50px;
}

.product .description > span {
    color: #d30b22;
    font-size: 25px;
    font-family: 'Lora';
    margin-bottom: 20px;
    display: inline-block;
}

.quantity .action {
    color: #8b8b8b;
    cursor: pointer;
    width: 30px;
    display: flex;
    justify-content: center;

    user-select: none;
}

input[type=number] {
    background-color: #fff;
}

.woocommerce-product-details__short-description {
    margin-top: 10px;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    /* display: none; <- Crashes Chrome on hover */
    -webkit-appearance: none;
    margin: 0; /* <-- Apparently some margin are still there even though it's hidden */
}

input[type=number] {
    -moz-appearance: textfield; /* Firefox */
}

.edit-link {
    display: none !important;
}

.single-product div.product form.cart {
    margin-bottom: 0;
}

.summary-consultation {
    width: 100%;
    float: right;
    display: inline-block;
}

@media (min-width: 768px) {
    .summary-consultation {
        width: 56.5217391304%;
    }
}

@media (min-width: 768px) {
    .summary-consultation {
        width: 52.9411764706%;
    }
}

.summary-consultation .summary {
    width: 100% !important;
    margin-bottom: 20px !important;
}

.consultation {
    width: 85%;

    border: 1px solid #e2001a;
    border-radius: 4px;

    text-align: center;

    padding: 15px;

    display: inline-flex;
    flex-direction: column;
    gap: 15px;
}

.consultation .icons {
    display: flex;
}

.consultation > h3 {
    text-align: center;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 15px;

    margin-bottom: 0;
}

.consultation .text {
    font-size: 12px;
    color: #4d4d4d;
}

.consultation .icons h3 {
    font-size: 12px;
    color: black;
    font-weight: 400;
}

button.alt.single_add_to_cart_button {
    background-color: #d30b22;
    border-radius: 8px;

    padding: 20px;
    min-width: 305px;

    text-transform: uppercase;
    margin-top: 10px;
}

.woocommerce-account h1, .woocommerce-cart h1 {
    background-color: #d30b22;
    color: white;
    font-weight: 700;
    font-size: 45px;
    line-height: 54px;
    font-family: 'Lora';
    text-align: left;
    padding: 18px 20px;
}

.woocommerce-account main .entry-content {
    background-color: #eef1f4;
}

.woocommerce-account main > article, .woocommerce-cart main > article {
    width: 100%;
}

.hentry .entry-content .woocommerce-MyAccount-navigation ul {
    border-top: none;
    margin-bottom: 0;
}

.woocommerce-MyAccount-navigation {
    border-right: solid 1px #bfbfbf;
    margin-right: 0;
    width: 200px;
}

.hentry .entry-content .woocommerce-MyAccount-navigation ul li {
    border-bottom: none;
    padding: 10px 20px 10px 15px;
}

.hentry .entry-content .woocommerce-MyAccount-navigation ul li.is-active {
    border-right: 3px solid black;
}

.woocommerce-MyAccount-navigation ul li a::before {
    display: none;
}

.hentry .entry-content .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link a {
    outline: none;
    color: black;
    font-size: 16px;
    line-height: 26px;
    font-weight: 400;
    opacity: 70%;
    transition: all .3s, font-weight 0s;
    padding: 0;
}

.hentry .entry-content .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link a:hover {
    opacity: 1;
}

.hentry .entry-content .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link.is-active a {
    opacity: 1;
    font-weight: 600;
}

.woocommerce-MyAccount-content {
    padding: 30px 13px;
    width: calc(100% - 200px);
    float: left;
    color: black;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
}

.woocommerce-MyAccount-content strong {
    font-weight: 700;
}

.woocommerce-MyAccount-content p a, .addresses header.title a, table.cart td.product-remove a.remove, .shipping-calculator-button {
    color: #d30b22;
    text-decoration: none !important;
    outline: none;
    transition: all 0.3s;
}

.woocommerce-MyAccount-content p a:hover, .addresses header.title a:hover, table.cart td.product-remove a.remove:hover {
    color: #f2102a;
}

.woocommerce-info, .woocommerce-noreviews, p.no-comments {
    background-color: transparent;
    padding: 0;
    color: black;
    border-left: none;
}

.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before, .woocommerce-noreviews::before, p.no-comments::before {
    display: none;
}

.archive .site-header {
    margin-bottom: 4.235801032em;
}

.woocommerce-page button, body button#site-navigation-menu-toggle, .woocommerce-page button:hover, .woocommerce-page input[type="button"]:hover, .woocommerce-page input[type="submit"], .woocommerce-page input[type="submit"]:hover, .woocommerce-message .button, .woocommerce-info .button, .woocommerce-error .button, .woocommerce-noreviews .button, p.no-comments .button, .woocommerce-message .button:hover, .woocommerce-info .button:hover, .woocommerce-error .button:hover, .woocommerce-noreviews .button:hover, p.no-comments .button:hover {
    text-decoration: none;
    background: #302d2d;
    color: white;
    font-size: 13px;
    line-height: 20px;
    text-transform: uppercase;
    font-weight: 600;
    padding: 11px 15px 9px 15px;
    outline: none;
}

body button#site-navigation-menu-toggle {
    background-color: unset;
}

.wc-forward::after, .woocommerce-Button--next::after {
    display: none;
}

.woocommerce-MyAccount-content h2 {
    font-family: 'Lora';
    font-size: 45px;
    line-height: 54px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 0;
}

.col2-set#customer_login, .col2-set.addresses {
    display: flex;
    grid-gap: 30px;
}

.col2-set#customer_login .col-1, .col2-set.addresses .col-1 {
    width: calc(50% - 15px);
    margin-right: 0;
}

.addresses header.title a {
    text-indent: inherit;
    width: auto;
    height: auto;
    font-size: 16px;
    line-height: 24px;
    font-weight: 700;
    padding: 0;
    float: none;
}

.addresses header.title a::before {
    display: none;
}

address {
    font-style: normal;
}

.form-row input, .form-row textarea, .form-row select {
    border: 1px solid #dddedf;
    font-size: 16px;
    font-weight: 400;
    line-height: 26px;
    padding: 7px 12px;
    outline: none;
    box-shadow: none;
    background-color: white;
    color: black;
}

.select2-container--default .select2-selection--single {
    height: auto;
    border: 1px solid #dddedf;
    border-radius: 0;
}

.select2-container .select2-selection--single .select2-selection__rendered {
    padding: 7px 12px;
}

.woocommerce-MyAccount-content .form-row-first, .woocommerce-MyAccount-content .form-row-last {
    width: calc(50% - 10px);
    margin-right: 0;
}

.woocommerce-EditAccountForm input {
    background-color: transparent;
    border: 2px solid white;
}

table:not( .has-background ) tbody tr:nth-child(2n) td, fieldset, fieldset legend {
    background-color: transparent;
}

.show-password-input {
    background-color: transparent;
}

input[type=text]:focus, input[type=number]:focus, input[type=email]:focus, input[type=tel]:focus, input[type=url]:focus, input[type=password]:focus, input[type=search]:focus, textarea:focus, .input-text:focus {
    background-color: inherit;
}

.woocommerce-message {
    background-color: #e6f6ed;
    color: #11b76b;
    border: none;
    outline: none;
}

.woocommerce-message .button, .woocommerce-message .button:hover {
    background-color: #11b76b;
    color: white;
    text-transform: none;
    font-size: 16px;
    line-height: 24px;
    font-weight: 700;
}

.woocommerce-cart .entry-content > .woocommerce {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.woocommerce-cart-form {
    background-color: #eef1f4;
    padding: 13px;
}

.woocommerce-cart-form table th, .woocommerce-cart-form table td {
    background-color: transparent !important;
}

.woocommerce-cart-form table th {
    border-bottom: 1px solid #dddedf;
    color: #302d2d;
    font-size: 16px;
    font-weight: 700;
    padding: 20px 0px;
}

.woocommerce-cart-form table th.product-remove {
    width: 30px;
}

a.remove::before {
    display: none;
}

table.cart td.product-remove {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0;
}

table.cart td.product-remove a.remove {
    text-indent: inherit;
    text-decoration: none;
    outline: none;
    font-size: 24px;
    line-height: 36px;
    width: auto;
}

table.cart .product-thumbnail img {
    max-width: none;
    width: 100px;
    height: auto;
    object-fit: cover;
    border-radius: 10px;
    margin-left: 0;
    margin-right: 0;
}

table.cart td {
    padding: 0;
    vertical-align: middle;
    padding-top: 37px;
    padding-bottom: 15px;
}

.woocommerce-cart-form a {
    text-decoration: none !important;
}

.woocommerce-cart-form .designation1, .woocommerce-cart-form .designation2, .woocommerce-cart-form .variation dt, .woocommerce-cart-form .variation dd {
    color: #1c2329;
    text-decoration: none;
    font-size: 16px;
    line-height: 24px;
    font-weight: 700;
}

.woocommerce-cart-form td.product-price {
    color: #d30b22;
    font-size: 16px;
    line-height: 24px;
    font-weight: 700;
}

.woocommerce-cart-form td .quantity {
    width: 115px;
    border: 1px solid #d30b22;
    height: 42px;
}

.woocommerce-cart-form td .quantity span {
    display: flex !important;
    background-color: transparent;
    align-items: center;
}

.woocommerce-cart-form td .quantity input {
    background-color: transparent;
    outline: none;
    font-size: 16px;
    line-height: 24px;
}

.woocommerce-cart-form td.product-quantity .unit, .woocommerce-cart-form td.product-subtotal {
    color: #302d2d;
    font-size: 16px;
    padding-left: 10px;

}

.woocommerce-cart-form td.product-quantity .quantity-unit {
    height: 42px;
    display: flex;
    align-items: center;
}

.woocommerce-cart-form tr.cart-bottom-wrapper td > div {
    position: relative;
    padding-top: 50px;
    display: flex;
    flex-wrap: wrap;
}

.woocommerce-cart-form tr.cart-bottom-wrapper td > div::before {
    content: "";
    position: absolute;
    left: -13px;
    top: 0;
    width: calc(100% + 26px);
    height: 25px;
    background-color: white;
}

.woocommerce-cart-form tr.cart-bottom-wrapper td > div > div {
    width: 50%;
    padding: 0px 40px;
}

.woocommerce-cart-form tr.cart-bottom-wrapper td > div > div:first-child {
    position: relative;
    padding-left: 10px;
}

.woocommerce-cart-form tr.cart-bottom-wrapper td > div > div:first-child::before {
    content: "";
    position: absolute;
    right: -13px;
    top: -25px;
    width: 25px;
    height: calc(100% + 70px);
    background-color: white;
    z-index: 10;
}

.woocommerce-cart-form tr.cart-bottom-wrapper .payment-methods {
    list-style: none;
    margin-left: 0;
    display: flex;
    flex-wrap: wrap;
    grid-gap: 8px;
}

.woocommerce-cart-form tr.cart-bottom-wrapper .payment-methods img {
    width: auto;
    height: 50px;
}

.woocommerce-cart-form tr.cart-bottom-wrapper h3 {
    font-family: 'Lora';
    font-size: 26px;
    line-height: 39px;
    font-weight: 700;
    color: #1a1a1a;
}

.woocommerce-cart-form tr.cart-bottom-wrapper .actions span {
    color: #302d2d;
    font-size: 16px;
    line-height: 24px;
}

.woocommerce-cart-form tr.cart-bottom-wrapper .actions .button {
    display: block;
    background-color: #d30b22;
    margin-top: 15px;
}

.woocommerce-cart-form tr.cart-bottom-wrapper .actions .input-text {
    background-color: white;
    border: 1px solid black;
    outline: none;
    margin-top: 10px;
}

.cart-collaterals {
    background-color: #eef1f4;
    padding: 13px;
}

.cart-collaterals h2 {
    display: none;
}

.cart-collaterals th, .cart-collaterals td {
    background-color: transparent !important;
    color: #302d2d;
}

.cart-collaterals th {
    color: #302d2d;
    font-size: 16px;
    font-weight: 700
}

.cart-collaterals .woocommerce-Price-amount {
    color: #302d2d;
    font-size: 16px;
}

.cart-collaterals .woocommerce-shipping-methods {
    font-size: 14px;
}

.cart-collaterals strong {
    font-weight: 700;
}

.shipping-calculator-button {
    text-decoration: underline !important;
    outline: none !important;
}

.cart-collaterals .checkout-button, .woocommerce-account:not(.logged-in) .woocommerce .u-columns > div .woocommerce-button {
    background-color: #d30b22;
    font-size: 13px !important;
    text-transform: uppercase;
    outline: none;
    color: white !important;
}

.cart-collaterals .wc-proceed-to-checkout {
    padding-top: 30px;
    border-top: 1px solid #dddedf;
}

.post-type-archive-product main {
    display: flex;
    flex-direction: column;
}

.post-type-archive-product main .categories {
    display: flex;
    flex-wrap: wrap;
    grid-gap: 38px;
}

.post-type-archive-product main .categories .category {
    width: calc(50% - 19px);
    outline: none !important;

}

.post-type-archive-product main .categories .category img {
    height: 360px;
    width: 100%;
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 20px;
}

.post-type-archive-product main .categories .category h3 {
    color: black;
    font-size: 23px;
    line-height: 34px;
    font-weight: 700;
    margin-bottom: 15px;
}

.post-type-archive-product main .categories .category span {
    color: black;
    font-size: 16px;
    line-height: 24px;
    font-weight: 400;
    margin-bottom: 25px;
    display: inline-block;
}

.post-type-archive-product main > h3 {
    font-family: 'Lora';
    font-size: 45px;
    line-height: 65px;
    font-weight: 400;
    text-align: center;
    margin-top: 80px;
    position: relative;
    padding-bottom: 15px;
    margin-bottom: 45px;
}

.post-type-archive-product main > h3::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    width: 20px;
    height: 4px;
    background-color: #d30b22;
}


.site-search .widget_product_search form::before {
    left: 0px;
    top: 14px;
    font-size: 20px;
    font-weight: 400;
}

input.search-field {
    margin-left: 30px;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns {
    background-color: white;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns > div {
    padding: 20px;
    background-color: #eef1f4;
    padding-bottom: 50px;
    width: calc(100% / 3) !important;
    margin-bottom: 0;
    position: relative;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns > div span.title {
    font-family: 'Nunito';
    font-weight: 700;
    font-size: 16px;
    line-height: 24px;
    display: inline-block;
    margin-bottom: 20px;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns > div span.text {
    display: inline-block;
    margin-bottom: 20px;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns > div .woocommerce-button {
    position: absolute;
    left: 18px;
    bottom: 18px;
    padding: 11px 15px 9px 15px;
    text-transform: uppercase;
    text-decoration: none !important;
    font-weight: 600;
    font-family: "Source Sans Pro", "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
}

.woocommerce-account:not(.logged-in) .woocommerce .u-columns > div .woocommerce-Input {
    background-color: transparent;
    border: 2px solid white;
}

.woocommerce-account:not(.logged-in) .loggedout-only {
    background-color: white;
    padding-bottom: 50px;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
}


.woocommerce-account:not(.logged-in) .loggedout-only .red {
    color: #d30b22;
}

.woocommerce-account:not(.logged-in) .loggedout-only strong {
    font-weight: 700;
}

.woocommerce-account.logged-in .loggedout-only {
    display: none;
}

.single-product .price del {
    opacity: 1;
    color: #d30b22;
}

.single-product .price del .woocommerce-Price-amount {
    color: #d30b22 !important;
}


@media only screen and (max-width: 768px) {
    .cart-count > span {
        top: 20px !important;
    }

    .header-icons {
        display: grid;
        width: 100%;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        justify-items: center;
        align-items: center;

        margin-bottom: -25px;
        margin-top: 25px;
    }

    .post-type-archive-product main .categories .category {
        width: 100%;
    }

    .products-filter {
        flex-direction: column;
    }

    .iksm-terms-tree {
        width: 100%;
    }

    ul.products {
        display: flex;
        flex-wrap: wrap;
        grid-gap: 20px;
    }

    ul.products li.product {
        width: calc(50% - 10px);
    }

    ul.products::before, ul.products::after {
        display: none;
    }

    .woocommerce-account:not(.logged-in) .woocommerce .u-columns {
        flex-direction: column;
    }

    .woocommerce-account:not(.logged-in) .woocommerce .u-columns > div {
        width: 100% !important;
    }

    .site-footer .wave--bottom {
        display: none;
    }

    .site-footer .site-info a:not(.button):not(.components-button) {
        display: block;
    }

    .category.slider .slide {
        padding: 0 15px !important;
        height: 500px !important;
    }
}

.site-footer {
    padding: 0;
    position: relative;
}

.site-footer > .col-full {
    max-width: unset;
    padding: unset;
    margin: unset !important;
}

.site-footer h3 {
    color: white;
}

.site-footer .footer-widgets {
    padding: 50px 100px;
    border-bottom: unset;

    background-color: #434343;
    color: white;
}

.site-footer .site-info {
    background-color: #d30b22;
    color: white;

    text-align: center;
}

.site-footer a:not(.button):not(.components-button) {
    color: white;
}

.site-footer .wave--bottom {
    position: absolute;
    bottom: 80px;
}

.search-results .site-main {
    padding-top: 100px;
}

.search-results .site-main > h2 {
    position: relative;
    max-width: 300px;

    font-size: 40px;
    font-weight: 500;
}

.search-results .site-main > h2::before {
    content: ' ';
    width: 150px;
    height: 150px;
    position: absolute;
    background-repeat: no-repeat;
    background-position: center left;
    background-size: auto;
    background-image: url(assets/img/stroke-left.svg);
    top: -.5rem;
    right: -5rem;

    z-index: 1;
}

.search-results .site-main > h2::after {
    content: ' ';
    width: 190px;
    height: 25px;
    position: absolute;
    background-position: top center;
    background-repeat: no-repeat;
    background-size: contain;
    background-image: url(assets/img/headline-rectangle.svg);
    bottom: 5px;
    right: 5px;
    z-index: -1;
}

.search-results .site-main .products {
    padding-top: 100px;
}

.search-results .site-main > span {
    text-align: right;
    font-size: 24px;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li img {
    opacity: 1;
    max-width: 70px;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li img.flex-active {
    border: 2px solid #d30b22;
}

.cross-sells {
    margin-top: 60px;
}

.cross-sells > h2:first-child {
    font-size: 1.618em;
    margin-bottom: 1em;
}

.storefront-full-width-content .cross-sells > h2:first-child {
    text-align: center;
}

.lost_reset_password {
    padding: 10px;
}

.category.slider .slide {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;

    position: relative;

    height: 650px;

    padding: 0 150px;
}

.category.slider .slide > img {
    position: absolute;
    width: 100%;
    height: 100%;

    object-fit: cover;

    top: 0;
    left: 0;
    right: 0;
    bottom: 0;

    z-index: -1;

    filter: brightness(50%);
}

.category.slider .slide > span {
    font-weight: 600;
}

.category.slider .slide > .button {
    background-color: #d30b22;
    border-radius: 8px;
}

.category.slider .slide > *:not(img) {
    margin: 10px 0;
    color: white;
}

.slick-dots {
    bottom: 20px;
}

.slick-dots li button:before {
    font-size: 40px;
    color: white;
}

.slick-dots li.slick-active button:before {
    color: white;
}

.slick-dots li button:hover, .slick-dots li button:focus {
    background-color: transparent;
    font-size: 0;
    line-height: 0;
}

.woocommerce-active .site-header .site-header-cart {
    width: 100%;
}

.cart-count {
    position: relative;
}

.cart-count > span {
    position: absolute;
    top: -5px;
    right: -10px;
    z-index: 1;
    background-color: black;
    color: white;
    border-radius: 25px;
    padding: 5px;
    font-size: 10px;
    font-weight: 600;

    width: 25px;
    height: 25px;
    text-align: center;
}

.handheld-navigation {
    position: absolute;
    z-index: 2;
}

table.cart {
    border-collapse: collapse;
}

table.cart td.actions {
    border: unset;
}

table.cart td.actions button {
    color: white;
    font-weight: 700;
    text-transform: uppercase;
    background-color: #d30b22;

    margin-top: 30px;
}

.woocommerce-cart-form tbody tr:not(:has(.actions)) {
    border-bottom: 1px solid #dddedf;
}

.tax-product_cat a.next.page-numbers:before {
    content: unset;
}

.tax-product_cat a.prev.page-numbers:before {
    content: unset;
}