:root {
    --bezier: cubic-bezier(0.15, 0.6, 0.07, 1);
    --bezier-2: cubic-bezier(0, 0.6, 0.3, 1);
    --padding-inline: clamp(30px, 4vw, 80px);
    --padding-inline-double: calc(var(--padding-inline) * 2);
    --padding-inline-half: calc(var(--padding-inline) / 2);
    --padding-inline-third: calc(var(--padding-inline) / 3);
    --padding-block: clamp(80px, 7.5vw, 120px);
    --padding-block-triple: calc(var(--padding-block) * 3);
    --padding-block-double: calc(var(--padding-block) * 2);
    --padding-block-and-a-half: calc(var(--padding-block) * 1.5);
    --padding-block-half: calc(var(--padding-block) / 2);
    --padding-block-third: calc(var(--padding-block) / 3);
    --home-text-padding-inline: calc(10px + 0.8vw);
    --nav-border-gap: 0.5rem;
    --nav-sub-menu-padding-top: 1rem;
    --nav-sub-menu-transition-size: -10px;
    --nav-sub-item-marker-width: 4rem;
    --font-light: 'Montserrat', sans-serif;
    ;
    --font-regular: 'Montserrat', sans-serif;
    ;
    --font-medium: 'Montserrat', sans-serif;
    ;
    --font-bold: 'Montserrat', sans-serif;
    ;
    --font-styled: 'Montserrat', sans-serif;
    ;
    --font-weight-light: 300;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-styled-2: "ivarfine_light";
    --font-size: 16px;
    --parallax-offset: 100px;
    --call-button-height: 80px;
    --hero-image-overflow: 5%;
    --image-loading-animation-duration: 0.5s;
    --transition-duration: 0.7s;
    --color-accent: #00AAAD;
    --color-accent-2: hsl(37.06deg 10.65% 35.4%);
    --bg-color-main: #f6f4f2;
    --text-color: #222;
    --image-background-color: #e0dfde;
    --gray-background: rgba(0, 0, 0, 0.02);
    --dark-background: var(--text-color);
    --sub-menu-color: #fff;
    --article-bg-opacity: 0.07;
    font-family: var(--font-styled);
    font-weight: var(--font-weight-regular);
    font-size: var(--font-size);
    color: var(--text-color)
}

.material-symbols-outlined {
    font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24
}

.cursor-content .material-symbols-outlined,
.service-icons .material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 200, 'GRAD' 0, 'opsz' 24
}

*,
*::before,
*::after {
    box-sizing: border-box
}

h1,
h2,
h3,
h4,
p,
a,
img,
button,
.title,
.service-icon,
.material-symbols-outlined,
.nav-item,
.carousel-pagination,
#cursor {
    user-select: none
}

img:not(.no-background) {
    background-color: var(--image-background-color)
}

.img_h1 {
    width: 100%;
    max-width: 497px;
}

img:not(.loaded) {
    opacity: 0
}

video.loaded,
img.loaded {
    animation: fade-in var(--image-loading-animation-duration)linear
}

html.fullscreen *,
img[data-expandable]:not(.no-expand) {
    cursor: pointer
}

#smooth-content {
    overflow: hidden
}

#image-showcase {
    --cpv: 0%;
    --cph: 0%;
    --cpv-2: 100%;
    --cph-2: 100%;
    transition-property: background-color, opacity;
    transition-duration: .2s, .25s;
    transition-delay: 0s, .25s;
    transition-timing-function: linear, ease-out;
    position: fixed;
    inset: 0;
    background-color: transparent;
    pointer-events: none;
    z-index: 101;
    opacity: 0
}

html.fullscreen #image-showcase {
    transition-duration: .2s, 0s;
    transition-delay: 0s;
    background-color: #000;
    pointer-events: all;
    opacity: 1
}

#image-showcase img {
    position: fixed !important;
    inset: 0 !important;
    z-index: 100 !important;
    object-fit: contain !important;
    object-position: center !important;
    opacity: 1 !important;
    background-color: transparent !important
}

html.is-mobile #image-showcase img {
    height: 100% !important;
    width: 100% !important
}

html:not(.is-mobile) #image-showcase[data-orientation=landscape] img {
    width: 100% !important;
    height: auto !important;
    margin-block: auto !important
}

html:not(.is-mobile) #image-showcase[data-orientation=portrait] img {
    width: auto !important;
    height: 100% !important;
    margin-inline: auto !important
}

html:not(.is-mobile) #image-showcase img {
    transform: var(--matrix);
    border-radius: var(--border-radius);
    clip-path: polygon(var(--cph) var(--cpv), var(--cph-2) var(--cpv), var(--cph-2) var(--cpv-2), var(--cph) var(--cpv-2));
    animation-name: image-showcase-appear;
    animation-duration: .5s;
    animation-timing-function: var(--bezier);
    animation-fill-mode: both;
    will-change: border-radius, transform
}

html:not(.is-mobile, .fullscreen) #image-showcase img {
    animation-name: image-showcase-disappear;
    animation-duration: .25s
}

html.scrolled-after-image-showcase:not(.fullscreen) #image-showcase img {
    animation: none
}

#cursor {
    transition-property: transform;
    transition-duration: .6s;
    transition-timing-function: var(--bezier-2);
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    height: 0;
    width: 0;
    color: #fff;
    font-family: var(--font-medium);
    font-size: 1rem;
    pointer-events: none;
    z-index: 102
}

html:not(.mouse-moved) #cursor {
    display: none
}

#cursor-shape {
    transition-property: transform, background-color, opacity;
    transition-duration: .6s;
    transition-timing-function: var(--bezier-2);
    transform: scale(.6);
    opacity: 0;
    display: grid;
    place-content: center;
    position: absolute;
    height: 90px;
    width: 90px;
    text-align: center;
    background-color: var(--color-accent);
    border-radius: 100vw
}

html:is([data-cursor], .fullscreen) #cursor-shape {
    background-color: var(--color-accent);
    opacity: 1
}

html[data-cursor=article] #cursor-shape,
html[data-cursor=close] #cursor-shape,
html.fullscreen #cursor-shape,
html[data-cursor=link] #cursor-shape {
    transform: translateY(-12px)
}

html[data-cursor=image-showcase] #cursor-shape {
    transform: translate(-7px, -5px)
}

html[data-cursor=scroll] #cursor-shape {
    transform: translate(-10px, -15px)
}

html[data-cursor=work_next] #cursor-shape,
html[data-cursor=work] #cursor-shape {
    transform: translateY(-20px)
}

.cursor-content {
    display: none
}

.cursor-content[data-type=image-showcase],
.cursor-content[data-type=scroll] {
    animation: scale-up .5s var(--bezier)both
}

.cursor-content[data-type=link],
.cursor-content[data-type=work],
.cursor-content[data-type=work_next],
.cursor-content[data-type=article],
.cursor-content[data-type=close] {
    animation: fade-in .3s linear both
}

html.fullscreen .cursor-content[data-type=close],
html[data-cursor=image-showcase] .cursor-content[data-type=image-showcase],
html[data-cursor=scroll] .cursor-content[data-type=scroll],
html[data-cursor=work] .cursor-content[data-type=work],
html[data-cursor=work_next] .cursor-content[data-type=work_next],
html[data-cursor=article] .cursor-content[data-type=article],
html[data-cursor=link] .cursor-content[data-type=link] {
    display: block
}

.cursor-content span.material-symbols-outlined {
    font-size: 3rem;
    pointer-events: none
}

.image-wrapper {
    display: contents
}

.image-wrapper>* {
    border-radius: inherit
}

.image-loader {
    display: grid;
    place-items: center;
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, .1);
    animation: pulse 2s infinite cubic-bezier(.7, .31, .09, .39);
    pointer-events: none;
    z-index: -1
}

section.dark-background .image-loader {
    background-color: rgba(255, 255, 255, .1)
}

img.loaded-animation-ended+.image-loader {
    display: none
}

em {
    font-style: italic
}

article :where(:not(h3, img, video, #breadcrumbs-wrapper, #breadcrumbs-wrapper *)),
.selectable,
.selectable * {
    user-select: text
}

article :where(:not(h3, img, video, #breadcrumbs-wrapper, #breadcrumbs-wrapper *))::selection,
:is(p, em)::selection,
.selectable::selection,
.selectable *::selection {
    background-color: var(--article-color, var(--color-accent));
    color: #fff
}

#hero h1>span:nth-child(2)::selection,
#hero h1>span:nth-child(2) strong::selection,
#hero h1>span:nth-child(3)::selection,
.image-and-text.small-text .image-and-text__text>p>em:first-child::selection,
article .article-header.white-text :not(h3, img, video)::selection {
    background-color: #fff;
    color: var(--text-color)
}

.service-icon :is(h3, p)::selection {
    background-color: #fff;
    color: var(--color-accent)
}

* {
    margin: 0;
    padding: 0;
    font: inherit
}

img,
picture,
svg,
video {
    display: block
}

ul {
    list-style-type: none
}

button {
    border: none;
    background: 0 0;
    color: inherit;
    cursor: pointer
}

a {
    text-decoration: none;
    color: inherit
}

a.button {
    transition-property: transform;
    transition-duration: .7s;
    transition-timing-function: var(--bezier);
    display: flex;
    align-items: center;
    column-gap: .5vw;
    flex-shrink: 0;
    flex-grow: 0;
    width: fit-content;
    font-weight: var(--font-weight-medium);
    background-color: var(--color-accent);
    color: #fff;
    padding: 1.3rem 2.5rem;
    white-space: nowrap
}

@media(max-width:1024px) {
    a.button {
        padding: 1rem 1.8rem
    }
}

html:not(.is-mobile) a.button:hover {
    transform: scale(1.05)
}

a.button.centered {
    margin-inline: auto
}

a.button span.material-symbols-outlined:not(.padded) {
    margin-right: -.4rem
}

a.button span.material-symbols-outlined.padded {
    margin-left: -.4rem;
    padding-right: .5rem;
    position: relative;
    bottom: -5px;
}

body {
    background-color: #ffffff
}

::-webkit-scrollbar {
    display: none
}

header {
    position: fixed;
    display: flex;
    justify-content: space-between;
    top: 0;
    width: 100%;
    height: 0;
    display: flex;
    align-items: center;
    padding-left: var(--padding-inline);
    padding-right: var(--padding-inline-half);
    pointer-events: none;
    z-index: 100;
    padding-block: var(--padding-block-half);
    color: var(--section-color, --text-color)
}

html.header-color-dark header {
    color: #fff
}

header>* {
    pointer-events: all
}

#header-background {
    position: absolute;
    inset: 0;
    pointer-events: none
}

section {
    position: relative
}

#visualisation-3d .video-wide .image-wrapper {
    overflow: hidden
}

#visualisation-3d .video-wide .image-wrapper img {
    width: 100%;
    height: 100%
}

#content-start {
    position: absolute;
    top: 0;
    height: 50px;
    pointer-events: none
}

