*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { min-height: 100%; font-size: 10px; line-height: 1.15; -webkit-text-size-adjust: 100%; }
body { min-height: 100dvh; display: flex; flex-direction: column; font-family: Arial, sans-serif; font-size: 1.6rem; line-height: 1.5; }
a { text-decoration: none; }
table { border-collapse: collapse; }
input, select, textarea, button { border: none; background: none; font: inherit; color: inherit; }
img { max-width: 100%; height: auto; }
button, input, optgroup, select, textarea { font-family: inherit; font-size: 100%; line-height: 1.15; margin: 0; }
.open-lightbox { cursor: pointer; }

/*** ---------- Background options ---------- ***/
.bg--light { background-color: var(--clr-light); }

/*** ---------- Whitespace options ---------- ***/
[class*="padding-top"] { padding-top: var(--pt); }
[class*="padding-bottom"] { padding-bottom: var(--pb); }

.padding-top--none  { --pt: 0; } 
.padding-bottom--none { --pb: 0; }
.padding-top--small { --pt: 3.2rem; }
.padding-bottom--small { --pb: 3.2rem; }
.padding-top--medium { --pt: 4.8rem; }
.padding-bottom--medium { --pb: 4.8rem; }
.padding-top--large { --pt: 6.4rem; } 
.padding-bottom--large { --pb: 6.4rem; }

@media (min-width: 992px) {
    .padding-top--small { --pt: 4.8rem; }
    .padding-bottom--small { --pb: 4.8rem; }
    .padding-top--medium { --pt: 6.4rem; }
    .padding-bottom--medium { --pb: 6.4rem; }
    .padding-top--large { --pt: 8rem; }
    .padding-bottom--large { --pb: 8rem; }
}

@media (min-width: 1200px) {
    .padding-top--small { --pt: 6.4rem; } 
    .padding-bottom--small { --pb: 6.4rem; }
    .padding-top--medium { --pt: 8rem; }
    .padding-bottom--medium { --pb: 8rem; }
    .padding-top--large { --pt: 9.6rem; }
    .padding-bottom--large { --pb: 9.6rem; }
}

@media (min-width: 1400px) {
    .padding-top--large { --pt: 12rem; }
    .padding-bottom--large { --pb: 12rem; }
}

/*** ---------- Typography ---------- ***/
h1, .h1, h2, .h2, h3, .h3, h4, .h4 { line-height: 1.1; } 
h1, .h1 { font-size: clamp(3.2rem, 2vw + 3rem, 6.4rem); }
h2, .h2 { font-size: clamp(3.2rem, 2vw + 3rem, 4.8rem); }
h3, .h3 { font-size: clamp(2rem, 2vw + 3rem, 2.8rem); }
.text ul { padding-left: 3.2rem; }
.text > * { --mt: 1em; margin: 0; } 
.text > * + * { margin-top: var(--mt); } 

.text .usps { --mt: 4em; margin-bottom: var(--mt); list-style: none; padding-left: 0; }
.text .usps li { --size: 3.2rem; display: grid; grid-template-columns: minmax(0, var(--size)) 1fr; column-gap: 2rem; }
.text .usps li + li { margin-top: 2em; }
.text .usps li i { width: var(--size); height: var(--size); border-radius: 50%; display: inline-grid; place-items: center; color: #fff; background-color: var(--clr-primary); }

.image { --br: var(--border-radius); display: flex; border-radius: var(--br); overflow: clip; }

.kraft-breadcrumbs { display: inline-grid; grid-template-columns: minmax(0, 1fr) }
.kraft-breadcrumbs * { font-size: clamp(1.4rem, 1vw + 1rem, 1.6rem);; color: var(--clr-text); }
.kraft-breadcrumbs i { font-size: 1.3rem; margin-inline: 1rem; }
.kraft-breadcrumbs > span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kraft-breadcrumbs a:hover { text-decoration: underline; }

.kraft-review .star-rating { display: flex; align-items: center; color: var(--clr-warning); }
.kraft-review { font-size: clamp(1.4rem, 1vw + 1rem, 1.6rem); }
.kraft-review > * + * { margin-top: .5em; }

.contact-link { font-size: inherit; line-height: 1.2; color: var(--clr-text); display: grid; grid-template-columns: minmax(0, 1fr); gap: .5rem; }
.contact-link strong { display: flex; align-items: center; justify-content: space-between; transition: color var(--ts-duration) var(--ts-function); }
.contact-link strong i { font-size: 1.5rem; }
a.contact-link:hover strong { text-decoration: underline; }

@media (min-width: 768px) {
    .text .usps li { --size: 5.8rem; }
}

/*** ---------- Aspect ratios ---------- ***/
[class*="aspect-ratio"]:not(.aspect-ratio--default) { position: relative; overflow: hidden; }
[class*="aspect-ratio"]:not(.aspect-ratio--default)::before { content: ''; display: block; padding-top: var(--ratio-percentage, 75%); }
[class*="aspect-ratio"]:not(.aspect-ratio--default) > * { position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; }
[class*="aspect-ratio"]:not(.aspect-ratio--default) > img { object-fit: cover; }
.aspect-ratio--16by9 { --ratio-percentage: 56.25%; }
.aspect-ratio--9by16 { --ratio-percentage: 177.77%; }
.aspect-ratio--4by3 { --ratio-percentage: 75%; }
.aspect-ratio--3by4 { --ratio-percentage: 133.33%; }
.aspect-ratio--1by1 { --ratio-percentage: 100%; }

/*** ---------- Icons ---------- ***/
.kraft-icon { --src: ; --clr: var(--clr-text); --w: 2rem; --h: 2rem; }
.kraft-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); }

