/*** Basic style v1 ***/

/*** ---------- Global ---------- ***/
:root {
    --ts-100: 1000ms; --ts-95: 950ms; --ts-90: 900ms; --ts-85: 850ms; --ts-80: 800ms; --ts-75: 750ms; --ts-70: 700ms; --ts-65: 650ms; --ts-60: 600ms; --ts-55: 550ms; --ts-50: 500ms; --ts-45: 450ms; --ts-40: 400ms; --ts-35: 350ms; --ts-30: 300ms; --ts-25: 250ms; --ts-20: 200ms; --ts-15: 150ms; 
}

/*** Disable animations & transitions ***/
@media (prefers-reduced-motion) {
    *, *::before, *::after { transition: 0s; animation: none; }
    :root {
        --ts-100: 0; --ts-95: 0; --ts-90: 0; --ts-85: 0; --ts-80: 0; --ts-75: 0; --ts-70: 0; --ts-65: 0; --ts-60: 0; --ts-55: 0; --ts-50: 0; --ts-45: 0; --ts-40: 0; --ts-35: 0; --ts-30: 0; --ts-25: 0; --ts-20: 0; --ts-15: 0;
    }
}

*, *::before, *::after { -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 10px; height: -webkit-fill-available; scroll-behavior: smooth; }
body { font-size: var(--fs); line-height: var(--lh); color: var(--clr-text); min-height: 100dvh; min-height: -webkit-fill-available; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; }
body.--no-scroll { overflow: hidden; }
.wpb-pagewrapper { -webkit-box-flex: 1; -ms-flex-positive: 1; flex-grow: 1; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; overflow: hidden; }