#header-line {
    position: absolute
}

nav>ul {
    display: flex;
    align-items: center
}

#nav-button {
    position: relative;
    display: flex;
    align-items: center;
    column-gap: 1rem;
    z-index: 100
}

#nav-button__icon-close {
    position: absolute;
    right: 0
}

.hidden {
    display: none !important
}

html.nav-opened #nav-button__icon-open,
html:not(.nav-opened) #nav-button__icon-close {
    opacity: 0
}

nav {
    font-size: .8rem;
    font-family: var(--font-styled);
    text-transform: uppercase;
    letter-spacing: .08rem;
    white-space: nowrap
}

nav>ul>li {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    counter-reset: nav-sub-item
}

.nav-item {
    display: flex;
    align-items: center;
    column-gap: .5rem;
    position: relative;
    font-weight: var(--font-weight-medium);
    padding-inline: var(--padding-inline-half);
    padding-block: var(--nav-border-gap)
}

.nav-item#nav-services {
    z-index: 2
}

.nav-item .material-symbols-outlined {
    font-size: 1.25rem
}

html.is-mobile .nav-item .material-symbols-outlined {
    display: none
}

.nav-item:not(a) {
    cursor: default
}

.nav-item::after {
    transition: transform .2s ease-out;
    transform-origin: right;
    content: "";
    position: absolute;
    bottom: 0;
    left: var(--padding-inline-half);
    right: var(--padding-inline-half);
    height: 1px;
    background-color: var(--color-accent);
    transform: scaleX(0)
}

html:not(.is-mobile) nav>ul>li:hover>.nav-item::after {
    transform-origin: left
}

.nav-item[aria-current=page] {
    color: var(--color-accent)
}

html:not(.is-mobile) nav>ul>li:hover>.nav-item:not(#nav-services)::after,
.nav-item[aria-current=page]::after {
    transform: scaleX(1)
}

nav>ul>li>ul {
    transition-property: opacity, transform, visibility;
    transition-duration: var(--transition-duration);
    transition-timing-function: var(--bezier);
    display: flex;
    flex-direction: column;
    align-items: center;
    position: absolute;
    top: calc(100% + var(--nav-sub-menu-padding-top));
    background-color: var(--sub-menu-color);
    color: var(--text-color);
    padding-block: .5rem;
    border-radius: 3px;
    z-index: 10
}

nav>ul>li>ul::before {
    content: "";
    position: absolute;
    bottom: 100%;
    height: var(--nav-sub-menu-padding-top);
    width: 100%
}

nav>ul>li>ul::after {
    content: "";
    position: absolute;
    bottom: calc(100% - 1px);
    height: 10px;
    width: 15px;
    background-color: var(--sub-menu-color);
    clip-path: polygon(50% 0, 100% 100%, 0 100%)
}

nav>ul>li:not(.hoverable:hover)>ul {
    transform: translateY(var(--nav-sub-menu-transition-size));
    opacity: 0;
    visibility: hidden;
    pointer-events: none
}

nav>ul>li>ul>li {
    align-self: stretch;
    counter-increment: nav-sub-item
}

.nav-sub-item {
    position: relative;
    transition-property: color, opacity, transform;
    transition-duration: .3s, .2s, .3s;
    transition-delay: 0s, var(--delay, 0s), var(--delay, 0s);
    transition-timing-function: ease, linear, var(--bezier);
    display: block;
    white-space: nowrap;
    padding: .825rem 1.825rem
}

.nav-sub-item:not([aria-current=page])::before,
.nav-sub-item:not([aria-current=page])::after {
    opacity: .15;
    color: var(--text-color)
}

nav>ul>li:not(.hoverable:hover) .nav-sub-item {
    opacity: 0;
    transform: rotate(5deg)translateY(-5px);
    transition-delay: 0s, 0s, .3s
}

li:nth-child(2)>.nav-sub-item {
    --delay: 40ms
}

li:nth-child(3)>.nav-sub-item {
    --delay: 80ms
}

li:nth-child(4)>.nav-sub-item {
    --delay: 120ms
}

li:nth-child(5)>.nav-sub-item {
    --delay: 160ms
}

li:nth-child(6)>.nav-sub-item {
    --delay: 200ms
}

li:nth-child(7)>.nav-sub-item {
    --delay: 240ms
}

li:nth-child(8)>.nav-sub-item {
    --delay: 280ms
}

li:nth-child(9)>.nav-sub-item {
    --delay: 340ms
}

.nav-sub-item[aria-current=page],
html:not(.is-mobile) .nav-sub-item:hover {
    color: var(--color-accent)
}

@media(min-width:1100px) {
    #nav-button {
        display: none
    }
}

@media(max-width:1099px) {
    #nav-button {
        display: flex
    }

    #nav-button__icon-open,
    #nav-button__icon-close {
        transition-property: transform;
        transition-duration: .6s;
        transition-timing-function: var(--bezier)
    }

    html.nav-opened :is(#nav-button__icon-open, #nav-button__icon-close) {
        transform: rotate(-90deg)
    }

    nav>ul {
        transition-property: transform, opacity, visibility;
        transition-duration: .8s;
        transition-timing-function: var(--bezier);
        transform: translateY(100px);
        display: flex;
        flex-direction: column;
        align-items: center;
        row-gap: var(--padding-block-half);
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100svh;
        visibility: hidden;
        padding-block: var(--padding-block);
        padding-inline: var(--padding-inline);
        color: #fff;
        background-color: #fff;
        padding-top: var(--padding-block-and-a-half);
        opacity: 0;
        pointer-events: none;
        z-index: 99
    }

    html.header-color-dark.nav-opened header,
    html.nav-opened header {
        color: var(--color-accent)
    }

    html.nav-opened nav>ul {
        transform: none;
        visibility: visible;
        opacity: 1;
        pointer-events: all
    }

    .nav-item {
        font-size: min(6vw, 1.5rem);
        color: var(--color-accent)
    }

    .nav-item[aria-current=page] {
        font-family: var(--font-bold)
    }

    .nav-item::after {}

    .nav-item .material-symbols-outlined {
        display: none
    }

    html:not(.is-mobile) nav>ul>li:hover>.nav-item#nav-services::after {
        transform: scaleX(1)
    }

    nav>ul>li>ul {
        display: none
    }
}

.footer-logo>span,
#logo {
    display: flex;
    column-gap: calc(.35 * var(--font-size));
    font-size: var(--font-size);
    font-family: var(--font-light);
    text-transform: uppercase;
    letter-spacing: calc(.15 * var(--font-size));
    z-index: 100
}

#logo {
    --font-size: 1.25rem
}

#logo .space {
    display: none
}

.footer-logo {
    --font-size: clamp(2rem, 2vw, 3rem);
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-inline: auto;
    color: #fff
}

.footer-logo>span span,
#logo span:last-child {
    font-family: var(--font-bold)
}

.footer-logo>span:last-child {
    font-size: calc(var(--font-size) * .4);
    flex-direction: column;
    align-items: center;
    letter-spacing: calc(var(--font-size) * .16);
    padding-top: calc(var(--font-size) * .2)
}

footer {
    --padding: var(--padding-block-and-a-half);
    position: relative;
    background-color: var(--dark-background);
    font-family: var(--font-regular);
    letter-spacing: .5px
}

footer:after {
    content: "";
    position: absolute;
    top: calc(100% - 2px);
    left: 0;
    width: 100%;
    height: var(--call-button-height);
    background-color: var(--dark-background);
    pointer-events: none
}

.footer-container {
    padding-block: var(--padding)
}

.footer-wrapper {
    display: flex;
    flex-direction: column;
    row-gap: var(--padding)
}

.footer-row {
    display: flex;
    flex-direction: row;
    row-gap: var(--padding)
}

.footer-row:nth-child(2) {
    padding-left: var(--padding)
}

.footer-col {
    flex-grow: 1
}

.footer-col:nth-last-child(2) {
    flex-grow: 0
}

.footer-col:last-child {
    flex-grow: 3
}

button#call-button {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: var(--call-button-height);
    font-weight: var(--font-weight-semibold);
    background-color: var(--color-accent);
    gap: 10px;
    z-index: 99
}

@media(max-width:1024px) {
    footer {
        --padding: var(--padding-block)
    }

    .footer-wrapper {
        row-gap: 0
    }

    .footer-row:nth-child(2) {
        padding-inline: var(--padding)
    }

    .footer-logo {
        display: none
    }
}

@media(max-width:749px) {
    .footer-row:nth-child(2) {
        display: grid;
        grid-template-columns: 1fr 1fr
    }

    .footer-row:nth-child(2) .footer-col:nth-child(3) {
        grid-column: span 2
    }

    .footer-container {
        padding-bottom: calc(var(--padding) + var(--call-button-height))
    }

    header {
        pointer-events: all
    }

    #header-background {
        background-color: var(--bg-color-main)
    }

    html.header-color-dark header {
        color: #fff
    }

    html.header-color-dark #header-background {
        background-color: var(--dark-background)
    }
}

@media(min-width:750px) {
    #call-button-link {
        display: none
    }
}

@media(max-width:549px) {
    .footer-row:nth-child(2) {
        padding-inline: var(--padding-inline)
    }
}

.footer-logo-symb {
    display: flex;
    justify-content: center;
    height: clamp(8rem, 16vw, 15rem)
}

.footer-logo-symb svg {
    fill: #000
}

.footer-col__title {
    display: inline-block;
    font-family: var(--font-bold);
    padding-bottom: 1.5rem;
    opacity: .8
}

footer ul {
    display: flex;
    flex-direction: column
}

footer ul li a:not(.no-pointer-events),
footer ul li.no-link {
    position: relative;
    display: inline-block;
    transition-property: opacity;
    transition-duration: .3s;
    transition-timing-function: linear;
    line-height: 1;
    opacity: .4;
    padding-inline: 1rem;
    margin-left: -1rem;
    padding-block: .5em
}

footer ul li#footer-address,
footer ul li#footer-identifier,
footer ul li#footer-since {
    font-size: 75%
}

footer ul li#footer-identifier,
footer ul li#footer-identifier a {
    cursor: text
}

footer ul li#footer-since {
    padding-top: 1.5em
}