/*** ---------- Buttons ---------- ***/
.btn, .page-numbers, .wpcf7-submit, button, .button {

    --clr           : #fff;
    --bg-clr        : #000;
    --border        : none;

    --hover-clr     : var(--clr);
    --hover-bg-clr  : var(--bg-clr);
    --hover-border  : var(--border);

    --focus-clr     : var(--hover-clr);
    --focus-bg-clr  : var(--hover-bg-clr);
    --focus-border  : var(--hover-border);

    --active-clr    : var(--focus-clr);
    --active-bg-clr : var(--focus-bg-clr);
    --active-border : var(--focus-border);

    --p             : .4rem 2.4rem;
    --br            : var(--border-radius);
    --gap           : 1rem;

    color: var(--clr); background-color: var(--bg-clr); border: var(--border); padding: var(--p); border-radius: var(--br); display: inline-flex; justify-content: center; align-items: center; column-gap: var(--gap); cursor: pointer;
    font-size: 1.6rem; font-weight: 500; min-height: 4.5rem;

    transition-property: color, background-color, border-color, box-shadow; transition-duration: var(--ts-duration); transition-timing-function: var(--ts-function);

    i { font-size: .9em; color: inherit; }
    
    &:hover { color: var(--hover-clr)!important; background-color: var(--hover-bg-clr)!important; border: var(--hover-border)!important; 
        i { color: inherit; }
    }
    &:focus { color: var(--focus-clr)!important; background-color: var(--focus-bg-clr)!important; border: var(--focus-border)!important; 
        i { color: inherit; }
    }
    &:active { color: var(--active-clr)!important; background-color: var(--active-bg-clr)!important; border: var(--active-border)!important; 
        i { color: inherit; }
    }
}


