/*
Theme Name: Wux Theme
Author: Wux
Author URI: https://wux.nl/
Description: Wux is het custom wordpress thema van Wux - Internetbureau
Version: 1.0
Requires PHP: 8.3.0
Text Domain: wuxnl-theme
*/

:root {
    --fs: 1.4rem;
    --lh: 1.6;
    
    /* Custom beziers */
    --cb--smooth: cubic-bezier(.58,.22,.2,.96);

    /* Color variables */
    --clr-primary: #ef0009;
    --clr-primary-120: #83000c;
    --clr-primary-60: #f17666;
    --clr-primary-40: #f5b299;
    --clr-primary-20: #fadccc;
    --clr-primary-rgb: 240, 0, 8;
    
    --clr-heading: #000000;
    --clr-text: #3d3d3d;

    --clr-dark: #51000d;
    --clr-gray: #d3d2d2;
    --clr-darkgray: #898d8d;
    --clr-light: #f4f4f4;

    --clr-border: var(--clr-gray); 
    
    --clr-danger: #e2401c;
    --clr-info: #3d9cd2;
    --clr-success: #008738;

    /* Font variables */
    --font-primary: "Montserrat", sans-serif;
    --font-heading: "Sora", sans-serif;

    /* Container max-width variables */
    --container-width: 100%;
    --container-width--sm: 540px;
    --container-width--md: 720px;
    --container-width--lg: 960px;
    --container-width--xl: 1140px;
    --container-width--xxl: 1320px;
    --container-width--xxxl: 1460px;

    --ts-duration: var(--ts-25);
    --ts-function: var(--cb--smooth);

}

@media (min-width: 768px) {
    :root {
        --fs: 1.6rem;
    }
}

body { font-family: var(--font-primary); 
    &.single-projects,
    &.page-template[class*="template-contact"] { background-color: var(--clr-light); }
}


/*** ---------- Typography ---------- ***/
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 { font-family: var(--font-heading); color: var(--clr-heading); font-weight: 700; word-break: break-word; hyphens: auto; }
:is(h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6):has(strong){ font-weight: 400; }
:is(h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6) strong{ font-weight: 700; }

h1, .h1 { --fs: clamp(3.6rem, 6vw, 7.2rem); --lh: 1.1; }
h2, .h2 { --fs: clamp(2.4rem, 3vw, 4rem); --lh: 1.2; }
h3, .h3 { --fs: clamp(2rem, 3vw, 2.4rem); --lh: 1.2; }
h4, .h4 { --fs: clamp(1.6rem, 1.75vw, 1.8rem); --lh: 1.2; }

.wpb-text p:has(+ :is(h1, h2, h3)) em { font-size: 1.4rem; color: var(--clr-primary); text-transform: uppercase; font-weight: 400; font-style: normal; letter-spacing: .2em; }
.wpb-text p:has(em) + :is(h1, h2, h3) { --mt: clamp(1.2rem, 2vw, 2.4rem); }
.wpb-text .btn-group{ --gap: .8rem; --mt: clamp(2.4rem, 3vw, 3.2rem); }

@media (min-width: 768px){
    .wpb-text .btn-group{ --gap: 1.6rem; }
}

.wpb-text--list-as-checks { --icon-size: 2.1rem; --icon-bg-clr: var(--clr-primary); --icon-clr: #FFFF; --gap: 1.2rem;
    & ul{ padding-left: 0; }
    & ul li{ list-style: none; position: relative; padding-left: calc(var(--icon-size) + var(--gap)); }
    & ul li:has(+ li){ padding-bottom: 1.2rem; }
    & ul li::before{ content: '\f00c'; font-family: 'Font Awesome 6 Pro'; font-weight: 600; display: inline-grid; place-items: center; width: var(--icon-size); min-width: var(--icon-size); height: var(--icon-size); background-color: var(--icon-bg-clr); color: var(--icon-clr); font-size: 1rem; line-height: 0; margin-top: .2em; border-radius: 50%; position: absolute; top: 0; left: 0; }
}

.response-text{ --lh: 1.5; color: var(--clr-success); font-size: 1.4rem; font-weight: 600; max-width: 26rem; line-height: var(--lh); display: flex; gap: .8rem; }
.response-text i{ height: fit-content; line-height: var(--lh); transform: scaleX(-1); }