footer ul li a[aria-current=page],
html:not(.is-mobile) footer ul li a:hover,
html:not(.is-mobile) footer ul li.no-link:hover {
    opacity: 1
}

footer ul li a[aria-current=page]::after {
    content: "";
    position: absolute;
    width: calc(100% - 2rem);
    left: 1rem;
    bottom: .5rem;
    border-bottom: 1px solid #fff;
    pointer-events: none
}

footer ul li a .material-symbols-outlined {
    font-size: 1rem;
    padding-right: .75rem
}

.overflow-hidden {
    overflow: hidden
}

.no-pointer-events {
    pointer-events: none
}

.z-background {
    z-index: -10
}

.content-centered {
    display: grid;
    place-content: center
}

.cover {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%
}

.bg-image {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50%
}

strong {
    color: var(--color-accent)
}

:is(h1, h2, p) strong {
    font-family: var(--font-bold)
}

h1.page-title {
    font-size: clamp(2rem, 7vw, 6rem);
    text-transform: uppercase;
    text-align: center
}

h2 {
    max-width: 830px;
    text-transform: none
}

h2 span {
    font-size: 150%;
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase
}

.title-and-text__text>p,
.image-and-text__text>p,
.title,
h2,
h3 {
    text-wrap: balance
}

.image-and-text__text>p>em>strong>span.material-symbols-outlined {
    font-size: 1.4rem;
    vertical-align: text-bottom
}

#services .title,
section:not(#services) .image-and-text h2 {
    text-wrap: unset
}

#services .title {
    padding-bottom: var(--padding-inline-third);
    font-size: calc(2rem + 3svh);
    font-family: var(--font-light);
    line-height: 1.05;
    text-wrap: nowrap
}

#services .image-and-text__text {
    max-width: unset;
    padding-left: var(--padding-inline-double)
}

#services h2 {
    width: 60ch;
    padding-right: var(--padding-inline)
}

article :where(:not(h3, img, video, #breadcrumbs-wrapper, #breadcrumbs-wrapper *)),
.title-and-text__text>p,
.image-and-text__text>p,
h2 {
    font-size: max(1rem, 11px + .36vw);
    letter-spacing: .05vw
}

.article br,
article a br {
    display: none
}

.title-and-text__text>p,
.image-and-text__text>p,
h2 {
    line-height: 1.75;
    font-family: var(--font-styled);
    font-weight: var(--font-weight-regular)
}

article :where(:not(h3, img, video, #breadcrumbs-wrapper, #breadcrumbs-wrapper *)),
.image-and-text.small-text .image-and-text__text>:is(p, em) {
    font-family: var(--font-light);
    line-height: 1.5
}

.image-and-text.small-text .image-and-text__text>p>em:first-child {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: .9rem;
    width: fit-content;
    border-radius: 4px;
    padding: 3px 7px 3px 5px;
    background: hsl(37.06deg 45.13% 55.69%);
    color: #fff;
    letter-spacing: 1.3px;
    margin-top: -.6rem
}

.h5 {
    font-size: clamp(11px, .8vw, 13px);
    font-family: var(--font-bold);
    font-style: normal;
    text-transform: uppercase;
    letter-spacing: 5px;
    padding-bottom: var(--padding-block-half);
    opacity: .85
}

section>.h5 {
    text-align: center
}

.image-and-text__text {
    max-width: min(36ch, 28vw)
}

.image-and-text.no-image {
    padding-inline: var(--padding-inline)
}

.image-and-text.no-image .image-and-text__text:last-child {
    text-wrap: nowrap;
    padding: 0 !important
}

.image-and-text.no-image .image-and-text__text {
    max-width: 60ch !important
}

h3.title-and-text__title {
    font-family: var(--font-regular);
    font-size: clamp(1.5rem, 3svh, 2rem);
    text-transform: uppercase
}

.image-and-text__text h1 {
    font-family: var(--font-light);
    font-size: min(96px, 6vmax);
    hyphens: auto;
    line-height: min(96px, 6vmax);
    text-transform: uppercase;
    padding-bottom: var(--padding-inline-half);
    margin-left: -.4vw
}

h3.section-title,
.image-and-text__text :is(h3, .title) {
    text-transform: uppercase
}

.image-and-text__text :is(h3, .title) {
    font-size: calc(2rem + 2svh);
    font-family: var(--font-light)
}

h3.section-title {
    font-size: calc(1rem + 2svh);
    font-family: var(--font-bold)
}

h3.title-and-text__title {
    text-align: right
}

h3.section-title:not(.no-padding-bottom),
.image-and-text:not(.no-image) .image-and-text__text :is(h3, .title) {
    padding-bottom: var(--padding-block-half)
}

h3.section-title {
    text-align: center;
    font-weight: bold;
    margin-top: 1em;
}

.title-and-text__text>a,
.image-and-text__text>a {
    width: fit-content;
    margin-top: var(--padding-block-half)
}

.article-content>:is(p, em):last-child,
.image-and-text__text>:is(p, em):last-child {
    position: relative
}

#contact h2::after,
.article-content>:is(p, em):last-child::after,
.image-and-text__text>:is(p, em):last-child::after {
    content: "";
    position: absolute;
    bottom: calc(var(--padding-inline) * -1);
    width: 25%;
    height: 1px;
    background-color: var(--color-accent)
}

.article-content>:is(p, em):last-child::after,
.image-and-text:not(.text-align-right) .image-and-text__text>:is(p, em):last-child::after {
    left: 0
}

.image-and-text.text-align-right .image-and-text__text>:is(p, em):last-child::after {
    right: 0
}

.images-sliding-rows {
    display: flex;
    flex-direction: column;
    row-gap: var(--padding-inline-third)
}

.images-sliding-rows__row {
    display: flex;
    column-gap: var(--padding-inline-third);
    height: max(23svh, 14vw)
}

.images-sliding-rows__row[data-direction=left] {
    justify-content: flex-start
}

.images-sliding-rows__row[data-direction=right] {
    justify-content: flex-end
}

.video-wide .image-wrapper,
.images-grid .image-wrapper,
.icons-and-image .image-wrapper,
.centered-image .image-wrapper,
.centered-images .image-wrapper,
.overlapping-images .image-wrapper,
.two-images .image-wrapper,
.three-images .image-wrapper,
.rounded-images .image-wrapper,
.full-width-image .image-wrapper,
.article-header .image-wrapper,
.article-header__content .image-wrapper,
.images-sliding-rows__row .image-wrapper {
    display: block;
    position: relative
}

.centered-images .image-wrapper {
    height: fit-content
}

.images-sliding-rows__row .image-wrapper {
    height: 100%;
    border-radius: 7px
}

.images-sliding-rows__row a {
    display: contents
}

.images-sliding-rows__row img {
    transition-property: transform, box-shadow;
    transition-duration: var(--transition-duration);
    transition-timing-function: var(--bezier);
    height: 100%;
    width: auto;
    box-shadow: 0 0 transparent;
    cursor: pointer
}

html:not(.is-mobile) .images-sliding-rows__row img:hover {
    transform: scale(1.1);
    box-shadow: 0 20px 30px -14px rgba(0, 0, 0, .2)
}

.images-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    width: 100%;
    max-width: 1500px;
    margin-inline: auto;
    gap: 3px;
    overflow: hidden
}

.images-grid .image-wrapper {
    height: 100%;
    width: 100%
}

.images-grid .image-wrapper.wide {
    grid-column: span 2
}

html:not(.is-mobile) .images-grid .image-wrapper {
    aspect-ratio: 3/4
}

html:not(.is-mobile) .images-grid .image-wrapper.wide {
    aspect-ratio: 3/2
}

.images-grid img {
    height: 100%;
    width: 100%;
    object-fit: cover
}

.video-wide {
    display: flex;
    flex-direction: column
}

.video-wide video {
    height: 50vw;
    object-fit: cover
}

.video-full-width video {
    height: auto;
    width: 100%;
    object-fit: cover
}

video:not(.loaded) {
    visibility: hidden;
    position: absolute
}

video.loaded+.video-alt-image {
    display: none
}

.title-and-text {
    display: flex;
    justify-content: center;
    column-gap: var(--padding-inline);
    row-gap: var(--padding-block-third)
}

h3.title-and-text__title {
    max-width: 15ch
}

h4 {
    display: flex;
    flex-direction: column;
    font-family: var(--font-styled-2);
    font-size: min(8vw, 75px + 2vw);
    font-style: italic
}

h4 strong {
    font-size: 120%;
    text-transform: uppercase;
    color: var(--color-accent);
    font-style: normal;
    padding-left: 1vw
}

h4 div span:nth-child(2) {
    margin-left: 20vw
}

#contact h4 {
    margin-inline: auto
}

#contact h4,
#contact h4 span {
    width: fit-content
}

#contact h4 div span:nth-child(2) {
    margin-left: 10vw
}

#contact h2::after {
    bottom: -20px;
    right: 0
}

#contact .contact-buttons {
    display: flex;
    gap: 20px
}

section+#contact {
    padding-top: var(--padding-block)
}

@media(min-width:1200px) {
    #contact h2 {
        position: relative;
        text-align: right
    }

    #contact .text-and-button {
        justify-content: center
    }

    #contact .contact-buttons {
        flex-direction: column
    }
}

@media(max-width:1199px) {
    #contact h2:after {
        display: none
    }

    #contact .text-and-button {
        align-content: center;
        row-gap: var(--padding-block)
    }

    #contact .contact-buttons {
        flex-direction: row;
        justify-content: center;
        flex-wrap: wrap
    }
}

mark {
    font-family: var(--font-bold);
    background: repeat 0 var(--color-accent);
    text-decoration: none;
    color: #fff;
    padding: 2px 8px;
    display: inline-block;
    border-radius: 2px
}

.overflow-hidden {
    overflow: hidden
}

.uppercase {
    text-transform: uppercase
}

.padding-block {
    padding-block: var(--padding-block)
}

.padding-block-triple {
    padding-block: var(--padding-block-triple)
}

.padding-block-double {
    padding-block: var(--padding-block-double)
}

.padding-block-half {
    padding-block: var(--padding-block-half)
}

.padding-block-third {
    padding-block: var(--padding-block-third)
}

.padding-top {
    padding-top: var(--padding-block)
}

.padding-top-triple {
    padding-top: var(--padding-block-triple)
}

.padding-top-double {
    padding-top: var(--padding-block-double)
}

.padding-top-and-a-half {
    padding-top: calc(var(--padding-block-and-a-half))
}

.padding-top-half {
    padding-top: var(--padding-block-half)
}

