:root {
    --header-height-top: 80px;
    --header-height-bottom: 54px;
    --topbar-height: 0px;
    --total-header-height: calc(var(--header-height-top) + var(--header-height-bottom) + var(--topbar-height));
}

@media only screen and (max-width: 980px) {
    :root {
        --total-header-height: var(--header-height-top);
        --header-height: var(--m-header-height);
    }
}

/* ==========================================================================
General 
========================================================================== */

*,
::after,
::before {
    box-sizing: border-box;
}

div[id] { 
	scroll-margin-top: calc(var(--total-header-height));
}

main {
    margin-top: var(--total-header-height);
}

.wp-block-heading[id] {
	scroll-snap-align: start;
	scroll-margin: calc(var(--total-header-height) + 60px);
}

/* Others 
========================================================================== */

/* reCAPTCHA */
.grecaptcha-badge {
    visibility: hidden;
}

/* Cookie declaration */
.CookieDeclaration * {
    font-size: initial;
}

/* Settings for splide
========================================================================== */
.splide {
    position: relative !important;
    overflow-x: hidden;
}

.splide__track {
    overflow: visible !important;
}

.splide__list :is(ul, ol) {
    padding: unset !important;
}

.splide__arrows {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    transform: translateY(-50%);
    z-index: 99;
}

.splide__arrow {
	height: 2.4rem;
	width: 2.4rem;
    border-radius: 0;
    background-color: #fff;
    opacity: 1;
}

.splide__arrow:disabled {
    opacity: 0;
}

.splide__arrow svg {
	/* height: 1.2rem;
	width: 1.2rem; */
}

.splide__arrow--prev {
    left: 0;
}

.splide__arrow--next {
    right: 0;
}


/* ==========================================================================
Header and navigation
========================================================================== */

/* Header
========================================================================== */
header.wp-block-template-part {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 99;
    background-color: var(--wp--preset--color--base);
}

.admin-bar header.wp-block-template-part {
    top: 32px;
}

@media screen and (max-width: 768px) {
    .admin-bar header.wp-block-template-part {
        top: 46px;
    }
}

/* Header style */
.is-style-header-top,
.is-style-header-bottom {
    padding-bottom: 0.875rem !important;
    padding-top: 0.875rem !important;
    border-bottom: 1px solid rgb(217 217 217 / 25%);
}

.is-style-header-top {
    min-height: var(--header-height-top);
}

.is-style-header-bottom {
    min-height: var(--header-height-bottom);
}

@media (max-width: 980px) {
    .is-style-header-bottom {
        border-bottom: unset;
    }
    .is-style-header-bottom {
        display: none !important;
    }
    .is-style-header-top .qt-section__inner {
        grid-template-columns: repeat(3, calc(33.33% - 2rem / 3));
        gap: 1rem;
    }
    .is-style-header-top .qt-container:first-child {
        display: flex;
        align-items: center;
    }
}

/* Menu navigation */
.menu-item-text-size-default a {
    font-size: var(--wp--preset--font-size--default);
}

.menu-item-text-size-small a {
    font-size: var(--wp--preset--font-size--s);
}

.menu-item-text-size-medium a {
    font-size: var(--wp--preset--font-size--m);
}

.menu-item-text-size-large a {
    font-size: var(--wp--preset--font-size--l);
}

.menu-item-text-size-x-large a {
    font-size: var(--wp--preset--font-size--xl);
}

.menu-item > span {
    display: flex;
    align-items: center;
    gap: var(--wp--preset--spacing--05);
}

header li a {
    color: var(--wp--preset--color--contrast-3);
}

/* Info banner above header
========================================================================== */
.banner-header {
    background-color: var(--wp--preset--color--primary);
    display: flex;
    flex-direction: column;
    margin: 0;
    align-items: center;
    padding: .2rem 1rem;
    /* height: var(--topbar-height); */
    overflow: hidden;
    transition: height .2s ease;
}

.banner-header p,
.banner-header a {
    color: var(--wp--preset--color--contrast-1);
}

.banner-header .accordion__header {
    margin-bottom: 0;
    cursor: initial;
}

#toggle-header-banner[aria-expanded="true"] {
    transform: rotate(180deg);
}

#close-header-banner {
    position: absolute;
    right: 0;
    filter: invert(1);
}

.banner-header p {
    margin: 0;
    font-family: var(--wp--preset--font-family--body);
    font-size: var(--wp--preset--font-size--s);
}

.banner-header button {
    appearance: none;
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: .5rem .7rem;
    transition: transform .2s ease;
}

.banner-header button.is-open {
    transform: rotate(180deg);
}

.banner-header button img {
    filter: invert(1);
}

/* Breadcrumbs
========================================================================== */
nav.rank-math-breadcrumb {
    padding: 0;
    max-width: 100%;
}

nav.rank-math-breadcrumb .separator {
    padding: 0;
}

nav.rank-math-breadcrumb a {
    text-decoration: unset;
    color: var(--wp--preset--color--contrast-3);
}