/*** ---------- Whitespace ---------- ***/
[class*="wpb-wst"] { --pt: 0; padding-top: var(--pt); }
[class*="wpb-wsb"] { --pb: 0; padding-bottom: var(--pb); }
.content-section{
    &[class*="wpb-wst"]{ padding-top: calc(var(--pt) - 1rem); }
    &[class*="wpb-wsb"]{ padding-bottom: calc(var(--pb) - 1rem); }
}

.wpb-wst--none { --pt: 0; }
.wpb-wst--small { --pt: 2.4rem; }
.wpb-wst--medium { --pt: 4rem; }
.wpb-wst--large { --pt: 5rem; }

.wpb-wsb--none { --pb: 0; }
.wpb-wsb--small { --pb: 2.4rem; }
.wpb-wsb--medium { --pb: 4rem; }
.wpb-wsb--large { --pb: 5rem; }

@media (min-width: 992px) {
    .content-section{
        &[class*="wpb-wst"]{ padding-top: calc(var(--pt) - 4rem); }
        &[class*="wpb-wsb"]{ padding-bottom: calc(var(--pb) - 4rem); }
    }

    .wpb-wst--small { --pt: 6.4rem; }
    .wpb-wst--medium { --pt: 10rem; }
    .wpb-wst--large { --pt: 12rem; }
    
    .wpb-wsb--small { --pb: 6.4rem; }
    .wpb-wsb--medium { --pb: 10rem; }
    .wpb-wsb--large { --pb: 12rem; }
}

/*** ---------- Background colors ---------- ***/
[class*="wpb-bg-clr--"] { --section-bg: transparent; background-color: var(--section-bg); }
.wpb-bg-clr--primary    { --section-bg: var(--clr-primary, transparent); }
.wpb-bg-clr--light      { --section-bg: var(--clr-light, transparent); }
.wpb-bg-clr--dark       { --section-bg: var(--clr-dark, transparent); }