.padding-top-third {
    padding-top: var(--padding-block-third)
}

.margin-top {
    margin-top: var(--padding-block)
}

.margin-top-double {
    margin-top: var(--padding-block-double)
}

.margin-bottom {
    margin-bottom: var(--padding-block)
}

.margin-bottom-double {
    margin-bottom: var(--padding-block-double)
}

.margin-bottom-half {
    margin-bottom: var(--padding-block-half)
}

.margin-bottom-and-a-half {
    margin-bottom: var(--padding-block-and-a-half)
}

.padding-inline {
    padding-inline: var(--padding-inline)
}

.padding-inline-double {
    padding-inline: var(--padding-inline-double)
}

.padding-bottom {
    padding-bottom: var(--padding-block)
}

.padding-bottom-triple {
    padding-bottom: var(--padding-block-triple)
}

.padding-bottom-double {
    padding-bottom: var(--padding-block-double)
}

.padding-bottom-half {
    padding-bottom: var(--padding-block-half)
}

.padding-bottom-third {
    padding-bottom: var(--padding-block-third)
}

@media(max-width:1024px) {

    .padding-top-triple,
    .padding-top-double:not(html[data-page-type=home] #realisations) {
        padding-top: var(--padding-block)
    }

    .padding-block-triple,
    .padding-block-double {
        padding-block: var(--padding-block)
    }
}

.white-text {
    color: #fff;
    -webkit-font-smoothing: antialiased
}

.gray-background {
    background-color: var(--gray-background)
}

.color-accent-background {
    background-color: var(--color-accent)
}

.dark-background {
    background-color: var(--dark-background)
}

section.dark-background+section.dark-background {
    margin-top: -1px
}

section.dark-background+section.dark-background:is(.padding-top-double, .padding-block-double) {
    padding-top: var(--padding-block-half)
}

.foreground {
    position: relative;
    z-index: 10
}

.full-width-image img {
    width: 100%;
    height: auto;
    object-fit: cover
}

.centered-image .image-wrapper {
    width: 50%;
    margin-inline: auto
}

.centered-image img {
    width: 100%;
    height: auto;
    object-fit: cover
}

.centered-images {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--padding-block-third)
}

.overlapping-images img,
.two-images img,
.three-images img,
.centered-images img {
    width: 100%;
    height: auto;
    object-fit: cover
}

html[data-page-type=articles] article .three-images img {
    height: 100%;
    aspect-ratio: 1/1
}

.rounded-images .image-wrapper {
    border-radius: 100vw
}

.two-images,
.three-images {
    display: grid;
    gap: var(--padding-block-third)
}

.two-images {
    grid-template-columns: 1fr 1fr
}

.three-images {
    grid-template-columns: 1fr 1fr 1fr
}

.overlapping-images {
    display: flex;
    align-items: end
}

.overlapping-images .image-wrapper:first-child {
    width: 0;
    flex-grow: 5
}

.overlapping-images .image-wrapper:nth-child(2) {
    transform: translate(-50%, 50%);
    width: 0;
    flex-grow: 2
}

.text-and-button {
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    column-gap: var(--padding-inline);
    row-gap: var(--padding-block-half)
}

.image-and-text {
    display: flex;
    align-items: center;
    row-gap: var(--padding-inline);
    column-gap: var(--padding-block);
    position: relative
}

.image-and-text.aligned-top {
    align-items: start
}

.image-and-text.inverted {
    flex-direction: row-reverse;
    padding-left: var(--padding-inline)
}

.image-and-text.text-align-right {
    text-align: right
}

.image-and-text__image {
    position: relative;
    width: 100%
}

.image-and-text__image__wrapper {
    position: relative;
    height: 100%;
    overflow: hidden
}

.image-and-text__image:not(.auto-height) {
    height: calc(max(100svh, 50vw) - var(--padding-block) * 2)
}

.work-title {
    transition-property: color, background-color;
    transition-duration: .3s;
    position: absolute;
    font-size: 16px;
    font-family: var(--font-styled);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-size: 14px;
    white-space: nowrap;
    padding-block: 20px;
    z-index: 2
}

#hero .work-title {
    pointer-events: all;
    padding: var(--padding-inline-half);
    bottom: -1px;
    left: -1px;
    color: var(--bg-color-main);
    border-top-right-radius: 7px
}

html:not(.is-mobile) #hero .work-title:hover,
html:not(.is-mobile) .image-and-text__image:hover .work-title {
    color: var(--color-accent)
}

html:not(.is-mobile) #hero .work-title:hover {
    background-color: rgba(255, 255, 255, .9)
}

.image-and-text img {
    height: auto;
    width: 100%
}

.image-and-text:first-child+.image-and-text,
:not(.image-and-text)+.image-and-text+.image-and-text {
    padding-block: var(--padding-block)
}

.background-icon {
    display: none;
    position: absolute;
    bottom: 0;
    right: 0;
    pointer-events: none;
    z-index: -1
}

.background-icon .material-symbols-outlined {
    --font-size: min(750px, max(45vw, 60svh));
    font-size: var(--font-size);
    color: #fff;
    font-variation-settings: 'FILL' 0, 'wght' 100, 'GRAD' -25, 'opsz' 48
}

@media(min-width:1025px) {
    .title-and-text__text {
        max-width: 43ch
    }

    .image-and-text.centered:not(.inverted) .image-and-text__text {
        padding-right: var(--padding-inline-half)
    }

    .image-and-text.centered.inverted .image-and-text__text {
        padding-left: var(--padding-inline-half)
    }

    .image-and-text:first-child+.image-and-text,
    :not(.image-and-text)+.image-and-text+.image-and-text {
        padding-block: var(--padding-block-double)
    }

    .image-and-text.small-text:not(.inverted) {
        padding-right: var(--padding-inline)
    }

    .centered-images .image-wrapper:first-child {
        margin-left: 10vw
    }
}

@media(min-width:1250px) {
    html:not(.is-mobile) .icons-and-image:not(.about) {
        transform: rotate(-4deg)
    }

    .no-rotate {
        transform: rotate(4deg);
    }

    html:not(.is-mobile) .icons-and-image:not(.about)::before {
        content: "";
        position: absolute;
        inset: 0 -50%;
        background-color: var(--color-accent)
    }

    html:not(.is-mobile) .icons-and-image:not(.about) .service-icons {
        transform: rotate(4deg)
    }
}

@media(min-width:1200px) {
    .image-and-text:not(.small-text, .inverted, .centered) {
        padding-right: var(--padding-inline-double)
    }

    .image-and-text:not(.inverted) .work-title {
        transform: rotate(-90deg)translateY(100%);
        transform-origin: bottom left;
        left: 100%;
        bottom: 0
    }

    .image-and-text.inverted .work-title {
        transform: rotate(-90deg);
        transform-origin: bottom left;
        left: 0;
        bottom: 0
    }
}

@media(min-width:1500px) {

    .image-and-text:first-child+.image-and-text,
    :not(.image-and-text)+.image-and-text+.image-and-text {
        padding-block: var(--padding-block-double)
    }

    .image-and-text.small-text:not(.inverted, .centered) {
        padding-right: var(--padding-inline-double)
    }
}

.image-and-text:first-child+.image-and-text:last-child,
:not(.image-and-text)+.image-and-text+.image-and-text:last-child {
    padding-bottom: var(--padding-block)
}

@media(max-width:1199px) {
    .image-and-text {
        column-gap: var(--padding-inline)
    }

    .image-and-text:not(.inverted) .work-title {
        right: 0
    }

    .image-and-text.inverted .work-title {
        left: 0
    }
}

@media(min-width:1025px) {

    h3.section-title strong,
    .image-and-text__text strong {
        font-style: italic
    }

    .image-and-text.centered .image-and-text__text {
        max-width: 42ch
    }

    .image-and-text.centered {
        justify-content: center
    }

    .image-and-text.centered .image-and-text__image {
        width: auto
    }

    .image-and-text.centered .image-and-text__image img {
        height: 100%;
        width: auto;
        max-width: 100%
    }
}

@media(max-width:1024px) {
    .title-and-text {
        flex-direction: column
    }

    h3.title-and-text__title {
        text-align: left
    }

    .image-and-text__text .h5 {
        padding-bottom: var(--padding-block-third)
    }

    .image-and-text {
        padding-inline: var(--padding-inline)
    }

    .image-and-text__image {
        position: relative
    }

    html[data-page-type=work] .image-and-text__image {
        width: calc(100% + var(--padding-inline) * 2);
        margin-left: calc(var(--padding-inline) * -1)
    }

    .image-and-text__image.auto-height,
    .image-and-text__image:not(.auto-height) {
        height: auto
    }

    .image-and-text,
    .image-and-text.inverted {
        flex-direction: column-reverse;
        align-items: flex-start
    }

    html[data-page-type=work] .image-and-text {
        flex-direction: column
    }

    .image-and-text__text {
        max-width: unset;
        text-align: left
    }

    .image-and-text__text :is(h3, .title) {
        font-size: max(1.5rem, 3vw);
        font-size: calc(1.5rem + 2vw);
        font-family: var(--font-medium)
    }

    .image-and-text__text>p {
        text-wrap: unset
    }

    .image-and-text__text>:is(p, em):last-child::after {
        display: none
    }

    .image-and-text__text>a {
        margin-top: var(--padding-block-half);
        margin-bottom: var(--padding-block-third)
    }

    h4 {
        padding-bottom: var(--padding-block-half);
        font-size: min(7vw, 65px + 1.5vw)
    }

    #a-propos h4 {
        font-size: min(9vw, 65px + 1.5vw)
    }

    .image-and-text:not(.inverted) .work-title,
    .image-and-text.inverted .work-title {
        left: 0;
        padding-block: 6px
    }

    .work-title {
        font-size: .8rem
    }
}

@media(max-width:749px) {
    .centered-image .image-wrapper {
        width: 100%
    }

    .centered-images .image-wrapper:first-child {
        margin-left: 0
    }

    html[data-page-type=work] .three-images {
        grid-template-columns: 1fr 1fr
    }

    html[data-page-type=work] .three-images .image-wrapper:first-child {
        grid-column: span 2
    }

    .centered-images .image-wrapper:first-child {
        margin-left: 0
    }

    html[data-page-type=work] section:is(.full-width-image, .centered-image, .centered-images, .three-images) {
        margin: 0;
        padding-bottom: 0;
        padding-top: var(--padding-block-third) !important
    }
}

.card {
    display: flex;
    flex-direction: column;
    height: 100%;
    border-radius: 1vw;
    overflow: hidden
}

