/*
Theme Name: FrauRaum care
Theme URI: https://www.frauraum-care.de/
Author: bavariansocialclub
Author URI: https://bavariansocialclub.de
Description: FrauRaum care - Block Theme
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8
Version: 1.1.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: frauraum
Tags: full-site-editing, 
*/

/* 
---------------------------------------------
 Smoothing everything up
---------------------------------------------
*/
* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@media screen and (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

html {
    interpolate-size: allow-keywords;
    scroll-padding-top: 80px;
}
@media (min-width: 782px) {
    html {
        scroll-padding-top: 80px;
    }
}


/* 
---------------------------------------------
  Site Blocks: Remove Spacing 
  between header, content and footer
---------------------------------------------
*/
:where(.wp-site-blocks)>* {
    margin-block-start: 0;
}


/*
-------------------------------------------------------------
 Navigation Block: Breakpoint
-------------------------------------------------------------
*/

@media screen and (max-width: 1023px) {
    /* hamburger button */
    .wp-block-navigation__responsive-container-open  {
        display: block !important;
    }

    /* full menu */
    .wp-block-navigation__responsive-container:not(.is-menu-open.has-modal-open) {
        display: none !important;
    }

    /* Align Burger Icon */
    .has-header-menu--main {
        width: 100%;
        justify-content: space-between;
    }

    .hide-in-mobile-menu {
        display: none!important;
    }

}
@media screen and (min-width: 1024px) {
    .show-in-mobile-menu {
        display: none!important;
    } 
}



/*
-------------------------------------------------------------
 Sticky Header

 Structure:
    .is-header
        .is-header--inner
            .is-header--logo
            .is-header--menu
                .is-header--navi
                    .is-mobile--link
                    .is-mobile--language
                .is-header--buttons
                .is-header--link
                .is-header--language
 -------------------------------------------------------------
*/
.is-header {
    position: absolute;
    top: 0;
    z-index: 100;
    width: 100%;
}
.admin-bar .is-header {
    top: 32px;
}

.is-header--menu {
    display: flex;
    flex-direction: row;
    flex-flow: wrap-reverse;
    gap: var(--wp--preset--spacing--rem-0100);
    justify-content: flex-end;
    align-items: center;
    /* max-width: 1000px; */
}
.is-header--navi a,
.is-header--buttons a {
    line-height: 24px;
}

/* Icons */

:is(.is-button--contact, .is-button--date) {
    display: none!important;
}
:is(.is-button--contact, .is-button--date) a {
    width: 1.5rem;
    height: 1.5rem;
}
.is-button--contact a::before,
.is-button--date a::before {
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    width: 1.5rem;
    height: 1.5rem;
    transform: translate(-50%, -50%);
    content: "";
    background: url(assets/img/icons/icon-contact.svg) no-repeat 50% 50%; 
    background-size: contain;
}

.is-button--date a::before {
    background-image: url(assets/img/icons/icon-calendar-lavender.svg);
}
:where(.is-button--contact, .is-button--date) span {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

/* mobile link/languageswitcher */
:is(.is-mobile--link, .is-mobile--language, .wp-block-navigation-item.lang-item) {
    display: none!important;
}

/* narrow screens */

@media (max-width: 1296px) {
    .is-header--menu {
        max-width: 800px;
        row-gap: 10px;
    }
    .is-header--navi .wp-block-navigation {
        gap: 14px;
    }
    :is(.is-button--contact, .is-button--date) {
        display: block!important;
    }
    .is-header--buttons { 
        order: 1;
        line-height: 1rem;
    }
    .is-header--buttons > .wp-block-button { 
        display: none;
    }
}
@media (min-width: 1070px) and (max-width: 1296px) {
    .is-header--navi .wp-block-navigation-item:not(.is-button--contact, .is-button--date) {
        margin-right: 10px;
    }
}

/* Sticky Menu */

@keyframes fadein {
    0% {
        opacity: 0;
        transform: translateY(-100%);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }

}

.has-sticky-menu .is-header {
    position: fixed;
    background: var(--wp--preset--color--white);
    padding-top: var(--wp--preset--spacing--rem-0100);
    padding-bottom: var(--wp--preset--spacing--rem-0100);
    animation: fadein 0.3s ease-out forwards;
}
.has-sticky-menu .is-header--logo {
    padding: 0!important;
    border-radius: 0!important;
}
.has-sticky-menu .custom-logo {
    width: 156px;
    height: 48px;
}
.has-sticky-menu .is-header--menu {
    max-width: none;
}
.has-sticky-menu .is-header--link,
.has-sticky-menu .is-header--language {
    display: none;
}

/* Mobile Menu */
@media (max-width: 1023px) {
    /* Mobile Default */
    .is-header {
        position: fixed;
        height: 81px;
        padding-top: 0;
        padding-bottom: 0;
        background: var(--wp--preset--color--white);
        animation: fadein 0.3s ease-out forwards;
    }
    .is-header > div {
        height: 100%;
        align-items: center;
    }
    .is-header--logo {
        padding: 0!important;
        border-radius: 0!important;
    }
    .custom-logo {
        width: 156px;
        height: 48px;
    }
    .is-header--menu {
        max-width: none;
    }
    .is-header--navi {
        padding: 0!important;
    }
    .is-header--link,
    .is-header--language {
        display: none!important;
    }
    /* Button Termine  */
    .is-header--buttons { 
        position: absolute;
        top: 16.5px;
        right: 80px;
        z-index: 100001;
    }
    .is-header--buttons .is-style-calendar { 
        display: block;
    }
    .is-header--buttons .is-style-calendar a {
        width: 48px;
        height: 48px;
        padding: 0;
        background: var(--wp--preset--color--white);
        border: 1.5px solid var(--wp--preset--color--lavender);
    }
    .is-header--buttons .is-style-calendar a::before {
        left: 50%;
        transform: translate(-50%, -50%);
        background-image: url(assets/img/icons/icon-calendar-lavender.svg);
    }
    .is-header--buttons .is-style-calendar strong { 
        clip: rect(1px, 1px, 1px, 1px);
        position: absolute;
        height: 1px;
        width: 1px;
        overflow: hidden;
    }
    /* Mobile Open */
    .has-modal-open .is-header {
        height: 100vh;
        height: 100dvh;
    }
    .has-modal-open .is-header > div {
        height: 81px;
    }
    .has-modal-open :where(.wp-block-navigation__responsive-close, .wp-block-navigation__responsive-dialog, .wp-block-navigation__responsive-container-content) {
        height: 100%;
    }
    .has-modal-open .is-header--navi .wp-block-navigation__container {
        width: 100%;
        height: 100%;
        justify-content: center!important;
        align-items: center!important;
    }
    /* .has-modal-open .is-header--link {
        display: block!important;
    } */
    .has-modal-open .is-mobile--link {
        position: fixed;
        top: calc(100dvh - 4rem);
        left: 50%;
        z-index: 1000000;
        transform: translateX(-50%);
        display: inline-block!important;
        font-size: var(--wp--preset--font-size--meta) !important;
        font-weight: 500!important;
        text-align: center;
    } 
    /* .has-modal-open .is-header--language {
        position: absolute;
        top: 7rem;
        right: 1.5rem;
        z-index: 100001;
        display: flex!important;
        border: 1.5px solid var(--wp--preset--color--lavender);
        font-size: var(--wp--preset--font-size--menu) !important;
        padding: 0.75rem 1.5rem !important;
        border-radius: var(--wp--preset--border-radius--medium) !important;
        gap: var(--wp--preset--spacing--rem-0100);
    } */

    /* mobile languageswitcher */
    .has-modal-open .wp-block-navigation-item.lang-item {
        position: fixed;
        top: 125px;
        right: 48px;
        z-index: 1;
        display: block!important;
    }
    .has-modal-open .wp-block-navigation-item.lang-item:not(.current-lang) a {
        opacity: 0.25;
    }
    .has-modal-open .wp-block-navigation-item.lang-item-de {
        right: 84px;
    }
    .has-modal-open .wp-block-navigation-item.lang-item-de::before {
        position: absolute;
        top: -12px;
        left: -24px;
        z-index: 0;
        display: block;
        width: 100px;
        height: 46px;
        content: '';
        border: 1.5px solid var(--wp--preset--color--lavender);
        border-radius: var(--wp--preset--border-radius--medium);
        pointer-events: none;
        opacity: 1;
    }

    .has-modal-open .wp-block-navigation a {
        /* font-size: var(--wp--preset--font-size--title-medium)!important; */
        color: var(--wp--preset--color--lavender)!important;
    }
    .is-button--contact {
        margin-top: 4rem;
    }
    :where(.is-button--contact, .is-button--date) span {
        clip: unset;
        position: static;
        height: auto;
        width: auto;
        overflow: visible;
    }
    :is(.is-button--contact, .is-button--date) a {
        width: auto;
        padding: 0.75rem 1.5rem 0.75rem 3.5rem!important;
        border: 1.5px solid transparent;
        border-radius: var(--wp--preset--border-radius--medium);
    }
    .is-button--date a {
        border-color: var(--wp--preset--color--lavender);
    }
    .is-button--contact a::before,
    .is-button--date a::before {
        top: 50%;
        left: 1.5rem;
        transform: translateY(-50%);
    }

}


/*
-------------------------------------------------------------
 Mobile Navigation: Logo / Buttons / Styling 
-------------------------------------------------------------
*/
/* Logo */
.wp-block-site-logo {
    position: relative;
    z-index: 100001;
    min-width: 200px;
}

/* Buttons */
.wp-block-navigation__responsive-container-open {
    width: 48px;
    height: 48px;
    background: var(--wp--preset--color--lavender) url(assets/img/icons/icon-mobile-default.svg) no-repeat 50% 50%;
    background-size: 24px 24px;
    border-radius: var(--wp--preset--border-radius--medium);
}   
.wp-block-navigation__responsive-container-close {
    top: 16px;
    right: 24px;
    width: 48px;
    height: 48px;
    background: var(--wp--preset--color--lavender) url(assets/img/icons/icon-mobile-active.svg) no-repeat 50% 50%;
    background-size: 24px 24px;
    border-radius: var(--wp--preset--border-radius--medium);
}   
.wp-block-navigation__responsive-container-open svg,
.wp-block-navigation__responsive-container-close svg {
    display: none;
}   

/* 
---------------------------------------------
 List
---------------------------------------------
*/
ul {
    padding-left: var(--wp--preset--spacing--rem-0150);
}


/* 
---------------------------------------------
  Icons
---------------------------------------------
*/
.has-icon-time {
    position: relative;
    padding-left: 2.25rem;
}
.has-icon-time::before {
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 1.5rem;
    height: 1.5rem;
    transform: translateY(-50%);
    content: '';
    background: url(assets/img/icons/icon-time.svg) no-repeat 0 0;
    background-position: contain;
}

/* 
---------------------------------------------
  Block: Cover
---------------------------------------------
*/
/* Hero */
.is-hero.wp-block-cover {
    align-items: flex-end;
    overflow: visible;
    min-height: 640px!important;
    height: 40vw;
    max-height: 920px;
    margin-bottom: 64px;
}
.is-hero .wp-block-cover__inner-container  {
    margin-bottom: -64px;
}
/*  Hero @ Home */
.home .is-hero.wp-block-cover {
    height: calc(100vh - var(--wp--preset--spacing--rem-0400));
}
.admin-bar.home .is-hero.wp-block-cover {
    height: calc(100vh - var(--wp--preset--spacing--rem-0400) - var(--wp-admin--admin-bar--height));
}

@media (max-width: 781px) {
    .is-hero.wp-block-cover {
        min-height: 412px!important;
        height: auto!important;
        max-height: none;
        padding-top: 412px!important;
    }
    .is-hero.wp-block-cover .wp-block-cover__image-background {
        max-height: 436px;
    }
}

/* 
---------------------------------------------
  Block: Image Caption
---------------------------------------------
*/
.wp-block-image {
    position: relative;
}
.wp-block-image figcaption {
    position: absolute;
    right: 20px;
    bottom: 20px;
    margin: 0;
    padding: var(--wp--preset--spacing--rem-0050) var(--wp--preset--spacing--rem-0075);
    border-radius: var(--wp--preset--border-radius--medium);
    background-color: var(--wp--preset--color--lavender);
    color: var(--wp--preset--color--white);
    font-size: var(--wp--preset--font-size--menu);
}

/* 
---------------------------------------------
  Block: Video / Youtube
---------------------------------------------
*/
.wp-block-embed-youtube {
    border-radius: 12px;
    overflow: hidden;
}

/* 
---------------------------------------------
  Block: Teaser - Text above offset Image 
---------------------------------------------
*/
.is-teaser-wrap {
    overflow: hidden;
}

/* Teaser */
.is-teaser {
    position: relative;
    min-height: 640px;
}
/* Teaser Image: */
.is-teaser .wp-block-image {
    position: absolute;
    width: 63.75%;
    left: -87px;
    height: 640px;
}
.is-teaser .wp-block-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center right;
}
/* odd */
:nth-child(2n of .is-teaser) .wp-block-image {
    left: auto;
    right: -87px ;
}
:nth-child(2n of .is-teaser) .wp-block-image img {
    object-position: center left;
}
/* Teaser Content */
.is-teaser .wp-block-column:last-child {
    flex-basis: 25%;
    max-width: 664px;
}
/* odd */
:nth-child(2n of .is-teaser) .wp-block-column:first-child {
    flex-basis: 25%;
    max-width: 664px;
}
:nth-child(2n of .is-teaser) .wp-block-column:last-child {
    flex-basis: 0;
    max-width: none;
}
/* Button */
.is-teaser .wp-block-button__link {
    width: fit-content;
    margin-left: -1.5rem;
}

@media (max-width: 781px) {
    .is-teaser .wp-block-image {
        position: static;
        width: auto;
        height: auto;
        margin-left: calc(var(--wp--style--root--padding-right) * -1);
        margin-right: calc(var(--wp--style--root--padding-right) * -1);
    }
    .is-teaser .wp-block-columns {
        gap: 0;
        margin-top: calc(var(--wp--preset--spacing--rem-0400) * -1);
    }

}


/* 
---------------------------------------------
  Swiper: Navi, etc. 
---------------------------------------------
*/
.is-slider-wrap {
    position: relative;
    overflow: hidden;
    height: calc(35.29vw + 4.5rem);
    max-height: 552px;
}
.is-slider-wrap .wp-swiper {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    /* basis 1360 */
    width: calc(3 * 48.82% + 64px); 
    /* basis 1600 */
    width: calc(3 * 41.5% + 64px); 
    max-width: 2056px;
    padding-bottom: 4.5rem;
}
/* Slide */
.swiper-slide {
    /* Basis 1600 */
    height: 30vw!important;
    max-height: 480px;
    border-radius: var(--wp--preset--border-radius--medium);
}
/* Navi */
.wp_swiper__navigation {
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 100%;
    max-width: 616px;
    height: 40px;
    transform: translateX(-50%);
}
.wp_swiper__navigation svg {
    display: none;
}
/* Navi Icons */
.swiper-button-next, 
.swiper-button-prev {
    width: 40px;
    z-index: 10;
}
.swiper-button-next {
    right: 24px;
} 
.swiper-button-prev {
    left: 24px;
}
.swiper-button-next::after, 
.swiper-button-prev::after {
    display: block;
    width: 40px;
    height: 40px;
    content: '';
    background: url(assets/img/icons/icon-arrow-lavender.svg) no-repeat 50% 50%;
    background-size: contain;
}
.swiper-button-prev::after {
    transform: rotate(180deg);
}

/* :hover */
.swiper-button-next:hover, 
.swiper-button-prev:hover,
.swiper-button-next:active, 
.swiper-button-prev:active {
    opacity: 1
}
.swiper-button-next:focus-visible, 
.swiper-button-prev:focus-visible {
    border-radius: 2px;
    outline: solid 2px var(--wp--preset--color--dark);
    outline-offset: 3px;
}

/* Pagination */
.swiper-pagination.swiper-pagination-bullets.swiper-pagination-horizontal {
    bottom: 6px;
    left: 50%;
    width: 400px;
    height: 26px;
    transform: translateX(-50%);
}
.swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    border: 1.5px solid var(--wp--preset--color--lavender);
    background: var(--wp--preset--color--white);
    opacity: 1;
}
.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-horizontal.swiper-pagination-bullets {
  & .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap,4px);
  }
}
.swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: var(--wp--preset--color--lavender);
}

