*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { min-height: 100%; font-size: 10px; line-height: 1.4; -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; }

/*** ---------- 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: 14rem; }
    .padding-bottom--large { --pb: 14rem; }
}

/*** ---------- Typography ---------- ***/
h1, .h1, h2, .h2, h3, .h3, h4, .h4 { line-height: 1.1; } 
h1, .h1 { font-size: clamp(3.2rem, 1vw + 3.5rem, 6.4rem); }
h2, .h2 { font-size: clamp(3.2rem, 1vw + 3rem, 4.8rem); }
h3, .h3 { font-size: clamp(2.4rem, 1vw + 3rem, 3.2rem); }
/* .text p { line-height: 1.4; } */
.text ul { padding-left: 3.2rem; }
.text > * { --mt: 1em; margin: 0; } 
.text {
    > * + * { margin-top: var(--mt); } 
    > * + img, > img + * { margin-top: 2em; }
    > .card + * { margin-top: 2em; }
}
.text a:not(.btn) { color: inherit; text-decoration: underline; }

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

.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 { color: var(--clr-primary); }

/*** ---------- 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; }
[class*="aspect-ratio"]:not(.aspect-ratio--default) > video { width: 100%; height: 100%; object-fit: cover; }
.aspect-ratio--16by9 { --ratio-percentage: 56.25%; }
.aspect-ratio--4by3 { --ratio-percentage: 75%; }
.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); }
.kraft-icon.kraft-icon--bg-pattern { --src: url('/wp-content/themes/kraft/assets/images/bg-pattern.svg'); }
.kraft-icon.kraft-icon--bg-pattern::after { -webkit-mask-size: 500rem; mask-size: 500rem; -webkit-mask-position: right center; mask-position: right center; }

/*** ---------- Buttons ---------- ***/
.btn, .page-numbers, .wpcf7-submit {

    --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: 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: 400; min-height: 4.5rem;

    transition-property: color, background, border-color, box-shadow; transition-duration: var(--ts-duration); transition-timing-function: var(--ts-function);
}

.btn i { font-size: 1em; }
.btn:hover, .page-numbers:hover, .wpcf7-submit:hover { color: var(--hover-clr); background: var(--hover-bg-clr); border: var(--hover-border); }
.btn:focus, .page-numbers:focus, .wpcf7-submit:focus { color: var(--focus-clr); background: var(--focus-bg-clr); border: var(--focus-border); }
.btn:active, .page-numbers:active, .page-numbers.current, .wpcf7-submit:active { color: var(--active-clr); background-color: var(--active-bg-clr); border: var(--active-border); }