.card__image {
    position: relative;
    flex-grow: 1;
    overflow: hidden;
    margin-bottom: -1px;
    pointer-events: none
}

h3.card__text {
    display: grid;
    place-items: center;
    position: relative;
    min-height: 4rem;
    font-family: var(--font-regular);
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: .125rem;
    text-align: center;
    padding: .7rem;
    background-color: #00AAAD;
    z-index: 1;
    pointer-events: none
}

.image-and-text__image img,
img.cover,
img.parallax {
    object-fit: cover;
    object-position: center
}

.parallax {
    position: absolute;
    bottom: 0;
    left: 0;
    height: calc(100% + var(--parallax-offset));
    width: 100%
}

@media(max-width:1024px) {

    [data-speed],
    .parallax,
    .no-animations-mobile {
        transform: none !important;
        translate: none !important;
        rotate: none !important;
        scale: none !important
    }

    .parallax {
        position: relative;
        bottom: unset;
        left: unset;
        height: 100%;
        width: 100%
    }
}

p.tag-line {
    padding-top: 2rem;
    font-size: 1rem;
    font-family: var(--font-medium) !important
}

span.num-divider {
    position: relative;
    display: inline-block;
    width: 1.5ch;
    padding-left: 5px
}

span.num-divider::before {
    content: "";
    width: 50%;
    display: inline-block;
    border-bottom: 2px solid
}

#hero {
    width: 100%;
    overflow: hidden
}

#hero-bg::after {
    transition-property: opacity;
    transition-duration: var(--image-loading-animation-duration);
    content: "";
    position: absolute;
    inset: 0 calc(var(--hero-image-overflow) * -1)0;
    background: linear-gradient(7deg, hsl(37.06deg 65.26% 14.08%/50%) 0%, transparent 35%)
}

#hero.padding-top #hero-bg::before {
    transition-property: opacity;
    transition-duration: var(--image-loading-animation-duration);
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, hsl(37.06deg 65.26% 14.08%/30%), transparent 50%), linear-gradient(195deg, hsl(37.06deg 65.26% 14.08%/30%), transparent 50%);
    z-index: 1
}

#hero.gradient-shadow:not(:has(img.loaded)) #hero-bg::after {
    opacity: 0
}

#hero-bg {
    position: relative;
    cursor: pointer
}

#hero-bg img {
    max-height: 58svh;
    width: 100%;
    object-fit: cover;
    object-position: 17% 57%
}

#hero.padding-top #hero-bg img {
    max-height: max(50svh, 33vw)
}

#hero.padding-top #hero-text-wrapper {
    padding-inline: calc(var(--padding-inline) * 2 - var(--home-text-padding-inline))
}

#hero #breadcrumbs-wrapper {
    position: absolute;
    width: 100%;
    z-index: 10
}

#breadcrumbs {
    display: flex;
    font-family: var(--font-regular);
    letter-spacing: 2px;
    font-size: .7rem;
    padding-bottom: 30px;
    text-transform: uppercase;
    overflow: hidden
}

#hero #breadcrumbs {
    position: absolute;
    top: 0;
    right: var(--padding-inline);
    color: #fff;
    font-size: .8rem;
    padding: 20px;
    pointer-events: all;
    z-index: 1
}

#breadcrumbs li,
#breadcrumbs li a {
    white-space: nowrap
}

#breadcrumbs.article-breadcrumbs li a {
    color: var(--color-accent)
}

.article-header:not(.white-text) #breadcrumbs li a {
    color: var(--article-color)
}

.article-header.white-text #breadcrumbs li a {
    color: #fff
}

html:not(.is-mobile) #breadcrumbs.article-breadcrumbs li:has(a:hover) {
    opacity: 1
}

article[data-type=article] #breadcrumbs-wrapper {
    margin-bottom: -17px
}

article[data-type=article] #breadcrumbs {
    padding-bottom: 0
}

.article-time,
.article-time * {
    font-size: .9rem;
    margin-bottom: -.5rem
}

#breadcrumbs li:last-child {
    text-overflow: ellipsis;
    overflow: hidden
}

#breadcrumbs li:not(:first-child):before {
    content: "/";
    padding-inline: 10px
}

#hero #breadcrumbs li:not(:first-child):before {
    padding-inline: 10px
}

@media(min-width:830px) {
    #hero-bg {
        margin-inline: var(--padding-inline)
    }

    #hero:not(.padding-top) #hero-bg {
        margin-top: var(--padding-block);
        margin-left: calc(var(--padding-inline) * 3)
    }
}

@media(max-width:829px) {
    #hero-bg img {
        max-height: 66svh
    }

    #hero.padding-top #hero-bg::before {
        background: linear-gradient(135deg, hsl(37.06deg 65.26% 14.08%/58%), transparent 76%)
    }

    #hero.padding-top #hero-text-wrapper {
        padding-inline: calc(var(--padding-inline) - var(--home-text-padding-inline))
    }
}

@media(max-width:549px) {
    #hero-bg img {
        object-position: 45% 57%;
        max-height: calc(100svh - var(--call-button-height))
    }
}

#hero-text-wrapper {
    position: absolute;
    display: flex;
    align-items: center;
    height: 0;
    top: clamp(220px, 18vw, 50%);
    padding-inline: var(--padding-inline);
    z-index: 10
}

#hero h1 {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    color: var(--text-color);
    font-size: calc(30px + 1.5vw);
    font-family: var(--font-medium);
    text-transform: uppercase;
    letter-spacing: .1vw
}

#hero h1 div {
    display: contents
}

#hero h1 span:not(:first-child) {
    margin-top: -1px
}

#hero h1 span {
    background-color: #fff;
    padding-block: .5vw .2vw;
    padding-inline: var(--home-text-padding-inline);
    font-family: var(--font-bold)
}

#hero.padding-top h1 span {
    background-color: var(--color-accent);
    color: #fff
}

#hero h1 div span:nth-child(1) {
    font-size: 116%;
    color: var(--color-accent);
    line-height: 55%;
    z-index: 1;
    letter-spacing: .15vw;
    padding-top: calc(22px + .5vw);
    padding-bottom: 0
}

#hero h1 div span:nth-child(2) {
    font-size: 116%;
    padding-top: calc(7px + .5vw);
    padding-bottom: calc(2px + .5vw);
    color: var(--color-accent);
    letter-spacing: .15vw;
    line-height: 105%
}

#hero h1>span:nth-child(2) {
    font-size: 30%;
    padding-bottom: calc(5px + .5vw);
    padding-top: 0;
    letter-spacing: .2vw;
    background-color: var(--color-accent);
    font-family: var(--font-regular);
    color: #fff;
    white-space: nowrap
}

#hero h1>span:nth-child(2) strong {
    font-family: var(--font-regular);
    color: #fff
}

#hero h1>span:nth-child(3) {
    font-size: 30%;
    padding-bottom: calc(5px + .5vw);
    padding-top: 0;
    letter-spacing: .2vw;
    background-color: var(--color-accent);
    font-family: var(--font-regular);
    color: #fff
}

#hero-footer {
    position: absolute;
    bottom: 2svh
}

#hero-footer .button-wrap {
    padding-left: 30px;
    background: var(--color-accent);
    border-radius: 10px
}

@media(min-width:1900px) {
    #hero h1>span:nth-child(2) {
        font-size: 25%
    }

    #hero h1>span:nth-child(3) {
        font-size: 25%
    }
}

@media(max-width:1199px) {
    #hero h1>span:nth-child(2) {
        font-size: 32%
    }

    #hero h1>span:nth-child(3) {
        font-size: 32%
    }
}

@media(max-width:899px) {
    #hero h1>span:nth-child(2) {
        font-size: 40%
    }

    #hero h1>span:nth-child(3) {
        font-size: 40%
    }
}

#hero #hero-text-wrapper {
    top: calc(var(--padding-block) + 22svh)
}

#hero.padding-top h1 {
    margin-left: -3px
}

#hero.padding-top h1 div span:nth-child(1),
#hero.padding-top h1 div span:nth-child(2) {
    background-color: transparent;
    text-shadow: 6px 4px 10px rgba(0, 0, 0, .1)
}

#hero.padding-top h1 div span:nth-child(1),
#hero.padding-top h1 div span:nth-child(2) {
    color: #fff
}

#hero.padding-top h1>span:nth-child(2),
#hero.padding-top h1>span:nth-child(3) {
    display: inline-block;
    padding-inline: calc(10px + .25vw)
}

#hero h1>span:nth-child(2) {
    padding-top: calc(5px + .5vw)
}

#hero.padding-top h1>span:nth-child(2),
#hero.padding-top h1>span:nth-child(3) {
    margin-left: calc(var(--home-text-padding-inline) + 3px)
}

#services {
    display: flex;
    align-items: center;
    margin-inline: auto;
    width: fit-content;
    z-index: 1
}

#services-images {
    position: relative;
    display: flex;
    align-items: center;
    height: 100%;
    width: 38vw;
    z-index: -1
}

.services-images__image:first-child {
    position: relative;
    width: 100%;
    padding-left: 20%;
    margin-top: calc(var(--padding-block) * -1)
}

.services-images__image:nth-child(2) {
    position: absolute;
    left: 0;
    width: 50%;
    bottom: calc(var(--padding-block) * -1)
}

.services-images__image .image-wrapper {
    display: flex;
    width: 100%;
    height: fit-content;
    position: relative
}

.services-images__image:first-child .image-wrapper {
    align-items: flex-start
}

.services-images__image:nth-child(2) .image-wrapper {
    align-items: flex-end
}

.services-images__image img {
    width: 100%;
    height: auto
}

#services~#services-grid {
    padding-top: 0;
    padding-bottom: var(--padding-block-double)
}

#services~#realisations {
    padding-top: 0;
    padding-bottom: 0
}

#services-grid ul {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    gap: 10px
}

#services-grid.large {
    padding-top: 0
}

#services-grid li {
    position: relative;
    display: grid;
    place-content: center;
    aspect-ratio: 7/14
}

h3.section-title strong {
    font-size: 75%
}

h3.section-title strong::before,
h3.section-title strong::after {
    content: "";
    vertical-align: middle;
    width: 20px;
    height: 1px;
    background: var(--color-accent);
    display: inline-block;
    margin-inline: 20px
}

.service-icons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    width: 100%;
    padding-left: var(--padding-inline);
    padding-right: calc(var(--padding-inline) - 8px)
}

@media(min-width:1200px) {
    .service-icons {
        grid-template-columns: repeat(3, 1fr);
        max-width: 1200px;
        margin-inline: auto;
    }
}