@media (max-width: 781px) {
    .is-slider-wrap {
        height: calc(412px + 4.5rem);
    }
    .is-slider-wrap .wp-swiper {
        position: static;
        width: calc(100% - 4rem); 
        margin-left: 1.5rem;
        margin-right: 1.5rem;
        transform: none;
    }
    /* Slide */
    .swiper-slide {
        width: calc(100% - 48px - 15px);
        height: 412px!important;
    }
}
@media (min-width: 2400px) {
    .is-slider-wrap .wp-swiper {
        width: calc(5 * 664px + 4 * 32px); 
        max-width: none;
    }
}

/*
-------------------------------------------------------------
 Block: Details - Custom Icon
-------------------------------------------------------------
*/
details {
    position: relative;
}
summary {
    list-style: none;
}
summary::-webkit-details-marker {
    display: none;
}
details summary::before {
    position: absolute;
    top: 1.25rem;
    right: var(--wp--preset--spacing--rem-0200);
    display: block;
    width: 24px;
    height: 24px;
    content: '';
    background: url(assets/img/icons/icon-plus-lavender.svg) no-repeat 50% 50%;
    background-size: contain;
}
details[open] summary::before {
    background-image: url(assets/img/icons/icon-minus-lavender.svg);
}

@media (max-width: 781px) {
    .has-faq {
        margin-left: calc(var(--wp--style--root--padding-left) * -1) !important;
        margin-right: calc(var(--wp--style--root--padding-right) * -1) !important;
    }
    .has-faq details {
        border-radius: 0!important;
    }
}