.btn.btn--primary, .wpcf7-submit { --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--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--link { --bg-clr: transparent; --clr: var(--clr-text); --p: 0; justify-content: space-between; min-height: 0; }

.btn.btn--link-icon, .btn.btn--link-icon-outline, .btn.btn--link-icon-outline-primary { --bg-clr: transparent; --p: 0!important; }
.btn.btn--link-icon i, .btn.btn--link-icon-outline i, .btn.btn--link-icon-outline-primary i { font-size: .85em; width: 3.2rem; height: 3.2rem; border-radius: 50%; background-color: rgba(var(--clr-dark-rgb), .4); display: grid; place-items: center; transition-property: background-color, border-color; transition-duration: var(--ts-duration); transition-timing-function: var(--ts-function); }
.btn.btn--link-icon:hover i, 
.btn.btn--link-icon-primary:hover i, 
.btn.btn--link-icon-outline:hover i, 
.btn.btn--link-icon-outline-primary:hover i, 
.card:hover .btn.btn--link-icon-primary i,
.card:hover .btn.btn--link-icon-outline i,
.card:hover .btn.btn--link-icon-outline-primary i { background-color: var(--clr-primary); border-color: var(--clr-primary); }

.btn.btn--link-icon-outline i { border: 2px solid #fff; background-color: transparent; }
.btn.btn--link-icon-outline-primary i { border: 2px solid var(--clr-primary); background-color: transparent; }

.btn.btn--link-outline-icon { --bg-clr: transparent; --p: 0; }
.btn.btn--link-outline-icon i { width: 3.2rem; height: 3.2rem; border-radius: 50%; border: 2px solid #fff; display: grid; place-items: center; transition-property: background-color, border-color; transition-duration: var(--ts-duration); transition-timing-function: var(--ts-function); }
.btn.btn--link-outline-icon:hover i { background-color: var(--clr-primary); border-color: var(--clr-primary); }

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

.btn .btn__words { display: grid; grid-template-areas: "words"; overflow: hidden;}
.btn .btn__words .words { white-space: nowrap; grid-area: words; }
.btn .btn__words .words .word { display: inline-flex; }
.btn .btn__words .words .word span { display: inline-block; position: relative; transition: transform 0.3s 0s ease-in-out, opacity 0.3s 0s ease-in-out; }
.btn .btn__words .words + .words .word span { transform: translateY(100%); opacity: 0; }
:is(.btn:hover, .card:hover) .btn__words .words .word span { opacity: 0; transform: translateY(-100%); transition: transform 0.4s 0s cubic-bezier(.85,0,.15,1), opacity 0.4s 0s ease-in-out; transition-delay: var(--ts-delay); }
:is(.btn:hover, .card:hover) .btn__words .words + .words .word span { opacity: 1; transform: translateY(0%); }

@media (min-width: 992px) {
    .btn.btn--large { min-height: 5.4rem; }
}

/*** ---------- Badge ---------- ***/
.badge-group { display: flex; flex-wrap: wrap; gap: .5rem; }
.badge { --p: .8rem 2rem; --br: 3rem; --bg-clr: var(--clr-primary); --clr: #fff; padding: var(--p); border-radius: var(--br); font-size: 1.4rem; font-weight: 500; background: var(--bg-clr); color: var(--clr); }

.badge.badge--light { --clr: #fff; --bg-clr: rgba(0,0,0,.15); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); }

.badge.badge--small { --p: .4rem 1.4rem; }

/*** ---------- 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: var(--clr-primary); color: #fff; 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: #fff; color: var(--clr-primary); }

/*** ---------- Cards ---------- ***/
.card {     
    --border: 1px solid var(--clr-border);
    --br: var(--border-radius);
    --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); font-weight: 700; 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.card--project .badge-group { position: absolute; top: 0; right: 0; left: 0; padding: var(--p); z-index: 1; }
.card.card--project .card__body { min-height: 25rem; display: flex; align-items: end; justify-content: space-between; }
.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--project .card__wrapper::after { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; background: var(--bg-gradient); z-index: -1; }

.card.card--product { border: none; background-color: transparent; }
.card.card--product .card__header .badge-group { position: absolute; top: 0; right: 0; left: 0; padding: var(--p); z-index: 1; }
.card.card--product .card__footer { display: grid; }
.card.card--product .product-sku { font-size: 1.4rem; opacity: .5; }
.card.card--product .product-price { font-size: clamp(1.8rem, 4vw, 2rem); }
.card.card--product .card-title { margin-top: 0; }
.card.card--product:hover .card__header img { transform: scale(1.1); }

.card .card__wrapper { position: relative; } 

.card.card--background { z-index: 1; background-color: transparent; border: none; }
.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__wrapper { display: flex; flex-direction: column; height: 100%; overflow: clip; transition: transform var(--ts-duration) var(--ts-function);  }
.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%; border-radius: var(--br); transition: backdrop-filter var(--ts-duration) var(--ts-function); }
.card.card--background:hover .card__header::before { backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
.card.card--background .card__body { color: #fff; transition: transform var(--ts-duration) var(--ts-function); }
.card.card--background .card__footer { padding: 2rem var(--p) 0; transition: transform var(--ts-duration) var(--ts-function); }
.card.card--background .btn.btn--link { --clr: #fff; }
.card.card--background:hover > * { transform: translate(1rem, -1rem); }

.card.card--services .card-title { font-size: clamp(1.8rem, 4vw, 2.8rem); }
.card.card--services .card__body { aspect-ratio: 1/1; display: flex; justify-content: space-between; align-items: end; }
.card.card--services .btn::after { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; }

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

.card.card--shortcode { border: none; background: var(--clr-dark-130); }
.card.card--shortcode.bg--pattern::after { display: none; }
.card.card--shortcode.bg--pattern .kraft-icon.kraft-icon--bg-pattern { --clr: rgba(255, 255, 255, .05); }
.card.card--shortcode.bg--pattern .kraft-icon.kraft-icon--bg-pattern::after { -webkit-mask-position: center; mask-position: center; }

.card.card--team .card-title { font-size: clamp(2.4rem, 4vw, 3.2rem); line-height: 1; }
.card.card--team .card__header { background: rgba(255, 255, 255, .1); }
.card.card--team .card__wrapper { position: relative; }
.card.card--team .card__wrapper::before { content: ''; display: block; padding-top: 145%; }
.card.card--team .card__wrapper .card__body { position: absolute; right: 0; bottom: 0; left: 0; }

.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: 992px) {
    .card.card--team { --p: 3.2rem; }
}

@media (min-width: 1200px) {
    .card.card--services { --p: 3.2rem; }
    .card.card--project { --p: 3.2rem; }
    .card.card--shortcode { --p: 4.8rem; }
}

/*** ---------- Logo ---------- ***/
.logo { display: inline-flex; }

/*** ---------- Header ---------- ***/
body.nav-open { overflow: hidden; position: relative; }

.header { z-index: 1030; }
.header .header__main { display: flex; align-items: center; gap: 2rem; }

.nav-toggle { cursor: pointer; display: flex; place-items: center;  }
.nav-toggle .nav-toggle__lines { width: 3.2rem; height: 3.2rem; border-radius: 50%; background-color: rgba(var(--clr-dark-rgb), .4); display: grid; place-items: center; transition: background-color var(--ts-duration) var(--ts-function); }
.nav-toggle .nav-toggle__lines .nav-toggle__lines-inner { position: relative; width: 1.2rem; height: 1.2rem; display: flex; align-items: center; }
.nav-toggle .nav-toggle__lines .nav-toggle__lines-inner span { display: block; width: 100%; height: .2rem; background-color: var(--clr); transition: background var(--ts-duration) var(--ts-function); }
.nav-toggle .nav-toggle__lines .nav-toggle__lines-inner span:nth-child(1) { position: absolute; top: 0; left: 0; transition: transform 350ms var(--ts-function), top 350ms var(--ts-function); }
.nav-toggle .nav-toggle__lines .nav-toggle__lines-inner span:nth-child(2) { transition: opacity 350ms var(--ts-function); }
.nav-toggle .nav-toggle__lines .nav-toggle__lines-inner span:nth-child(3) { position: absolute; bottom: 0; left: 0; transition: transform 350ms var(--ts-function), bottom 350ms var(--ts-function); }
.nav-toggle:hover .nav-toggle__lines { background-color: var(--clr-primary); }

.nav-toggle:hover .nav-toggle__lines .nav-toggle__lines-inner span { background-color: var(--hover-clr); }
.nav-toggle[aria-expanded="true"] .nav-toggle__lines .nav-toggle__lines-inner span:nth-child(1) { transform: rotate(45deg); top: 41%; }
.nav-toggle[aria-expanded="true"] .nav-toggle__lines .nav-toggle__lines-inner span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__lines .nav-toggle__lines-inner span:nth-child(3) { transform: rotate(-45deg); bottom: 48%; }

.header .navigation { background-color: rgba(var(--clr-dark-rgb), .6); backdrop-filter: blur(3rem); -webkit-backdrop-filter: blur(3rem); transform: translateY(-100%); pointer-events: none; position: fixed; top: 0; right: 0; bottom: 0; left: 0; display: flex; flex-direction: column; justify-content: center; width: 100%; height: 100dvh; z-index: 1020; transition: transform 1s var(--ts-function); }
.header .navigation > * { padding-inline: var(--inline-spacing); width: 100%; max-width: 1420px; margin-inline: auto; }
.header .navigation.is-active { transform: translateY(0); pointer-events: all; }
.header .navigation ul { list-style: none; }
.header .navigation .nav__item { width: 100%; display: flex; align-items: center; }
.header .navigation .nav__link { font-size: 2.4rem; width: 100%; color: #fff; padding: 1rem 0; }
.header .navigation .nav__link span { padding: .5rem 0; position: relative; }
.header .navigation .nav__link span::after { content: ''; position: absolute; top: 100%; left: 0; width: 0; height: .3rem; border-radius: 3rem; background-color: var(--clr-primary); transition: width var(--ts-duration) var(--ts-function); }
.header .navigation .nav__link:hover span::after { width: 100%; }
.header .navigation .nav__item .nav-link__toggle { width: 1rem; height: 1rem; font-size: 1.3rem; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.header .logo img { width: 15rem; z-index: 1030; transition: transform var(--ts-duration) var(--ts-function); }
.header .logo img:hover { transform: scale(1.05); }

@media (min-width: 992px) {
    .header .navigation .navigation__header,
    .header .navigation .navigation-dropdown .navigation-dropdown__header { display: none; }
    .header .navigation .navigation-dropdown .nav__link { min-width: 15rem; }
    .header .navigation .navigation-dropdown .nav__link:hover { background-color: #f2f2f2; }

    .header .navigation .nav__item .nav-link__toggle { position: absolute; right: 2rem; top: 50%; transform: translateY(-50%); }
    .header .navigation .nav > .nav__item--has-children > .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; }
}

/*** ---------- Footer ---------- ***/
footer { position: relative; margin-top: auto; }
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 { display: block; width: 100%; }
footer .footer__main .footer-menu .nav__link span { position: relative; padding: .5rem 0; }
footer .footer__main .footer-menu .nav__link span::after { content: ''; position: absolute; top: 100%; left: 0; width: 0; height: .2rem; background-color: var(--clr-primary); transition: width var(--ts-duration) var(--ts-function); }
footer .footer__main .footer-menu .nav__link:hover span::after { width: 100%; }
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); row-gap: 1rem; }
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; }
}

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

/*** ---------- Timeline ---------- ***/
.timeline { --size: 6.4rem; position: relative; overflow-y: clip; }
.timeline .timeline__item { position: relative; display: grid; grid-template-columns: var(--size) 1fr; align-items: center; row-gap: 3.2rem; opacity: 0; transform: translateY(6.4rem); transition-property: opacity, transform; transition-duration: 750ms; transition-timing-function: ease; }
.timeline .timeline__item .timeline__item-image::after { content: ''; position: absolute; top: 0; right: 0; left: 0; height: 100%; background-color: var(--clr-dark); transition-property: height; transition-duration: 1000ms; transition-timing-function: ease; }
.timeline .timeline__item.in { opacity: 1; transform: translateY(0); }
.timeline .timeline__item.in .timeline__item-image::after { height: 0; }
.timeline .timeline__item h2 { font-size: clamp(2.4rem, 1vw + 3rem, 3.2rem); }
.timeline .timeline__item .timeline__item-year { grid-row: span 2; font-size: 1.6rem; width: var(--size); 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-scroller { position: absolute; top: 0; bottom: 0; left: 0; z-index: 2; }
.timeline .timeline-scroller div { width: 3rem; height: 10rem; position: sticky; top: 40%; overflow-x: clip; }
.timeline .timeline-scroller div::before { content: ''; position: absolute; display: block; width: 1px; height: 100vh; bottom: 1.2rem; left: 0; border-left: 1px solid rgba(255,255,255,.5); }
.timeline .timeline-scroller div::after { content: ''; display: block; width: 10rem; height: 10rem; background: url('/wp-content/themes/kraft/assets/images/circular_saw_blade.png') no-repeat center/contain; position: absolute; top: 0; right: 0; animation: rotate 4s linear infinite; }


@media (min-width: 768px) {
    .timeline .timeline__item { display: grid; grid-template-columns: 1fr var(--size) 1fr; row-gap: 0; }
    .timeline .timeline__item .timeline__item-image { order: -1; align-self: start; }  
    .timeline .timeline__item:nth-child(odd) .timeline__item-image { order: 2;  }  
    .timeline .timeline__item:nth-child(odd) .timeline__item-body { order: -1;  }  
    /* .timeline .timeline__item::after { grid-column: 2; left: calc(var(--size) / 2); } */
    .timeline .timeline-scroller { left: 50%; transform: translateX(-50%); }
}

@media (min-width: 1200px) {
    .timeline .timeline__item + .timeline__item { padding-top: 4.8rem; }
}

/*** ---------- FAQ / Accordion ---------- ***/
.accordion { --br: var(--border-radius, .45rem); 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; --border: none; display: flex; align-items: center; justify-content: space-between; font-size: 1.6rem; padding: 1.4rem 2rem; border-radius: .45rem; 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 { --bg-clr: #d1ecf1; --clr: #0c5460; }
.kraft-alert.kraft-alert--warning, .wpcf7 form .wpcf7-response-output { --bg-clr: #fff3cd; --clr: #856404; }


/*** ---------- Forms ---------- ***/
[type="text"], [type="password"], [type="email"], [type="tel"], select, textarea { display: inline-block; border: 1px solid var(--clr-border); border-radius: var(--border-radius, .45rem); padding: .4rem 1rem; font-size: 1.6rem; min-height: 4.5rem; }
[type="radio"], [type="checkbox"] { display: inline-block; width: 1.6rem; height: 1.6rem; }
.form-label { display: block; width: 100%; }
.form-check { cursor: pointer; display: flex; align-items: center; column-gap: 1rem; }

/*** ---------- 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 label { font-size: 1.6rem; margin-bottom: .5rem; display: block; width: 100%; }
.wpcf7 form .wpcf7-form__group .wpcf7-form-control-wrap { display: grid; grid-template-columns: minmax(0, 1fr); width: 100%; }
.wpcf7 form .wpcf7-not-valid-tip { font-size: .8em; margin-top: .25rem; }
.wpcf7 form .wpcf7-response-output { order: -1; margin: 0 1rem; }

@media (min-width: 768px) {
    .wpcf7-form__group.wpcf7-form__group--6 { grid-column: span 6; }
}

/*** ---------- offcanvas ---------- ***/
.offcanvas { display: flex; flex-direction: column; width: 100%; max-width: var(--max-width, 100%); background-color: var(--clr-dark); }
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; }
}

/*** ---------- 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; }
.kraft-filter-results.is-loading > * { opacity: .5; pointer-events: none; }  

@media (min-width: 576px) {
    .kraft-filter-results { --gc: 2; }  
}

@media (min-width: 768px) {
    .kraft-filter-results { --gc: 3; }  
}

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

/*** ---------- Pagination ---------- ***/
.pagination { display: flex; justify-content: end; column-gap: 1rem; }
.pagination .page-numbers { min-height: 3.8rem; border-radius: 4rem; }
.pagination .page-numbers:not(.prev, .next) { --p: 0; min-width: 3.8rem; }

/*** ----- Forms ----- ***/
button, input[type="button"], input[type="reset"], input[type="submit"]:not(.wpcf7-submit, #searchsubmit) { border: 1px solid; border-color: #ccc #ccc #bbb; border-radius: 3px; background: #e6e6e6; color: rgba(0, 0, 0, 0.8); line-height: 1; padding: 0.6em 1em; }
button:hover, input[type="button"]:hover, input[type="reset"]:hover, input[type="submit"]:hover { border-color: #ccc #bbb #aaa; }
button:active, button:focus, input[type="button"]:active, input[type="button"]:focus, input[type="reset"]:active, input[type="reset"]:focus, input[type="submit"]:active, input[type="submit"]:focus { border-color: #aaa #bbb #bbb; }
input[type="text"], input[type="email"], input[type="url"], input[type="password"], input[type="search"], input[type="number"], input[type="tel"], input[type="date"], input[type="month"], input[type="week"], input[type="time"], input[type="datetime"], input[type="datetime-local"], input[type="color"], textarea { --h: 4.5rem; --padding: 1.5rem 1.5rem; --border-radius: .45rem; padding: var(--p); min-height: var(--h); background-color: var(--clr-dark); color: #fff; border: none; border-radius: var(--border-radius)!important; padding: var(--padding); -webkit-appearance: none; box-sizing: border-box; font-weight: 400; box-shadow: none; outline: none; }
input[type="text"]:focus, input[type="email"]:focus, input[type="url"]:focus, input[type="password"]:focus, input[type="search"]:focus, input[type="number"]:focus, input[type="tel"]:focus, input[type="date"]:focus, input[type="month"]:focus, input[type="week"]:focus, input[type="time"]:focus, input[type="datetime"]:focus, input[type="datetime-local"]:focus, input[type="color"]:focus, textarea:focus { outline-color: var(--clr-primary); outline-offset: -1px; }

select { border: 1px solid #ccc; }
textarea { width: 100%; }

.form-check { display: block; min-height: 1.5rem; padding-left: 1.5em; margin-bottom: 0.125rem; }
.form-check .form-check-input { float: left; margin-left: -1.5em; }
.form-check-input { width: 1em; height: 1em; margin-top: 0.25em; vertical-align: top; -webkit-appearance: none; -moz-appearance: none; appearance: none; background-image: var(--form-check-bg-image); background-repeat: no-repeat; background-position: center; background-size: contain; border: 1px solid #dee2e6; }
.form-check-input[type=checkbox] { border-radius: .25em; }
.form-check-input[type=radio] { border-radius: 50%; }
.form-check-input:checked { background-color: var(--clr-primary); border-color: var(--clr-primary); }
.form-check-input:checked[type=checkbox] { --form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e"); }
.form-check-input:checked[type=radio] { --form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e"); }

.form-select,
.form-control, select { --border: none; --border-radius: 5rem; color: var(--clr-dark); outline: none; min-height: 4.3rem; cursor: pointer; display: block; width: 100%; padding: .5rem 1.2rem; font-size: 1.4rem; font-weight: 400; line-height: 1.5; background-color: rgba(255,255,255,.75); background-clip: padding-box; border: var(--border); border-radius: var(--border-radius); }
.form-select:focus, select:focus {  }

.form-select option { color: var(--clr-dark); }

.form-buttons { display: flex; column-gap: .8rem; }
.form-buttons input { position: absolute; width: 0; height: 0; left: -999rem; }
.form-buttons .form-button { width: 100%;  
    --clr: var(--clr-primary);
	--bg-clr: var(--clr-primary-30);
    --border: 1px solid var(--clr-primary-30);
    --box-shadow: none;
    --padding: .5rem 1.8rem;
    --border-radius: .45rem;
    --fs: 1.6rem;
    --ts: var(--ts-15);
	--active-clr: #fff;
	--active-bg-clr: var(--clr-primary);
	--active-border: 1px solid var(--clr-primary);

	font-size: var(--fs); line-height: 1.2; font-weight: 600; cursor: pointer; text-decoration: none; min-height: 4.3rem; display: inline-flex; align-items: center; justify-content: center; 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: border var(--ts) ease, background-color var(--ts) ease, color var(--ts) ease, box-shadow var(--ts) ease;
}

.form-buttons input:checked + .form-button { color: var(--active-clr); background-color: var(--active-bg-clr); border: var(--active-border); }

.form-group { display: flex; }
.form-group .form-group__append,
.form-group .form-group__prepend { background-color: var(--clr-border); padding: .5rem; border-radius: .45rem; }
.form-group .form-group__prepend { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.form-group .form-group__append { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.form-group input:has( + .form-group__append) { border-top-right-radius: 0; border-bottom-right-radius: 0; }

/*** ---------- Archive ---------- ***/
.kraft-filter__sort { display: flex; align-items: center; column-gap: 2rem; }
.kraft-filter__sort label { white-space: nowrap; 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; }

/*** ---------- Keyframes ---------- ***/
@keyframes rotate {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

/*** ---------- Containers ---------- ***/
.container { padding-inline: var(--inline-spacing); width: 100%; max-width: 1420px; 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; }
}