section:not(.icons-and-image) .service-icons {
    padding-block: 20px;
}

.icons-and-image .service-icons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    padding-block: var(--padding-inline);
    row-gap: 0
}

.service-icon {
    transition-property: background-color;
    transition-duration: .2s;
    display: flex;
    align-items: flex-start;
    border-radius: 12px;
    padding-block: calc(var(--padding-block-third)/2);
    padding-inline: calc(var(--padding-block-third)/2)
}

section.services-section .service-icon {
    transform: none !important
}

.service-icon h3 {
    font-size: calc(.75rem + .2vw);
    font-weight: var(--font-weight-light);
    padding-bottom: .5rem;
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 1px
}

.service-icon p {
    font-size: .9rem;
    line-height: 1.2;
    font-weight: var(--font-weight-semibold);
    text-wrap: balance;
    max-width: 20ch
}

.service-icon__image {
    width: auto;
    display: flex;
    gap: 15px;
    align-items: center;
    margin-right: 28px
}

.service-icon__image .material-symbols-outlined {
    font-size: calc(3rem + 1vw);
    font-variation-settings: 'FILL' 0, 'wght' 100, 'GRAD' -25, 'opsz' 48
}

.icons-and-image {
    display: flex;
    align-items: center
}

.icons-and-image>* {
    flex-grow: 3;
    flex-shrink: 0;
    flex-basis: 0
}

.icons-and-image .image-wrapper {
    margin-right: var(--padding-inline);
    margin-bottom: -50px
}

.icons-and-image img {
    width: 100%;
    height: auto
}

html.mouse-moved.header-color-dark #logo {
    opacity: 0;
}

@media(min-width:1979px) {
    .icons-and-image .service-icons {
        padding-inline: var(--padding-inline-double)
    }
}

@media(max-width:1699px) {
    #services-images {
        width: 45vw
    }

    .icons-and-image.about .service-icons {
        grid-template-columns: repeat(3, 1fr)
    }

    .about .service-icon__image {
        min-width: 200px;
        margin: auto;
    }
}

@media(min-width:1500px) {
    html:not([data-page-type=services][data-page-kind=section]) #services-grid ul {
        transform: rotate(-.15deg);
        margin-top: var(--padding-block-third)
    }

    html:not([data-page-type=services][data-page-kind=section]) #services-grid li {
        /* transform: rotate(-3deg) */
    }
}

@media(max-width:1499px) {
    #services-grid ul {
        grid-template-columns: repeat(3, 1fr);
        margin-inline: auto
    }

    #services-grid li {
        aspect-ratio: 3/4
    }

    h3.card__text {
        min-height: unset
    }

    .card {
        border-radius: 0
    }

    .service-icon__image {
        margin-right: 20px
    }
}

@media(max-width:1399px) {
    #services {
        width: 100%;
        padding-inline: var(--padding-inline)
    }

    #services-images {
        margin-left: calc(var(--padding-inline-half) * -1)
    }

    #services .image-and-text__text {
        padding-left: 0
    }
}

@media(max-width:1199px) {
    .icons-and-image {
        flex-direction: column
    }

    .service-icons {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        padding-block: var(--padding-inline)
    }

    .service-icon {
        transform: none !important;
        padding-block: var(--padding-inline);
        row-gap: 0
    }

    .service-icon {
        transform: none !important
    }

    .icons-and-image__image {
        transform: none !important
    }

    .icons-and-image .image-wrapper {
        max-width: unset;
        margin-inline: 0;
        margin-bottom: 0
    }

    .icons-and-image .service-icons {
        grid-template-columns: repeat(3, 1fr)
    }

    .service-icon__image .material-symbols-outlined {
        font-size: 4rem
    }
}

@media(max-width:1199px) {
    .text-and-button {
        flex-direction: column;
        text-align: center
    }

    #services h2 {
        text-wrap: unset
    }

    #services {
        flex-direction: column-reverse
    }

    #services-images {
        max-width: 630px;
        width: 100%;
        margin-bottom: var(--padding-block-double)
    }

    .services-images__image:first-child {
        margin-top: 0
    }
}

@media(max-width:929px) {

    #services-grid.large ul,
    #services-grid ul {
        grid-template-columns: 1fr 1fr
    }

    #services-grid li {
        aspect-ratio: 5/6
    }

    #services .title {
        font-size: max(2.5rem, 8vw)
    }

    .icons-and-image .service-icons {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media(max-width:829px) {
    h2 {
        text-align: left
    }

    .text-and-button {
        align-items: flex-start
    }

    #contact .contact-buttons {
        justify-content: flex-start
    }

    #hero #breadcrumbs {
        right: 0
    }
}

@media(max-width:649px) {

    #services-grid.large ul,
    #services-grid ul {
        grid-template-columns: 1fr;
        gap: var(--padding-inline-half)
    }

    #services-grid li {
        aspect-ratio: 5/6
    }

    #services h2 {
        width: 100%;
        max-width: 60ch
    }

    .service-icon p {
        max-width: 15ch
    }

    .service-icon__image {
        margin-right: 17px
    }

    .background-icon {
        display: none
    }
}

@media(max-width:619px) {

    #services-grid.large ul,
    #services-grid ul {
        grid-template-columns: 1fr;
        gap: var(--padding-inline-half)
    }

    #services-grid li {
        aspect-ratio: 5/6
    }
}

@media(max-width:549px) {
    .service-icon__image {
        aspect-ratio: unset;
        padding-inline: 5px
    }

    .service-icon__image span {
        margin-left: -15px
    }

    .service-icon__image span[data-extra-margin-left="1"] {
        margin-left: -20px
    }

    .service-icon__image span[data-extra-margin-left="2"] {
        margin-left: -33px
    }

    .service-icon p {
        max-width: unset
    }

    .icons-and-image .service-icons,
    .service-icons {
        padding-block: var(--padding-block-half)
    }

    .service-icon {
        flex-direction: column;
        padding-block: calc(var(--padding-block-half)/2)
    }

    .service-icon__image {
        width: 70px;
        height: 60px;
        margin-bottom: 8px
    }

    .service-icon__text p {
        line-height: 1.05
    }

    section.padding-inline a.button.centered {
        margin-left: 0
    }

    section:not(.padding-inline) a.button.centered {
        margin-left: var(--padding-inline)
    }

    #hero:not(.padding-top) #hero-text-wrapper {
        top: calc(var(--padding-block) + 29svh)
    }

    #hero.padding-top #hero-text-wrapper {
        top: calc(var(--padding-block) + 22svh)
    }

    #hero h1 {
        margin-left: -3px
    }

    #hero h1 div span:nth-child(1) {
        padding-top: 0
    }

    #hero h1 div span:nth-child(1),
    #hero h1 div span:nth-child(2) {
        background-color: transparent;
        text-shadow: 6px 4px 4px rgba(0, 0, 0, .2), 0 0 50px rgba(0, 0, 0, .2), 0 0 5px rgba(0, 0, 0, .2)
    }

    #hero:not(.padding-top) h1 {
        filter: drop-shadow(0 -20px 32px rgba(67, 46, 12, .4))
    }

    #hero h1 div span:nth-child(1),
    #hero h1 div span:nth-child(2) {
        color: #fff
    }

    #hero h1>span:nth-child(2),
    #hero h1>span:nth-child(3) {
        display: inline-block;
        padding-inline: calc(10px + .25vw)
    }

    #hero h1>span:nth-child(2) {
        padding-top: calc(5px + .5vw)
    }

    #hero h1>span:nth-child(2),
    #hero h1>span:nth-child(3) {
        margin-left: calc(var(--home-text-padding-inline) + 3px)
    }
}

article {
    --article-color: var(--color, var(--color-accent))
}

article strong {
    color: var(--article-color);
    font-family: var(--font-bold)
}

article ul:not(#breadcrumbs),
article ol {
    position: relative;
    margin-top: 1rem;
    padding-block: 1.25rem;
    padding-inline: 2.5rem 1rem;
    border-radius: 10px px;
    max-width: 700px
}

article ul:not(#breadcrumbs)::before,
article ol::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: var(--article-color);
    opacity: var(--article-bg-opacity);
    border-radius: 7px;
    pointer-events: none;
    z-index: -1
}

article ul:not(#breadcrumbs) li,
article ol li {
    padding-bottom: .4rem
}

article ol li::marker {
    font-family: var(--font-medium)
}

:is(p, em) a {
    color: var(--article-color, var(--color-accent));
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-thickness: 1px
}

.article-header__content,
.article-content {
    max-width: 1000px;
    max-width: calc(max(1rem, 11px + .36vw) * 58);
    margin-inline: auto;
    padding-inline: var(--padding-inline)
}

.article-header {
    padding-bottom: var(--padding-block-half);
    margin-bottom: var(--padding-block-half)
}

.article-header::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: var(--article-color);
    pointer-events: none
}

.article-header:not(.white-text)::before {
    opacity: var(--article-bg-opacity)
}

.article-header__content {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--padding-block-third);
    z-index: 2
}

.article-header .tag-line {
    padding-top: 0
}

.article-header__content img {
    width: 100%;
    height: auto
}

.article-header h1 {
    font-family: Oswald, sans-serif;
    font-size: 4rem;
    text-transform: uppercase;
    letter-spacing: .1rem;
    line-height: 1.1
}

.article-header:not(.white-text) h1 {
    color: var(--article-color)
}

.article-header h1 strong {
    font-family: var(--font-light)
}

.article-header__image {
    position: absolute;
    top: 0;
    left: 100%;
    height: 100%;
    margin-left: 2rem
}

.article-header__image img {
    height: 100%;
    width: auto
}

.article-content>h2 {
    font-size: 1.75rem;
    font-family: var(--font-bold);
    padding-bottom: 1.5rem;
    max-width: unset;
    text-align: left;
    line-height: 1.2;
    color: var(--article-color);
    letter-spacing: 0;
    text-wrap: unset
}

.article-content p+h2 {
    padding-top: var(--padding-block-half)
}

.article-content .full-width-image,
.article-content .two-images,
.article-content .three-images {
    gap: 5px;
    padding-top: var(--padding-block-third);
    padding-bottom: var(--padding-block-half)
}

html[data-page-type=articles] article .video-full-width,
html[data-page-type=articles] article :not(.rounded-images, .three-images)>.image-wrapper {
    border-radius: 8px;
    overflow: hidden
}

article .image-wrapper {
    overflow: hidden
}

article .image-loader {
    background-color: transparent
}

article .image-loader::after {
    content: "";
    position: absolute;
    inset: 0;
    background-color: var(--article-color);
    opacity: .25
}