/*
-------------------------------------------------------------
 Pattern: Accordion
-------------------------------------------------------------
*/
.is-accordion.is-open {
    background-color: var(--wp--preset--color--lavender-dark)!important;
}
.is-accordion:hover {
    background-color: var(--wp--preset--color--lavender-darker)!important;
}
.is-accordion--header {
    position: relative;
    cursor: pointer;
}
.is-accordion--header::before {
    position: absolute;
    top: 27px;
    right: var(--wp--preset--spacing--rem-0200);
    display: block;
    width: 1.5rem;
    height: 1.5rem;
    content: '';
    background: url(assets/img/icons/icon-plus-white.svg) no-repeat 50% 50%;
    background-size: contain;
}
.is-accordion.is-open .is-accordion--header::before {
    background-image: url(assets/img/icons/icon-minus-white.svg);
}
.is-accordion:not(.is-open) .is-accordion--body {
    display: none;
}
.is-accordion.is-open .is-accordion--body {
    display: flex;
}

/* Content */
.is-accordion--header .wp-block-column:last-child p:first-child {
    padding-top: 2px;
}
.is-accordion--header .wp-block-column:last-child p:last-child {
    flex-shrink: 0;
}

@media (max-width: 781px) {
    .is-accordion--header {
        padding-right: var(--wp--preset--spacing--rem-0400)!important;
        gap: var(--wp--preset--spacing--rem-0075)!important;
    }
}