nav.rank-math-breadcrumb a:hover {
    text-decoration: underline;
}

nav.rank-math-breadcrumb :is(span, a, p) .last {
    color: var(--text-clr);
    font-weight: var(--font-regular);
    font-size: var(--paragraph-small);
}

/*
WooSearch block
========================================================================== */
.wp-block-search__inside-wrapper {
    display: flex;
    flex: auto;
    flex-wrap: nowrap;
    max-width: 100%;
}

.wp-block-search__input {
    -webkit-appearance: initial;
    appearance: none;
    border: 1px solid #949494;
    flex-grow: 1;
    margin-left: 0;
    margin-right: 0;
    min-width: 3rem;
    padding: 8px;
    text-decoration: unset !important;
}

:where(.wp-block-search__button-inside .wp-block-search__inside-wrapper) {
    border: 1px solid #949494;
    box-sizing: border-box;
    padding: 4px;
}

:where(.wp-block-search__button-inside .wp-block-search__inside-wrapper) .wp-block-search__input {
    border: none;
    border-radius: 0;
    padding: 0 4px;
}

.wp-block-search__button {
    margin-left: 10px;
    word-break: normal;
}

.wp-block-search__button.has-icon {
    line-height: 0;
}

.wp-block-search__button svg {
    height: 1.25em;
    min-height: 24px;
    min-width: 24px;
    width: 1.25em;
    fill: currentColor;
    vertical-align: text-bottom;
}

/* Woo Menu
========================================================================== */
.woo-menu {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
    gap: .2rem;
    position: relative;
}

.woo-menu img {
    filter: invert(1) brightness(100);
}

.wc-block-mini-cart svg path {
    fill: var(--wp--preset--color--contrast-3);
}

.woo-menu-item__icon {
    padding: 6px 4px;
    position: relative;
}

.woo-menu-item__icon a,
.woo-menu-item__icon button {
    display: flex;
    justify-content: center;
    align-items: center;
}

.woo-menu-mobile {
    display: none;
}

.woo-menu-mobile .search img {
    filter: invert(1) brightness(100);
}

.hamburger-icon::before, 
.hamburger-icon::after {
    background-color: #fff;
}

@media (max-width: 980px) {
    .woo-menu .woo-menu__item.account,
    .woo-menu .woo-menu__item.search {
        display: none;
    }
    .woo-menu-mobile {
        display: block;
    }
    .woo-menu #qt-search {
        max-height: max-content !important;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        padding: 0 1rem;
        z-index: 99999;
        overflow: visible;
        transform: translateY(-100%);
        height: var(--header-height-top);
        background-color: var(--wp--preset--color--white);
    }
    .woo-menu #qt-search[aria-expanded="true"] {
        transform: initial;
    }
    .woo-menu #qt-search *:not(.qt-search-results, .qt-search-close, svg) {
        height: 100%;
    }
}

/* Mega menu mobile
========================================================================== */
#mega-menu-mobile {
    display: none;
}

@media (max-width: 980px) {
    #mega-menu-mobile {
        display: flex;
    }

    .menu-kundtjanst-container {
        display: none !important;
    }

    .mega-menu .menu > .menu-item > span {
        font-size: unset;
    }
}

/* Search
========================================================================== */
#qt-search {
    flex: 0 0 100%;
    max-height: 0;
    overflow: hidden;
    transition: max-height .2s cubic-bezier(0.23, 1, 0.320, 1);
}

.qt-search__inner {
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    margin-bottom: 1rem;
    display: flex;
    background-color: var(--wp--preset--color--white);
}

.qt-search__input {
    flex-grow: 1;
    border: 0;
    background: transparent;
    padding: .6rem 1rem;
    outline: none;
}

.qt-search-results {
    position: absolute;
    top: calc(100% - 1rem);
    left: 0;
    right: 0;
    padding: 1.5rem 1rem;
    background-color: #fff;
    z-index: 9999;
}

.qt-search-results ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.qt-search-item__highlight {
    font-weight: 700;
    color: var(--wp--preset--color--contrast-1);
}

.qt-search-item {
    color: var(--wp--preset--color--contrast-1);
}

.qt-search-item__title {
    /* TODO: Set correct variable */
    display: inline-flex;
    color: var(--wp--preset--color--contrast-1);
}

.qt-search-results svg {
    transform: scaleX(-1);
}

.qt-search-item a {
    display: flex;
    padding: .7rem 0;
}

.qt-search-item a:hover {
    background-color: rgba(0, 0, 0, 0.1);
}

.qt-search-results__type {
    /* TODO: Set correct varible */
    color: rgba(0, 0, 0, 0.6);
}

.qt-search-item + .qt-search-results__type {
    padding-top: 1rem;
    margin-top: .3rem;
    border-top: 1px solid rgba(0, 0, 0, 0.2);
}

.qt-search-close {
    display: flex;
    justify-content: center;
    align-items: center;
}
.qt-search-close svg {
    height: 18px;
}

