: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: var(--wp--preset--color--base);
	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 var(--wp--preset--color--tertiary);
}

.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-1);
}

/* 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--white);
}

.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;
}

.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-1);
}

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-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;
}

@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;
}

.qt-search__input {
	font-size: 1rem;
	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;
}

.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-1);
	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;
}

.wp-block-button__link:hover {
	border-color: var(--wp--preset--color--contrast-1);
}

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

/* Paddings and margins
========================================================================== */
/* .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
========================================================================== */
/* 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);
}

.grid .qt-container:not(:has(.woo-menu)) {
	overflow: hidden;
	word-break: break-word;
}

/* 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 slider
========================================================================== */
.qt-section.is-style-hero {
	padding-bottom: 0;
}

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

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

.block-heroslider img {
	max-width: 100%;
	height: auto;
	object-fit: cover;
	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: var(--wp--preset--color--quaternary);
	padding: 0;
}

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

.faq .accordion-item.is-open {
	background-color: var(--wp--preset--color--secondary);
}

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

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

.faq .accordion-icon img {
	transition: 150ms all linear;
}

.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: color .2s cubic-bezier(0.23, 1, 0.320, 1), background-color .2s cubic-bezier(0.23, 1, 0.320, 1);
}

/* Secondary
========================================================================== */
.is-style-secondary .wp-block-button__link {
	border-color: var(--wp--preset--color--quaternary);
	background-color: var(--wp--preset--color--quaternary);
	color: var(--wp--preset--color--contrast-1);
	border-radius: 0.5rem;
}

.is-style-secondary .wp-block-button__link:hover,
.is-style-secondary .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-secondary.is-active .wp-block-button__link {
	border-color: var(--wp--preset--color--secondary);
	background-color: var(--wp--preset--color--secondary);
}

/* 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--base);
	border: 1px solid var(--wp--preset--color--base);
	color: var(--wp--preset--color--contrast-1);
}

.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--primary);
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
}

/* ==========================================================================
Custom blocks and shortcodes
========================================================================== */

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

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

/* 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: 3/4;
}

/* ==========================================================================
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: initial;
	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: var(--wp--preset--color--white);
	border: none;
	padding: 12px;
	border: 1px solid var(--wp--preset--color--tertiary);
	margin: 0;
	width: 100%;
	font-family: inherit;
	font-size: initial;
	cursor: pointer;
	line-height: inherit;
	font-size: inherit;
	border-radius: 0;
	background: rgba(255, 255, 255, 1) url('../images/chevron-down.svg') no-repeat;
	background-position-x: 96.5%;
	background-position-y: 50%;
	background-size: 10px 10px;
}

.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: pink;
	z-index: 1;
	border-radius: 50rem;
}

.wpcf7-form .submit p::before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-image: pink;
	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: var(--wp--preset--font-size--default);
	font-weight: 500;
	line-height: inherit;
	color: var(--wp--preset--color--white);
	padding: 0.625rem 1.25rem;
	transition: all 150ms linear;
	border: none;
	cursor: pointer;
	border-radius: 50px;
	background-color: var(--wp--preset--color--primary);
}

.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: 0.75rem;
	}
}

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

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);
}

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

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--tertiary);
	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--white);
	font-weight: 500;
	border: 1px solid transparent;
	border-radius: 50px;
	padding-top: 0.625rem;
	padding-right: 1rem;
	padding-bottom: 0.625rem;
	padding-left: 1rem;
	text-decoration: none;
	line-height: inherit;
	cursor: pointer;
}

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-register-product p {
		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
========================================================================== */

/* ==========================================================================
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(75%) sepia(12%) saturate(605%) hue-rotate(158deg) brightness(90%) contrast(80%);
}

/* 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--base);
	text-decoration: none;
	line-height: 2;
}

footer a:hover {
	color: var(--wp--preset--color--base);
	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 {
	filter: brightness(0) invert(1);
	max-width: 200px;
}

footer img {
	filter: brightness(100);
}

.is-style-footer-bottom .qt-section__inner {
	border-top: 1px solid var(--wp--preset--color--base);
	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;
}

@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;
}