/*
-------------------------------------------------------------
 Plugin: Polylang
-------------------------------------------------------------
*/
.wp-block-polylang-language-switcher {
    display: flex;
    gap: var(--wp--preset--spacing--rem-0025);;
    margin: 0;
    padding: 0;
    list-style: none;
}
.wp-block-polylang-language-switcher .lang-item:not(.current-lang) {
    opacity: 0.25;
}
.has-modal-open .wp-block-polylang-language-switcher {
    gap: var(--wp--preset--spacing--rem-0100);;
}

[lang="de-DE"] .is-navi-en,
[lang="en-GB"] .is-navi-de {
    display: none;
}


/*
-------------------------------------------------------------
 Plugin: Exovid Youtube Video
-------------------------------------------------------------
*/
.exovid-wrapper {
    border-radius: var(--wp--preset--border-radius--medium);
    min-height: 315px;
}
.exovid-wrapper .exovid-mask {
    background: url(assets/img/emsela_video_teaserbild_2x.webp) no-repeat 50% 50%!important;
    background-size: cover;
}
.exovid-wrapper .exovid-mask-content .exovid-caption {
    box-sizing: border-box;
    position: absolute;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 524px;
    padding: 0 var(--wp--preset--spacing--rem-0050);
    font-size: var(--wp--preset--font-size--menu)!important;
    color: var(--wp--preset--color--black);
}
.exovid-wrapper .exovid-mask-content .exovid-btn {
    position: relative;
    padding-left: 3.5rem;
    padding-top: var(--wp--preset--spacing--rem-0075);
    padding-right: var(--wp--preset--spacing--rem-0150);
    padding-bottom: var(--wp--preset--spacing--rem-0075);
    background-color: var(--wp--preset--color--lavender)!important;;
    border: none!important;
    border-radius: var(--wp--preset--border-radius--medium);
    color: var(--wp--preset--color--white);
    font-family: var(--wp--preset--font-family--poppins);
    font-size: var(--wp--preset--font-size--small);
    font-weight: 600;
    line-height: 2em;
    text-decoration: none;
    text-transform: inherit;
}
.exovid-wrapper .exovid-mask-content .exovid-btn::before {
    position: absolute;
    top: 50%;
    left: 1.5rem;
    display: block;
    width: 1.5rem;
    height: 1.5rem;
    transform: translateY(-50%);
    content: "";
    background: url(assets/img/icons/icon-calendar.svg) no-repeat 0 0; 
    background-size: contain;
}
.exovid-wrapper .exovid-mask-content .exovid-btn:hover {
    background-color: var(--wp--preset--color--lavender-darker)!important;;
}
.exovid-wrapper .exovid-mask-content .exovid-btn:active {
    background-color: var(--wp--preset--color--lavender-dark)!important;;
}
.exovid-hints {
    display: none;
}
/*
-------------------------------------------------------------
 Footer: Kontakt moble override
-------------------------------------------------------------
*/
@media (max-width: 781px) {
    .has-contact-form {
        margin-left: -1.5rem;
        margin-right: -1.5rem;
        padding: 4rem 1.5rem!important;
        border-radius: 0!important;
    }
}