/* ==========================================================================
Buttons
========================================================================== */
.wp-block-buttons + p {
    margin-top: var(--wp--preset--spacing--20);
}

button {
    font-family: var(--wp--preset--font-family--body);
    font-size: var(--wp--preset--font-size--default);
}

.primary-btn {
    background-color: var(--wp--preset--color--primary);
    color: var(--wp--preset--color--white);
}

.is-style-btn-text-arrow .wp-block-button__link, 
.is-style-btn-text-arrow .wp-block-button__link:hover {
    background-color: transparent;
    color: var(--wp--preset--color--contrast-3);
    padding: .5rem 0;
    display: flex;
	border: none;
}

.is-style-btn-text-arrow .wp-block-button__link::after {
    content: url(../images/arrow-right.svg);
    margin-left: 0.5rem;
    bottom: -1px;
    position: relative;
    filter: invert(1);
}

/* ==========================================================================
Core settings
========================================================================== */

/* Paddings and margins
========================================================================== */
.qt-section .qt-section {
    /* margin: var(--wp--preset--spacing--25) 0; */
}

.qt-section :is(ul, p, .wp-block-heading) ~ .qt-section {
    margin: var(--wp--preset--spacing--25) 0;
}

.qt-section .qt-section:last-of-type {
    margin-bottom: 0;
}

/* .qt-section .qt-section {
    padding: 0 !important;
}

.qt-section.has-background,
.qt-section__inner.has-background {
    padding: var(--wp--preset--spacing--60);
}

.qt-section:has(.card-overflow) {
    padding-bottom: calc(1.5 * var(--wp--preset--spacing--60));
} */

/* @media (max-width: 768px) {
    .qt-section.has-background,
    .qt-section__inner.has-background {
        padding: var(--wp--preset--spacing--20);
    }
    .qt-section:has(.card-overflow) .qt-section__inner {
        gap: var(--wp--preset--spacing--60) var(--wp--preset--spacing--15);
    }
} */

/* Elememt spacing
========================================================================== */
.qt-section.is-style-breadcrumbs {
    padding-top: var(--wp--preset--spacing--15);
    padding-bottom: var(--wp--preset--spacing--40);
}

main > .entry-content .qt-section:not(.is-style-breadcrumbs):first-of-type {
    padding-top: 0;
}

.qt-section:not(.is-style-breadcrumbs):first-of-type {
    padding-top: var(--wp--preset--spacing--40);
}

/* Typography
========================================================================== */
h1, h2, h3, h4, h5, h6, .wp-block-heading {
    color: var(--wp--preset--color--contrast-3);
}

/* p {
    margin-bottom: 1em;
}

p:only-of-type {
    margin-bottom: 0;
}

p:last-child {
    margin-bottom: 0;
} */

/* Links */
p a {
    text-decoration: underline;
}

p a:hover {
    text-decoration: underline;
}

/* Lists */
ul, ol {
    padding-left: 1em;
    margin-bottom: var(--wp--preset--spacing--10);
}

:is(ul, ol) ~ p {
    margin-top: var(--wp--preset--spacing--10);
}

/* Typography and element spacing
========================================================================== */
.single .qt-container p ~ section {
    margin-top: var(--wp--preset--spacing--25);
    margin-bottom: var(--wp--preset--spacing--25);
}

/* ==========================================================================
Sections, blocks and CPT's
========================================================================== */

/* Grid
========================================================================== */
.grid {
    grid-gap: var(--wp--preset--spacing--25) var(--wp--preset--spacing--15) ;
}

/* Custom section styling
========================================================================== */
.qt-section.is-style-hero {
    padding-top: var(--wp--preset--spacing--40) !important;
}

.qt-section.is-style-subhero {
    padding: 0;
}

.qt-section.is-style-large-left-col .qt-section__inner {
    grid-template-columns: 7fr 5fr;
}

.qt-section.is-style-large-right-col .qt-section__inner {
    grid-template-columns: 5fr 7fr;
}