article section.white-text .image-loader::after {
    background-color: #fff
}

@media(max-width:1024px) {
    #services {
        width: 100%;
        padding-inline: var(--padding-inline);
        padding-bottom: 0;
        margin-top: var(--padding-block)
    }

    #services .image-and-text__text {
        padding-inline: 0
    }

    .background-icon .material-symbols-outlined {
        margin-right: calc(var(--font-size) * -.08)
    }

    .icons-and-image {
        margin-bottom: 0
    }
}

@media(max-width:930px) {
    .article-header h1 {
        font-size: calc(2rem + 3vw)
    }

    .article-header h1 br {
        display: none
    }

    html[data-page-type=articles] article .video-full-width,
    html[data-page-type=articles] article :not(.rounded-images, .three-images)>.image-wrapper {
        border-radius: 0;
        margin-left: calc(var(--padding-inline) * -1);
        width: calc(100% + var(--padding-inline) * 2)
    }

    .article-header:not(.white-text)::before {
        display: none
    }
}

.articles-grid {
    display: grid;
    gap: 10px;
    margin-inline: auto;
    grid-template-columns: 1fr 1fr 1fr 1fr
}

.articles-grid[data-count="1"] {
    grid-template-columns: 1fr;
    max-width: 380px
}

.articles-grid.is-next-project[data-count="1"] {
    max-width: 700px
}

.articles-grid[data-count="2"] {
    grid-template-columns: 1fr 1fr;
    max-width: 760px
}

.articles-grid[data-count="3"] {
    grid-template-columns: 1fr 1fr 1fr;
    max-width: 1150px
}

.articles-grid a {
    display: contents
}

.articles-grid .article {
    display: flex;
    align-items: flex-end;
    position: relative;
    overflow: hidden
}

html[data-page-type=work][data-page-kind=section] .articles-grid .article {
    border-radius: 10px
}

.articles-grid[data-count] .article {
    aspect-ratio: 3/4
}

.articles-grid.is-next-project[data-count="1"] .article {
    aspect-ratio: 4/3
}

.articles-grid:not([data-count]) .article {
    height: 660px
}

.articles-grid .image-wrapper {
    display: block;
    overflow: hidden;
    position: absolute;
    inset: 0
}

.articles-grid .article::before {
    transition-property: opacity;
    transition-duration: var(--image-loading-animation-duration);
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, hsl(37.06deg 72.41% 5.34%/50%) 0%, hsl(37.06deg 65.26% 14.08%/0%) 58%);
    z-index: 1
}

.articles-grid__text {
    position: relative;
    padding-inline: 6.4%;
    padding-bottom: 40px;
    z-index: 10
}

h3.articles-grid__title {
    font-family: Oswald, sans-serif;
    font-size: 29px;
    text-transform: uppercase;
    line-height: 1.2em;
    letter-spacing: -.02em;
    margin-top: 4px
}

h3.articles-grid__title strong {
    color: inherit;
    font-weight: 400
}

.articles-grid__subtitle {
    display: inline;
    width: fit-content;
    font-family: var(--font-styled);
    font-weight: var(--font-weight-medium);
    font-style: italic;
    padding-inline: 4px 6px;
    border-radius: 3px;
    background-color: var(--color-accent)
}

.icon_c {
    max-width: 40px;
}

@media(max-width:1379px) {
    .articles-grid:not([data-count]) .article {
        height: 500px
    }
}

@media(min-width:1040px) {
    html[data-page-type=work][data-page-kind=section] .articles-grid {
        gap: 60px
    }

    html[data-page-type=work][data-page-kind=section] .articles-grid a:nth-child(6n - 4) .article,
    html[data-page-type=work][data-page-kind=section] .articles-grid a:nth-child(6n) .article {
        margin-top: 500px
    }

    html[data-page-type=work][data-page-kind=section] .articles-grid a:nth-child(12n - 8) .article,
    html[data-page-type=work][data-page-kind=section] .articles-grid a:nth-child(6n - 3) .article {
        margin-top: 1000px
    }

    html[data-page-type=work][data-page-kind=section] .articles-grid a:nth-child(6n+1) .article,
    html[data-page-type=work][data-page-kind=section] .articles-grid a:nth-child(6n - 3) .article,
    html[data-page-type=work][data-page-kind=section] .articles-grid a:nth-child(6n) .article {
        transform: none !important
    }
}

@media(max-width:1039px) {
    .articles-grid:not([data-count]) {
        grid-template-columns: 1fr 1fr
    }

    html[data-page-type=work][data-page-kind=section] .articles-grid a .article {
        transform: none !important
    }
}

@media(max-width:799px) {
    .articles-grid[data-count] {
        grid-template-columns: 1fr
    }
}

@media(min-width:600px) {
    .articles-grid:not([data-count])>a:is(:nth-child(6n), :nth-child(6n - 5), :nth-child(10n)) .article {
        grid-column: span 2
    }
}

@media(max-width:599px) {
    .articles-grid:not([data-count]) {
        grid-template-columns: 1fr
    }

    .articles-grid:not([data-count]) .article {
        height: 440px
    }
}

.partners-grid {
    --height: 65px;
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    gap: var(--padding-block);
    width: fit-content;
    margin-inline: auto;
    border-block: 1px solid rgba(0, 0, 0, .3);
    padding-block: var(--padding-block-third)
}

.partner svg {
    transition-property: fill, transform;
    transition-duration: .7s;
    transition-timing-function: var(--bezier);
    fill: var(--text-color);
    height: var(--height)
}

html:not(.is-mobile) .partner:hover svg {
    fill: var(--color-accent);
    transform: scale(1.1)
}

html:not(.is-mobile) .partner.small:hover svg {
    transform: scale(1.05)
}

#partner-cuisines-action svg {
    height: calc(var(--height) * 5/6);
    margin-left: calc(var(--height) * -.15)
}

.partner.small svg {
    height: calc(var(--height)/4)
}

.partners-group {
    display: contents
}

@media(max-width:1099px) {
    .partners-grid {
        --height: 50px;
        width: 100%;
        justify-content: space-around;
        gap: 0
    }
}

@media(max-width:799px) {
    .partners-grid {
        flex-direction: column;
        gap: var(--padding-block-half)
    }

    .partner {
        display: grid;
        place-content: center
    }

    .partners-group {
        display: flex;
        align-items: center;
        justify-content: space-evenly;
        width: calc(100% + var(--padding-inline-double))
    }

    #partners .h5 {
        text-align: left
    }
}

@keyframes fade-in {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1
    }

    50% {
        opacity: .4
    }
}

@keyframes scale-up {
    from {
        transform: scale(0)
    }

    to {
        transform: none
    }
}

@keyframes nav-item-appear {
    0% {
        transform: translateX(100px);
        opacity: 0
    }

    100% {
        transform: translateX(0);
        opacity: 1
    }
}

@keyframes image-showcase-appear {
    100% {
        transform: none;
        border-radius: 0;
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)
    }
}

@keyframes image-showcase-disappear {
    0% {
        transform: none;
        border-radius: 0;
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)
    }
}

.image-and-text__image:has(a) .image-wrapper,
.parent-hovered-zoom {
    transition-property: transform;
    transition-duration: 1.5s;
    transition-timing-function: var(--bezier)
}

.parent-hovered-darken::before {
    transition-property: opacity;
    transition-duration: .3s;
    transition-timing-function: linear;
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, .3);
    z-index: -1;
    opacity: 0
}

.catalogue_subpage .parent-hovered-darken::before {
    height: 1000px;
    top: -400px;
}

.parent-hovered-darken {
    transition-property: opacity
}

.image-and-text__image:has(a) .image-wrapper {
    display: block;
    height: 100%
}

html:not(.is-mobile) .image-and-text__image:has(a):hover .image-wrapper,
html:not(.is-mobile) .hover-parent:hover .parent-hovered-zoom {
    transform: scale(1.05)
}

html:not(.is-mobile) .hover-parent:hover .parent-hovered-darken::before {
    opacity: 1
}

[data-skew-content-on-reveal] * {
    display: inline-block
}

.phones {
    display: none;
}

.contact-buttons .button {
    text-align: center;
}

.contact-buttons .button:hover .branches {
    display: none;
}

.contact-buttons .button:hover .phones {
    display: block;
}

.contact-buttons .button .branches,
.contact-buttons .button .phones {
    min-width: 233px;
    min-height: 31px;
}

.pt-100 {
    padding-top: 100px !important;
}

#services-grid.catalogue_page ul {
    grid-template-columns: 1fr;
}

#services-grid.catalogue_page li {
    aspect-ratio: 7/2;
}

#services-grid.catalogue_subpage ul {
    grid-template-columns: 1fr 1fr 1fr;
}

#services-grid.catalogue_subpage li {
    aspect-ratio: 7/7;
}

#services-grid.catalogue_subpage h3.parent-hovered-darken {
    color: #FFF;
    font-family: Montserrat;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 50px;
    text-transform: uppercase;
    position: absolute;
    bottom: 0;
    width: 100%;
    left: 50%;
    text-align: center;
    transform: translate(-50%, -50%);
}

.mt-5 {
    margin-top: 50px;
}

.map .map_flex {
    display: flex;
    align-items: center;
}

.map .map_content {
    background: #00AAAD;
    margin-left: -75px;
    width: 460px;
    z-index: 2;
    padding: 2em;
}

.map .map_content * {
    color: white;
}

.map .map_content h3 {
    font-size: 25px;
    font-weight: bold;
    margin-bottom: 0.5rem;
    line-height: 1.2;
}

.map .map_content p {
    font-size: 13px;
    margin-bottom: 1rem;
}

.map .map_img {
    position: relative;
}

.map .map_img .img {
    max-width: 100%;
}

.map .map_img span,
.map .map_img a {
    position: absolute;
}

.colors {
    display: flex;
    gap: 8px;
}

.colors span {
    width: 25px;
    height: 25px;
}

.product {
    overflow: hidden;
    position: relative;
}

.product .swiper {
    width: 100%;
    height: 100%;
}

.product .swiper-slide {
    text-align: center;
    font-size: 18px;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}

.product .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}

.product .swiper {
    width: 100%;
    height: 300px;
    margin-left: auto;
    margin-right: auto;
}

.product .swiper-slide {
    background-size: cover;
    background-position: center;
}

.product .mySwiper2 {
    height: 550px;
    width: 100%;
}

.about-section.container.mt-5 {
    display: flex;
    gap: 30px;
}

.about-section .content,
.about-section .product {
    width: 50%;
}