/*
-------------------------------------------------------------
 Formular
-------------------------------------------------------------
*/
/* wpcf7 - normalize, variables */
.wpcf7 {
    --gap-input: 24px;
    --gap-radio: 40px;
    --radius: var(--wp--preset--border-radius--medium);
    --font-family: var(--wp--preset--font-family--poppins);
    --font-size: var(--wp--preset--font-size--small);
    --font-size-alert: var(--wp--preset--font-size--meta);
    --font-size-label: 10px;
    --line-height: 2rem;
    --color-default: var(--wp--preset--color--black);
    --color-active: var(--wp--preset--color--lavender);
    --color-border: var(--wp--preset--color--white);
    --color-light: var(--wp--preset--color--white);
    --color-alert: var(--wp--preset--color--red);
    --color-success: var(--wp--preset--color--beige);
    --input-padding: 0.75rem 1.5rem ;
}
.wpcf7 p {
    margin: 0;
}
.wpcf7-list-item {
    margin: 0;
}
.input-wrap br {
    display: none;
}

/* Fieldset */
fieldset {
    width: 100%;
    border: none;
    padding: 0;
}
fieldset + fieldset {
    margin-block-start: var(--wp--preset--spacing--rem-0350);
}

/* Positioning + Grid */
/* Columns */
.input-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-input);
}
.col-s { flex-basis: calc((50% - calc(var(--gap-input) * 1.5)) * 0.38); flex-grow: 1;}
.col-m { flex-basis: calc((50% - calc(var(--gap-input) * 1.5)) * 0.62); flex-grow: 1;}
.col-l { flex-basis: calc((100% - var(--gap-input)) * 0.5); flex-grow: 1;}
.col-xl { flex-basis: 100%; flex-grow: 1;}