@media (max-width: 1200px) {
    .qt-section.is-style-large-left-col .qt-section__inner,
    .qt-section.is-style-large-right-col .qt-section__inner {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 768px) {
    .qt-section.is-style-large-left-col .qt-section__inner,
    .qt-section.is-style-large-right-col .qt-section__inner {
        grid-template-columns: 1fr;
    }
}

/* Hero
========================================================================== */
.qt-section.is-style-hero {
    padding: 0 !important;
}

.block-heroslider {
    padding-bottom: var(--wp--preset--spacing--40);
}

.block-heroslider .grid {
    align-items: center;
}

.block-heroslider img {
    max-width: 100%;
    height: auto;
    aspect-ratio: var(--aspect-ratio-landscape);
}

section.qt-section.container-default.is-style-hero .text {
    padding-left: var(--wp--preset--spacing--20);
}

.splide .splide__pagination {
    position: relative !important;
    display: flex !important;
    gap: 1rem;
    padding-top: var(--wp--preset--spacing--25);
}

.splide__pagination__page {
    background: var(--wp--preset--color--tertiary);
    transform: scale(2);
    z-index: 1;
}

.splide__pagination__page.is-active {
    background: var(--wp--preset--color--primary);
    transform: scale(2);
    z-index: 1;
}

@media (max-width: 670px) {
    .block-heroslider .grid {
        grid-gap: var(--wp--preset--spacing--20);
    }

    .qt-section.is-style-hero {
        padding: 0 !important;
    }

    .block-heroslider img {
        aspect-ratio: 3/2;
    }

    section.qt-section.container-default.is-style-hero .text {
        padding: 0 var(--wp--preset--spacing--15);
    }
}

/* Product selector slider
========================================================================== */
.qt-section.qt-section.product-selector-slider {
    padding-right: 0;
}
.qt-section.product-selector-slider .qt-section__inner {
    display: grid;
    grid-template-columns: 1fr var(--wp--style--global--content-size) 1fr;
    grid-gap: var(--wp--preset--spacing--15) 0;
    max-width: none;
}

.qt-section.product-selector-slider .qt-container {
    grid-column: 2 / 3;
    left: calc(-1 * var(--wp--preset--spacing--10));
    position: relative;
}

.qt-section.product-selector-slider .product-slider {
    grid-column: 2 / -1;
    left: calc(-1 * var(--wp--preset--spacing--10));
    width: calc(100% + var(--wp--preset--spacing--10));
    position: relative;
}

.qt-section.product-selector-slider .wp-block-buttons {
    margin-top: 0;
    padding-right: var(--wp--preset--spacing--15);
}

.product-selector-slider .wp-block-heading {
    margin: 0;
    margin-top: var(--wp--preset--spacing--10);
    font-weight: 600;
    letter-spacing: 0.25px;
}

.product-selector-slider .splide__slide {
    max-width: 285px;
}

@media screen and (max-width: 1280px) {
    .qt-section.product-selector-slider .qt-section__inner {
        grid-template-columns: 1fr;
    }

    .qt-section.product-selector-slider .qt-container,
    .qt-section.product-selector-slider .product-slider {
        grid-column: initial;
        left: initial;
        width: auto;
    }
}

@media screen and (max-width: 1240px) {
    .qt-section.product-selector-slider {
        padding-right: var(--wp--preset--spacing--20);
    }
    .qt-section.product-selector-slider .qt-section__inner {
        grid-template-columns: 1fr;
    }
    .product-selector-slider__heading {
        padding-right: var(--wp--preset--spacing--20);
    }
}

.product-selector-slider__heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
    /* padding-bottom: var(--wp--preset--spacing--10); */
}
.product-selector-slider__heading > * {
    margin: 0;
}