.btn.btn--primary, .wpcf7-submit, .button { --clr: #fff; --bg-clr: var(--clr-primary); }
.btn.btn--primary-20 { --clr: var(--clr-primary); --bg-clr: var(--clr-primary-20); --hover-bg-clr: var(--clr-primary); --hover-clr: #fff; }

.btn.btn--white { --hover-bg-clr: var(--clr-primary-110); --hover-clr: #fff; --hover-bg-clr: ; }

.btn.btn--outline { --clr: var(--clr-primary); --bg-clr: transparent; --border: 1px solid var(--clr-primary); --hover-clr: #fff; --hover-bg-clr: var(--clr-primary); --hover-border: 1px solid var(--clr-primary); }
.btn.btn--outline-light { --clr: var(--clr-text); --bg-clr: transparent; --border: 1px solid var(--clr-border); --hover-clr: #fff; --hover-bg-clr: var(--clr-primary); --hover-border: 1px solid var(--clr-primary); }
.btn.btn--outline-lighter { --clr: #fff; --bg-clr: transparent; --border: 1px solid rgba(255,255,255,.5); --hover-clr: #fff; --hover-bg-clr: transparent; --hover-border: 1px solid var(--clr-primary); }
.btn.btn--outline-dark { --clr: var(--clr-dark); --bg-clr: transparent; --border: 1px solid var(--clr-dark); --hover-clr: #fff; --hover-bg-clr: var(--clr-primary); --hover-border: 1px solid var(--clr-primary); }

.btn.btn--link { --bg-clr: transparent; --clr: var(--clr-text); --p: 0; justify-content: space-between; min-height: 0; }

.btn.btn--ghost::after { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; }

.btn.btn--small { --p: .4rem 2rem; min-height: 4rem; }
.btn.btn--large { --p: .4rem 3.2rem; font-size: 1.8rem; min-height: 5rem; }

.btn.btn--square { --p: 0; min-width: 4.5rem; }

.btn-group { display: flex; align-items: center; gap: 1rem 2rem; flex-wrap: wrap; }

@media (min-width: 992px) {
    .btn.btn--large { min-height: 5.4rem; }
}

/*** ---------- Badge ---------- ***/
.badge-group { display: flex; flex-wrap: wrap; gap: .5rem; }
.badge { --p: .2rem 1rem; --br: var(--border-radius); --bg-clr: var(--clr-primary); --clr: #fff; padding: var(--p); border-radius: var(--br); font-size: 1.4rem; background: var(--bg-clr); color: var(--clr); }

.badge.badge--secondary { --clr: var(--clr-primary); --bg-clr: var(--clr-primary-20); }

/*** ---------- Social media ---------- ***/
.social-media { list-style: none; display: flex; gap: 1rem; }
.social-media .social-media__item a { display: inline-grid; place-items: center; width: 4.2rem; height: 4.2rem; border-radius: 50%; background-color: #fff; color: var(--clr-primary); transition-property: background-color, color; transition-duration: var(--ts-duration); transition-timing-function: var(--ts-function); }
.social-media .social-media__item a:hover { background-color: var(--clr-primary); color: #fff; }

/*** ---------- Cards ---------- ***/
.card {     
    --border: 1px solid var(--clr-border);
    --br: .45rem;
    --p: 2rem;

    background-color: #fff; display: flex; flex-direction: column; border-radius: var(--br); border: var(--border); position: relative; height: 100%; }
.card .card__header { overflow: clip; position: relative; }
.card .card__header figure { border-radius: inherit; }
.card .card__header img { transition: transform var(--ts-duration) var(--ts-function); }
.card .card__body { flex-grow: 1; padding: var(--p); }
.card .card__body > * { --mt: .5em; }
.card .card__body > * + * { margin-top: var(--mt); }
.card .card__footer { padding: var(--p); padding-top: 0; }
.card .card-title { font-size: clamp(1.8rem, 4vw, 2rem); line-height: 1.2; }
.card > *:first-child { border-radius: var(--br) var(--br) 0 0; }
.card .contact-link { --mt: 1em; }
.card .contact-link + .contact-link { border-top: 1px solid var(--clr-border); padding-top: 1em; }
.card .fa-caret-right { font-size: 1.4rem; }

.card:has(.card__tabs:not(.is-hidden)) { border-top-left-radius: 0; }
.card .card__tabs { display: flex; flex-wrap: nowrap; }
.card .card__tabs.is-hidden { display: none; }
.card .card__tabs .card-tab { --p: 0 1.6rem; --bg-clr: #fff; --clr: var(--clr-text); --border: 1px solid var(--clr-border); --br: 0; margin-top: -4.5rem; margin-bottom: -1px;
    &:not(.is-active-step) { --border: 1px solid transparent; border-bottom: 1px solid var(--clr-border)!important; }
    &.is-active-step { border-bottom: 1px solid transparent!important; }
}

.card.card--project .card__header .badge-group { position: absolute; top: 0; right: 0; left: 0; padding: var(--p); z-index: 1; }
.card.card--project .card__body { padding-bottom: 1.4rem; min-height: 25rem; display: flex; flex-direction: column; justify-content: end; }
.card.card--project .card__footer { display: grid; }
.card.card--project:hover .card__header img { transform: scale(1.05); }
.card.card--project .card-title { font-size: clamp(1.8rem, 4vw, 2.8rem); }

.card.card--product { border: none; color: var(--clr-text);
    .card__header { position: relative; border-radius: var(--br); }
    .card__body { padding: var(--p) 0 0 0; display: grid; grid-template-columns: 1fr auto; column-gap: 1rem;
        .card-title { grid-column: span 2; font-size: 1.8rem; font-family: var(--font-family); }
        .product-colors { display: flex; flex-wrap: wrap; gap: .5rem; 
            img { width: 2rem; height: 2rem; border-radius: 50%; object-fit: cover; }
        }
        .product-price { display: flex; align-items: baseline; column-gap: .5rem; font-size: clamp(1.8rem, 4vw, 2rem); color: var(--clr-text);
            small { font-size: 1.1rem; font-weight: 400; display: block; margin-bottom: .25rem; }
        }
    } 
}
.card.card--product .card__body .btn { font-size: 1.5rem; z-index: 2; }
.card.card--product:hover .card__header img { transform: scale(1.1); }

.card.card--background { z-index: 1; background-color: var(--clr-dark); border: none; overflow: clip; }
.card.card--background .card__header { z-index: -1; position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; }  
.card.card--background .card__header img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--br); }
.card.card--background .card__header::before { z-index: 1; content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; background: var(--linear-gradient); border-radius: var(--br); transition: backdrop-filter var(--ts-duration) var(--ts-function); }
.card.card--background .card__body { color: #fff; }
.card.card--background .btn.btn--link { --clr: #fff; }
.card.card--background:hover .card__header img { transform: scale(1.1); }

.card.card--services .card__body { aspect-ratio: 4/3; display: flex; justify-content: space-between; align-items: end; }

.card.card--header-cta { font-size: clamp(1.4rem, 1vw + 1rem, 1.6rem); border: none; background-color: rgba(0, 0, 0, .3); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); color: #fff; }

.bg--light .card.card--product { border: none; }
.bg--light .card.card--header-cta { background-color: #fff; color: var(--clr-text); }
.bg--light .card.card--header-cta a { color: var(--clr-primary); }
.bg--light .card.card--header-cta a:hover { text-decoration: underline; }

@media (min-width: 1200px) {
    .card.card--services { --p: 3.2rem; }
    .card.card--project { --p: 3.2rem; }
    /* .card.card--project .card__body { padding-bottom: 2rem;  */
}

/*** ---------- Logo ---------- ***/
.logo { display: inline-flex; }

/*** ---------- Header ---------- ***/
body.nav-open { overflow: hidden; position: relative; }
body::after { content: ''; opacity: 0; pointer-events: none; position: fixed; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,.4); z-index: 1000; transition: opacity var(--ts-duration) var(--ts-function); }
body.nav-open::after { pointer-events: all; opacity: 1; }
.header { z-index: 1030; }
.header .container { display: flex; align-items: center; gap: .8rem; }

.nav-toggle { --p: 0; --size: 4.5rem; cursor: pointer; display: none; place-items: center; width: var(--size); height: var(--size); min-width: var(--size); }
.nav-toggle .nav-toggle__lines { width: 2rem; height: 1.6rem; position: relative; display: flex; align-items: center; }
.nav-toggle .nav-toggle__lines span { display: block; width: 100%; height: .2rem; background-color: var(--clr); transition: background var(--ts-duration) var(--ts-function); }
.nav-toggle .nav-toggle__lines span:nth-child(1) { position: absolute; top: 0; left: 0; transition: transform var(--ts-duration) var(--ts-function), top var(--ts-duration) var(--ts-function); }
.nav-toggle .nav-toggle__lines span:nth-child(2) { transition: opacity var(--ts-duration) var(--ts-function); }
.nav-toggle .nav-toggle__lines span:nth-child(3) { position: absolute; bottom: 0; left: 0; transition: transform var(--ts-duration) var(--ts-function), bottom var(--ts-duration) var(--ts-function); }
.nav-toggle:hover .nav-toggle__lines span { background-color: var(--hover-clr); }
.nav-toggle[aria-expanded="true"] .nav-toggle__lines span:nth-child(1) { transform: rotate(45deg); top: 40%; }
.nav-toggle[aria-expanded="true"] .nav-toggle__lines span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__lines span:nth-child(3) { transform: rotate(-45deg); bottom: 40%; }

.header .navigation ul { list-style: none; }
.header .navigation .nav__item { width: 100%; display: flex; align-items: center; }
.header .navigation .nav__link { font-size: 1.6rem; width: 100%; color: var(--clr-text); padding: 1.2rem 2rem; position: relative; }
.header .navigation .nav__item .nav-link__toggle { color: var(--clr-text); width: 1rem; height: 1rem; font-size: 1.3rem; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.header .logo img { width: 12rem; }

@media (max-width: 991.98px) {
    .nav-toggle { display: inline-grid; }

    .header .navigation { --max-width: 38rem; display: flex; flex-direction: column; width: 100%; max-width: var(--max-width); position: fixed; top: var(--nav-height, 0); right: 0; bottom: 0; transform: translateX(100%); background-color: #fff; z-index: 1020; transition: transform .25s var(--ts-function); }
    .header .navigation.is-active { transform: translateX(0); }
    .header .navigation .navigation__header { z-index: 1030; display: flex; align-items: center; justify-content: space-between; padding: 1rem 2.4rem; }
    .header .navigation .navigation__header .navigation-title { font-size: 2.4rem; font-weight: 700; }
    .header .navigation .navigation__body { flex-grow: 1; overflow-y: auto; }

    .header .navigation .nav__item { border-bottom: 1px solid var(--clr-border); }
    .header .navigation .nav__item:first-child { border-top: 1px solid var(--clr-border); }
    .header .navigation .nav__item .nav-link__toggle { position: absolute; top: 0; right: 0; bottom: 0; border-left: 1px solid var(--clr-border); min-width: 5.2rem; width: 5.2rem; height: 5.1rem; margin-left: auto; }
    .header .navigation .nav__link { font-size: 1.8rem; }
    
    .header .navigation .navigation-dropdown { display: flex; flex-direction: column; width: 100%; max-width: var(--max-width); position: fixed; top: 0; right: 0; bottom: 0; transform: translateX(100%); background-color: #fff; z-index: 1020; transition: transform .25s var(--ts-function); }
    .header .navigation .navigation-dropdown .navigation-dropdown__header { display: flex; align-items: center; justify-content: start; gap: 2rem; border-top: 1px solid var(--clr-border); }
    .header .navigation .navigation-dropdown .navigation-dropdown__header .title { font-size: 2rem; font-weight: 500; margin: auto; padding-right: 4.2rem; }
    .header .navigation .navigation-dropdown .navigation-dropdown__header .nav-link__toggle { position: static; margin-left: 0; border-left: none; border-right: 1px solid var(--clr-border); }
    .header .navigation .navigation-dropdown .navigation-dropdown__body { flex-grow: 1; }
    .header .navigation .navigation-dropdown.is-active { transform: translateX(0); }
}

@media (max-width: 575.98px) {
    .header .navigation { --max-width: 100%; }
}

@media (min-width: 992px) {
    .header .navigation { display: flex; align-items: center; justify-content: space-between; width: 100%; }  
    .header .navigation ul { display: flex; align-items: center; }
    .header .navigation .nav__link { padding: 1rem; }
    .header .navigation .navigation__header,
    .header .navigation .navigation-dropdown .navigation-dropdown__header { display: none; }
    .header .navigation .navigation-dropdown .nav__link { min-width: 15rem; }

    .header .nav > .nav__item > .nav__link { white-space: nowrap; padding: 1.4rem 2.2rem; }
    .header .navigation .nav__item .nav-link__toggle { position: absolute; right: 0; top: 50%; transform: translateY(-50%); }
    .header .navigation .nav > .nav__item--has-children > .nav__link > .nav-link__toggle { transform: translateY(-50%) rotate(90deg); }

    .header .nav__item--has-children { position: relative; }
    .header .nav__item--has-children .navigation-dropdown { opacity: 0; pointer-events: none; position: absolute; top: 100%; left: 0; background-color: #fff; transition: opacity var(--ts-duration) var(--ts-function); }  
    .header .nav__item--has-children .navigation-dropdown ul { flex-direction: column; align-items: start; }
    .header .nav__item--has-children:hover > .navigation-dropdown { opacity: 1; pointer-events: auto; }
    .header .nav__item--has-children .navigation-dropdown { min-width: 25rem; }
    .header .nav > .nav__item--has-children > .nav__link { padding-right: 4rem; }
}

.kraft-block.kraft-block--cta { border-top: 1px solid rgba(255,255,255,.2);

    &.bg-primary {
        .btn--white { --hover-bg-clr: #ccc; --hover-clr: var(--clr); }
    }    
    &.bg-dark {
        .btn--white { --hover-bg-clr: #ccc; --hover-clr: var(--clr); }
    }
} 

/*** ---------- Footer ---------- ***/
footer { position: relative; margin-top: auto; border-top: 1px solid rgba(255,255,255,.2); }
footer .footer__main { padding-block: 4.8rem; }
footer .footer__main .row { row-gap: 3.2rem; }
footer .footer__main .footer-menu > * + * { margin-top: 1em; }
footer .footer__main .footer-menu .nav { list-style: none; }
footer .footer__main .footer-menu .nav > * + * { margin-top: .5em; }
footer .footer__main .footer-menu .nav__link:hover { text-decoration: underline; text-underline-offset: .4rem; }
footer .footer__main address { font-style: normal; }
footer .footer__main address > * + * { margin-top: 1em; }

footer .footer__bottom { padding-block: 2rem; }
footer .footer__bottom .container { display: grid; grid-template-columns: minmax(0, 1fr); gap: 1rem 2rem; }
footer .footer__bottom .nav { list-style: none; display: flex; align-items: center; gap: .5rem 2rem; }

@media (min-width: 768px) {
    footer .footer__bottom .container { display: flex; justify-content: space-between; align-items: center; }
    footer .footer__bottom .container .kraft-payment-methods { margin-right: auto; }
}

@media (min-width: 992px) {
    footer .footer__main { padding-block: 6.4rem; }
    footer .footer__bottom { padding-block: 3.2rem; }
}

@media (min-width: 1200px) {
    footer .footer__main { padding-block: 10rem; }
    footer .footer__bottom .nav { column-gap: 3.2rem; }
}

/*** ---------- Dropdown ---------- ***/
.kraft-dropdown { position: relative; width: 100%; }
.kraft-dropdown .btn { --p: 1.4rem 1.6rem; justify-content: space-between; }
.kraft-dropdown .kraft-dropdown__menu { padding: 0 1rem 1rem 1rem; pointer-events: none; opacity: 0; position: absolute; top: calc(100% - 1px); right: 0; left: 0; z-index: 2; background-color: #fff; border: 1px solid var(--clr-dark); border-top: 0; border-radius: 0 0 .45rem .45rem; }
.kraft-dropdown .kraft-dropdown__menu > div { cursor: pointer; font-size: 1.4rem; padding: 1rem 1.6rem; border-radius: .5rem; transition: background var(--ts-duration) var(--ts-function); }
.kraft-dropdown .kraft-dropdown__menu > div:hover { background-color: var(--clr-primary); color: #fff; }
.kraft-dropdown.is-expanded .kraft-dropdown__toggle { border-bottom-right-radius: 0; border-bottom-left-radius: 0; }
.kraft-dropdown.is-expanded .kraft-dropdown__menu { opacity: 1; pointer-events: all; }

/*** ---------- Timeline ---------- ***/
.timeline { --size: 6.4rem; padding-left: calc(var(--size) / 2); }
.timeline .timeline__item { position: relative; display: grid; grid-template-columns: var(--size) 1fr; border-left: 1px solid var(--clr-primary); }
.timeline .timeline__item .timeline__item-year { font-size: 1.6rem; width: var(--size); margin-left: calc((var(--size) / 2) * -1); height: var(--size); border-radius: 50%; display: inline-grid; place-items: center; text-align: center; background-color: var(--clr-primary-20); color: var(--clr-primary); }
.timeline .timeline__item + .timeline__item { padding-top: 3.2rem; }
.timeline .timeline__item:last-child::after { position: absolute; bottom: 0; left: 0; content: ''; width: 1rem; height: 1rem; border-radius: 50%; background-color: var(--clr-primary); transform: translateX(-50%) }

@media (min-width: 1200px) {
    .timeline .timeline__item + .timeline__item { padding-top: 4.8rem; }
}

/*** ---------- FAQ / Accordion ---------- ***/
.accordion { --br: var(--border-radius); display: grid; gap: 1rem; width: 100%; }
.accordion [type="radio"], .accordion [type="checkbox"] { opacity: 0; position: absolute; left: -9999rem; }

.accordion__item { background: #fff; border-radius: var(--br); border: 1px solid var(--clr-border); overflow: hidden; }
.accordion__item .accordion__toggle { font-size: 1.6rem; cursor: pointer; display: flex; align-items: center; justify-content: space-between; padding: .4rem 2.4rem; min-height: 4.5rem; }
.accordion__item .accordion__toggle i { transition: transform var(--ts-duration) var(--ts-function); }
.accordion__item .accordion__body {  font-size: clamp(1.4rem, 1vw + 1rem, 1.6rem); display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--ts-duration) var(--ts-function); }
.accordion__item .accordion__inner { overflow: hidden; }
.accordion__item .accordion__content { padding: 2rem 2rem 2rem; border-top: 1px solid var(--clr-border); }
.accordion [type="radio"]:checked + .accordion__toggle i,
.accordion [type="checkbox"]:checked + .accordion__toggle i { transform: rotate(-180deg); }
.accordion [type="radio"]:checked + .accordion__toggle + .accordion__body,
.accordion [type="checkbox"]:checked + .accordion__toggle + .accordion__body { grid-template-rows: 1fr; }

/*** ---------- Alert ---------- ***/
.kraft-alert, .wpcf7 form .wpcf7-response-output { --bg-clr: #f5ced0; --clr: #b4060e; --br: var(--border-radius); --border: none; display: flex; align-items: center; justify-content: space-between; padding: 1.6rem 2.4rem; border-radius: var(--br); background-color: var(--bg-clr); color: var(--clr); border: var(--border); }
.kraft-alert.kraft-alert--success, .wpcf7 form.sent .wpcf7-response-output { --bg-clr: #d4edda; --clr: #155724; }
.kraft-alert.kraft-alert--info { font-size: 1.4rem; --bg-clr: var(--clr-dark-10); --clr: var(--clr-text); 
    a { color: inherit; 
        &:hover { text-decoration: underline; }
    }  
}
.kraft-alert.kraft-alert--warning, .wpcf7 form .wpcf7-response-output { --bg-clr: #fff3cd; --clr: #856404; }


/*** ---------- Forms ---------- ***/
[type="text"], [type="password"], [type="email"], [type="tel"], [type="number"], select, textarea, form .form-row .woocommerce-input-wrapper:has([type="hidden"]) > strong { display: inline-block; border: 1px solid var(--clr-border); border-radius: var(--border-radius); padding: .4rem 1.6rem; font-size: 1.6rem; min-height: 4.5rem; outline: none; }
.bg--gradient-1 :is([type="text"], [type="password"], [type="email"], [type="tel"], [type="number"], select, textarea, form .form-row .woocommerce-input-wrapper:has([type="hidden"]) > strong) { border-color: rgba(255,255,255,.25); }

[type="radio"], [type="checkbox"] { display: inline-block; width: 1.6rem; height: 1.6rem; }
.form-label, label { display: block; width: 100%; font-size: 16px; }
.form-check { cursor: pointer; display: flex; align-items: center; column-gap: 1rem; }

.form-buttons { display: flex; flex-direction: column; gap: .8rem;
    .form-button { width: 100%;  
        --clr: var(--clr-primary);
        --bg-clr: var(--clr-dark-10);
        --border: 1px solid transparent;
        --box-shadow: none;
        --padding: 1.4rem 1.8rem;
        --border-radius: .45rem;
        --fs: 1.6rem;
        --ts: var(--ts-duration);
        --ts-function: var(--ts-function);
        --active-clr: #fff;
        --active-bg-clr: var(--clr-primary);
        --active-border: 1px solid var(--clr-primary);

        font-size: var(--fs); font-weight: 600; cursor: pointer; text-decoration: none; min-height: 4.3rem; display: inline-flex; align-items: center; justify-content: start; column-gap: 1rem; color: var(--clr); background-color: var(--bg-clr); border: var(--border); box-shadow: var(--box-shadow); border-radius: var(--border-radius); padding: var(--padding); transition-property: border, background-color, color, box-shadow; transition-duration: var(--ts); transition-timing-function: var(--ts-function);

        &::before {
            content: '';
            display: block;
            width: 2rem;
            height: 2rem;
            border-radius: 50%;
            border: 1px solid var(--clr-dark-20);
        }

        [data-toggle="modal"] { margin-left: auto; 
            &:hover { color: var(--clr-primary-110); }
        }
    }

    [type="checkbox"] + .form-button::before { border-radius: .45rem; }

    input { position: absolute; width: 0; height: 0; left: -999rem; 
        &:checked + .form-button::before { border-color: var(--clr-dark); background-color: var(--clr-dark); outline: .2rem solid #fff; outline-offset: -.4rem; }
    }
}
form .form-row .woocommerce-input-wrapper:has([type="hidden"]) > strong { width: 100%; display: flex; align-items: center; }

.form-group { display: flex; 
    .form-group__append, .form-group__prepend { background-color: var(--clr-border); padding: .5rem; border-radius: .45rem; display: flex; align-items: center; }
    .form-group__prepend { border-top-right-radius: 0; border-bottom-right-radius: 0; }
    .form-group__append { border-top-left-radius: 0; border-bottom-left-radius: 0; }
    input:has( + .form-group__append) { border-top-right-radius: 0; border-bottom-right-radius: 0; }
}


/* .kraft-form {}
.kraft-form__body { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); row-gap: 2rem; }
.kraft-form__body .kraft-form__field { grid-column: span 12; display: grid; grid-template-columns: minmax(0, 1fr); } */

/*** ---------- Contact form 7 ---------- ***/
.wpcf7 form { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); row-gap: 2rem; margin-inline: -1rem; }
.wpcf7 form > * { grid-column: span 12; padding: 0 1rem; }
.wpcf7 form .wpcf7-form__group .wpcf7-form-control-wrap { display: grid; grid-template-columns: minmax(0, 1fr); width: 100%; }
.wpcf7-form .wpcf7-form__group .wpcf7-form-control-wrap input { width: 100%; }
.wpcf7 form .wpcf7-not-valid-tip { font-size: .8em; margin-top: .25rem; }
.wpcf7 form .wpcf7-response-output { order: -1; margin: 0 1rem; }

.wpcf7-form .wpcf7-checkbox { display: flex; flex-wrap: wrap; gap: 1rem; }
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item { margin: 0; }
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item label { display: flex; align-items: center; column-gap: .5rem; line-height: 1; white-space: nowrap; }

.wpcf7 form.sent .wpcf7-response-output { background-color: #46b450; color: #fff; }

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output, 
.wpcf7 form.payment-required .wpcf7-response-output { padding: 1.4rem 2rem; font-size: 1.6rem; background: #ffb900; border-radius: .45rem; }

@media (min-width: 768px) {
    .wpcf7-form__group.wpcf7-form__group--6 { grid-column: span 6; }
}

/* .wpcf7-form { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: 1rem; }
.wpcf7-form > * { grid-column: span 12; }
.wpcf7-form p { margin: 0!important; }
.wpcf7-form > p label { display: block; width: 100%; }
.wpcf7-form .wpcf7-form-control-wrap { display: block; width: 100%; }

.wpcf7-form .wpcf7-response-output { order: -1; }

.wpcf7-form .wpcf7-checkbox { display: flex; flex-wrap: wrap; gap: 1rem; }
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item { margin: 0; }
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item label { display: flex; align-items: center; column-gap: .5rem; line-height: 1; white-space: nowrap;  }

.wpcf7 form .wpcf7-response-output  { border-radius: .45rem; margin: 0; padding: 1rem 2rem; }

.wpcf7 form.sent .wpcf7-response-output { background-color: #46b450; color: #fff; }

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output, 
.wpcf7 form.payment-required .wpcf7-response-output { background: #ffb900; border-radius: .45rem; }

@media (min-width: 992px) {
	.wpcf7-form-row--4 { grid-column: span 4; }
	.wpcf7-form-row--6 { grid-column: span 6; }
} */

/*** ---------- offcanvas ---------- ***/
.offcanvas { display: flex; flex-direction: column; width: 100%; max-width: var(--max-width, 100%); background-color: #fff; }
body:has(.offcanvas.is-active) { overflow: hidden; }  
body:has(.offcanvas.is-active)::after { pointer-events: all; opacity: 1; }

@media (max-width: 575.98px) {
    .offcanvas { --max-width: 100%; }
}

@media(max-width: 991.98px) {
    .offcanvas { --max-width: 38rem; position: fixed; left: -100%; top: 0; bottom: 0; z-index: 1030; transition: left .25s var(--ts-function); border-right: 1px solid var(--clr-border); }
    .offcanvas.is-active { left: 0%; }

    .offcanvas .offcanvas__header { display: flex; align-items: center; justify-content: space-between; padding: 1rem 2.4rem; border-bottom: 1px solid var(--clr-border); }
    .offcanvas .offcanvas__header .offcanvas-title { font-size: 2.4rem; font-weight: 700; }
    .offcanvas .offcanvas__body { flex-grow: 1; padding: 2rem 2.4rem }
    .offcanvas .offcanvas__footer { display: grid; padding: 2rem 2.4rem }
}

@media (min-width: 992px) {
    .offcanvas .offcanvas__header,
    .offcanvas .offcanvas__footer { display: none; }
}

/* Modal
--------------------------------------------- */
.kraft-modal { opacity: 0; pointer-events: none; display: none; position: fixed; top: 0; right: 0; bottom: 0; left: 0; padding: 2rem; display: grid; place-items: center; background: rgba(0,0,0,.75); z-index: 9999; transition: opacity 250ms ease-in-out; }
.kraft-modal.is-active { opacity: 1; pointer-events: all; }
.kraft-modal .modal-dialog { --p: 2rem; --br: .45rem; border-radius: var(--br); background-color: #fff; width: 100%; max-width: 75rem; position: relative; }
.kraft-modal .modal-dialog .modal-dialog__header { display: flex; justify-content: space-between; align-items: center; column-gap: 3.2rem; padding: var(--p); }
.kraft-modal .modal-dialog .modal-dialog__header button { cursor: pointer; }
.kraft-modal .modal-dialog .modal-dialog__body { padding: 0 var(--p); overflow-y: auto; max-height: 60dvh; }
.kraft-modal .modal-dialog .modal-dialog__footer { padding: var(--p); }
.kraft-modal .modal-title { font-size: clamp(2rem, 2vw + 3rem, 2.8rem); }

.kraft-modal.kraft-modal--color .modal-dialog { max-width: 120rem; }
.kraft-modal.kraft-modal--color .modal-dialog .modal-dialog__body { display: grid; grid-template-columns: minmax(0, 1fr); gap: 2rem; }
.kraft-modal.kraft-modal--color .modal-dialog .modal-dialog__footer { padding-top: 0; }

.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-submit { position: absolute; right: var(--p); bottom: 2rem; }
.kraft-modal.kraft-modal--samples .modal-dialog__footer { min-height: 6.25rem; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox { display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, auto)); gap: 1rem; }
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item label input { position: absolute; left: -999rem; opacity: 0; width: 0; height: 0; }

.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item { aspect-ratio: 4/3; position: relative; }  
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label { position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; } 
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item span {  font-size: 1.3rem; font-weight: bold; color: #fff; white-space: normal; background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_S128_Pembroke.jpg') no-repeat center/cover; cursor: pointer; position: relative; user-select: none; overflow: clip; border-radius: .45rem; width: 100%; height: 100%; padding: 1rem; display: flex; align-items: end; transition: box-shadow 150ms ease-in-out, padding 150ms ease-in-out; } 
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item span::before,
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item span::after { display: none!important; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input:checked + span { box-shadow: inset 0 0 0 .5rem var(--clr-primary); }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="Licht Eiken Hout"] + span { background: url('https://meubel-opmaat.nl/wp-content/uploads/2025/11/DecoLegno-S174-Corteccia-Detailafbeelding-LR-1536x2048-1-638x850.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="Noten Hout"] + span { background: url('https://meubel-opmaat.nl/wp-content/uploads/2025/11/LS14_PoroNoce_LRD-768x1024-1-638x850.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="Zwart Eiken hout"] + span { background: url('https://meubel-opmaat.nl/wp-content/uploads/2025/11/DecoLegno-S182-Quercia-Detailafbeelding-LR-767x1024-1-637x850.jpg') no-repeat center/cover; }
/* .kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="S128 Pembroke"] + span { background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_S128_Pembroke.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="S173 Corteccia"] + span { background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_S173_Corteccia.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="S176 Corteccia"] + span { background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_S176_Corteccia.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="S181 Quercia"] + span { background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_S181_Quercia.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="UA94 DECObasic"] + span { background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_UA94_DECObasic.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="UB19 Talco"] + span { color: var(--clr-primary); background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_UB19_Talco.jpg') no-repeat center/cover; }
.kraft-modal.kraft-modal--samples .wpcf7-form .wpcf7-checkbox .wpcf7-list-item input[value="UB40 Ovatta"] + span { background: url('/wp-content/themes/kraft/assets/images/decolegno/DecoLegno_UB40_Ovatta_.jpg') no-repeat center/cover; } */
.kraft-modal.kraft-modal--samples .modal-dialog__footer { min-height: 10.7rem; }

@media (min-width: 576px) {
    .kraft-modal.kraft-modal--color .modal-dialog .modal-dialog__body { display: grid; grid-template-columns: 1fr 2fr; }
}

@media (min-width: 992px) {
    .kraft-modal .modal-dialog { --p: 3.2rem; }
    .kraft-modal.kraft-modal--color .modal-dialog .modal-dialog__body { gap: 3.2rem; }
}

/*** ---------- Filters ---------- ***/
.kraft-filters { display: flex; flex-direction: column; gap: 2rem; }
.kraft-filters__group .kraft-filters__group-header { display: flex; justify-content: space-between; padding-bottom: 1rem; }
.kraft-filters__group .kraft-filters__group-body { display: flex; flex-direction: column; }

.kraft-selected-filters { display: flex; flex-wrap: wrap; gap: .3rem; }
.kraft-selected-filters__item { display: inline-flex; align-items: center; background: #f0f0f0; padding: 4px 8px; border-radius: 4px; font-size: 14px; }
.kraft-selected-filters__item-remove { margin-left: 8px; display: inline-flex; align-items: center; border: none; background: none; padding: 0 4px; cursor: pointer; font-size: 18px; }
.kraft-selected-filters__item-remove:hover { color: red; }

.filter-results.is-loading { opacity: .5; pointer-events: none; }

.kraft-pagination:has(.page-numbers) { margin-top: 3.2rem; }

.kraft-filter-results { display: grid; grid-template-columns: repeat(var(--gc), minmax(0, 1fr)); gap: 2rem; }

@media (min-width: 576px) {
    .kraft-filter-results { --gc: 2; gap: 3.2rem 2rem; }  
}

@media (min-width: 768px) {
    .kraft-filter-results { --gc: 3; gap: 4.8rem 2rem; }  
}
@media (min-width: 1200px) {
     .kraft-filter-results { gap: 6.4rem 3.2rem; }  
}
@media (min-width: 1320px) {
     .kraft-filter-results { gap: 7.4rem 4.8rem; }  
}

/*** ----- Blaze slider ----- ***/
.blaze-slider.static .blaze-controls { display: none; }
.blaze-slider.start .blaze-prev { opacity: .5; pointer-events: none; }
.blaze-slider.end .blaze-next { opacity: .5; pointer-events: none; }
.blaze-slider .blaze-thumbnails { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); }
.blaze-slider .blaze-thumbnails .blaze-thumbnail { position: relative; }
.blaze-slider .blaze-thumbnails .blaze-thumbnail::before { content: ''; display: block; padding-top: 100%; }
.blaze-slider .blaze-thumbnails .blaze-thumbnail img { position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }

/*** ---------- Pagination ---------- ***/
.pagination { display: flex; justify-content: end; column-gap: 1rem; }
.pagination .page-numbers { min-height: 3.8rem; }
.pagination .page-numbers:not(.prev, .next) { --p: 0; min-width: 3.8rem; }

/*** ---------- Archive ---------- ***/
.kraft-filter__sort { display: flex; align-items: center; column-gap: 2rem; }
.kraft-filter__sort label { font-size: 1.4rem; margin: 0 0 .5rem 0; }

.kraft-archive__toolbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; margin-bottom: 3.2rem; gap: 2rem; }   
.kraft-archive__toolbar .kraft-filter__sort { margin-left: auto; }

/*** ---------- Containers ---------- ***/
.container { padding-inline: var(--inline-spacing); width: 100%; max-width: 1320px; margin-inline: auto; }
.container.container--small { max-width: 960px; }

/*** ---------- Rows / cols ---------- ***/
.row { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); margin-inline: calc(var(--inline-spacing) * -1); row-gap: 2rem; }
.row > .col { grid-column: span 12; padding-inline: var(--inline-spacing); }

.row.gap--20 { --inline-spacing: 1rem; }

.vertical-align--top { align-items: start; }
.vertical-align--middle { align-items: center; }
.vertical-align--bottom { align-items: end; }

.col--12 { grid-column: span 12; }

@media (min-width: 576px) {
    .col.col--sm-2 { grid-column: span 2; }
    .col.col--sm-3 { grid-column: span 3; }
    .col.col--sm-4 { grid-column: span 4; }
    .col.col--sm-5 { grid-column: span 5; }
    .col.col--sm-6 { grid-column: span 6; }
    .col.col--sm-7 { grid-column: span 7; }
    .col.col--sm-8 { grid-column: span 8; }
    .col.col--sm-9 { grid-column: span 9; }
    .col.col--sm-10 { grid-column: span 10; }
    .col.col--sm-11 { grid-column: span 11; }
    .col.col--sm-12 { grid-column: span 12; }

    .justify-content--sm-start { justify-content: start; }
    .justify-content--sm-center { justify-content: center; }
    .justify-content--sm-end { justify-content: end; }
    .justify-content--sm-between { justify-content: space-between; }
    .justify-content--sm-evenly { justify-content: space-evenly; }
    .justify-content--sm-around { justify-content: space-around; }
}

@media (min-width: 768px) {
    .col.col--md-2 { grid-column: span 2; }
    .col.col--md-3 { grid-column: span 3; }
    .col.col--md-4 { grid-column: span 4; }
    .col.col--md-5 { grid-column: span 5; }
    .col.col--md-6 { grid-column: span 6; }
    .col.col--md-7 { grid-column: span 7; }
    .col.col--md-8 { grid-column: span 8; }
    .col.col--md-9 { grid-column: span 9; }
    .col.col--md-10 { grid-column: span 10; }
    .col.col--md-11 { grid-column: span 11; }
    .col.col--md-12 { grid-column: span 12; }
    
    .order--md-1 { order: 1; }

    .justify-content--md-start { justify-content: start; }
    .justify-content--md-center { justify-content: center; }
    .justify-content--md-end { justify-content: end; }
    .justify-content--md-between { justify-content: space-between; }
    .justify-content--md-evenly { justify-content: space-evenly; }
    .justify-content--md-around { justify-content: space-around; }

    .row-span--md-2 { grid-row: span 2; }
}

@media (min-width: 992px) {
    .col.col--lg-2 { grid-column: span 2; }
    .col.col--lg-3 { grid-column: span 3; }
    .col.col--lg-4 { grid-column: span 4; }
    .col.col--lg-5 { grid-column: span 5; }
    .col.col--lg-6 { grid-column: span 6; }
    .col.col--lg-7 { grid-column: span 7; }
    .col.col--lg-8 { grid-column: span 8; }
    .col.col--lg-9 { grid-column: span 9; }
    .col.col--lg-10 { grid-column: span 10; }
    .col.col--lg-11 { grid-column: span 11; }
    .col.col--lg-12 { grid-column: span 12; }

    .justify-content--lg-start { justify-content: start; }
    .justify-content--lg-center { justify-content: center; }
    .justify-content--lg-end { justify-content: end; }
    .justify-content--lg-between { justify-content: space-between; }
    .justify-content--lg-evenly { justify-content: space-evenly; }
    .justify-content--lg-around { justify-content: space-around; }
}

@media (min-width: 1200px) {
    .col.col--xl-2 { grid-column: span 2; }
    .col.col--xl-3 { grid-column: span 3; }
    .col.col--xl-4 { grid-column: span 4; }
    .col.col--xl-5 { grid-column: span 5; }
    .col.col--xl-6 { grid-column: span 6; }
    .col.col--xl-7 { grid-column: span 7; }
    .col.col--xl-8 { grid-column: span 8; }
    .col.col--xl-9 { grid-column: span 9; }
    .col.col--xl-10 { grid-column: span 10; }
    .col.col--xl-11 { grid-column: span 11; }
    .col.col--xl-12 { grid-column: span 12; }

    .justify-content--xl-start { justify-content: start; }
    .justify-content--xl-center { justify-content: center; }
    .justify-content--xl-end { justify-content: end; }
    .justify-content--xl-between { justify-content: space-between; }
    .justify-content--xl-evenly { justify-content: space-evenly; }
    .justify-content--xl-around { justify-content: space-around; }
}

@media (min-width: 1400px) {
    .col.col--xxl-2 { grid-column: span 2; }
    .col.col--xxl-3 { grid-column: span 3; }
    .col.col--xxl-4 { grid-column: span 4; }
    .col.col--xxl-5 { grid-column: span 5; }
    .col.col--xxl-6 { grid-column: span 6; }
    .col.col--xxl-7 { grid-column: span 7; }
    .col.col--xxl-8 { grid-column: span 8; }
    .col.col--xxl-9 { grid-column: span 9; }
    .col.col--xxl-10 { grid-column: span 10; }
    .col.col--xxl-11 { grid-column: span 11; }
    .col.col--xxl-12 { grid-column: span 12; }

    .justify-content--xxl-start { justify-content: start; }
    .justify-content--xxl-center { justify-content: center; }
    .justify-content--xxl-end { justify-content: end; }
    .justify-content--xxl-between { justify-content: space-between; }
    .justify-content--xxl-evenly { justify-content: space-evenly; }
    .justify-content--xxl-around { justify-content: space-around; }
}