@media (max-width: 1023px) {
    .wpcf7 {
        --gap-input: 24px;
        --gap-radio: 40px;
    }
    fieldset .has-background {
        padding: var(--wp--preset--spacing--rem-0150) var(--wp--preset--spacing--rem-0100);
    }    
    .col-s,
    .col-m,
    .col-l,
    .col-xl { flex-basis: 100%; }
}

.flex-col {
    display: flex;
    flex-direction: column;
}
.flex-col > .input-box:not(:first-child) {
    margin-top: var(--gap-input);
}
.flex-col > p:empty {display: none;}

/* Radios */
.wpcf7-form-control.wpcf7-radio {
    display: flex;
    gap: var(--gap-radio);
}
/* Checkboxes */
.wpcf7-form-control.wpcf7-acceptance {
    display: block;
    padding-bottom: 1.5rem;
    font-size: var(--font-size-alert);
    line-height: 1.6;
}
.wpcf7-form-control-wrap:last-child .wpcf7-acceptance {
    padding-bottom: 0;
}

/* Form Fields */
/* Input */
input {
    box-sizing: border-box;
    border: 2px solid var(--color-border);
}
/* Text */
input:not([type="checkbox"], [type="radio"], [type="submit"]),
textarea {
    width: 100%;
    border-radius: var(--radius);
    padding: var(--input-padding);
    font-family: var(--font-family);
    font-size: var(--font-size);
    line-height: var(--line-height);
    color: var(--color-default);
}
input:not([type="checkbox"], [type="radio"], [type="submit"])::placeholder,
textarea::placeholder {
    color: var(--color-default);
    opacity: 1;
}
input:not([type="checkbox"], [type="radio"], [type="submit"]):hover,
textarea:hover {
    border-color: var(--color-active);
}
input:not([type="checkbox"], [type="radio"], [type="submit"]):focus,
textarea:focus {
    border-color: var(--color-active);
    color: var(--color-default);
    outline: none;
}
.has-value input:not([type="checkbox"], [type="radio"], [type="submit"]),
.has-value select,
.has-value textarea,
.has-value .choices__inner .choices__item {
    color: var(--color-default);
    border-color: var(--color-active);
}
/* input:not([type="checkbox"], [type="radio"], [type="submit"]):focus-visible {
    outline: 2px solid var(--color-active);
    outline-offset: 2px;
} */