@media screen and (max-width: 768px) {
    .product-selector-slider__heading {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* Accordion (base)
========================================================================== */
.accordion-item {
    height: fit-content;
    margin-bottom: var(--wp--preset--spacing--30);
}

.accordion-item:last-of-type {
    margin-bottom: 0;
}

.accordion-heading * {
    pointer-events: none;
}

.accordion-heading {
    display: grid;
    grid-template-columns: repeat(2, auto);
    justify-content: space-between;
    align-items: center;
    grid-gap: var(--wp--preset--spacing--15);
    cursor: pointer;
    line-height: normal;
}

.accordion-heading h2 {
    line-height: inherit;
    font-size: var(--wp--preset--font-size--default);
    margin: 0;
}

.accordion-content * {
    font-size: var(--wp--preset--font-size--s);
}

.accordion-icon {
    display: flex;
    cursor: pointer;
    padding: 3.5px;
    height: 100%;
}

/* .accordion-icon-inner {
    position: relative;
    width: 15px;
    height: 15px;
    border-radius: 50rem;
    border: 1px solid #000000;
}

.accordion-icon-inner:before,
.accordion-icon-inner:after {
    content: '';
    display: block;
    background-color: #000000;
    position: absolute;
    top: 50%;
    left: 50%;
    transition: 250ms;
    width: 7.5px;
    height: 1px;
}

.accordion-icon-inner::before {
    transform: translateX(-50%);
} 

.accordion-item.is-open .accordion-icon-inner:before {
    transform: translateY(-50%) rotate(-90deg);
    opacity: 0;
}

.accordion-icon-inner:after {
    transform: translateX(-50%) rotate(90deg);
}
.accordion-item.is-open .accordion-icon-inner:after {
    transform: translateX(-50%) rotate(0);
} */

.accordion-content {
    max-height: 0;
    transition: max-height 150ms linear;
    overflow: hidden;
    max-width: 100%;
    height: fit-content;
}

.accordion-content-inner {
    padding-top: var(--wp--preset--spacing--10);
}

/* .accordion-menu .accordion-icon-inner {
    border-color: var(--wp--preset--color--base);
}

.accordion-menu .accordion-icon-inner:before, 
.accordion-menu .accordion-icon-inner:after {
    background-color: var(--wp--preset--color--base);
} */ 

/* Accordion menus */
@media (min-width: 769px) {
    .accordion-item.accordion-menu .accordion-heading {
        cursor: text;
    }
    .accordion-item.accordion-menu .accordion-content {
        max-height: unset;
    }

    .accordion-item.accordion-menu .accordion-icon {
        display: none;
    }
}

/* Block: FAQ
========================================================================== */
.faq {
    background-color: transparent;
    padding: 0;
    border: 1px solid #fff;
}

.faq .accordion-item {
    margin-bottom: 0;
    padding: var(--wp--preset--spacing--15) var(--wp--preset--spacing--20);
}

.faq .accordion-item.is-open {
    background-color: #fff;
}

.faq .accordion-item.is-open * {
    color: var(--wp--preset--color--contrast-1);
}

.faq .accordion-item:not(:last-of-type) {
    border-bottom: 1px solid var(--wp--preset--color--tertiary);
}

.accordion-heading h2 {
    line-height: inherit;
    font-size: var(--wp--preset--font-size--default);
    margin: 0;
    font-family: var(--wp--preset--font-family--body);
    letter-spacing: 0;
}

.faq .accordion-icon {
    padding: 0;
    display: block;
}

.faq .accordion-icon img {
    transition: all 150ms linear;
    filter: invert(0) brightness(100);
}

.faq .accordion-item.is-open .accordion-icon img {
    transform: rotate(-180deg);
}

.faq .accordion-icon-inner::before,
.faq .accordion-icon-inner::after {
    display: none;
}

.faq .accordion-icon-inner {
    border: none;
    border-radius: 0;
}

@media screen and (max-width: 599px) {
    .faq .accordion-item {
        padding: var(--wp--preset--spacing--15);
    }
}

/* ==========================================================================
Buttons
========================================================================== */
.wp-block-buttons {
    margin-top: var(--wp--preset--spacing--20);
    gap: var(--wp--preset--spacing--10);
}

button,
.wp-block-button__link {
    /* border: 1px solid transparent; */
    transition: all 150ms linear;
    font-size: 1.125rem !important;
}

/* Secondary
========================================================================== */
.is-style-secondary .wp-block-button__link {
    border-color: var(--wp--preset--color--contrast-3);
    background-color: transparent;
    color: var(--wp--preset--color--contrast-3);
    border-radius: 0;
}

.is-style-secondary .wp-block-button__link:hover,
.is-style-secondary .wp-block-button__link[data-selected] {
    border-color: var(--wp--preset--color--primary);
    background-color: var(--wp--preset--color--primary);
    color: var(--wp--preset--color--contrast-1);
}

.is-style-secondary.is-active .wp-block-button__link {
    border-color: var(--wp--preset--color--primary);
    background-color: var(--wp--preset--color--primary);
    color: var(--wp--preset--color--contrast-1);
}

/* Button outline
========================================================================== */
.is-style-outline .wp-block-button__link {
    background-color: transparent;
    border: 1px solid var(--wp--preset--color--contrast-2);
    color: var(--wp--preset--color--contrast-1);
}

.is-style-outline .wp-block-button__link:hover,
.is-style-outline .wp-block-button__link[data-selected] {
    border-color: var(--wp--preset--color--secondary);
    background-color: var(--wp--preset--color--secondary);
    color: var(--wp--preset--color--contrast-1);
}

.is-style-outline.is-active .wp-block-button__link {
    border-color: var(--wp--preset--color--secondary);
    background-color: var(--wp--preset--color--secondary); 
}

/* Button on background
========================================================================== */
.is-style-button-on-background .wp-block-button__link {
    background-color: var(--wp--preset--color--contrast-1);
    border: 1px solid var(--wp--preset--color--contrast-1);
    color: var(--wp--preset--color--contrast-3);
}

.is-style-button-on-background .wp-block-button__link:hover,
.is-style-button-on-background .wp-block-button__link[data-selected] {
    border-color: var(--wp--preset--color--contrast-1);
    background-color: transparent;
    color: var(--wp--preset--color--contrast-1);
}

/* ==========================================================================
Custom blocks and shortcodes
========================================================================== */
.qt-section.container-fullwidth {
	padding-right: 0;
	padding-left: 0;
}

/* Images 
========================================================================== */
.wp-block-image figcaption {
    margin-top: 1rem;
    font-size: var(--wp--preset--font-size--s);
}

.single .wp-block-post-featured-image {
    margin-bottom: var(--wp--preset--spacing--25);
}


/* Gutenberg styles
========================================================================== */
.qt-section .is-style-container-align-left {
    margin-left: 0;
}

.qt-section .is-style-container-align-right {
    margin-right: 0;
}

.is-style-ratio-landscape,
.is-style-ratio-landscape img {
    aspect-ratio: 3/2;
}

.is-style-ratio-square img {
    aspect-ratio: 1/1;
}

.is-style-ratio-portrait img {
    aspect-ratio: 4/5;
}

.is-style-full-width img,
.is-style-full-width a {
    width: 100%;
}

/* ==========================================================================
Forms
========================================================================== */

/* Text and fields
========================================================================== */
.wpcf7-form {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--wp--preset--spacing--10) var(--wp--preset--spacing--15);
}

.wpcf7-form * {
    text-align: left;
}

.wpcf7-form label {
    font-size: var(--wp--preset--font-size--s);
}

.wpcf7-form p {
    margin-bottom: unset;
    display: flex;
    flex-direction: column;
    grid-gap: var(--wp--preset--spacing--05);
} 

.wpcf7-form p:nth-of-type(n+5) {
    grid-column: 1/3;
}

.wpcf7-form .acceptance,
.wpcf7-form .acceptance a, 
.wpcf7-form .acceptance span {
    font-size: var(--wp--preset--font-size--s);
    line-height: normal;
    text-align: left;
    text-transform: initial;
    letter-spacing: initial;
    font-family: inherit;
    display: inline;
}

.wpcf7-form p span :is(select, textarea, input:not([type="checkbox"], [type="radio"])) {
    width: 100%;
    padding: 12px;
    color: inherit;
    font-family: inherit;
    font-size: var(--wp--preset--font-size--default);
    font-weight: inherit;
    margin: 0;
    border: 1px solid var(--wp--preset--color--tertiary);
    background-color: transparent;
    border-radius: 0;
}

.wpcf7-form p span :is(select, textarea, input):focus {
    outline: none;
}

select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: transparent;
    border: none;
    padding: 12px;
    border: 1px solid var(--wp--preset--color--contrast-3);
    margin: 0;
    width: 100%;
    font-family: inherit;
    font-size: initial;
    cursor: pointer;
    line-height: inherit;
    font-size: inherit;
    color: inherit;
    border-radius: 0;
    background: rgba(255, 255, 255, 0) url('../images/chevron-down.svg') no-repeat;
    background-position-x: 96.5%;
    background-position-y: 50%;
    background-size: 10px 10px;
}