:is(.wpb-bg-clr--dark, .has-background-asset) *:not(.btn, .btn *, .modal, .modal *, .wpb-person i, .wpb-usp i, .wpb-accordion__button i){ color: #FFFF !important; }


/*** ---------- Buttons ---------- ***/
.btn, .gform_button, .gform_next_button, .gform_previous_button, .button { --mh: 5.4rem; --br: 5rem; --fs: 1.4rem; --p: 0 1.6rem; font-family: var(--font-heading); min-height: var(--mh); font-weight: 600; 
    & .btn__count{position: relative;  --bg-clr: var(--clr-primary); --clr: #FFFF; --size: var(--fs); background-color: var(--bg-clr); color: var(--clr); width: var(--size); height: var(--size); min-width: var(--size); border-radius: 50%; font-size: 1.4rem; }
    & .btn__count span { position: absolute; top: 50%; left: 50%; transform: translate(-45%, -55%); }
}

.btn.btn--primary, .button { --clr: rgb(255,255,255); --bg-clr: var(--clr-primary); --border: 1px solid transparent; }
.btn.btn--primary{ --hover-bg-clr: transparent; --hover-border: 1px solid var(--clr-border); --hover-clr: var(--clr-primary); }
.btn.btn--white { --clr: var(--clr-heading); --bg-clr: #FFFF; --border: 1px solid var(--bg-clr); --hover-clr: #FFFF; --hover-bg-clr: var(--clr-primary); --hover-border: 1px solid var(--hover-bg-clr); }
.btn.btn--dark { --clr: var(--clr-light); --bg-clr: var(--clr-heading); --border: 1px solid var(--clr-heading); --hover-clr: var(--clr-heading); --hover-bg-clr: transparent; --hover-border: 1px solid var(--clr-heading); }
.btn.btn--gray { --clr: var(--clr-heading); --bg-clr: var(--clr-gray); --border: 1px solid var(--bg-clr); --hover-clr: #FFFF; --hover-bg-clr: var(--clr-dark); --hover-border: 1px solid var(--hover-bg-clr); }
.btn.btn--outline { --clr: var(--clr-heading); --border: 1px solid var(--clr-heading); --hover-bg-clr: var(--clr-heading); --hover-border: 1px solid var(--hover-bg-clr); }
.btn.btn--square {--mh: 4.4rem}

.btn.btn--link{ --mh: auto; --p: 0 !important; --fs: 1.4rem; --gap: .8rem; --clr: var(--clr-heading); --hover-clr: var(--clr-primary); }
.btn[class*="btn--link-"]{ --mh: 3rem; --p: 0 !important; --gap: 1.2rem; --bg-clr: transparent; --clr: var(--clr-heading); --border: none; --hover-border: var(--border); --hover-clr: var(--clr-primary); --icon-bg-clr: var(--clr-primary); --icon-clr: #FFFF; --icon-border-clr: transparent; --hover-icon-bg-clr: transparent; --hover-icon-clr: var(--clr-primary); --hover-icon-border-clr: var(--clr-border); text-align: start; 
    & i{ font-size: calc(var(--fs) - .2rem); width: var(--mh); min-width: var(--mh); height: var(--mh); border-radius: 50%; background-color: var(--icon-bg-clr); border: 1px solid var(--icon-border-clr); color: var(--icon-clr); display: inline-grid; place-items: center; transition: background-color var(--ts-25) ease, color var(--ts-25) ease, border var(--ts-25) ease, transform var(--ts-25) ease; }
    &:hover{ --icon-bg-clr: var(--hover-icon-bg-clr); --icon-clr: var(--hover-icon-clr); --icon-border-clr: var(--hover-icon-border-clr); }
    &:hover i{ transform: rotate(-45deg); }
    &:is(:focus, :focus-within, :active){ outline: none !important; box-shadow: none !important;  }
}
.btn.btn--link-white{ --icon-bg-clr: #FFFF; --icon-clr: var(--clr-heading); --icon-border-clr: transparent; --hover-icon-bg-clr: var(--clr-primary); --hover-icon-clr: #FFFF; --hover-icon-border-clr: var(--hover-icon-bg-clr); }

:is(.wpb-bg-clr--dark, .has-background-asset) .btn.btn--outline{ --clr: #FFF; --border: 1px solid #FFFF; --hover-bg-clr: transparent; --hover-border: 1px solid transparent; --hover-bg-clr: #FFF4; }
:is(.wpb-bg-clr--dark, .has-background-asset) .btn.btn--link{ --clr: #FFFF; }
:is(.wpb-bg-clr--dark, .has-background-asset) .btn.btn--link-primary{ --clr: #FFFF; }

@media (min-width: 768px){
    .btn:not(.btn.btn--square), .gform_button, .gform_next_button, .gform_previous_button, .button{ --fs: 1.6rem; --p: 0 2.4rem; }
}

/*** ---------- Animating header ---------- ***/
h2.animating-header{ --lh: 1.6; overflow: hidden; text-wrap: unset !important;
    & .animating-header__words { --icon-size: clamp(2.8rem, 3.5vw, 4.6rem); --py: .7rem; --bg-clr: var(--clr-primary-20); display: inline-block; position: relative; vertical-align: middle; height: calc(var(--fs)); width: var(--word-width); transform: translateY(calc(-1 * var(--py) / 2)); line-height: 1.8; transition: width var(--ts-100) ease; 
        &::before{ content: ''; position: absolute; left: 0; top: calc(-1 * var(--py)); bottom: calc(-1 * var(--py)); right: 0; background-color: var(--bg-clr); z-index: -1; border-radius: .8rem; transition: background var(--ts-100) ease; }
        &.animating{ --bg-clr: var(--clr-primary-40); }
    }
    & .animating-header__words .word { display: flex; justify-content: space-between; align-items: center; opacity: 0; gap: .6rem; transform: translateY(-2rem); position: absolute; top: 0; right: 0; bottom: 0; left: 0; padding: 0 var(--py) 0 calc(var(--py) * 1.5); width: min-content; transition: transform var(--ts-50) ease, opacity var(--ts-50) ease; 
        & p{ font-size: calc(var(--fs) - .2rem); text-wrap: nowrap; white-space: nowrap; line-height: 1; }
        & i{ width: var(--icon-size); min-width: var(--icon-size); height: var(--icon-size); display: inline-grid; place-items: center; color: var(--clr-primary); background-color: #fff; border-radius: .6rem; font-size: clamp(1.4rem, 1.5vw, 1.8rem); transform: scale(1.5); opacity: 0; transition: transform var(--ts-25) ease, opacity var(--ts-25) ease; }
        &.active { opacity: 1; transform: translateY(0); transition: transform var(--ts-50) ease 0s, opacity var(--ts-100) ease var(--ts-50); }
        &.active i{ transform: scale(1); opacity: 1; }
    }
}

@media (min-width: 992px){
    h2.animating-header .animating-header__words::before{ top: calc(-1 * var(--py) * 1.5); bottom: calc(-1 * var(--py) * 1.5); border-radius: 1.6rem;  }
    h2.animating-header .animating-header__words .word{ gap: 1.4rem; }
    h2.animating-header .animating-header__words .word i{  border-radius: 1.1rem; }
}

/*** ---------- Quote ---------- ***/
.wpb-quote{ --br: 1.6rem; --marking-bg-clr: var(--clr-primary-40); --clr: var(--clr-heading); --padding-inline: .3em;
    & p{ font-family: var(--font-heading); font-size: clamp(2rem, 3vw, 3.2rem); font-weight: 700; color: var(--clr); line-height: 1.4; }
    & p strong span.quote-visual span{ position: relative; background-color: var(--marking-bg-clr);
        &::before{ content: ''; position: absolute; top: 0; right: 100%; bottom: 0; width: .3em; background-color: var(--marking-bg-clr); }
        &.rounded-all::before, &.rounded-left::before{ display: none; }

        &.rounded-all{ border-radius: var(--br); padding-inline: var(--padding-inline); }
        &.rounded-right{ border-top-right-radius: var(--br); border-bottom-right-radius: var(--br); padding-right: var(--padding-inline); }
        &.rounded-left{ border-top-left-radius: var(--br); border-bottom-left-radius: var(--br); padding-left: var(--padding-inline); }
    }
    & p strong .sr-only{ position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border-width: 0; }
}
:is(.wpb-bg-clr--dark, .has-background-asset) .wpb-quote{ --marking-bg-clr: var(--clr-primary); }

@media(min-width: 992px){
    & p strong span.quote-visual span{ padding-block: .35rem; }
}


/*** ---------- Snippet : CTA ---------- ***/
.wpb-cta{ --gap: 1.6rem; display: flex; flex-direction: column; gap: var(--gap); max-width: 35rem;
    & .wpb-cta__header img{ height: 3.4rem; width: auto; }
    & .wpb-cta__body > *{ font-family: var(--font-heading); display: block; font-size: clamp(1.5rem, 1.6vw, 1.8rem); }
    & .wpb-cta__footer .btn{ width: 100%; }
}

/*** ---------- Snippet : Person ---------- ***/
.wpb-person{ --image-size: 5.3rem; --icon-size: 2.2rem; display: flex; align-items: center; gap: 1.6rem;
    & .wpb-person__image{ position: relative; width: var(--image-size); min-width: var(--image-size); height: var(--image-size); }
    & .wpb-person__image img{ width: 100%; height: 100%; object-fit: cover; border-radius: 50%; background-color: var(--clr-darkgray); }
    & .wpb-person__image i{ position: absolute; bottom: -.3rem; right: -.6rem; width: var(--icon-size); min-width: var(--icon-size); height: var(--icon-size); font-size: calc(var(--icon-size) - .5rem); transform: rotate(-10deg); background-color: #FFF; color: var(--clr-primary); display: inline-grid; place-items: center; border-radius: 50%; }
    & .wpb-person__text > *{ display: block; line-height: 1.2; color: var(--clr-heading); }
    & .wpb-person__text strong{ font-family: var(--font-heading); margin-bottom: .2em; }
}
[class*="wpb-bg-clr--"] .wpb-person .wpb-person__image i{ background-color: var(--section-bg); }
.has-background-asset .wpb-person .wpb-person__image i{ background-color: transparent; }


/*** ---------- Read more ---------- ***/
.read-more-content{ --max-height: 20rem; max-height: var(--max-height); position: relative; overflow: hidden; transition: max-height var(--ts-25) ease;
    &::before{ content: ''; position: absolute; left: 0; bottom: -2rem; right: 0; height: 8rem; background: linear-gradient(to top, #FFFF, #FFF0); opacity: 1; pointer-events: none; transition: opacity var(--ts-25) ease; }
    & + .btn.btn--read-more{ position: relative; z-index: 5; padding-top: 1.2rem; }
    &:has( + .btn.btn--read-more input[type="checkbox"]:checked){ max-height: var(--element-height, 100%); 
        &::before{ opacity: 0; }
    }
}
.btn.btn--read-more{ --fs: 1.2rem; --mh: 2rem;
    & input[type="checkbox"]{ display: none; }
    & .btn__less{ display: none; }
    & > i{ transition: transform var(--ts-25) ease; }

    &:has(input[type="checkbox"]:checked){
        & .btn__less{ display: block; }
        & .btn__more{ display: none; }
        & > i{ transform: rotate(180deg); }
    }
}

@media (min-width: 576px){
    .read-more-content{ --max-height: 12rem; }
}
@media (min-width: 992px){
    .read-more-content{ --max-height: 20rem; 
        &.wpb-specifications-table{ --max-height: 24rem; }
    }
    .btn.btn--read-more{ --fs: 1.4rem; }
}


/*** ---------- Snippet : teamgrid ---------- ***/
.wpb-teamgrid { display: flex;}
.wpb-teamgrid .thumb {--bg-clr: #fff; width: 5.3rem; height: 5.3rem; border-radius: 50%; overflow: hidden;  background-color: var(--clr-primary-40); border: 3px solid var(--bg-clr); display: flex; justify-content: center; }
.wpb-teamgrid .thumb:not(:first-of-type) {margin-left: -1rem;}
.wpb-teamgrid .thumb img { object-fit: cover; }

.wpb-bg-clr--primary .wpb-teamgrid .thumb   { --bg-clr: var(--clr-primary); }
.wpb-bg-clr--light .wpb-teamgrid .thumb     { --bg-clr: var(--clr-light); }
.wpb-bg-clr--dark .wpb-teamgrid .thumb      { --bg-clr: var(--clr-dark); }


/*** ---------- Snippet : USPs ---------- ***/
.wpb-text .wpb-usps { padding-left: 0; }

.wpb-usps .wpb-usp{ --icon-size: 2.5rem; --icon-clr: var(--clr-primary); position: relative; list-style: none; padding-left: calc(var(--icon-size) + .8rem);
    & i{ position: absolute; left: 0; top: 0; width: var(--icon-size); height: var(--icon-size); font-size: calc(var(--icon-size) - .5rem); color: var(--icon-clr); padding-top: .2em; }
    & strong{ font-size: clamp(1.6rem, 1.75vw, 1.8rem); color: var(--clr-heading);
        & + p{ padding-top: .2em; }
    }
    & + .wpb-usp{ margin-top: 2.4rem; }
}
.wpb-bg-clr--dark .wpb-usps .wpb-usp{ --icon-clr: var(--clr-primary-40); }


/*** ---------- Specifications table ---------- */
.specifications-container{ container: spec / inline-size; }

.wpb-specifications-table{ --p-block: .5rem; display: grid; column-gap: 2.4rem; row-gap: var(--p-block);
    & .wpb-specifications-table__row{ padding-block: var(--p-block); border-bottom: 1px solid var(--clr-border); display: flex; justify-content: space-between; align-items: center; } 
    & .wpb-specifications-table__row:first-child{ padding-top: 0; }
    & .wpb-specifications-table__row span{ font-size: 1.2rem; line-height: 1.2; }
    & .wpb-specifications-table__row span:last-child{ text-align: end; }
}

@container spec (inline-size > 440px){
    .wpb-specifications-table{ --p-block: .8rem; grid-template-columns: 1fr 1fr; }
    .wpb-specifications-table .wpb-specifications-table__row:nth-child(2){ padding-top: 0; }
    .wpb-specifications-table .wpb-specifications-table__row span{ font-size: 1.4rem; }
}

.wpb-single-specification{ font-family: var(--font-heading); display: flex; flex-direction: column; gap: .8rem; padding-top: 1.6rem;
    > *{ color: var(--clr-heading); line-height: 1; }
    small{ font-size: 1.2rem; font-weight: 600; }
    span{ font-size: 1.6rem; display: flex; gap: .8rem; line-height: 1.1; padding-top: .2rem; }
    span i{ color: var(--clr-primary); }
}


/*** ---------- Header ---------- ***/
.wpb-header .container .wpb-text p{ font-size: clamp(1.6rem, 1.75vw, 2rem); }

.wpb-header--home{ --max-height: 70rem; min-height: min(100dvh, var(--max-height)); display: flex; align-items: end; text-align: center;
    & .btn {width: 100%;}
    
    @media (min-width: 992px){
        & { --max-height: 100rem; text-align: start;}
        & .btn {width: fit-content;}
    }
}

.wpb-header--subpage .container{ display: grid; align-items: end; gap: 4rem; }
.wpb-header--subpage .wpb-bg-asset{ --right: auto; --left: calc(-1 * var(--w) / 3); --bottom: calc(-1 * var(--h) / 5); }
.wpb-header--subpage.wpb-bg-clr--dark .wpb-cta .btn{ --bg-clr: #FFFF; --clr: var(--clr-heading); --hover-clr: #FFFF; --hover-border: 1px solid transparent; --hover-bg-clr: #fff4; }

.wpb-header--single .wpb-text h1 { --fs: clamp(2.8rem, 3.5vw, 4rem); --mt: 1.2rem; }
.wpb-header--single .wpb-text .badge-group{ --mt: 0rem; }
.wpb-header--single .wpb-bg-assets .wpb-bg-asset{ --w: clamp(32rem, 40vw, 58rem); --h: var(--w); --top: 1.5rem; --bottom: auto; --right: -5%; }


@media (min-width: 992px){
    .wpb-header--subpage .container{ grid-template-columns: 1fr auto; }
    .wpb-header--single .wpb-bg-assets .wpb-bg-asset{ --right: 20%; }
}

/* Thumbnail */
.wpb-thumbnail{ --aspect-ratio: clamp(24rem, 40%, 54rem); --br: .8rem; border-radius: var(--br); position: relative; padding-bottom: var(--aspect-ratio); overflow: hidden; }
.wpb-thumbnail img{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }


/*** ---------- Footer ---------- ***/
.footer-wrapper .wpb-bg-assets .wpb-bg-asset.wpb-bg-asset--monogram{ --w: 120%; --h: 40rem; --top: -4%; --left: -10%; --right: auto; mask-position: center; -webkit-mask-position: center; }

.wpb-footer-cta .wpb-teamgrid {justify-content: center;}
.wpb-footer-cta .wpb-text{ text-align: center; }
.wpb-footer-cta .wpb-text > img{ height: 5.3rem; width: auto; margin: auto; }
.wpb-footer-cta .wpb-text p{ font-size: clamp(1.6rem, 2vw, 2.4rem); }
.wpb-footer-cta .wpb-text .btn{ --mt: 2.8rem }

.wpb-footer { margin-top: auto; } 
.wpb-footer .wpb-footer__main { --gc: 2; }
.wpb-footer .wpb-footer__main .container { display: grid; grid-template-columns: repeat(var(--gc), minmax(0, 1fr)); column-gap: 2rem; row-gap: 2rem; }

.wpb-footer .logo img { width: 100px; height: auto; }

.wpb-footer .wpb-footer__menu{
    & .footer-menu__title { display: block; padding: 0 0 1.6rem 0; font-size: 1.8rem; font-weight: 600; color: inherit; text-decoration: none; word-break: break-word; }
    & ul { list-style: none; }
    & ul li a{ --icon-size: 1.5rem; line-height: 1.2; position: relative; text-decoration: none; padding-left: 0; display: flex; align-items: center; padding-block: .4em; transition: padding-left var(--ts-25) ease;
        i{ font-size: var(--icon-size); position: absolute; top: auto; left: 0; bottom: auto; opacity: 0; transform: translateX(-.5rem); transition: opacity var(--ts-25) ease, transform var(--ts-25) ease; }
        &:hover{ padding-left: calc(var(--icon-size) + .5rem); }
        &:hover i{ opacity: .4; transform: translateX(0); }
    }
} 

.wpb-footer .wpb-footer__bottom .container { display: flex; flex-direction: column; justify-content: space-between; align-items: center; column-gap: 2rem; row-gap: 2rem; }
.wpb-footer .wpb-footer__bottom .wpb-footer__sub-links { --fs: 1.4rem; font-size: var(--fs); text-align: center; display: flex; flex-wrap: wrap; column-gap: 2.4rem; row-gap: 1.2rem; }
.wpb-footer .wpb-footer__bottom .wpb-footer__sub-links a{ text-decoration: none; transition: opacity var(--ts-25) ease; }
.wpb-footer .wpb-footer__bottom .wpb-footer__sub-links a:hover{ opacity: .6; }

@media (min-width: 768px) {
    .wpb-footer .wpb-footer__bottom .container { flex-direction: row; }
}
@media (min-width: 992px) {
    .footer-wrapper .wpb-bg-assets .wpb-bg-asset.wpb-bg-asset--monogram{ --h: 120%; --top: -12%; }
    .wpb-footer .wpb-footer__main { --gc: 4; }
    .wpb-footer .wpb-footer__bottom .wpb-footer__sub-links { column-gap: 3.2rem; }
}


.by-wux { display: flex; align-items: center; gap: .4rem; text-decoration: none; opacity: 1; transition: opacity var(--ts-25) ease; }
.by-wux span { font-size: 1.1rem; line-height: 1; }
.by-wux img { width: 1.6rem; height: 1.6rem; }
.by-wux:hover{ opacity: .6; }