/*** ---------- Accordion ---------- ***/
.wpb-accordion {
    --br: .5rem; 
    --p: 0 1.8rem; 
    --bg: #fff; 
    --body-p: 1.8rem; 
    --gap: 1.8rem;
}
.wpb-accordion .collapse:not(.show) { display: none; }
.wpb-accordion__item .collapse:not(.show) { display: none; }
.wpb-accordion__item { color: var(--clr); outline: .1rem solid var(--clr-border); outline-offset: .4rem; border-radius: var(--br); overflow: hidden; }
.wpb-accordion__item + .wpb-accordion__item { margin-top: var(--gap); }
.wpb-accordion__item .wpb-accordion__header { --fs: 1.8rem; margin: 0; }
.wpb-accordion__item .wpb-accordion__button { font: inherit; color: inherit; min-height: 6rem; cursor: pointer; display: grid; grid-template-columns: 1fr 4rem; column-gap: 2rem; align-items: center; width: 100%; font-size: 1.6rem; text-align: left; padding: var(--p); padding-right: 1.2rem; background-color: var(--bg); border: 0; overflow-anchor: none; border-radius: 0; transition: background-color var(--ts-duration) ease-in-out, color var(--ts-duration) ease-in-out, border-radius var(--ts-duration) ease-in-out; }
.wpb-accordion__item .wpb-accordion__button span { font-size: clamp(1.5rem, 1.5vw, 1.8rem); line-height: 1.2; color: var(--clr-text); opacity: .8; transition: opacity var(--ts-duration) ease-in-out; }
.wpb-accordion__item .wpb-accordion__button .btn{ min-height: 3.6rem; pointer-events: none; }
.wpb-accordion__item .wpb-accordion__button .btn i { --w: 1.4rem; --h: 1.4rem; margin: auto; transition: transform var(--ts-25) ease; }
.wpb-accordion__item .wpb-accordion__button.is-active { }
.wpb-accordion__item .wpb-accordion__button.is-active span{ opacity: 1; }
.wpb-accordion__item .wpb-accordion__button.is-active .btn i { transform: rotate(90deg); }
.wpb-accordion__item .wpb-accordion__body { background-color: #fff; padding: var(--body-p); border-top: 1px solid transparent; transition: border var(--ts-duration) ease; }
.wpb-accordion__item .wpb-accordion__body .wpb-text p{ font-size: clamp(1.4rem, 1.5vw, 1.6rem); }
.wpb-accordion__item:has(.wpb-accordion__button.is-active) .wpb-accordion__body{ border-top: 1px solid var(--clr-border); }
.wpb-accordion__item .collapsing { height: 0; overflow: hidden; transition: height .35s ease; }

/*** ---------- Images ---------- ***/
.wpb-image { --br: 0; }
.wpb-image img { border-radius: var(--br); }
.wpb-image figcaption { display: block; padding-top: .5rem; font-size: 1.4rem; }
img { display: block; width: 100%; height: auto; }

.wpb-image.wpb-image--mask { position: relative; }
.wpb-image.wpb-image--mask::before { 
    --mask-value: var(--image-mask-border) no-repeat center/contain; --mask-offset: clamp(2rem, 2vw, 10rem); --offset: -.5rem; content: ''; position: absolute; top: var(--offset); left: var(--offset); right: var(--offset); bottom: var(--offset);
    -webkit-mask: var(--mask-value); mask: var(--mask-value); mask-size: calc(100% - var(--mask-offset)); background-color: var(--clr-border); z-index: -1; 
}
.wpb-image.wpb-image--mask img { --mask-value: var(--image-mask) no-repeat center/contain; -webkit-mask: var(--mask-value); mask: var(--mask-value); mask-size: contain; }

/*** ----- Sections ----- ***/
section { position: relative; }
.has-background-asset { position: relative; }
.has-background-asset::after { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; background: linear-gradient(to bottom right, rgb(var(--clr-dark-80-rgb), 1), rgb(var(--clr-dark-80-rgb), 0)); }
.has-background-asset .container { z-index: 1; }

.is-background-asset { position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%!important; object-fit: cover; z-index: -1; }
.is-background-asset { position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
.is-background-asset :is(img, video) { width: 100%; height: 100%!important; object-fit: cover; }

.wpb-section__header { padding-bottom: 3.2rem; }
.wpb-section__header .container:has(.wpb-text + *) { display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; gap: 1.6rem; }
.wpb-section__header .wpb-text { margin: 0; }

.wpb-block:has(.wpb-section__header-cta){ overflow: hidden; }
.wpb-section__header .container .wpb-section__header-cta{ --br: 1rem; --bg-clr: var(--clr-primary); --p: 1.2rem; order: -1; border-radius: var(--br); padding: var(--p); background-color: var(--bg-clr); margin-bottom: 2.4rem; outline: 1px solid var(--clr-border); outline-offset: 4px; }

.wpb-section__footer{ padding-top: 3.2rem; }
.wpb-section__footer .container{ display: flex; justify-content: space-between; align-items: center; gap: 1.2rem; flex-wrap: wrap; }

@media (min-width: 768px){
    .wpb-section__footer{ padding-top: 4.8rem; }
    .wpb-section__header { padding-bottom: 4.8rem; }

    .wpb-section__header .container:has(.wpb-section__header-cta){ display: grid; grid-template-columns: 1fr 35rem; }
    .wpb-section__header .container .wpb-section__header-cta{ order: 999; margin-bottom: 0; position: absolute; right: 0; top: calc(-1 * var(--pt)); width: 36rem; background-color: transparent; outline: none; }
    
    .wpb-section__header .container .wpb-section__header-cta .wpb-person{ position: relative; z-index: 2; }
    .wpb-section__header .container .wpb-section__header-cta::after { content: '';
        --mask-value: var(--image-mask) no-repeat bottom/contain; --mask-offset: clamp(2rem, 2vw, 10rem); --offset: -4rem; content: ''; position: absolute; top: var(--offset); left: calc(-1 * var(--p)); right: var(--offset); bottom: var(--offset);
        -webkit-mask: var(--mask-value); mask: var(--mask-value); mask-size: cover; background-color: var(--clr-primary);
    }
    .wpb-section__header .container .wpb-section__header-cta::before { content: '';
        --mask-value: var(--image-mask-border) no-repeat bottom/contain; --mask-offset: clamp(2rem, 2vw, 10rem); --offset: -4.5rem; content: ''; position: absolute; top: var(--offset); left: calc(-1 * var(--p) - .5rem); right: var(--offset); bottom: var(--offset);
        -webkit-mask: var(--mask-value); mask: var(--mask-value); mask-size: cover; background-color: var(--clr-border);
    }
}
@media (min-width: 992px){
    .wpb-section__header .container:has(.wpb-section__header-cta){ grid-template-columns: 1fr 40rem; }

    .wpb-section__header .container .wpb-section__header-cta{ 
        --p: 2.4rem; width: 42rem; 
        &::before{ left: calc(-1 * var(--p) / 2); right: calc(var(--offset) - 2.4rem); }
        &::after{ left: calc(-1 * var(--p) / 2 + .5rem); right: calc(var(--offset) - 2.4rem); } 
    }
}
@media (min-width: 1200px){
    .wpb-section__footer{ padding-top: 7.2rem; }
    .wpb-section__header { padding-bottom: 7.2rem; }

    .wpb-section__header .container:has(.wpb-section__header-cta){ grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .wpb-section__header .container .wpb-section__header-cta{ --p: 3.2rem; width: 54rem; }
}

/*** ---------- Icons ---------- ***/
.wpb-icon { --src: ; --clr: var(--clr-dark); --w: 1.8rem; --h: 1.8rem; display: inline-flex; background: transparent; }
.wpb-icon::after { content:''; -webkit-mask-image: var(--src); mask-image: var(--src); -webkit-mask-size: contain; mask-size: contain; -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; display: inline-block; width: var(--w); height: var(--h); min-width: var(--w); min-height: var(--h); background-color: var(--clr); transition: background-color var(--ts-duration) var(--ts-function); }

.fa-battery{ transform: rotate(-90deg); }

/*** ---------- Person ---------- ***/
.wpb-person{ display: flex; flex-direction: column; gap: 1rem; }
.wpb-person .wpb-person__speech{ --bg: linear-gradient(to bottom left, rgba(255, 255, 255, .6), rgba(153, 153, 153, 0)); font-weight: 600; padding: 0 1.2rem; min-height: 3.2rem; background: var(--bg); border-radius: .6rem; width: fit-content; display: flex; align-items: center; backdrop-filter: var(--blur); 
    &::before{ --bg: linear-gradient(to bottom left, rgba(255, 255, 255, .9), rgba(153, 153, 153, 0)); content: ''; position: absolute; right: 1rem; top: 100%; width: 2rem; height: 2rem; background: var(--bg); mask-image: var(--speech-addon); mask-repeat: no-repeat; mask-position: top; mask-size: contain; backdrop-filter: var(--blur) }
}
.wpb-person .wpb-person__content{ position: relative; display: flex; align-items: center; gap: 1.2rem; }
.wpb-person .wpb-person__content .btn{ margin-left: auto; }
.wpb-person .wpb-person__content .btn::before{ content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
.wpb-person .wpb-person__content > p{ text-wrap: pretty; }
.wpb-person .wpb-person__content:has(.wpb-person__text){ gap: 1.2rem; }
.wpb-person .wpb-person__profile{ --size: 4.4rem; --br: 50%; width: var(--size); min-width: var(--size); height: var(--size); min-height: var(--size); border-radius: var(--br); border: 1px solid var(--clr-border); padding: .32rem; overflow: hidden; }
.wpb-person .wpb-person__profile > img{ width: 100%; height: 100%; border-radius: var(--br); object-fit: cover; }

.wpb-person .wpb-person__text > *{ display: block; line-height: 1.2; color: var(--clr-text); }
.wpb-person .wpb-person__text strong{ font-weight: 600; }
.wpb-person .wpb-person__text span{ opacity: .8; font-weight: 300; }

@media (min-width: 992px){
    .wpb-person{ gap: 1.6rem; }
    .wpb-person .wpb-person__speech{ padding: 0 1.6rem; min-height: 4rem; }
    .wpb-person .wpb-person__content{ gap: 2.4rem; }
    .wpb-person .wpb-person__profile{ --size: 5.6rem; }
}

/*** ---------- Background colors ---------- ***/
.wpb-bg-clr--transparent { background-color: transparent; }
.wpb-bg-clr--white { background-color: #fff; }
.wpb-bg-clr--grey { background-color: #f2f2f2; }

/*** ---------- Typography ---------- ***/
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 { color: var(--clr-text); font-size: var(--fs); line-height: var(--lh); text-wrap: balance; }

h1, .h1 { --fs: clamp(0.32rem, 0.32rem + 0.40000vw, 6.4rem); --lh: 1.15; }
h2, .h2 { --fs: clamp(2.8rem, 2.8rem + 0.10526vw, 4.4rem); --lh: 1.15; }
h3, .h3 { --fs: clamp(2rem, 2rem + 0.05263vw, 2.8rem); --lh: 1.15; }
h4, .h4 { --fs: 1.8rem; --lh: 1.15; }
h5, .h5 { --fs: 1.6rem; --lh: 1.15; }
h6, .h6 { --fs: 1.4rem; --lh: 1.15; }

.wpb-text { --mt: 1em; }
.wpb-text > * + *:not(.btn .blockquote) { margin-top: var(--mt); } 

.wpb-text :is(ul, ol) { padding-left: 3.8rem; }
.wpb-text :is(ul, ol) li { font: inherit; }

.wpb-text a:not(.btn) { font: inherit; text-underline-offset: .25rem; }
.wpb-text blockquote { border-left: 4px solid #f2f2f2; padding-left: 1.6rem; }
.wpb-text p{ opacity: .8; }
.wpb-text .btn-group{ --mt: clamp(2.4rem, 2vw, 3.2rem); }

.wpb-text iframe { width: 100%; height: 100%; aspect-ratio: 16/9; border-radius: 1rem; }

.wpb-text.wpb-text--center{ text-align: center; }

strong, strong * { font: inherit; font-weight: 800; color: inherit; }
em, em * { color: inherit; }

.text-uppercase { text-transform: uppercase; }
.text-heading { font-family: var(--wpb-font-headings); }

/*** ---------- Cards ----------  ***/
.wpb-card { --br: 1rem; --p: 2.4rem; border-radius: var(--br); border: 1px solid var(--clr-border); background-color: #fff; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; position: relative; text-decoration: none; }
.wpb-card a { text-decoration: none; }
.wpb-card .wpb-card__header { display: flex; overflow: hidden; }
.wpb-card .wpb-card__header img { width: 100%; height: auto; } 
.wpb-card .wpb-card__body { padding: var(--p); -webkit-box-flex: 1; -ms-flex-positive: 1; flex-grow: 1; }
.wpb-card .wpb-card__footer  { padding: var(--p); padding-top: 0; }
.wpb-card > *:first-child { border-top-left-radius: var(--br); border-top-right-radius: var(--br); }
.wpb-card > *:first-child img { border-top-left-radius: var(--br); border-top-right-radius: var(--br); } 
.wpb-card > *:last-child { border-bottom-left-radius: var(--br); border-bottom-right-radius: var(--br); }

.wpb-card.wpb-card--diensten{ background-color: transparent; outline: 1px solid var(--clr-border); outline-offset: .65rem; transition: background var(--ts-duration) ease, border var(--ts-duration) ease, outline-color var(--ts-duration) ease, outline-offset var(--ts-duration) ease; }
.wpb-card.wpb-card--diensten .wpb-card__header{ padding-bottom: 50%; position: relative; }
.wpb-card.wpb-card--diensten .wpb-card__header img{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; object-fit: cover; transition: transform var(--ts-duration) ease; }
.wpb-card.wpb-card--diensten .wpb-card__title { margin-bottom: .8rem; display: flex; align-items: center; gap: 1rem; }
.wpb-card.wpb-card--diensten .wpb-card__title i{ color: var(--clr-primary); font-size: calc(var(--fs) - .5rem); }
.wpb-card.wpb-card--diensten .wpb-card__body{ display: flex; justify-content: space-between; align-items: end; flex-wrap: wrap; gap: 2rem; row-gap: .8rem; }
.wpb-card.wpb-card--diensten .excerpt { --excerpt-line-clamp: 3; display: -webkit-box; -webkit-line-clamp: var(--excerpt-line-clamp); -webkit-box-orient: vertical; overflow: hidden; font-weight: 300; font-size: clamp(1.3rem, 1.5vw, 1.6rem); opacity: .8; max-width: calc(100% - 6rem); }
.wpb-card.wpb-card--diensten .btn{ min-height: 4rem; pointer-events: none; }

:is(.wpb-bg-clr--light, .wpb-bg-clr--dark) .wpb-card.wpb-card--diensten{ background-color: #FFFF; outline-color: #FFF5; }
:is(.wpb-bg-clr--transparent, .wpb-bg-clr--light-50, .wpb-bg-clr--white) .wpb-card.wpb-card--diensten:hover{ outline-color: #0002; }

.wpb-card.wpb-card--diensten:hover{ background-color: #FFFF; border-color: transparent; outline-color: #FFF; outline-offset: .4rem; }
.wpb-card.wpb-card--diensten:hover .wpb-card__header img{ transform: scale(1.1); }
.wpb-card.wpb-card--diensten:hover .btn{ background-color: var(--clr-dark); }
.wpb-card.wpb-card--diensten:hover .btn i{ transform: rotate(-45deg); color: #FFFF; font-size: calc(var(--fs) - .4rem); }

@media (min-width: 768px){
    .wpb-card.wpb-card--diensten .wpb-card__header{ padding-bottom: 65%; }
}
@media (min-width: 992px){
    .wpb-card.wpb-card--diensten .wpb-card__header{ padding-bottom: 85%; }
}

.wpb-card.wpb-card--projecten{ --br: 2rem; border-radius: var(--br); background-color: transparent; overflow: hidden; outline: 1px solid var(--clr-border); outline-offset: .4rem; }
.wpb-card.wpb-card--projecten .wpb-card__header{ padding: var(--p); padding-bottom: 40%; background: linear-gradient(to bottom, rgb(var(--clr-dark-80-rgb), .8), rgb(var(--clr-dark-80-rgb), 0) 60%);  }
.wpb-card.wpb-card--projecten .wpb-card__header > img{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: -1; transition: transform var(--ts-duration) ease; }
.wpb-card.wpb-card--projecten .wpb-card__header .wpb-person{ z-index: 2; }
.wpb-card.wpb-card--projecten .wpb-card__header .wpb-person .wpb-person__profile{ --size: 4rem; border: none; padding: 0; }
.wpb-card.wpb-card--projecten .wpb-card__header .wpb-person .wpb-person__text{ font-size: 1.4rem; }
.wpb-card.wpb-card--projecten .wpb-card__header .wpb-person .wpb-person__text span{ opacity: 1; display: flex; align-items: center; gap: .4rem; margin-top: .4rem; }
.wpb-card.wpb-card--projecten .wpb-card__body{ flex-grow: 0; margin-top: auto; padding-top: 20%; background: linear-gradient(to top, rgb(var(--clr-dark-80-rgb), .8), rgb(var(--clr-dark-80-rgb), 0)); }
.wpb-card.wpb-card--projecten :is(.wpb-card__body, .wpb-card__header) *{ color: #FFFF; }
.wpb-card.wpb-card--projecten .wpb-card__title{ --fs: 1.8rem; font-family: var(--font-primary); margin-bottom: .8rem; }
.wpb-card.wpb-card--projecten .badge-group{ margin-bottom: 2rem; }
.wpb-card.wpb-card--projecten .excerpt { --excerpt-line-clamp: 2; display: -webkit-box; -webkit-line-clamp: var(--excerpt-line-clamp); -webkit-box-orient: vertical; overflow: hidden; font-weight: 300; line-height: 1.4; font-size: clamp(1.3rem, 1.5vw, 1.6rem); }
.wpb-card.wpb-card--projecten:hover .wpb-card__header > img{ transform: scale(1.1); }

.wpb-card.wpb-card--blurb{ --p: 3.2rem 2.4rem; border: none; outline: 1px solid var(--clr-border); outline-offset: .4rem; overflow: hidden; }
.wpb-card.wpb-card--blurb .wpb-card__header{ padding-bottom: 100%; height: 100%; position: relative; }
.wpb-card.wpb-card--blurb .wpb-card__header img{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.wpb-card.wpb-card--blurb .wpb-card__title{ display: flex; align-items: center; gap: 1rem; }
.wpb-card.wpb-card--blurb .wpb-card__title i{ font-size: calc(var(--fs) - .5rem); color: var(--clr-primary); }
.wpb-card.wpb-card--blurb.wpb-bg-clr--primary .wpb-card__title i{ color: rgb(var(--clr-dark-80-rgb), .5); }
.wpb-card.wpb-card--blurb .wpb-card__body .wpb-text p{ font-size: clamp(1.3rem, 1.5vw, 1.6rem); }
.wpb-card.wpb-card--blurb:has(.wpb-card__header img) .wpb-card__body{ position: absolute; left: 0; bottom: 0; right: 0; padding-top: 10rem; background: linear-gradient(to top, rgb(var(--clr-dark-80-rgb), .6),  rgb(var(--clr-dark-80-rgb), 0)); }
.wpb-card.wpb-card--blurb:has(.wpb-card__header img) .wpb-text *{ color: #FFFF; }

:is(.wpb-bg-clr--white, .wpb-bg-clr--light-50) .wpb-card.wpb-card--blurb:not(.wpb-bg-clr--primary){ background-color: var(--clr-light); }
:is(.wpb-bg-clr--primary, .wpb-bg-clr--dark) .wpb-card.wpb-card--blurb:not(.wpb-bg-clr--primary){ background-color: #FFF3; outline-color: #FFF8; }

.wpb-card.wpb-card--reviews{ --br: 2rem; outline: 1px solid var(--clr-border); outline-offset: .4rem; }
.wpb-card.wpb-card--reviews .wpb-card__header{ flex-direction: column; gap: 1.6rem; padding: var(--p); }
.wpb-card.wpb-card--reviews .wpb-card__header .excerpt{ --excerpt-line-clamp: 4; display: -webkit-box; -webkit-line-clamp: var(--excerpt-line-clamp); -webkit-box-orient: vertical; overflow: hidden; }
.wpb-card.wpb-card--reviews:has(:not(.wpb-person)) .wpb-card__header .excerpt{ --excerpt-line-clamp: 7; }
.wpb-card.wpb-card--reviews .wpb-person .wpb-person__text span{ margin-top: .3rem; font-size: 1.4rem; opacity: 1; }
.wpb-card.wpb-card--reviews .wpb-card__body{ flex-grow: 0; margin-top: auto; }

.wpb-card.wpb-card--contact-form{ border: none; outline: 1px solid var(--clr-border); outline-offset: .65rem; }

.wpb-card.wpb-card--contact{ background-color: var(--clr-primary); border: none; outline: 1px solid rgb(var(--clr-primary-rgb), .2); outline-offset: .65rem; }
.wpb-card.wpb-card--contact .contact-link{ color: var(--clr-dark); font-size: clamp(1.5rem, 1.5vw, 1.8rem); gap: 1.8rem; transition: opacity var(--ts-duration) ease;}
.wpb-card.wpb-card--contact .contact-link i{ width: 2rem; font-size: 2rem; color: var(--clr-dark); }
.wpb-card.wpb-card--contact .contact-link + .contact-link { margin-top: 2rem; }
.wpb-card.wpb-card--contact .contact-link:hover{ opacity: .6; }

/*** ---------- Tabs ---------- ***/
.wpb-tabs { 
    --p: 0 2rem; 
    --clr: var(--clr-text); 
    --bg-clr: transparent; 
    --br: .5rem;
    --border: .1rem solid transparent; 
    --active-clr: var(--clr-primary); 
    --active-bg-clr: #fff; 
    --active-border: .1rem solid var(--clr-border);

    display: grid; }
.wpb-tabs .wpb-tabs__header { display: flex; flex-wrap: wrap; position: relative; z-index: 1; margin-bottom: -0.1rem; }
.wpb-tabs .tab-button { font: inherit; display: inline-block; padding: var(--p); color: var(--clr); min-height: 4.3rem; background-color: var(--bg-clr); border-radius: var(--br) var(--br) 0 0; border: var(--border); text-align: center; text-decoration: none; vertical-align: middle; cursor: pointer; user-select: none; transition-duration: var(--ts-duration); transition-timing-function: var(--ts-function); transition-property: color, background-color, border-color; }
.wpb-tabs .tab-button.is-active { color: var(--active-clr); border-color: var(--active-clr); background-color: var(--active-bg-clr); border: var(--active-border); border-bottom: 1px solid transparent; }
.wpb-tabs .wpb-tabs__content { background-color: #fff; display: grid; border: .1rem solid var(--clr-border); border-radius: 0 0 var(--br) var(--br); }
.wpb-tabs .wpb-tabs__content .tab-pane { grid-column: 1/-1; grid-row: 1/-1; pointer-events: none; opacity: 0; transition: opacity var(--ts-25) ease; }
.wpb-tabs .wpb-tabs__content .tab-pane.is-active { pointer-events: all; opacity: 1; }
.wpb-tabs .wpb-tabs__content .tab-pane { padding: 2rem; }
.wpb-tabs .wpb-tabs__content .tab-pane > * + * { margin-top: 1em; }

.wpb-bg-clr--dark .wpb-tabs .tab-button { color: #fff; } 
.wpb-bg-clr--dark .wpb-tabs .tab-button.is-active { color: var(--active-clr); }

.wpb-tabs.wpb-tabs--secondary { --gc: 15rem 1fr; display: grid; grid-template-columns: var(--gc); align-items: start; }
.wpb-tabs.wpb-tabs--secondary .wpb-tabs__header { margin-bottom: 0; margin-right: -0.1rem; }
.wpb-tabs.wpb-tabs--secondary .tab-button { border-right: 0; margin: 0; width: 100%; border-radius: var(--br) 0 0 var(--br); } 
.wpb-tabs.wpb-tabs--secondary .tab-button.is-active { border: var(--active-border); border-right: 0; }
.wpb-tabs.wpb-tabs--secondary .wpb-tabs__content { border-radius: 0 var(--br) var(--br) 0; }



/*** ---------- Alignment ---------- ***/
.wpb-align-y__top .inner { -webkit-box-align: start; -ms-flex-align: start; align-items: start; }
.wpb-align-y__center .inner { -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.wpb-align-y__bottom .inner { -webkit-box-align: end; -ms-flex-align: end; align-items: end; }

@media (min-width: 992px) {
    .wpb-align-left { order: -1; }
    .wpb-align-right { order: 999; }
}

/*** ---------- Badge ---------- ***/
.badge-group { display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; gap: .5rem; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.badge { --fs: 1.3rem; --lh: 1; --p: .5rem 1rem; --clr: #fff; --bg-clr: rgb(var(--clr-dark-80-rgb), .6); --br: 2rem; --border: 1px solid var(--clr-border); --box-shadow: none; --hover-clr: var(--clr); --hover-bg-clr: var(--bg-clr); --hover-border: var(--border); --hover-box-shadow: var(--box-shadow); 
    display: inline-block; font-size: var(--fs); line-height: var(--lh); padding: var(--p); color: var(--clr); background-color: var(--bg-clr); border-radius: var(--br); border: var(--border); box-shadow: var(--box-shadow); text-align: center; text-decoration: none; 
    vertical-align: middle; user-select: none; transition-duration: var(--ts-duration); backdrop-filter: var(--blur); transition-timing-function: var(--ts-function); transition-property: color, background-color, border-color, box-shadow; 
}
.badge:hover { color: var(--hover-clr); background-color: var(--hover-bg-clr); border: var(--hover-border); box-shadow: var(--hover-box-shadow); }
.badge.badge--primary { --clr: #fff; --bg-clr: var(--clr-primary); }
.badge.badge--primary-light { --clr: var(--clr-primary); --bg-clr: var(--clr-primary-20); }

/*** ---------- backdrop ---------- ***/
.wpb-backdrop { background-color: rgba(0,0,0,.5); position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 1010; opacity: 0; pointer-events: none; backdrop-filter: blur(3px); transition: opacity var(--ts-25) ease; }    
.wpb-backdrop.active { opacity: 1; pointer-events: all; }

/*** ---------- Breadcrumb ---------- ***/
.wpb-breadcrumbs { margin-bottom: .6rem; }
.wpb-breadcrumbs :is(span, a) { display: flex; align-items: center; color: inherit; text-decoration: none; font-size: 1.4rem; }
.wpb-breadcrumbs span > span:first-child:before{ content: '\f015'; font-family: 'Font Awesome 6 sharp'; display: block; color: var(--clr-primary); padding-right: .8rem; }
.wpb-breadcrumbs a:hover { text-decoration: underline }
.wpb-breadcrumbs .breadcrumb_last { font-weight: 500; }
.wpb-breadcrumbs > span { display: flex; column-gap: .8rem; }
.wpb-breadcrumbs i.dot { --fs: .5rem; opacity: .6; font-size: var(--fs); width: var(--fs); height: var(--fs); background-color: rgba(255, 255, 255, 0.4); border-radius: 50%; }

.wpb-bg-clr--primary .wpb-breadcrumbs *{ color: #FFFF; }
.wpb-bg-clr--primary .wpb-breadcrumbs span > span:first-child:before{ color: #FFFF; }


/*** ---------- Social media ---------- ***/
.wpb-social-media {
    --br: 50%; 
    --clr: var(--clr-primary); 
    --bg-clr: var(--clr-primary-20); 
    --border: none; 
    --box-shadow: none; 
    --hover-clr: var(--clr-primary-20); 
    --hover-bg-clr: var(--clr-primary); 
    --hover-border: var(--border); 
    --hover-box-shadow: var(--box-shadow); 
    --focus-clr: var(--hover-clr); 
    --focus-bg-clr: var(--hover-bg-clr); 
    --focus-border: var(--hover-border); 
    --focus-box-shadow: var(--hover-box-shadow); 
    --active-clr: var(--focus-clr); 
    --active-bg-clr: var(--focus-bg-clr); 
    --active-border: var(--focus-border); 
    --active-box-shadow: var(--focus-box-shadow); 
}

.wpb-social-media { display: flex; flex-wrap: wrap; column-gap: 1rem; row-gap: 1rem; }
.wpb-social-media a { background-color: var(--bg-clr); border-radius: var(--br); text-decoration: none; width: 3.8rem; height: 3.8rem; display: inline-grid; place-items: center; transition: background-color var(--ts-duration) ease-in-out; }
.wpb-social-media a i { --clr: inherit;; --w: 1.6rem; --h: 1.6rem; }
.wpb-social-media a:hover { background-color: var(--hover-bg-clr)!important; border: var(--hover-border)!important; box-shadow: var(--hover-box-shadow)!important; }
.wpb-social-media a:hover i { --clr: var(--hover-clr); }
.wpb-social-media a:focus { background-color: var(--focus-bg-clr)!important; border: var(--focus-border)!important; box-shadow: var(--focus-box-shadow)!important; }
.wpb-social-media a:focus i { --clr: var(--focus-clr); }
.wpb-social-media a:active { background-color: var(--active-bg-clr)!important; border: var(--active-border)!important; box-shadow: var(--active-box-shadow)!important; }
.wpb-social-media a:hover i { --clr: var(--active-clr); }

/*** ---------- Footer CTA ---------- ***/
.wpb-footer-cta { --image-height: 30rem; position: relative; overflow: hidden;
    & .container { padding-bottom: var(--image-height); display: grid; gap: 4.8rem; 
        & .btn-group{ gap: 2.4rem 3.2rem; }
        & .wpb-person .wpb-person__profile{ --size: 4.4rem; }
        & .wpb-person .wpb-person__text{ font-size: 1.4rem; 
            & span{ margin-top: .3em; } 
        }
    }
    & .wpb-image { --rotation-deg: 2.5deg; --offset: -2rem; position: absolute; bottom: var(--offset); right: var(--offset); left: var(--offset); height: var(--image-height); outline: 1px solid rgba(255, 255, 255, 0.75); outline-offset: .4rem; transform: rotate(var(--rotation-deg)); overflow: hidden;
        & img { width: 110%; height: 110%; object-fit: cover; transform: rotate(calc(-1 * var(--rotation-deg))) translate(-5rem, -4rem); }
    }
    @media (min-width: 992px){ 
        & { --image-height: 100%; }
        & .container { padding-bottom: 0; grid-template-columns: repeat(2, minmax(0, 1fr)); } & .wpb-image { top: var(--offset); left: auto; width: 45%; height: calc(100% + 4rem); }
    }
}


/*** ---------- Footer ---------- ***/
.wpb-footer { --main-color: #FFF; background-color: var(--clr-dark-80); margin-top: auto; position: relative;
    & .wpb-footer__menu{ 
        & a.logo img{ width: 12rem; height: auto; margin-bottom: 3.2rem; }
        & .wpb-footer__title{ display: block; font-family: var(--font-heading); color: var(--main-color); margin-bottom: 1.8rem; opacity: .8; 
            p{ font-weight: 800; font-size: clamp(1.8rem, 2vw, 2.2rem); }
        }
        ul { list-style: none;
            li a{ display: block; color: var(--main-color); text-decoration: none; padding: .2em 0; transition: color var(--ts-duration) ease; 
                &.wpb-footer__icolink{ font-family: var(--font-heading); font-size: clamp(2rem, 2vw, 2.8rem); font-weight: 800; display: flex; align-items: center; gap: 1.6rem; 
                    i:first-child{ color: var(--clr-primary); width: fit-content; font-size: clamp(1.6rem, 2vw, 2rem); }
                    i.fa-arrow-right{ opacity: .6; font-size: clamp(1.6rem, 2vw, 2rem); transition: transform var(--ts-duration) ease; }
                }
                &:hover{ color: var(--clr-primary);
                    i.fa-arrow-right{ transform: translateX(.5rem); }
                }
            }
        }
        & .wpb-text{ --clr-text: var(--main-color);
            & h2{ --fs: clamp(1.8rem, 2vw, 2.4rem); }
            & .btn.btn--outline{ color: var(--main-color); background: linear-gradient(to top right, rgba(153, 153, 153, 0), rgba(153, 153, 153, .4)); }
        }
    }
    & .wpb-footer__main { --p: 3.2rem; --gc: 1; padding: var(--p) 0; 
        & .container--breadcrumbs{ padding-bottom: var(--p); color: #FFFF; }
        & .container--main { display: grid; grid-template-columns: repeat(var(--gc), minmax(0, 1fr)); column-gap: 2rem; row-gap: 4.8rem;  
            .wpb-text *{ color: #FFFF; }
            .wpb-text p{ line-height: 2; font-weight: 300; }
            .wpb-text p:has(em:only-child){ line-height: 1.4; font-size: clamp(1.4rem, 1.5vw, 1.6rem); }
            .wpb-text p:has(em:only-child) em{ font-style: normal; }
            .wpb-text strong{ font-family: var(--font-heading); font-size: clamp(1.6rem, 2vw, 2.2rem); font-weight: 800; }
            .wpb-text p:has(strong) + p{ --mt: 1.8rem; }
        }
    }
    & .wpb-footer__bottom { --p: 2rem; padding: var(--p) 0; 
        & .container { display: flex; flex-direction: column; justify-content: space-between; align-items: center; column-gap: 2rem; row-gap: 2rem; }
        & .wpb-footer__sub-links { --fs: 1.4rem; text-align: center;  display: flex; flex-wrap: wrap; column-gap: 2rem; 
            * { font-size: 1.4rem; display: flex; align-items: center; column-gap: 2rem; text-decoration: none; color: var(--main-color); opacity: .85; transition: opacity var(--ts-duration) ease;
                &:is(a):hover{ opacity: 1; }
            }
            * + *::before { content: '|'; font-size: 1rem; line-height: 1; }
        }
    }
    &::before{ content: ''; background-image: var(--bg-asset); background-repeat: no-repeat; background-size: cover; position: absolute; top: 0; right: 0; left: 0; width: 100%; height: 48%; opacity: .2; pointer-events: none; transform: rotate(180deg); }
    @media (min-width: 576px){
        & .wpb-footer__main { --gc: 2; }
        &::before{ height: 50%; background-size: 150%; }
    }
    @media (min-width: 768px){
        & .wpb-footer__main { --p: 6.4rem; padding-top: 4.8rem; }
        & .wpb-footer__bottom .container { flex-direction: row; }
    }
    @media (min-width: 992px){
        & .wpb-footer__menu .wpb-footer__title{ margin-bottom: 2.8rem; }
        & .wpb-footer__main { --gc: 4; --p: 8rem;
            & .container--main{ column-gap: 8rem; 
                .wpb-text p:has(strong) + p{ --mt: 2.8rem; }
            }
            & .wpb-footer__menu:is(:nth-child(3), :nth-child(4)){ margin-left: auto; }
        }
         & .wpb-footer__bottom{ --p: 4.8rem; }
        &::before{ height: 100%; width: 52%; transform: rotate(0deg); background-size: cover; background-position: right; }
    }
} 

.contact-link{ display: flex !important; gap: 1rem; 
    & i{ font-size: 1.4rem; margin-top: .6rem; color: var(--clr-primary); }
}


/*** ---------- Modal ---------- ***/
.modal { --br: 1.6rem; --p: 2rem; --backdrop-clr: rgba(0,0,0,.45); position: fixed; top: 0; right: 0; bottom: 0; left: 0; opacity: 0; pointer-events: none; padding: 2rem; background-color: var(--backdrop-clr); display: none; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; transition: opacity var(--ts-duration) ease-in-out; z-index: 1090; }
.modal.show { display: flex; opacity: 1; pointer-events: all; }
.modal.show .modal-dialog { transform: translateY(0); }
.modal .modal-dialog { display: flex; flex-direction: column; border-radius: var(--br); width: 100%; max-width: 74rem; height: auto; max-height: 80vh; transform: translateY(5rem); transition: transform var(--ts-25) ease; background-color: #fff; overflow: hidden; }
.modal.modal--small .modal-dialog { max-width: 60rem; max-height: 60rem; }
.modal.modal--large .modal-dialog { max-width: 100rem; max-height: 60rem; }
.modal.modal--fullscreen { padding: 0; }
.modal.modal--fullscreen .modal-dialog { height: 100%; max-height: 100%; max-width: 100%; border-radius: 0; }
.modal .modal-dialog .modal-dialog__header { display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; align-items: center; padding: var(--p); background-color: #fff; font-family: inherit; }
.modal .modal-dialog .modal-dialog__header .modal-title { font-size: 2rem; margin: 0; }
.modal .modal-dialog .modal-dialog__header .btn-close { cursor: pointer; background-color: transparent; width: 3.2rem; height: 3.2rem; border-radius: 50%; border: 1px solid var(--clr-border); display: inline-grid; place-items: center; transition: background-color var(--ts-duration) ease-in-out, border-color var(--ts-duration) ease-in-out; }
.modal .modal-dialog .modal-dialog__header .btn-close i { --w: 1.4rem; --h: 1.4rem; }
.modal .modal-dialog .modal-dialog__header .btn-close:hover { border-color: var(--clr-primary); background-color: var(--clr-primary); }
.modal .modal-dialog .modal-dialog__header .btn-close:hover i { --clr: #fff; } 
.modal .modal-dialog .modal-dialog__header p { margin: 0; font-size: 1.6rem; line-height: 1.6rem; }
.modal .modal-dialog .modal-dialog__body { background-color: #fff; padding: var(--p); overflow-y: auto; overflow-x: hidden; }
.modal .modal-dialog .modal-dialog__footer { display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; border-top: 1px solid #E4E9EA; background-color: #fff; padding: var(--p); z-index: 2; margin-top: auto; }

.modal.modal--video{ --br: 0; --p: 0; --bg-clr: #000; --backdrop-clr: var(--bg-clr); }
.modal.modal--video .modal-dialog{ max-width: 100%; max-height: 100%; background-color: var(--bg-clr); }
.modal.modal--video .modal-dialog .modal-dialog__body{ display: flex; justify-content: center; overflow: hidden; background-color: var(--bg-clr); }
.modal.modal--video .modal-dialog video{ object-fit: contain !important; width: 100%; height: auto !important; }
.modal.modal--video .btn--close{ --hover-bg-clr: transparent; --hover-border: 1px solid #FFFF; --size: 4.4rem; width: var(--size); min-width: var(--size); height: var(--size); min-height: var(--size); position: absolute; top: 1.2rem; right: 1.2rem; z-index: 5; }

@media (min-width: 576px) {
    .modal.modal--fullscreen { --p: 2rem calc((100% - 540px) / 2 + 2rem); }
}

@media (min-width: 768px) {
    .modal.modal--fullscreen { --p: 2rem; }
    .modal.modal--fullscreen .modal-dialog { max-width: 74rem; height: auto; max-height: 80vh; border-radius: var(--br); }

    .modal.modal--video .btn--close{ top: 2.4rem; right: 3.2rem; }
}

@media (min-width: 992px) {
    .modal { --p: 3.2rem; }
    .modal.modal--fullscreen { --p: 3.2rem; }
}

/*** ---------- Tooltips ---------- ***/
.wpb-tooltip { --bg: rgb( 255,255,255); position: absolute; pointer-events: none; opacity: 0; background-color: var(--bg); color: inherit; font-size: 1.3rem; line-height: 2rem; padding: .5rem 1rem; border-radius: .5rem; z-index: 9999; box-shadow: 0 0 .75rem .25rem rgba(0,0,0,.1); }
.wpb-tooltip::after { content: ''; position: absolute; width: 0; height: 0; border-style: solid; border-width: 0 .5rem .5rem .5rem; border-color: transparent transparent var(--bg) transparent; bottom: 100%; transform: translateX(-50%); left: 50%; }
.wpb-tooltip.wpb-tooltip--left::after { border-width: .7rem 0 .7rem .7rem; border-color: transparent transparent transparent var(--bg); top: 50%; transform: translateY(-50%); left: calc(100% - 1px); }
.wpb-tooltip.wpb-tooltip--right::after { border-width: .7rem .7rem .7rem 0; border-color: transparent var(--bg) transparent transparent; top: 50%; transform: translateY(-50%); right: calc(100% - 1px); left: auto; }
.wpb-tooltip.wpb-tooltip--top::after { border-width:  .5rem .5rem 0 .5rem; border-color: var(--bg) transparent transparent transparent; top: 100%; transform: translateX(-50%); left: 50%; }
.wpb-tooltip.show { opacity: 1; }

/*** ---------- Dropdowns ---------- ***/
.wpb-dropdown { position: relative; }
.wpb-dropdown .wpb-dropdown__menu { opacity: 0; pointer-events: none; min-width: 10rem; border-radius: .5rem; position: absolute; top: calc(100% + .5rem); left: 0; background-color: #fff; box-shadow: 0 0.5rem 0.5rem rgb(21, 47, 51, .1); border: 1px solid rgba(var(--clr-border)); padding: 1.25rem; transition: opacity var(--ts-duration) ease-in-out; }
.wpb-dropdown .wpb-dropdown__menu-right { left: auto; right: 0; }
.wpb-dropdown .wpb-dropdown__menu ul { list-style: none; }
.wpb-dropdown .wpb-dropdown__menu ul .dropdown-item { white-space: nowrap; display: flex; gap: .5rem; text-decoration: none; }
.wpb-dropdown.wpb-dropdown__left .wpb-dropdown__menu { top: 0; right: calc(100% + .5rem); left: auto; } 
.wpb-dropdown.wpb-dropdown__left .wpb-dropdown__toggle i { order: -1; transform: rotate(90deg); }
.wpb-dropdown.wpb-dropdown__right .wpb-dropdown__menu { top: 0; left: calc(100% + .5rem); right: auto; } 
.wpb-dropdown.wpb-dropdown__right .wpb-dropdown__toggle i { order: 9999; transform: rotate(-90deg); }
.wpb-dropdown .wpb-dropdown__toggle[aria-expanded="true"] + .wpb-dropdown__menu { opacity: 1; pointer-events: all; z-index: 850; }  

/*** ---------- Tables ---------- ***/
.wpb-table { overflow-x: auto; }
table { 
    --clr: var(--clr-text); 
    --border-clr: var(--clr-border); 
    --accent-bg-clr: transparent; 
    --hover-clr: var(--clr-text); 
    --hover-bg-clr: rgba(0, 0, 0, 0.075); 
    --border-width: .1rem; 
    
    border-collapse: collapse; width: 100%; color: var(--clr); vertical-align: top; border-color: var(--border-clr); border-spacing: 0; margin: 0 0 1.41575em; }
table td, table th { padding: 1em 1.41575em; text-align: left; vertical-align: top; border-color: inherit; border-style: solid; border-width: 0; border-bottom-width: var(--border-width); }
table thead { vertical-align: bottom; }

/*** ---------- Filters ---------- ***/
.wpb-toolbar .container { display: grid; grid-template-columns: 1fr; }

@media (width > 576px) {
    .wpb-toolbar .container { grid-template-columns: 1fr 20rem; }
}

/*** ---------- Pagination ---------- ***/
.wpb-pagination { --p: 0; --clr: var(--clr-text); --bg-clr: #fff; --border: 1px solid transparent; --br: 4rem; --hover-clr: #fff; --hover-bg-clr: var(--clr-primary); --hover-border: var(--border); --active-color: var(--hover-clr); --active-bg-clr: var(--hover-bg-clr); --active-border: var(--hover-border); position: relative; }
.wpb-pagination .has-prev-next { padding-left: 3.8rem; padding-right: 3.8rem; } 
.wpb-pagination ul { --gap: .25rem; list-style: none; display: flex; justify-content: center; flex-wrap: wrap; gap: var(--gap); padding-top: 3.2rem; }
.wpb-pagination li > * { width: 3.8rem; height: 3.8rem; display: inline-grid; place-items: center; font-weight: 600; font-size: 1.6rem; line-height: 1.6; color: var(--clr-text); color: inherit; padding: var(--p); color: var(--clr); background-color: var(--bg-clr); border-radius: var(--br); border: var(--border); text-align: center; text-decoration: none; vertical-align: middle; cursor: pointer; user-select: none; transition-property: color, background-color, border-color; transition-duration: var(--ts-duration); transition-timing-function: var(--ts-function); }
.wpb-pagination li > * i { --w: 1.5rem; --h: 1.5rem; pointer-events: none; }
.wpb-pagination li > *:hover i { --clr: var(--hover-clr) }
.wpb-pagination li :is(> *:hover, > *:focus, > *:active) { color: var(--hover-clr); background-color: var(--hover-bg-clr); border: var(--hover-border); }
.wpb-pagination li > *.current { color: var(--active-color); background-color: var(--active-bg-clr); border: var(--active-border); }
.wpb-pagination li .page-number__prev { position: absolute; left: 0; }
.wpb-pagination li .page-number__next { position: absolute; right: 0; }
.wpb-pagination li:has([data-page="…"]),
.wpb-pagination li [data-page="…"] { pointer-events: none!important; }

/*** ---------- Offcanvas ---------- ***/
.wpb-offcanvas { --p: 1.8rem; width: 100%; position: fixed; top: 0; right: 0; bottom: 0; left: auto; flex-direction: column; z-index: 9999; background-color: #fff; transform: translate3d(100%, 0, 0); transition: transform var(--ts-35) ease; }
.wpb-offcanvas.wpb-offcanvas--left { transform: translate3d(-100%, 0, 0); top: 0; right: auto; bottom: 0; left: 0; }
.wpb-offcanvas.is-active { pointer-events: all; transform: translate3d(0%, 0, 0); }
.wpb-offcanvas .wpb-offcanvas__header { display: flex; justify-content: space-between; align-items: center; padding: var(--p); }
.wpb-offcanvas .wpb-offcanvas__body { padding: var(--p); flex-grow: 1; overflow-y: auto; }
.wpb-offcanvas .wpb-offcanvas__footer { display: grid; padding: var(--p); }
.btn[data-target="#productFilters"] { position: fixed; bottom: 2rem; left: 50%; transform: translateX(-50%); z-index: 600; }

.wpb-offcanvas.wpb-offcanvas--filters form > * + * { margin-top: 2rem; }

@media (min-width: 576px) {
    .wpb-offcanvas { max-width: 45rem; }
}

@media (min-width: 992px) {
    .wpb-offcanvas.wpb-offcanvas--filters { --p: 0; display: flex!important; position: static; transform: none; }
    .wpb-offcanvas.wpb-offcanvas--filters .wpb-offcanvas__header,
    .wpb-offcanvas.wpb-offcanvas--filters .wpb-offcanvas__footer { display: none; }
    .btn[data-target="#productFilters"] { display: none; }
}

/* Contact links */
.contact-link { display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; text-decoration: none; }
.contact-link strong { display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; gap: 1rem; width: 100%; }

/*** ---------- Archive ---------- ***/
.wpb-archive { --gc: 1; --gap: 2.2rem; }
.wpb-archive .container.container--results { display: grid; grid-template-columns: repeat(var(--gc), minmax(0, 1fr)); gap: var(--gap); }

@media (min-width: 768px) {
    .wpb-archive { --gc: 2; }
}

@media (min-width: 992px) {
    .wpb-archive { --gc: 3; }
}

/*** ---------- Single ---------- ***/
.wpb-related--posts { --gc: 1; --gap: 3.2rem; }
.wpb-related--posts .wpb-text { margin-bottom: 3.2rem; }
.wpb-related--posts .container.container--articles { display: grid; grid-template-columns: repeat(var(--gc), minmax(0, 1fr)); gap: var(--gap); }

.wpb-content .container { display: grid; grid-template-columns: minmax(0, 1fr); }

@media (min-width: 992px) {
    .wpb-related--posts { --gc: 3; }  

    .wpb-content .container { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); column-gap: 3.2rem; }
}

@media (min-width: 1200px) {
    .wpb-content .container { grid-template-columns: minmax(0, 1fr) minmax(0, 40rem); column-gap: 6.4rem; }
}

.social-share-icons { display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; gap: .25rem; padding-top: 1.6rem; }

/*** ---------- Aspect ratio ---------- ***/
.wpb-ratio { --wpb-aspect-ratio: 100%; position: relative; width: 100%; }
.wpb-ratio::before { display: block; padding-top: var(--wpb-aspect-ratio); content: ""; }
.wpb-ratio--21x9 { --wpb-aspect-ratio: 42.8571428571%; }
.wpb-ratio--16x9 { --wpb-aspect-ratio: 56.25%; }
.wpb-ratio--1x1 { --wpb-aspect-ratio: 100%; }
.wpb-ratio--4x3 { --wpb-aspect-ratio: 75%; }
.wpb-ratio > * { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.wpb-ratio > img { object-fit: cover; } 

/*** ---------- Alerts ---------- ***/
.wpb-alert { --clr: #fff; --bg: var(--clr-primary); --br: 1.6rem; display: block; padding: 1.6rem; color: var(--clr); background-color: var(--bg); border-radius: var(--br); }
.wpb-alert.wpb-alert-icon { display: grid; grid-template-columns: 2.8rem 1fr; gap: 1.6rem; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.wpb-alert.wpb-alert-icon i-wrapper { width: 2.8rem; height: 2.8rem; }
.wpb-alert.wpb-alert-icon i-wrapper i { --w: 2.8rem; --h: 2.8rem; }
.wpb-alert *:not(.btn) { color: inherit; }

.wpb-alert.wpb-alert--info { --border: 1px solid rgb(0, 143, 214); --bg: rgb(0, 143, 214); }
.wpb-alert.wpb-alert--warning { --border: 1px solid rgb(194, 100, 47); --bg: rgb(194, 100, 47); }
.wpb-alert.wpb-alert--danger { --border: 1px solid rgb(216, 19, 19); --bg: rgb(216, 19, 19); }
.wpb-alert.wpb-alert--success { --border: 1px solid rgb(78, 168, 69); --bg: rgb(78, 168, 69); }

/*** ---------- Page: Search ---------- ***/
.wpb-search-results { --gc: 1; --gap: 2.2rem; }
.wpb-search-results .wpb-text { margin-bottom: 3.2rem; }
.wpb-search-results .inner { display: grid; gap: var(--gap); grid-template-columns: repeat(var(--gc), minmax(0, 1fr)); }
.wpb-search-results .result { text-decoration: none; display: flex; gap: .5rem; padding: .75rem 1.25rem; margin-bottom: -.1rem; transition: background-color var(--ts-duration) ease-in-out; }
.wpb-search-results .result .info { display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 100%; gap: .5rem; }
.wpb-search-results .result .info i { margin-left: auto; }
.wpb-search-results .result { border: 1px solid var(--clr-border); }
.wpb-search-results .result:hover { background-color: #f2f2f2; }
.wpb-search-results :is(.result:first-child, .no-result) { margin-top: 1.6rem; }

/*** ---------- Wux Advanced Search ---------- ***/
.wpb-search-results { display: grid; gap: 2.2rem; position: relative; }
.wpb-search-results h3 { --fs: 2rem; padding-bottom: .8rem; }
.wpb-search-results.--loading { min-height: 6.4rem; margin-top: 2.2rem; }
.wpb-search-results.--loading::after { content: ''; --src: url('/app/themes/wuxnl-theme/assets/icons/default/icon_loading.svg'); --clr: var(--clr-text); --w: 2rem; --h: 2rem; -webkit-mask-image: var(--src); mask-image: var(--src); -webkit-mask-size: contain; mask-size: contain; -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; display: inline-block; width: var(--w); height: var(--h); background-color: var(--clr); position: absolute; top: calc(50% - (var(--h) / 2)); left: calc(50% - (var(--w) / 2)); animation: rotate 0.5s linear infinite; }
.wpb-search-results.--loading .result-section { opacity: .5; }
.wpb-search-results .result-section:nth-child(1) { margin-top: 2.2rem; }
.wpb-search-results.--loading .result-section:nth-child(1) { margin-top: 0; }
.wpb-search-results .result-section .results:is(.posts, .terms) { display: grid; grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr)); gap: .8rem; }
.wpb-search-results .no-result-section { border: 1px solid var(--clr-border); padding: 2.2rem; border-radius: 1rem; margin-top: 2.2rem; }
.wpb-search-results.--loading .no-result-section { margin-top: 0; }

@media (min-width: 768px) {
    .wpb-search-results .result-section .results:is(.posts, .terms) { grid-template-columns: repeat(auto-fill, minmax(25rem, 1fr)); }
}

/* Add to cart/bookmark animation */
.add-success, .saved-success { position: fixed; top: 3.2rem; right: 3.2rem; background-color: var(--clr-primary); z-index: 9999; width: 4.4rem; height: 4.4rem; border-radius: 50%; display: inline-grid; place-items: center; transform: scale(0); animation: scale .5s cubic-bezier(0,0,.5,1.5) forwards, transform .5s forwards; animation-delay: 0s, 1.6s; } 
.add-success i, .saved-success i { --clr: #fff; }
.add-success:after, .saved-success:after { content: ''; display: block; position: absolute; top: 0; right: 0; bottom: 0; left: 0; border-radius: 50%; animation: pulse 1s forwards; animation-delay: .6s; }

@keyframes rotate {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@keyframes scale {
    0% { transform: scale(0); }
    100% { transform: scale(100%); }
}

@keyframes transform {
    0% { transform: scale(100%) translateY(0px); opacity: 1; }
    100% { transform: scale(100%)  translateY(-10rem); opacity: 0; }
}

@keyframes pulse {
    0% { transform: scale(0.95); box-shadow: 0 0 0 0 var(--clr-primary); opacity: .7; }
    70% { transform: scale(1); box-shadow: 0 0 0 1.5rem var(--clr-primary); opacity: 0; }
    100% { transform: scale(0.95); box-shadow: 0 0 0 0 var(--clr-primary); opacity: 0; }
}

/*** ---------- Wux Bulk Pricing ---------- ***/
.wpb-bp-overview { margin-bottom: 2.2rem; }
.wpb-bp-overview .wpb-bp-rules { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .8rem; }
.wpb-bp-overview .wpb-bp-rules .wpb-bp-rule { cursor: pointer; border: 1px solid var(--clr-border); border-radius: .5rem; display: grid;}
.wpb-bp-overview .wpb-bp-rules .wpb-bp-rule > span { font-size: 1.6rem; line-height: 1; padding: 1rem 1.5rem; display: flex; gap: .5rem; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.wpb-bp-overview .wpb-bp-rules .wpb-bp-rule > span strong { font-size: 1.8rem; }
.wpb-bp-overview .wpb-bp-rules .wpb-bp-rule > span small { margin-left: auto; font-size: 1.2rem; line-height: 1; }
.wpb-bp-overview .wpb-bp-rules .wpb-bp-rule > span small * { font-size: inherit; line-height: inherit; }
.wpb-bp-overview .wpb-bp-rules .wpb-bp-rule > span + * { border-top: 1px solid var(--clr-border); }

@media (min-width: 992px) {
    .wpb-bp-overview { margin-bottom: 3.2rem; }
}

/*** ---------- Blaze slider ---------- ***/
.wpb-block:has(.blaze-slider .blaze-track-container){ overflow: hidden; }
.wpb-block .blaze-slider .blaze-track-container{ overflow: visible; }
.wpb-block .blaze-slider.blaze-slider--logos{ opacity: .6; }

.blaze-slider--wide .blaze-track-container .blaze-track{ --offset: 75%; width: calc(100% + var(--offset) + var(--offset)); margin-left: calc(-1 * var(--offset)); }

.blaze-slider .blaze-pagination-container { --p: 2.4rem 0 0 0; padding: var(--p); }
.blaze-slider .blaze-pagination-container .blaze-pagination { display: flex; justify-content: center; align-items: center; gap: .6rem; }
.blaze-slider .blaze-pagination-container .blaze-pagination button { --size: .9rem; --br: 50%; --bg: rgba(198, 201, 200, 1); cursor: pointer; width: var(--size); height: var(--size); border-radius: var(--br); background: var(--bg); border: none; text-indent: -9999rem; overflow: clip; transition: background var(--ts-duration) var(--ts-function); }
.blaze-slider .blaze-pagination-container .blaze-pagination button.active { --bg: rgba(149, 149, 149, 1); }
.blaze-slider .blaze-nav-container { --p: 1.8rem 0 0 0; padding: var(--p); }
.blaze-slider .blaze-nav-container > button { --size: 3.6rem; --inner-clr: var(--clr-primary); --hover-inner-clr: #fff; --bg-clr: transparent; --hover-bg-clr: var(--clr-primary); --border: 1px solid var(--clr-primary); --hover-border: 1px solid transparent; --br: .5rem; width: var(--size); min-width: var(--size); height: var(--size); min-height: var(--size); background: var(--bg-clr); color: var(--inner-clr); border: var(--border); border-radius: var(--br); cursor: pointer; transition: background var(--ts-duration) var(--ts-function), border var(--ts-duration) var(--ts-function);  }
.blaze-slider .blaze-nav-container > button:hover{ background: var(--hover-bg-clr); color: var(--hover-inner-clr); border: var(--hover-border); } 

@media (min-width: 576px) {
    .blaze-slider--wide .blaze-track-container .blaze-track{ --offset: 30%; }
}
@media (min-width: 992px) {
    .blaze-slider .blaze-pagination-container { --p: 4.8rem 0 0 0; }
    .blaze-slider--wide .blaze-track-container .blaze-track{ --offset: 50%; }
}
@media (min-width: 1200px) {
    .blaze-slider--wide .blaze-track-container .blaze-track{ --offset: 26rem; }
    .blaze-slider--reviews.blaze-slider--wide .blaze-track-container .blaze-track{ --offset: 35rem; }
}

/*** ---------- Logo marquee ---------- ***/
@keyframes translate_x_left {
    0% {
        transform: translate3d(-20%, 0, 0);
    }
    100% {
        transform: translate3d(-120%, 0, 0);
    }
}

.wpb-logo-marquee{ 
    --gap: 6rem; --image-height: 8rem; display: flex; position: relative; 
    & .wpb-logo-marquee__items{ 
        display: flex; align-items: center; justify-content: space-between; column-gap: var(--gap); padding-left: var(--gap); animation: translate_x_left 40s linear infinite; 
        & img{ height: var(--image-height); min-height: var(--image-height); object-fit: contain; width: auto; opacity: .6; }
    }
}

@media (min-width: 768px) {
    .wpb-logo-marquee{ --gap: 8rem; --image-height: 10rem; }
}
@media (min-width: 1200px) {
    .wpb-logo-marquee{ --gap: 10rem; --image-height: 12rem; }
}

/*** ---------- Temlate: Contact ---------- ***/
.wpb-contact { --gc: 1; --gap: 2.2rem; }
.wpb-contact .container { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); gap: var(--gap); -webkit-box-align: start; -ms-flex-align: start; align-items: start; }

@media (min-width: 992px) {
    .wpb-contact .container { grid-template-columns: minmax(0, 1fr) minmax(0, 40rem); --gap: 4.8rem; }
}