select svg path {
    filter: invert(1);
}

.wpcf7-radio .wpcf7-list-item {
    display: grid;
    grid-template-columns: 2rem auto;
    grid-gap: var(--wp--preset--spacing--05);
    font-size: var(--wp--preset--font-size--s);
}

.wpcf7-list-item {
    margin-left: unset;
}

.wpcf7-form .hidden {
    display: none;
}

@media only screen and (max-width: 600px) {
    .wpcf7-form {
        grid-gap: 1.5rem;
    }

    .wpcf7-form p {
        grid-column: 1/3;
    }
}

/* Error message
========================================================================== */
.wpcf7-not-valid-tip,
.wpcf7 form .wpcf7-response-output {
    color: #dc3232;
    font-size: var(--wp--preset--font-size--s);
    font-weight: inherit;
    display: block;
    border: none;
    margin: 0;
    margin-top: var(--wp--preset--spacing--05);
    padding: 0;
    text-align: left;
    font-family: inherit;
}

.wpcf7 form .wpcf7-response-output {
    border: 1px solid #dc3232 !important;
    padding: 0 0.5em;
    color: #dc3232;
    width: fit-content;
}

.wpcf7 form .wpcf7-response-output:last-of-type {
    margin-top: 1em;
    grid-column: 1/-1;
}

.wpcf7 form.sent .wpcf7-response-output {
    border: 1px solid #46b450 !important;
    padding: 0 0.5em;
    color: #46b450;
}

/* Acceptance
========================================================================== */
input[type="checkbox"] {
    vertical-align: middle;
    margin-right: 0.5rem;
    margin-top: 0.05em;
    padding: 0.5rem !important;
}

.wpcf7-form .wpcf7-acceptance label {
    display: inline-block;
}

.wpcf7-form .wpcf7-acceptance .wpcf7-list-item {
    margin: unset;
}
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label a {
    font-size: var(--wp--preset--font-size--s);
}

/* Submit
========================================================================== */
.wpcf7-form .submit {
    display: flex;
    justify-content: flex-start;
    margin-top: 1rem;
}

input.wpcf7-submit {
    margin-top: 0;
}

.wpcf7-spinner {
    display: none;
}

.wpcf7-form .submit p {
    position: relative;
}

.wpcf7-form .submit p {
    background-image: ;
    z-index: 1;
    border-radius: 50rem;
}

.wpcf7-form .submit p::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-image: ;
    z-index: -1;
    transition: opacity 150ms linear;
    opacity: 0;
    border-radius: inherit;  
}

.wpcf7-form .submit p:hover::before {
    opacity: 1;
}