/* Textarea */
textarea {
    height: 143px;
    box-sizing: border-box;
    border: 2px solid var(--color-border);
    resize: vertical;
}

/* Radio + Checkbox */
input[type="radio"],
input[type="checkbox"] {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
  height: 1px;
  width: 1px;
  overflow: hidden;
}
input[type="radio"] + span,
input[type="checkbox"] + span {
  position: relative;
  display: inline-block;
  padding-left: 36px;
}
/* Pseudo-Input ----- */
input[type="radio"] + span::before,
input[type="checkbox"] + span::before {
  position: absolute;
  top: -2px;
  left: 0;
  display: inline-block;
  width: 20px;
  height: 20px;
  content: '';
  background: var(--color-light);
  border: 2px solid var(--color-border);
  border-radius: 4px;
}
input[type="checkbox"] + span::before {
  background-color: #fff;
}
input[type="radio"] + span::before {
  border-radius: 50%;
}
/* Hover -------------- */
input[type="radio"] + span:hover::before,
input[type="checkbox"] + span:hover::before {
  border-color: var(--color-active);
}
/* Checked + Active ----------- */
input[type="radio"]:checked + span::before,
input[type="checkbox"]:checked + span::before,
input[type="radio"]:active + span::before,
input[type="checkbox"]:active + span::before {
  border-color: var(--color-active);
  background-color: var(--color-light);
}
input[type="radio"]:checked + span::after,
input[type="radio"]:active + span::after {
  position: absolute;
  top: 6px;
  left: 6px;
  display: inline-block;
  content: '';
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: var(--color-light);
}
input[type="checkbox"]:checked + span::after {
  position: absolute;
  top: -2px;
  left: 0px;
  width: 24px;
  height: 24px;
  background: url(assets/img/icons/icon-check-lavender.svg) no-repeat 50% 50%;
  background-size: 24px 24px;
}

input[type="radio"]:active + span::before,
input[type="checkbox"]:active + span::before {
    box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.2);
}

/* Submit Button */
.has-submit {
    position: relative;
    margin-top: var(--gap-input);
    text-align: right;
}
.has-submit > p:first-child {
    position: relative;
    display: inline-block;
}
.has-submit > p:first-child::before {
    position: absolute;
    top: 50%;
    right: 1.5rem;
    display: block;
    width: 2.5rem;
    height: 2.5rem;
    transform: translateY(-50%);
    content: "";
    background-image: url(assets/img/icons/icon-arrow-white.svg); 
    background-repeat: no-repeat;
    background-position: 0 0; 
    background-size: contain;
    pointer-events: none;
}
input[type="submit"] {
    width: fit-content;
    cursor: pointer;
    padding-right: 4.5rem;
}
.has-submit .wpcf7-spinner {
    position: absolute;
    top: 50%;
    right: 0.75rem;
    margin: 0;
    transform: translateY(-50%); 
}