.desc-title {
    color: #222222;
    font-family: Montserrat;
    font-size: 40px;
    font-style: normal;
    font-weight: 700;
    line-height: 68.5px;
    /* 114.167% */
    text-transform: uppercase;
    margin-bottom: 10px;
}

.desc-titl {
    color: #3D3D3D;
    font-family: Montserrat;
    font-size: 30px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
}

.desc *,
.desc {
    /* color: #747474; */
    font-family: Open Sans !important;
    font-size: 18px !important;
    font-style: normal !important;
    font-weight: 400 !important;
    line-height: 24px !important;
}

.desc p {
    margin-bottom: 10px;
}

.interst-btn {
    border-radius: 5px;
    background: #00AAAD;
    width: 100%;
    text-align: center;
    margin-top: 1em;
    padding: 10px;
    color: #FFF;

    text-align: center;
    font-family: Montserrat;
    font-size: 24px;
    font-style: normal;
    font-weight: 500;
    line-height: 38.5px;
    /* 160.417% */
}

.breadcambs {
    color: #000;
    font-family: Montserrat;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-bottom: 1em;
    text-transform: uppercase;
}

.breadcambs span {
    color: #00AAAD;
}

.breadcambs .no-style {
    text-decoration: none;
    color: #000;
}

.mt-1 {
    margin-top: 10px;
}

.new-style h3.card__text {
    opacity: 0;
    transition: all ease-in-out .4s;
}

.new-style:hover h3.card__text {
    opacity: 1;
}

.new-style h3.card__text.btn_ {
    position: absolute;
    top: 45%;
    left: 50%;
    min-width: 50%;
    transform: translate(-50%, -50%);
    font-size: 50px;
    background: transparent;
    font-weight: bold;
    opacity: 1;
    transition: all ease-in-out .3s;
}

.new-style:hover h3.card__text.btn_ {
    opacity: 0;
    left: 100%;
}

/* .new-style h3.card__text {
    bottom: 50%;
    font-size: 50px;
    background: transparent;
    font-weight: bold;
    transition: all ease-in-out .4s;
}
.new-style:hover h3.card__text {
    bottom: 0;
    font-size: 1rem;
    background-color: #00AAAD;
    font-weight: inherit;
} */
@media only screen and (max-width:480px) {

    /* .new-style h3.card__text {
        font-size: 18px;
    }
    .new-style:hover h3.card__text {
        bottom: 0;
    } */
    .product .mySwiper2 {
        height: 220px;
    }

    .about-section.container.mt-5 {
        flex-wrap: wrap;
    }

    .about-section .content,
    .about-section .product {
        width: 100%;
    }
}

.product .mySwiper {
    height: 20%;
    box-sizing: border-box;
    padding: 10px 0;
}

.product .mySwiper .swiper-slide {
    width: 25%;
    height: 100%;
    opacity: 0.4;
}

.product .mySwiper .swiper-slide-thumb-active {
    opacity: 1;
}

.product .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}

.form-control {
    display: block;
    width: 100%;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0.25rem;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.form-control input,
.form-control textarea {
    border-radius: 0.25rem;
    border: 2px solid #bcccdc;
}

section .section-button {
    font-size: 20px;
    color: white;
    text-align: center;
    background-color: #00AAAD;
    border-radius: 10px;
    padding: 5px 30px;
    transition: all 0.4s ease-in-out;
    margin-top: 1rem;
}

.contact-form {
    margin-bottom: 8em;
}

.contact-form form {
    width: 95%;
    max-width: 600px;
    margin: auto;
    background: white;
    padding: 2em;
}

.alert {
    position: relative;
    padding: .5rem 1rem;
    border: 1px solid transparent;
    border-radius: 0.25rem;
    margin-top: .5em
}

.alert-danger {
    color: #842029;
    background-color: #f8d7da;
    border-color: #f5c2c7;
}

#toast-container>div {
    opacity: 1;
    width: inherit;
    min-width: 300px;
    max-width: 400px;
}

.toast.toast-error {
    background: #b71b2b;
    color: white;
}

.toast.toast-success {
    background: green;
    color: white;
}

span.invalid-feedback strong {
    color: red;
    margin-top: 15px;
    display: block;
}

.form-control {
    display: block;
    width: 100%;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0.25rem;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

/* cart */
/* Sidebar Style */
.sidebar.cart {
    height: 100%;
    width: 0;
    position: fixed;
    z-index: 1000;
    top: 0;
    right: 0;
    background-color: #00aaad;
    overflow-x: hidden;
    transition: 0.5s;
    padding-top: 60px;
    color: white;
    box-shadow: 0 0 13px -1px #535353;
}

#mySidebar.active {
    width: 350px;
}

.sidebar.cart .cart-content {
    padding: 20px;
    overflow-y: auto;
    height: 100%;
}

.sidebar.cart .cart-header {
    font-size: 24px;
    margin-bottom: 20px;
}

.cart-item {
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid #444;
}

.cart-item img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 5px;
    margin: 10px 0;
    opacity: 1;
}

.cart-item h4 {
    margin: 0;
    font-size: 20px;
    margin-bottom: 6px;
}

.d-flex {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.gap-5 {
    gap: 5px;
}

.gap-15 {
    gap: 15px;
}

.cart-item .price {
    color: #f8b400;
    font-weight: bold;
}

.cart-item .quantity {
    font-size: 14px;
    color: #ccc;
}

.cart-item .buttons {
    margin-left: 20px;
    font-size: 14px;
}

.open-cart-btn {
    position: fixed;
    top: 20px;
    right: 20px;
    background: #f8b400;
    color: white;
    padding: 10px 15px;
    border: none;
    cursor: pointer;
    border-radius: 5px;
}

/* Button to close the sidebar */
.close-btn {
    position: absolute;
    top: 20px;
    left: 20px;
    font-size: 36px;
    color: white;
    cursor: pointer;
}

.cart-item .quantity-controls button {
    padding: 5px;
    margin: 0 5px;
    cursor: pointer;
}

button.remove-item-btn {
    background: #ffffff;
    color: red;
    font-size: 12px;
    padding: 2px 5px;
    font-weight: bold;
}

a.interst-btn.checkout {
    background: white;
    color: #00AAAD;
    font-size: 22px;
    font-weight: bold;
    margin-top: 1.5em;
    display: block;
}

.cart_icon {
    position: relative;
    cursor: pointer !important;
}

div#cart-items {
    max-height: calc(100vh - 280px);
    overflow-y: auto;
}

/* width */
#cart-items::-webkit-scrollbar {
    width: 10px !important;
}

/* Track */
#cart-items::-webkit-scrollbar-track {
    background: #f1f1f1;
}

/* Handle */
#cart-items::-webkit-scrollbar-thumb {
    background: #888;
}

/* Handle on hover */
#cart-items::-webkit-scrollbar-thumb:hover {
    background: #555;
}

span#cart-count {
    position: absolute;
    top: -2px;
    left: 50%;
    background: #00aaad;
    color: white;
    width: 17px;
    height: 17px;
    border-radius: 50%;
    font-size: 10px;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* cart */
/* Product card */
.product-card-general {
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.product-card-general .card-top {
    position: relative;
}

.product-card-general .badge {
    position: absolute;
    width: 90%;
    top: 10px;
    left: 50%;
    transform: translate(-50%, 0)
}

.product-card-general .sale-badge {
    background: #AD0000;
    color: white;
    padding: 4px 8px;
    font-size: 12px;
    border-radius: 4px;
    display: inline-block;
    margin-bottom: 8px;
}

.product-card-general .discount-badge {
    background: #00c4cc;
    color: white;
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 4px;
    float: right;
}

.product-card-general .product-image {
    width: 100%;
    height: 300px;
    object-fit: cover;
    margin-bottom: 12px;
    border-radius: 8px;
}

.product-card-general .titles {
    position: absolute;
    width: 100%;
    padding: 15px;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0);
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
    padding-top: 30px;
}

.product-card-general .product-title {
    font-weight: bold;
    font-size: 18px;
    color: #fff;
}

.product-card-general .product-category {
    color: #fff;
    margin-bottom: 8px;
}

.product-card-general .prices {
    padding: 15px
}

.product-card-general .price {
    font-size: 18px;
    color: #222;
}

.product-card-general .old-price {
    font-size: 14px;
    color: #aaa;
    text-decoration: line-through;
}

@media only screen and (max-width: 480px) {
    .swiper {
        margin-top: -65px;
        max-width: 90%;
    }

    .product-card-general .section-header h2 {
        font-size: 28px;
    }
}

/* Product card */
@media only screen and (max-width: 480px) {
    .map .map_flex {
        flex-wrap: wrap;
    }

    .map .map_content {
        margin-left: 0;
        width: 100%;
        padding: 1em;
    }

    h3.section-title {
        margin-top: 1.5em;
        font-size: 22px;
    }

    .desc-title {
        font-size: 45px;
        line-height: 55.5px;
    }

    .desc-titl {
        margin-bottom: .5em;
    }

    #services-grid.catalogue_subpage ul {
        grid-template-columns: 1fr;
        margin-top: 2em;
    }

    .breadcambs {
        font-size: 13px;
    }

    .interst-btn {
        margin-top: 2em;
        padding: 6px;
        font-size: 20px;
    }

    .icons-and-image.about .service-icons {
        grid-template-columns: repeat(2, 1fr);
    }

    section.icons-and-image.about.margin-bottom.color-accent-background.white-text {
        margin-bottom: 2em;
    }

    #services-grid.catalogue_page li {
        aspect-ratio: 7/3;
    }

    #services-grid.catalogue_page ul {
        margin-top: 2em;
    }

    .service-icon h3 {
        font-size: 11px;
    }

    .service-icon__image {
        padding: 0;
    }

    .service-icon {
        padding-inline: 0;
    }

    .service-icon__image img.icon_c.no-background {
        max-width: 35px;
    }

    #contact .contact-buttons {
        justify-content: center;
    }

    .about .service-icon__image {
        min-width: 100%;
    }

    .new-style h3.card__text.btn_ {
        top: 35%;
        min-width: 90%;
        font-size: 22px;
    }

    .mt-sm-50 {
        margin-top: 50px;
    }

    .mt-sm-0 {
        margin-top: 0 !important;
    }

    section#a-propos {
        padding-bottom: 0 !important;
    }

    #services .title {
        font-size: max(2rem, 9vw);
    }

    #mySidebar.active {
        width: 80vw;
    }

    a.interst-btn.checkout {
        font-size: 17px;
    }

    .product-card-general .product-image {
        height: 185px;
    }

}