.wpcf7-form :is(input[type="submit"], input[type="submit"]:disabled),
.form-calendar :is(input[type="submit"], input[type="submit"]:disabled) {
    font-size: 1.125rem;
    letter-spacing: 0.015em;
    font-family: var(--wp--preset--font-family--heading);
    font-weight: 400;
    line-height: inherit;
    color: var(--wp--preset--color--contrast-1);
    padding: 0.625rem 1.25rem;
    transition: all 150ms linear;
    border: 1px solid transparent;
    cursor: pointer;
    border-radius: 0;
    background-color: var(--wp--preset--color--primary);
}

.wpcf7-form :is(input[type="submit"]:hover),
.form-calendar :is(input[type="submit"]:hover) {
    background-color: transparent;
    color: var(--wp--preset--color--contrast-3);
    border: 1px solid var(--wp--preset--color--contrast-3);
}

.wpcf7 .wpcf7-submit:disabled,
.wpcf7-form input[type="submit"]:disabled, 
.form-calendar input[type="submit"]:disabled {
    cursor: not-allowed;
}

/* @media only screen and (max-width: 510px) {
    .wpcf7-form p span :is(select, textarea, input:not([type="checkbox"])) {
        padding: 1.5rem 2rem;
    }
} */

/* External forms
========================================================================== */
input[type="checkbox"]:checked, input[type="radio"]:checked {
    background-color: var(--wp--preset--color--contrast-1);
    border-color: var(--wp--preset--color--contrast-1);
}

form#rule-optin-form div[data-lastpass-icon-root] {
    display: none;
}

form#rule-optin-form {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: var(--wp--preset--spacing--10) var(--wp--preset--spacing--15) ;
}  

form#rule-optin-form p {
    margin-bottom: 0;
    display: flex;
    flex-direction: column;
    gap: var(--wp--preset--spacing--05);
    color: var(--wp--preset--color--contrast-1);
}

form#rule-optin-form p:nth-of-type(2) {
    grid-column: 1/2;
}
form#rule-optin-form p:nth-of-type(3) {
    grid-column: 2/3;
}

form#rule-optin-form label {
    display: block;
    font-size: var(--wp--preset--font-size--s);
    color: var(--wp--preset--color--contrast-1);
}

form#rule-optin-form input, 
form#rule-optin-form textarea {
    border-radius: 0;
    box-shadow: none;
    padding: 12px;
    border: 1px solid var(--wp--preset--color--contrast-1);
    font-size: var(--wp--preset--font-size--default);
}

form#rule-optin-form .acceptance {
    flex-direction: row;
    align-items: baseline;
    font-size: var(--wp--preset--font-size--s);
    margin-top: var(--wp--preset--spacing--10);
}

form#rule-optin-form .email-check {
    flex-direction: row;
    align-items: center;
}

form#rule-optin-form .submit {
    grid-column: 1 / -1;
    max-width: fit-content;
    background-color: var(--wp--preset--color--primary);
    color: var(--wp--preset--color--contrast-1);
    font-family: var(--wp--preset--font-family--heading);
    font-weight: 400;
    border: 1px solid transparent;
    border-radius: 0;
    padding-top: 0.625rem;
    padding-right: 1rem;
    padding-bottom: 0.625rem;
    padding-left: 1rem;
    text-decoration: none;
    line-height: inherit;
    cursor: pointer;
    transition: all 150ms linear;
}

form#rule-optin-form .submit:hover {
    background-color: transparent;
    color: var(--wp--preset--color--contrast-1);
    border-color: var(--wp--preset--color--contrast-1);
}

@media only screen and (max-width: 510px) {
    form#rule-optin-form p:nth-of-type(2),
    form#rule-optin-form p:nth-of-type(3) {
        grid-column: 1/-1;
    }
}

/* Register products */
.form-register-product p:first-of-type {
    grid-column: 1 / -1;
}

.form-register-product p:nth-of-type(n + 6) {
    grid-column: 1 / -1;
}

/* Subscribe newsletter */
form.form-subscribe-newsletter p {
    grid-column: 1 / -1;  
}

.form-subscribe-newsletter .submit {
    max-width: 100%;
}

/* ==========================================================================
Footer
========================================================================== */
footer .accordion-heading {
    font-family: var(--wp--preset--font-family--heading);
    font-size: var(--wp--preset--font-size--m);
}

footer .has-heading-font-family {
    line-height: normal;
}

/* ==========================================================================
WP dashboard and Gutenberg editor
========================================================================== */

/* ==========================================================================
/* Admin bar
========================================================================== */


/* ==========================================================================
Patterns
========================================================================== */

/* CTA - Image right
========================================================================== */
.is-style-cta-image-right .grid {
    grid-gap: 0;
}

.is-style-cta-image-right .qt-section__inner {
    padding: 0;
}

.is-style-cta-image-right .is-style-text {
    padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--25);
}

.is-style-cta-image-right .is-style-image figure,
.is-style-cta-image-right .is-style-image img {
    height: 100%;
    width: 100%;
}

