/* Basis */
* { box-sizing: border-box; }
:root { --page-bg: #f4f6f8; --bg-orange: #ed4024; --bg-lightgrey: #ddeaee; --bg-fontblack: #333333; --bg-grey: #a8a6ab; --bg-white: #ffffff; --bg-blue: #0073c7; --bg-brown: #472412; --site-max: 1200px; --wrapper-max: 1200px; --mobile-switch }
html,
body { margin: 0; padding: 0; }
@font-face { font-family: 'Inter'; src: url('fonts/Inter-VariableFont_opsz,wght.woff2') format('woff2'); font-weight: 100 900; font-style: normal; font-display: swap; }

body { background: var(--bg-white); color: var(--bg-fontblack); font-family: 'Inter', Helvetica, Arial, sans-serif; line-height: 1.4; font-size: clamp(12px, 1.25vw, 15px); }
a { color: inherit; }
img { display: block; max-width: 100%; }
.font18 { font-size: clamp(9px, 1.08vw, 13px); font-weight: 800; line-height: 1.1; }
.font21 { font-size: clamp(12px, 1.25vw, 15px); line-height: 1.4; }
.font26 { font-size: clamp(15px, 1.50vw, 18px); line-height: 1.6; }
.font41 { font-size: clamp(12px, 2.08vw, 25px); font-weight: 700; line-height: 1.1; }
.font49 { font-size: clamp(20px, 3.0vw, 35px); font-weight: 600; line-height: 1; }
.font91, blueback .font49 { font-size: clamp(30px, 5vw, 60px); font-weight: 500; line-height: 1.1; }
.font142 { font-size: clamp(45px, 7.5vw, 90px); font-weight: 500; line-height: 0.9 }
.wrapper { width: min(var(--wrapper-max),100%); margin: 60px auto; }

.arrow::before {
    content: "→";
}

/* FONT: mobile switch */
@media (max-width: 750px) {
    body { font-size: clamp(15px, 1.25vw, 15px); }
    .font18 { font-size: clamp(9px, 2.08vw, 13px); font-weight: 800; line-height: 1.1; }
    .font41 { font-size: clamp(12px, 3.08vw, 25px); font-weight: 700; line-height: 1.1; }
    .font49 { font-size: clamp(35px, 5vw, 35px); font-weight: 600; line-height: 1.0; }
    .font91, blueback .font49 { font-size: clamp(30px, 10vw, 60px); font-weight: 500; line-height: 1.1; }
    .font142 { font-size: clamp(45px, 15vw, 90px); font-weight: 500; line-height: 0.9 }
}


.wrapper ul { list-style: none; padding-left: 0; }
.wrapper ul li { position: relative; padding-left: 1.2em; }
.wrapper ul:not(.sublist):not(.sublist2)  li::before { content: ""; position: absolute;  left: 5px;  top: 50%;  transform: translateY(-50%); width: 0.45em; height: 0.45em; background-color:  var(--bg-blue);}



/*******/
/* NAVMENU  mobile first */
.navmenu-shell { position: absolute; top: 30px; left: 0; width: 100%; z-index: 30; pointer-events: none; }
.navmenu { width: min(var(--site-max), calc(100% - 10px)); margin: 5px auto; background: var(--bg-white); box-shadow: 0 16px 40px rgba(0, 0, 0, 0.12); pointer-events: auto; }
    .navmenu .bar { display: flex; align-items: center; gap: 14px; min-height: 72px; padding: 0 14px; flex-wrap: wrap; }
    .navmenu .logo { width: 120px; height: 65px; background: url(../css/Logo.svg) no-repeat; }
    .navmenu .mobile-toggle,
    .navmenu .submenu-toggle { display: none; }
    .navmenu .tools { display: flex; align-items: center; gap: 8px; margin-left: auto; order: 2; }
    .navmenu .track { display: inline-flex; align-items: center; justify-content: center; min-height: 38px; padding: 0 10px; background: var(--bg-lightgrey); color: var(--bg-blue); font-size: 0.86rem; font-weight: 700; white-space: nowrap; }
    .navmenu .lang { position: relative; display: inline-flex; align-items: center; }
    .navmenu .lang-select { appearance: none; -webkit-appearance: none; -moz-appearance: none; min-height: 38px; padding: 0 28px 0 10px; border: 1px solid var(--bg-lightgrey); background: var(--bg-white); color: var(--bg-blue); font-size: 0.86rem; font-weight: 700; cursor: pointer; }
    .navmenu .lang-dot { position: absolute; right: 11px; top: 50%; width: 7px; height: 7px; margin-top: -3.5px; border-radius: 50%; background: var(--bg-blue); pointer-events: none; }
    .navmenu .hamburger { display: inline-flex; width: 42px; height: 42px; align-items: center; justify-content: center; cursor: pointer; order: 3; margin-left: 0; }
        .navmenu .hamburger span { position: relative; display: block; width: 22px; height: 2px; background: var(--bg-blue); }
            .navmenu .hamburger span::before,
            .navmenu .hamburger span::after { content: ""; position: absolute; left: 0; width: 22px; height: 2px; background: var(--bg-blue); }
            .navmenu .hamburger span::before { top: -7px; }
            .navmenu .hamburger span::after { top: 7px; }
    .navmenu .main { display: none; width: 100%; order: 4; }
    .navmenu .mobile-toggle:checked ~ .main { display: block; }
    .navmenu .list { list-style: none; margin: 5px; padding: 0; display: block; background: var(--bg-white); }
    .navmenu .item { padding-top: 14px; border-bottom: 1px solid var(--bg-lightgrey); position: relative; }

    .navmenu .link,
    .navmenu .toggle-label { display: block; width: 100%; padding: 0 0 14px; color: var(--bg-blue); font-size: 15px; font-weight: 600; cursor: pointer; }
    .navmenu .item.has-dropdown > .link::after,
    .navmenu .item.has-dropdown > .toggle-label::after { content: none; }
    .navmenu .dropdown { display: block; width: 100%; margin-bottom: 4px; }
    .navmenu .dropdown-content { padding: 0 0 8px; }
    .navmenu .dropdown-title,
    .navmenu .dropdown-text,
    .navmenu .dropdown-media { display: none; }
    .navmenu .sublist,  .navmenu .sublist2 { list-style: none; margin: 0; padding: 0; display: block; }
        .navmenu .sublist li { border-top: 1px solid var(--bg-lightgrey); }
    .navmenu .subitem-link { display: block; padding: 12px 0 12px 12px; color: var(--bg-blue); font-size: 0.98rem; font-weight: 600; background: transparent; }

.navmenu .sublist2 a{font-size:0.7rem;margin-left:10px;}

@media (min-width: 981px) {
       .navmenu { width: min(var(--site-max), calc(100% - 32px)); margin: 0 auto; }
        .navmenu .bar { min-height: 78px; padding: 0 28px; gap: 20px; flex-wrap: nowrap; }

        .navmenu .tools { gap: 10px; order: 3; margin-left: auto; }
        .navmenu .track { padding: 0 14px; font-size: 0.92rem; }
        .navmenu .lang-select { padding: 0 28px 0 12px; font-size: 0.92rem; }
        .navmenu .hamburger { display: none; }
        .navmenu .main { display: block; width: auto; flex: 1 1 auto; order: 2; }
        .navmenu .list { display: flex; align-items: center; gap: 2px; margin: 0; background: transparent; }
        .navmenu .item { padding-top: 0; border-bottom: 0; }
        .navmenu .link,
        .navmenu .toggle-label { display: inline-flex; align-items: center; min-height: 78px; width: auto; padding: 0 10px; font-weight: 600; transition: color 0.2s ease; gap: 0.4em; }
            .navmenu .link:hover,
            .navmenu .toggle-label:hover,
            .navmenu .item.is-active > .link,
            .navmenu .item.is-active > .toggle-label { color: var(--bg-orange); }
        .navmenu .item.has-dropdown > .link::after,
        .navmenu .item.has-dropdown > .toggle-label::after { content: ""; width: 0.35em; height: 0.35em; border-radius: 50%; background: var(--bg-orange); display: inline-block; transform: rotate(45deg); transform-origin: center; flex: 0 0 auto; }
        .navmenu .dropdown { position: absolute; top: 100%; left: 0; width: 760px; display: none; background: var(--bg-white); box-shadow: 0 20px 46px rgba(0, 0, 0, 0.16); z-index: 60; }
        .navmenu .item:hover > .dropdown { display: grid; grid-template-columns: 1.05fr 0.95fr; }
        .navmenu .dropdown-content { padding: 28px; }
        .navmenu .dropdown-title { display: block; margin: 0 0 10px; font-size: 1.05rem; font-weight: 800; color: var(--bg-blue); }
        .navmenu .dropdown-text { display: block; margin: 0 0 18px; opacity: 0.75; max-width: 92%; }
        .navmenu .dropdown-media { display: block; position: relative; overflow: hidden; min-height: 100%; }
            .navmenu .dropdown-media img { width: 100%; height: 100%; object-fit: cover; }
        .navmenu .dropdown-overlay { position: absolute; left: 0; right: 0; bottom: 0; padding: 20px; background: linear-gradient(to top, rgba(71, 36, 18, 0.8), rgba(71, 36, 18, 0.08)); color: var(--bg-white); }
            .navmenu .dropdown-overlay h4 { margin: 0 0 8px; font-size: 1rem; font-weight: 800; }
            .navmenu .dropdown-overlay p { margin: 0; font-size: 0.92rem; line-height: 1.5; }
        .navmenu .sublist { display: grid; gap: 8px; }
            .navmenu .sublist li { border-top: 0; }
        .navmenu .subitem-link { padding: 5px 12px; font-size: 1rem; font-weight: 700; transition: color 0.2s ease, background 0.2s ease; }
            .navmenu .subitem-link:hover,
            .navmenu .subitem-link.is-active { color: var(--bg-orange); background: #f8fafb; }
        .navmenu .item.industries .sublist,
        .navmenu .item.over .sublist { grid-template-columns: 1fr 1fr; gap: 8px 12px; }

.navmenu .sublist2 a{font-size:0.7rem;margin-left:10px;}
}

@media (max-width: 750px) {
    .navmenu-shell { top: 0px; }
    .navmenu { width: 100%; margin: 0 }
}


/*******/
/* header-banner */
.header { position: relative; overflow: visible; }
.header-banner { position: absolute; bottom: -75px; min-height: 130px; z-index: 20; width: min(var(--wrapper-max), 100%); }
.header-banner-content { position: relative; z-index: 2; min-height: 130px; display: grid; grid-template-columns: 58% 42%; color: #fff; }
.header-banner::before,
.header-banner::after { content: ""; position: absolute; inset: 0; }
.header-banner::before { background: var(--bg-blue); clip-path: polygon(0 0, 58.75% 0, 58.75% 65.9%, 62.5% 100%, 0 100%); z-index: 0; }
.header-banner::after { background: var(--bg-orange); clip-path: polygon(58.75% 0, 100% 0, 100% 100%, 62.5% 100%, 58.75% 65.9%); z-index: 1; }
.header-banner-left,
.header-banner-right { display: flex; align-items: center; }
.header-banner-left { justify-content: space-between; gap: 40px; padding: clamp(24px, 3.17vw, 38px) clamp(22px, 4.33vw, 52px); }
.header-banner-brand { width: 350px; height: 45px; background: url(../css/thatshow_white.svg) no-repeat; }
.header-banner-text { max-width: 560px; line-height: 1.35; font-weight: 400; }
.header-banner-right { justify-content: center; padding: 40px; }
.header-banner-button { display: inline-flex; align-items: center; justify-content: space-between; gap: 28px; min-width: 190px; padding: 5px 18px; border: 1px solid #fff; color: #fff; text-decoration: none; line-height: 1; position: relative; z-index: 3; }
    .header-banner-button .arrow { font-size: 26px; line-height: 1; }



/*******/
/* Header image */
/* .is-cover = beeldvullend, gecentreerd, crop toegestaan */
.header { width: 100%; margin-bottom: 40px; background: var(--bg-grey); }
    .header > img { display: block; width: 100%; height: auto; }
    .header .shade,
    .header .content { display: none; }
    .header.is-cover .shade { display: block; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(71, 36, 18, 0.2), rgba(71, 36, 18, 0.08)); }
    .header.is-cover .content { position: absolute; inset: 0; z-index: 1; width: min(var(--wrapper-max), calc(100% - 32px)); text-align: left; margin: 0 auto; display: flex; align-items: center; color: var(--bg-white); }
    .header h1 { max-width: 560px; padding: clamp(24px, 3.17vw, 38px) }

.header { position: relative; height: calc(50vh - 75px); margin-bottom: 100px }
    .header.fullheight { position: relative; height: calc(100vh - 75px); margin-bottom: 100px }
    .header > img { width: 100%; height: 100%; object-fit: cover; object-position: center center; }

.header-banner.blue::after { background: var(--bg-blue) }
.header-banner.orange::before { background: var(--bg-orange) }

@media (max-width: 750px) {
    .header.is-cover .content { width: calc(100% - 20px); padd5ing: 0 18px 34px; }
    .header-banner-content { display: block }
    .header-banner-left { display: block; }
    .header-banner-brand { margin-bottom: 15px; width: 100% }
    .header-banner-button { display: block; width: 100%; background: var(--bg-orange); border: none; height: 50px; }
    .header-banner-right { padding: 0 }
    .header-banner::after { background: var(--bg-blue); clip-path: unset }
    .phototext .readmore, .phototext .readmore .arrow { color: var(--bg-white) }
}






/*******/
/* moving heror */
.moving-hero { position: relative; overflow: hidden; isolation: isolate; background: radial-gradient(22% 26% at 8% 10%, rgba(237,64,36,.14) 0%, rgba(237,64,36,0) 100%), linear-gradient( 90deg, #ef5a1b 0%, #db6f4b 16%, #b08089 34%, #8c88a8 48%, #4e84be 64%, #0073c7 80%, #0073c7 100% ); }
.moving-hero__vector svg { position: absolute; top: 50%; left: 50%; width: 100%; height: 100%; min-width: 100%; min-height: 100%; display: block; transform: translate(-50%, -50%) scale(1.14); }
.moving-hero__content { position: relative; z-index: 3; display: grid; place-items: center; text-align: center; padding: 88px 20px; }
.moving-hero__inner { max-width: 760px; color: var(--white); }
.moving-hero__vector { position: absolute; inset: 0; z-index: 1; opacity: .20; mix-blend-mode: normal; pointer-events: none; will-change: transform; animation: vectorFloat 6.8s ease-in-out infinite alternate; overflow: hidden; }
    .moving-hero__vector svg { position: absolute; top: 50%; left: 50%; width: 100%; height: 100%; min-width: 100%; min-height: 100%; display: block; transform: translate(-50%, -50%) scale(1.14); }
.moving-hero__title { margin: 0 0 5px; font-size: 50px; line-height: 1; font-weight: 800; color: var(--bg-white) }
.moving-hero__text { margin: 0 auto 20px; max-width: 680px; font-size: 35px; line-height: .95; aletter-spacing: -.035em; font-weight: 500; color: var(--bg-white) }
.moving-hero__button { position: relative; display: inline-flex; align-items: center; justify-content: space-between; gap: 28px; min-width: 340px; padding: 18px 24px; border: 1.5px solid rgba(255,255,255,.9); color: #fff; text-decoration: none; overflow: hidden; transition: color .45s ease, border-color .45s ease; backdrop-filter: blur(1px); }
    .moving-hero__button::before { content: ""; position: absolute; inset: 0; background: rgba(255,255,255,.10); transform: scaleX(0); transform-origin: left center; transition: transform .5s ease; z-index: 0; }
    .moving-hero__button:hover::before { transform: scaleX(1); }
    .moving-hero__button > span { position: relative; z-index: 1; font-size: clamp(18px, 1.7vw, 26px); line-height: 1; }
    .moving-hero__button .arrow { font-size: clamp(34px, 2.8vw, 48px); line-height: .8; font-weight: 300; }

@keyframes vectorFloat {
    0% { transform: translateY(-14px); }
    50% { transform: translateY(14px); }
    100% { transform: translateY(-6px); }
}

@media (prefers-reduced-motion: reduce) {
    .moving-hero__vector { animation: none; }
}

@media (max-width: 900px) {
    .moving-hero,
    .moving-hero__content { min-height: 460px; }
    .moving-hero__button { min-width: 0; width: 100%; max-width: 360px; }
    .moving-hero__bg::before { left: 12%; width: 78%; }
    .moving-hero__bg::after { left: 22%; width: 56%; }
    .moving-hero__vector svg { transform: translate(-50%, -50%) scale(1.2); }
}



/*******/
/* phototext blok */
.phototext { background: var(--bg-lightgrey); }
.phototext__inner { display: grid; grid-template-columns: 1fr 1fr; }
.phototext__left,
.phototext__right { min-width: 0; aspect-ratio: 1 / 1; }
.phototext__left { padding: 60px 42px 35px 42px; display: flex; flex-direction: column; }
.phototext__copy { max-width: 460px; }
.phototext__eyebrow, .phototext__title { margin: 0 0 17px; color: var(--bg-blue); }
.phototext__title { margin: 0 0 10px; }
.phototext__text { max-width: 590px; margin: 0; color: var(--bg-fontblack); }
.phototext__stats { display: grid; grid-template-columns: repeat(2, minmax(0, min(200px, 20vw))); gap: 8px; margin-top: auto; margin-bottom: 24px; max-width: 416px }
.phototext__stat { min-height: 60px; background: #f4f4f4; border-bottom: 3px solid var(--bg-orange); padding: min(17px, 1.42vw) min(15px, 1.25vw) min(8px, 0.67vw) min(15px, 1.25vw); display: flex; align-items: center; justify-content: space-between; }
.phototext__stat-text { min-width: 0; }
.phototext__stat-label { color: var(--bg-blue); font-weight: 700 }
.phototext__stat-icon { width: 40px; height: 40px; flex: 0 0 64px; display: flex; align-items: center; justify-content: center; }
    .phototext__stat-icon img { width: 100%; height: 100%; object-fit: contain; display: block; }
.phototext.blueback .phototext__left { background-image: url("blueback.svg"); background-repeat: no-repeat; background-position: left top; background-size: 210% auto !important; }
.phototext.blueback .phototext__eyebrow, .phototext.blueback .phototext__title, .phototext.blueback .phototext__text { color: var(--bg-white) }
.phototext.blueback .phototext__title { margin: 0 0 clamp(40px, 12.295vw, 150px); }
.phototext .readmore { border-color: var(--bg-blue) }
    .phototext .readmore ::before { content: ""; position: absolute; inset: 0; background: var(--bg-white, #fff); transform: scaleX(0); transform-origin: left center; transition: transform 0.5s ease; z-index: 0; }
    .phototext .readmore :hover::before { transform: scaleX(1); }
    .phototext .readmore > span { color: var(--bg-blue) }
    .phototext .readmore .arrow { font-size: 26px; line-height: 1; color: var(--bg-orange); }
    .phototext .readmore :hover { color: var(--bg-orange); }
.phototext__cta { margin: auto 0 }
/* rechter beeldvlak */
.phototext__right { position: relative; background: #dbe3e7; border-left: 1px solid rgba(0, 0, 0, 0.03); display: flex; align-items: center; justify-content: center; }
.phototext__image-placeholder { font-size: 18px; font-weight: 700; line-height: 1.15; text-transform: uppercase; color: var(--blue); text-align: center; }
.phototext__image { width: 100%; height: 100%; object-fit: cover; display: block; }

/* effect */
.phototext__right { position: relative; overflow: hidden; }
    .phototext__right img,
    .phototext__image { width: 100%; height: 100%; object-fit: cover; display: block; clip-path: inset(0 100% 0 0); transform: scale(1.03); opacity: 0; filter: saturate(0.94) contrast(0.97); transition: clip-path 1.15s cubic-bezier(0.22, 1, 0.36, 1), transform 1.2s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.8s ease, filter 1.1s ease; }
    .phototext__right.is-visible img,
    .phototext__right.is-visible .phototext__image { clip-path: inset(0 0 0 0); transform: scale(1); opacity: 1; filter: saturate(1) contrast(1); }


/*PHOTO TEXT: mobile switch*/
@media (max-width: 750px) {
}


/* responsive */
@media (max-width: 750px) {
    .phototext__inner { display: flex; flex-direction: column-reverse; }
    .phototext__right { min-height: 420px; }
    .phototext__left { padding: 56px 28px 36px; aspect-ratio: unset }
    .phototext__stats { grid-template-columns: repeat(2, minmax(0, 1fr)); margin-top: 40px; }
    .phototext.blueback ..phototext__left { background-size: 420% auto !important; }
}


/*******/
/* FAQ list */
.faqlist { }
.faq-item { margin-bottom: 8px;  overflow: hidden; background: var(--bg-lightgrey); }
.faq-question { width: 100%; padding: 18px 22px; text-align: left; cursor: pointer; display: flex; justify-content: space-between; align-items: center; background: var(--bg-lightgrey); color: var(--bg-blue); appearance: none; -webkit-appearance: none; border: none; }
.faq-icon { font-size: 24px; font-weight: bold; margin-left: 20px; }
.faq-answer { display: none; padding: 18px 22px; font-size: 16px; line-height: 1.5; color: #333; }
.faq-item.active .faq-answer { display: block; }

/*******/
/* Vacacture list */
.vacaturelist { padding: 0; color: var(--bg-fontblack); display: grid; grid-template-columns:  repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; align-items: stretch; }
.vacature-item.is-hidden { display: none; }
    .vacaturelist > div { display: flex; flex-direction: column; min-width: 0; height: 100%; color: var(--bg-blue); background: var(--bg-lightgrey); }
    .vacaturelist img { display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
    .vacaturelist .hoverlink { margin-top: auto; }
    .vacaturelist .location { align-self: flex-start; width: fit-content; background: var(--bg-orange); display: inline-block; margin-top: -41px; padding: 10px 35px; color: #fff; }
    .vacaturelist .textblock { display: flex; flex-direction: column; flex: 1 1 auto; min-width: 0; padding: 20px }
        .vacaturelist .textblock .title { margin-bottom: 10px; min-height: 55px; }
        .vacaturelist .textblock .content { display: flex; flex-direction: column; gap: 20px; flex: 1 1 auto; margin-bottom: 30px }
.vacatureselect { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 35px; }
    .vacatureselect .selectbox,
    .vacatureselect .dropdown,
    .vacatureselect select { width: 227px; }
    .vacatureselect label,
    .vacatureselect .select-label { display: block; margin-bottom: 14px; font-size: 15px; font-weight: 700; line-height: 1; text-transform: uppercase; color: #0071ce; }
    .vacatureselect select { height: 42px; padding: 0 44px 0 18px; font-size: 15px; font-weight: 400; color: #005eb8; background-color: #fff; border: 1px solid #5da2ff; border-radius: 0; appearance: none; -webkit-appearance: none; -moz-appearance: none; cursor: pointer; }
    /* Plusje rechts in de dropdown */
    .vacatureselect .selectbox,
    .vacatureselect .dropdown { position: relative; }
        .vacatureselect .selectbox::after,
        .vacatureselect .dropdown::after { content: "+"; position: absolute; right: 20px; bottom: 11px; font-size: 13px; font-weight: 700; color: #e54200; pointer-events: none; }

/* Mobiel */
@media (max-width: 600px) {
    .vacatureselect { flex-direction: column; gap: 20px; }
        .vacatureselect .selectbox,
        .vacatureselect .dropdown,
        .vacatureselect select { width: 100%; }
}


/*******/
/* Contact detail */
.contactline a { border: 2px solid var(--bg-blue); padding: 10px 30px; margin-right: 20px; display: inline-block; color: var(--bg-blue);text-decoration:none }


/*******/
/* vacature detailpagina */


/*******/
/* video */
/* videoblock */
.videocontainer { position: relative; width: 100%; padding-bottom: 56.25%; overflow: hidden }
    .videocontainer .hlsvideo-wrap { position: absolute; inset: 0; width: 100%; height: auto; overflow: hidden; }
        .videocontainer .hlsvideo-wrap > video { width: 100%; object-fit: cover; object-position: center center; display: block; }
.embed-container { position: relative; width: 100%; height: 100vh; padding-bottom: 56.25%; overflow: hidden; }
.video-wrap { --videoRatio: calc(16 / 9); padding: 0; margin: 0; width: 100vw; height: 100vh; overflow: hidden; position: relative; }
.hlsvideo-wrap { position: absolute; inset: 0; width: 100%; height: 100%; overflow: hidden; }
    .hlsvideo-wrap > video { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; }

@supports not (aspect-ratio: 1/1) {
    .video-wrap { height: 0; padding-top: 56.25%; }
}


/*******/
/* textline3col */
.textline3col { display: grid; padding: 0 40px; gap: 16px; grid-template-columns: 2fr 2fr; }
    .textline3col > div:first-child { grid-column: 1 / -1; }

@media (max-width: 750px) {
    .textline3col { display: block }
        .textline3col > div { margin-bottom: 20px }
}

/*******/
/* textblockcol1  */
.textblockcol1 {   display: grid;  padding: 0 40px;  gap: 16px;  grid-template-columns: 1fr;  max-width: 800px;  margin: 0 auto;  box-sizing: border-box; }

@media (max-width: 750px) {
    .textblockcol1 { display: block }
        .textblockcol1 > div { margin-bottom: 20px }
}

/*******/
/* textblockcol2  */
.textblockcol2 { display: grid; padding: 0 40px; gap: 16px; grid-template-columns: 2fr 2fr; }

@media (max-width: 750px) {
    .textblockcol2 { display: block }
        .textblockcol2 > div { margin-bottom: 20px }
}


/*******/
/* TITLE */
.titlewrapper { padding: 20px 0; }
    .titlewrapper h2 { margin: 0; width: 100%; text-align: center; color: var(--bg-blue); transform: translateY(36px) scale(0.82); transform-origin: center center; filter: blur(8px); opacity: 0; transition: transform 2s cubic-bezier(0.22, 1, 0.36, 1), filter 1s ease, opacity 0.8s ease; }
        .titlewrapper h2.is-visible { transform: translateY(0) scale(1); filter: blur(0); opacity: 1; }

/*******/
/* Photo*/
.wrapper.photo, .wrapper.photo img { width: 100% }

/*******/
/* caroussel*/
.services-slider { padding: 0; }
.services-slider__viewport { position: relative; overflow: hidden; cursor: grab; user-select: none; -webkit-user-select: none; touch-action: pan-y; }
.services-slider__track { display: flex; gap: 12px; will-change: transform; }
.services-slider__item { position: relative; flex: 0 0 clamp(200px, 20vw, 300px); aspect-ratio: 0.85 / 1; overflow: hidden; text-decoration: none; color: #fff; background: #d9d9d9; }
    .services-slider__item img { width: 100%; height: 100%; object-fit: cover; display: block; pointer-events: none; }
    .services-slider__item::after { content: ""; position: absolute; inset: 0; background: linear-gradient( to top, rgba(0, 0, 0, 0.42) 0%, rgba(0, 0, 0, 0.14) 36%, rgba(0, 0, 0, 0) 68% ); pointer-events: none; }
.services-slider__title { position: absolute; left: 22px; bottom: 18px; z-index: 2; color: #fff; pointer-events: none; }

@media (max-width: 750px) {
    .services-slider__track { gap: 12px; }
    .services-slider__item { flex-basis: min(33vw, 340px); }
    .services-slider__title { left: 16px; bottom: 14px; }
}

/*******/
/* textblock */
.textblock { color:var(--bg-blue);padding:0 40px}


/*******/
/* blocklist */
.blocklist { padding: 0; color: var(--bg-fontblack); display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 24px; align-items: stretch; }
.blocklist.colcount2 {grid-template-columns: repeat(2, minmax(0, 1fr)); }
.blocklist.colcount3 {grid-template-columns: repeat(3, minmax(0, 1fr)); }
.blocklist.colcount4 {grid-template-columns: repeat(4, minmax(0, 1fr)); }
.blocklist.colcount5 {grid-template-columns: repeat(5, minmax(0, 1fr)); }
    .blocklist > div { display: flex; flex-direction: column; min-width: 0; height: 100%; color: var(--bg-blue); background: var(--bg-lightgrey); }
    .blocklist img { display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
    .blocklist .hoverlink { margin-top: auto; }
    .blocklist .textblock { display: flex; flex-direction: column; flex: 1 1 auto; min-width: 0; padding: 20px }
       .blocklist .textblock .title { margin-bottom: 10px;min-height:55px; }
       .blocklist .textblock .content { display: flex; flex-direction: column; gap: 20px; flex: 1 1 auto; margin-bottom: 30px }


/*******/
/* footer */
.footer { background: var(--bg-lightgrey); color: var(--bg-blue); margin-bottom: 0; padding-top: 140px; padding-bottom: 40px }
    .footer.contactbar { background: var(--bg-orange); color: var(--bg-white); padding-top: 40px; }
    .footer .wrapper { margin: 0 auto; }
    .footer .menuitems > div { display: flex; flex-direction: column; }
    .footer .sublist,  .footer .sublist2 { list-style: none; margin: 0; padding: 0; display: block; }

    .footer .logobar { display: block; width: 80%; background: url(../css/thatshow_blue.svg) no-repeat; display: block; background-size: 100% auto; min-height: 230px; padding: 40px 0; margin-left: 10% }
    .footer .menuitems, .footer .contactbar { display: inline-flex; gap: 50px; flex-wrap: wrap; margin-top: 20px; width: 100% }
        .footer .menuitems .sublist { list-style: none; margin: 0; padding: 0; }
            .footer .menuitems .sublist > li { display: block }
        .footer .menuitems .toplevelmenu, .footer .menuitems h3 { font-weight: 700; margin: 10px 0; display: inline-block; }
        .footer.contactbar .wrapper { margin-top: 0 }
.footerbar { background: var(--bg-white); color: var(--bg-orange); display: flex; justify-content: space-between; align-items: center; }
    .footerbar .companyname { font-weight: 700 }
    .footerbar a { text-decoration: none }


/*******/
/* hoverlink */
.hoverlink { transition: color 0.5s ease; display: inline-flex; align-items: center; justify-content: space-between; gap: 28px; min-height: 40px; min-width: 190px; margin-bottom: 10px; padding: 5px 18px; border: 1px solid var(--bg-white); color: var(--bg-white); text-decoration: none; line-height: 1; position: relative; z-index: 3; text-decoration: none }
    .hoverlink::before { content: ""; position: absolute; inset: 0; background: var(--bg-lightgrey); transform: scaleX(0); transform-origin: left center; transition: transform 0.5s ease; z-index: -1; }
    .hoverlink:hover::before { transform: scaleX(1); }
    .hoverlink > span { position: relative; z-index: 1; }
    .hoverlink .arrow { font-size: 26px; line-height: 1; }
    .hoverlink:hover, .hoverlink:hover .arrow { color: var(--bg-fontblack); }
    .hoverlink.bluetext { border-color: var(--bg-blue); color: var(--bg-blue); }
    .hoverlink.orangetext { border-color: var(--bg-orange); color: var(--bg-orange); }
    .hoverlink.whitetext { border-color: var(--bg-white); color: var(--bg-white); }
    .hoverlink.orangearrow .arrow { color: var(--bg-orange) }
    .hoverlink.bluearrow .arrow { color: var(--bg-blue) }
    .hoverlink.blueback:hover { color: var(--bg-white); }
    .hoverlink.orangeback:hover, .hoverlink:hover .arrow { color: var(--bg-white); }
    .hoverlink.orangeback::before { background: var(--bg-orange); }
    .hoverlink.blueback::before { background: var(--bg-blue); }