/* Invalid + Alerts */
input[aria-invalid="true"] {
    border-color: var(--color-alert);
}
.wpcf7-not-valid-tip {
    padding: .5rem 2rem;
    font-size: var(--font-size-alert);
    color: var(--color-alert);
}
.wpcf7 form .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    margin: 1rem 0 0;
    padding: 1em;
    background: var(--color-light);
    color: var(--color-active);
    border: 2px solid var(--color-alert);
    border-radius: 8px;
}
.wpcf7 form.sent .wpcf7-response-output {
    border-color: var(--color-success);
}

/* Buttons */
.is-add-button .wp-block-button__link,
.wpcf7-field-group-add.wp-block-button__link {
    background: transparent;
    color: var(--wp--preset--color--dark);
}
.is-add-button .wp-block-button__link:hover,
.wpcf7-field-group-add.wp-block-button__link:hover {
    background:var(--wp--preset--color--dark); 
    color:var(--wp--preset--color--light)
}
.is-add-button .wp-block-button__link:active,
.wpcf7-field-group-add.wp-block-button__link:active {
    background:var(--wp--preset--color--grey); 
    border-color:var(--wp--preset--color--grey); 
    color:var(--wp--preset--color--light)
}


/* Choices Styles */
.has-select {
    height: 56px;
}
.choices {
    box-sizing: border-box;
    margin: 0;
    /* fonts-size: var(--wp--preset--font-size--copy); */
}
.choices[data-type*="select-one"]::after {
    content: none;
}
.choices[data-type*="select-one"] .choices__inner {
    box-sizing: border-box;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    color: var(--color-default);
}
.col-l .choices[data-type*="select-one"] .choices__inner {
    width: calc((100% - var(--gap-input)) * 0.5);
}
.choices__inner .choices__list--single {
    padding: 0;
}
.choices__inner .choices__item {
    box-sizing: border-box;
    padding: var(--input-padding);
    border: 2px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-light) url(assets/img/icons/icon-dropdown.svg) no-repeat calc(100% - 20px) 50%;
    background-size: 24px 24px;
    color: var(--white);
    font-size: var(--font-size);
    line-height: var(--line-height);
}
.choices__inner .choices__item:hover {
    border-color: var(--color-active)
}
.choices__inner .choices__placeholder {
    opacity: 1;
    color: var(--color-default);
}
.choices[aria-expanded="true"] .choices__inner .choices__item {
    padding: var(--input-padding);
    border: 2px solid var(--color-active);
}


.choices__list--dropdown, 
.choices__list[aria-expanded] {
    z-index: 2;
    margin: 16px 0 0;
    background: var(--color-light);
    border: 2px solid var(--color-active);
    border-radius: var(--radius);
    color: var(--color--black);
}
.choices__list--dropdown .choices__item, 
.choices__list[aria-expanded] .choices__item {
    position: relative;
    padding: var(--input-padding);
    font-size: var(--font-size);
    line-height: var(--line-height);
}
.choices__list--dropdown .choices__item--selectable.is-highlighted, 
.choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
    background-color: var(--color-border);
}

.choices__inner select.wpcf7-not-valid + .choices__list--single .choices__item {
    /* padding: 12px 22px; */
    border: 2px solid var(--color-alert);
}

.choices.is-focused:not(.is-open, :hover) {
    border-radius: 8px;
    outline: 2px solid var(--color-active);
    outline-offset: 2px;
}

/* Label */
.input-box {
    position: relative;
}
.has-text label,
.has-textarea label {
    position: absolute;
    top: 17px;
    left: 26px;
    z-index: 1;
    transition: .3s;
    font-size: var(--font-size);
    color: var(--color-default);
    pointer-events: none;
}
.has-textarea label {
    top: 18px;
}
.has-text:focus-within label,
.has-text.has-value label,
.has-textarea:focus-within label,
.has-textarea.has-value label {
    top: 6px;
    font-size: var(--font-size-label);
    color: var(--color-active);
}
.has-text:focus-within input,
.has-text.has-value input,
.has-textarea:focus-within textarea,
.has-textarea.has-value textarea {
    padding: 1rem 1.5rem 0.5rem;
}

@media (max-width: 781px) {
    .has-submit {
        text-align: left;
    }
    .has-submit > p:first-child {
    width: 100%;
    }
    input[type="submit"] {
        width: 100%;
    }
}

@media (max-width: 1023px) {
    .col-l .choices[data-type*="select-one"] .choices__inner {
        width: 100%;
    }
}