@media screen and (max-width: 670px) {
    .is-style-cta-image-right .is-style-text {
        padding: var(--wp--preset--spacing--20) var(--wp--preset--spacing--15);
    }

    .is-style-cta-image-right .is-style-image {
        grid-row: -1;
    }
}

/* CTA - Image left
========================================================================== */
.is-style-cta-image-left .grid {
    grid-gap: 0;
}

.is-style-cta-image-left .qt-section__inner {
    padding: 0;
}

.is-style-cta-image-left .is-style-text {
    padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--25);
}

.is-style-cta-image-left .is-style-image figure,
.is-style-cta-image-left .is-style-image img {
    height: 100%;
    width: 100%;
}

@media screen and (max-width: 670px) {
    .is-style-cta-image-left .is-style-text {
        padding: var(--wp--preset--spacing--20) var(--wp--preset--spacing--15);
    }
}    

/* CTA - Image left
========================================================================== */
.is-style-cta-image-left .grid {
    grid-gap: 0;
}

.is-style-cta-image-left .qt-section__inner {
    padding: 0;
}

.is-style-cta-image-left .is-style-text {
    padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--25);
}

.is-style-cta-image-left .is-style-image figure,
.is-style-cta-image-left .is-style-image img {
    height: 100%;
    width: 100%;
}

@media screen and (max-width: 670px) {
    .is-style-cta-image-left .is-style-text {
        padding: var(--wp--preset--spacing--20) var(--wp--preset--spacing--15);
    }
}   

/* ==========================================================================
CPT
========================================================================== */

/* Support pages
========================================================================== */
.support-pages .grid {
    grid-gap: var(--wp--preset--spacing--15);
}

@media (max-width: 510px) {
    .support-pages .grid {
        grid-gap: var(--wp--preset--spacing--10);
    }
}

.card-support-page {
    background-color: var(--wp--preset--color--quaternary);
    border: 1px solid transparent;
    border-radius: 6px;
    padding: 1.5rem 0.75rem;
    text-align: center;
}

.card-support-page:hover {
    background-color: var(--wp--preset--color--secondary);
}

/* Manuals & files
========================================================================== */
.files-list {
    list-style-type: none;
    padding-left: 0;
}

.files-list li {
    display: flex;
    grid-gap: var(--wp--preset--spacing--05);
}

.files-list span {
    vertical-align: middle;
}

.files-list a {
    text-decoration: underline;
    font-size: var(--wp--preset--font-size--s);
}

.files-list img {
    filter: invert(88%) sepia(60%) saturate(7499%) hue-rotate(336deg) brightness(107%) contrast(97%);
}

/* Rows */
.wp-block-group.is-nowrap {
    grid-gap: var(--wp--preset--spacing--10);
}

p ~ .wp-block-group {
    margin-top: var(--wp--preset--spacing--20);
}

/* ==========================================================================
Footer
========================================================================== */
footer {
    background-color: var(--wp--preset--color--primary);
}

footer .grid {
    grid-gap: var(--wp--preset--spacing--25) var(--wp--preset--spacing--40);
}

footer :is(li, a, p) {
    color: var(--wp--preset--color--contrast-1);
    text-decoration: none;
    line-height: 2;
}

footer a:hover {
    color: var(--wp--preset--color--contrast-2);
    text-decoration: underline;
}

.footer-menu .menu {
    display: block;
    margin-top: var(--wp--preset--spacing--05);
}

.footer-menu .menu * {
    font-size: var(--wp--preset--font-size--s);
}

footer .wp-block-site-logo img {
	max-width: 200px;
}

.is-style-footer-bottom .qt-section__inner {
    border-top: 1px solid var(--wp--preset--color--contrast-1);
    padding-top: var(--wp--preset--spacing--25);
}

/* Payment and delivery logos
========================================================================== */
.payment-delivery-alternatives {
    display: flex;
    flex-wrap: wrap;
    grid-gap: var(--wp--preset--spacing--15);
    justify-content: flex-end;
}

.payment-delivery-alternatives img {
    filter: invert(1) brightness(0);
}

@media (max-width: 670px) {
	.payment-delivery-alternatives {
		justify-content: flex-start;
	}	
}

/* Social icons (ej footer?)
========================================================================== */
.social-link {
    text-align: center;
}

.social-link img {
    margin-bottom: var(--wp--preset--spacing--05);
}

.social-link__heading {
    font-size: var(--wp--preset--font-size--m);
    font-weight: 600;
    margin-bottom: 0;
}

/* WPML Currency Selector
========================================================================== */
.wcml_currency_switcher li {
    background-color: #000;
}
.wcml_currency_switcher li:hover,
.wcml_currency_switcher li:focus,
.wcml_currency_switcher li a:hover {
    background-color: var(--wp--preset--color--primary);
	color: #000;
}

.wcml-dropdown-click.product.wcml_currency_switcher {
	max-width: max-content;
	margin: 0;
}

/* WPML Language selector */
.wpml-language-switcher-block.is-layout-flex {
	max-width: max-content;
}
