@charset "UTF-8";
/* CSS Document */

@font-face {
    font-family: 'RobotoLight';
    src: url('../assets/fonts/Roboto-Light.ttf');
}

@font-face {
    font-family: 'RobotoRegular';
    src: url('../assets/fonts/Roboto-Regular.ttf');
}

@font-face {
    font-family: 'RobotoItalic';
    src: url('../assets/fonts/Roboto-Italic.ttf');
}

@font-face {
    font-family: 'RobotoMedium';
    src: url('../assets/fonts/Roboto-Medium.ttf');
}

@font-face {
    font-family: 'RobotoBold';
    src: url('../assets/fonts/Roboto-Bold.ttf');
}

@font-face {
    font-family: 'RobotoBlack';
    src: url('../assets/fonts/Roboto-Black.ttf');
}

@font-face {
    font-family: 'Bahnschrift';
    src: url('../assets/fonts/BAHNSCHRIFT 5.ttf');
}

:root {
    --text-translate-x: -40px;
    --section-side-padding: 3.9vw;
    --section-vertical-padding: 80px;
    --section-title-height: 48px;
    --section-title-padding: 8px;
    --project-style-b-gap: 12px;
    --background-translate-y: calc(var(--vh) / 3);
}

html {
	-webkit-font-smoothing: antialiased !important;
    font-family: 'RobotoRegular';
    pointer-events: none;
}
html.active {
    pointer-events: all;
}

p {
	margin: 0;
	padding: 0;
}

::-webkit-scrollbar {
    display: none;
}

html, body {
	margin: 0;
	padding: 0;
	width: 100vw;
	height: var(--vh);
	position: fixed;
	/*font-family: 'RobotoBold';*/
	font-size: 1vw;
    zoom: 100%;
    overflow-x: hidden;
    overflow-y: hidden;
}

html[data-is-mobile="true"] body {
    overflow-y: scroll;
}

i {
    font-family: 'RobotoItalic';
}

/* Common Elements */

.section {
    position: relative;
    width: 100vw;
    box-sizing: border-box;
}

.page {
    position: relative;
    width: 100vw;
    height: var(--vh);
}

.section-title {
    position: absolute;
    width: fit-content;
    height: var(--section-title-height);
    top: var(--section-title-padding);
    margin-left: var(--section-title-padding);
    font-family: 'RobotoBlack';
    font-size: var(--section-title-height);
    opacity: 0;
    transition: all .5s ease;
}
.page.show .section-title {
    opacity: 1;
}

#section-title-work {
    position: fixed;
    top: var(--section-title-padding);
    margin-left: var(--section-title-padding);
    transform: translateX(var(--text-translate-x));
    z-index: 2;
}
#section-title-work.show {
    opacity: 1;
    transform: none;
}

.multi-line {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.line {
    opacity: 0;
    transform: translateX(var(--text-translate-x));
    --line-intro-duration: .5s;
    --line-intro-delay: .25s;
}
.page.show .multi-line .line {
    opacity: 1;
    transform: none;
}
.multi-line .line:nth-child(5) { transition: all var(--line-intro-duration) ease; }
.multi-line .line:nth-child(4) { transition: all var(--line-intro-duration) ease var(--line-intro-delay); }
.multi-line .line:nth-child(3) { transition: all var(--line-intro-duration) ease calc(2 * var(--line-intro-delay)); }
.multi-line .line:nth-child(2) { transition: all var(--line-intro-duration) ease calc(3 * var(--line-intro-delay)); }
.multi-line .line:nth-child(1) { transition: all var(--line-intro-duration) ease calc(4 * var(--line-intro-delay)); }

.page.show .multi-line .line:nth-child(1) { transition: all var(--line-intro-duration) ease; }
.page.show .multi-line .line:nth-child(2) { transition: all var(--line-intro-duration) ease var(--line-intro-delay); }
.page.show .multi-line .line:nth-child(3) { transition: all var(--line-intro-duration) ease calc(2 * var(--line-intro-delay)); }
.page.show .multi-line .line:nth-child(4) { transition: all var(--line-intro-duration) ease calc(3 * var(--line-intro-delay)); }
.page.show .multi-line .line:nth-child(5) { transition: all var(--line-intro-duration) ease calc(4 * var(--line-intro-delay)); }

#background-container,
#main-container {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    transition: all 1s ease;
}
@media (min-width: 801px) {
    html[data-view="home"][data-page-index="1"] #main-container { transform: translateY(calc(-1 * var(--vh))); }
    html[data-view="home"][data-page-index="2"] #main-container { transform: translateY(calc(-2 * var(--vh))); }
    html[data-view="home"][data-page-index="3"] #main-container { transform: translateY(calc(-3 * var(--vh))); }
    html[data-view="home"][data-page-index="4"] #main-container { transform: translateY(calc(-4 * var(--vh))); }
    html[data-view="home"][data-page-index="5"] #main-container { transform: translateY(calc(-5 * var(--vh))); }
    html[data-view="home"][data-page-index="6"] #main-container { transform: translateY(calc(-6 * var(--vh))); }
    html[data-view="home"][data-page-index="7"] #main-container { transform: translateY(calc(-7 * var(--vh))); }
    html[data-view="home"][data-page-index="8"] #main-container { transform: translateY(calc(-8 * var(--vh))); }
    html[data-view="home"][data-page-index="9"] #main-container { transform: translateY(calc(-9 * var(--vh))); }
}

/* Background & Particles */

#background-container {
    position: fixed;
}

#background-particles {
    position: absolute;
    left: 0;
    top: 0;
    width: 100vw;
    height: calc(2 * var(--vh) + var(--num-pages) * var(--background-translate-y));
    opacity: 0;
    transition: all 1s ease;
    will-change: contents;
}
html.active #background-particles {
    opacity: .5;
}
html.active #background-particles.dim {
    opacity: .3;
}
html.active #background-particles.extra-dim {
    opacity: .2;
}
html[data-view="home"][data-page-index="1"] #background-particles { transform: translateY(calc(-1 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="2"] #background-particles { transform: translateY(calc(-2 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="3"] #background-particles { transform: translateY(calc(-3 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="4"] #background-particles { transform: translateY(calc(-4 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="5"] #background-particles { transform: translateY(calc(-5 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="6"] #background-particles { transform: translateY(calc(-6 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="7"] #background-particles { transform: translateY(calc(-7 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="8"] #background-particles { transform: translateY(calc(-8 * var(--background-translate-y))); }
html[data-view="home"][data-page-index="9"] #background-particles { transform: translateY(calc(-9 * var(--background-translate-y))); }

/* Intro */

/* Used to quickly test particles */
html.particle-debug #iad-logo-container,
html.particle-debug #intro-landing {
    opacity: 0 !important;
}

#intro-video {
    position: absolute;
    left: 0;
    top: 0;
    width: 100vw;
    height: calc(.85 * var(--vh));
    object-fit: cover;
    opacity: 0;
    transition: all 1s;
    pointer-events: none;
}
#intro-video.show {
    opacity: 1;
}

#intro-headline-1,
#intro-headline-2 {
    position: absolute;
    width: 100vw;
    top: 0;
    left: 0;
    padding: 0 5vw;
    box-sizing: border-box;
    font-size: 64px;
    line-height: 72px;
    font-family: 'RobotoBold';
    letter-spacing: 1px;
}

#intro-headline-1 {
    bottom: calc(.15 * var(--vh));
    justify-content: flex-end;
    color: white;
    transform: translateY(2px);
}

#intro-headline-2 {
    top: calc(.3 * var(--vh));
    height: calc(.4 * var(--vh));
    align-items: flex-end;
    justify-content: center;
    font-size: 48px;
    padding: 0 10vw;
}
#intro-headline-2 .line {
    width: 100%;
    transition: all var(--line-intro-duration) ease;
    line-height: 120px;
}
#intro-headline-2 .line:nth-child(2) {
    text-align: center;
}
#intro-headline-2 .line:nth-child(2) {
    transition: all var(--line-intro-duration) ease calc(1.5 * var(--line-intro-delay));
}
#intro-headline-2 .line:nth-child(3) {
    text-align: right;
}
#intro-headline-2 .line:nth-child(3) {
    transition: all var(--line-intro-duration) ease calc(3 * var(--line-intro-delay));
}

/* Work */

.project {
    position: absolute;
    width: 100vw;
    height: var(--vh);
    left: 0;
}
.project[data-index="0"] { top: 0; }
.project[data-index="1"] { top: var(--vh); }
.project[data-index="2"] { top: calc(var(--vh) * 2); }
.project[data-index="3"] { top: calc(var(--vh) * 3); }
.project[data-index="4"] { top: calc(var(--vh) * 4); }
.project[data-index="5"] { top: calc(var(--vh) * 5); }
.project[data-index="6"] { top: calc(var(--vh) * 6); }
.project[data-index="7"] { top: calc(var(--vh) * 7); }
.project[data-index="8"] { top: calc(var(--vh) * 8); }

.project-text {
    position: absolute;
    left: var(--section-side-padding);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 12px;
    pointer-events: none;
}

.project-title {
    opacity: 0;
    transform: translateX(var(--text-translate-x));
    font-family: 'RobotoBold';
    font-size: 28px;
    line-height: 32px;
    transition: all .5s ease;
    z-index: 1;
}

.project-subtitle {
    opacity: 0;
    transform: translateX(var(--text-translate-x));
    font-family: 'RobotoMedium';
    font-size: 20px;
    line-height: 24px;
    transition: all .5s ease;
    z-index: 1;
}

.project.details .project-subtitle { 
    color: white;
}

.page.show .project-text .project-title,
.page.show .project-text .project-subtitle {
    opacity: 1;
    transform: none;
}

.project-details-button {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 8px;
    margin: 4px;
    font-family: 'RobotoMedium';
    font-size: 14px;
    line-height: 14px;
    height: 18px;
    text-transform: uppercase;
    opacity: 0;
    transform: translateX(var(--text-translate-x));
    transition: transform .5s ease, opacity .5s ease, box-shadow .25s;
    cursor: pointer;
    color: white;
}
.page.show .project-details-button {
    opacity: 1;
    transform: none;
    transition: transform .5s ease .8s, opacity .5s ease .8s, box-shadow .25s;
}
.page.show .project-details-button:hover {
    box-shadow: 0 0 8px 4px #00000065;
}

.project-description {
    position: absolute;
    left: var(--section-side-padding);
    max-width: 1000px;
    padding-right: var(--section-side-padding);
    box-sizing: border-box;
    opacity: 0;
    font-family: 'RobotoRegular';
    font-size: 18px;
    line-height: 24px;
    transition: all .5s ease .25s;
    pointer-events: none;
    color: white;
    z-index: 1;
    white-space: pre-line;
}
.project.details .project-description {
    opacity: 1;
    pointer-events: all;
    cursor: pointer;
}

.project-description b {
    font-family: 'RobotoBold';
}

.project-details-background {
    opacity: 0;
    position: relative;
    width: 100vw;
    background-color: rgba(0,0,0,.8);
    transition: all .5s ease;
    pointer-events: none;
    z-index: 1;
}
.project.details .project-details-background {
    opacity: 1;
    pointer-events: all;
}

.project-details-close-button {
    position: absolute;
    font-family: 'RobotoBold';
    font-size: 32px;
    top: 8px;
    right: 8px;
    color: white;
    cursor: pointer;
}

.project-media {
    opacity: 0;
    position: absolute;
    object-fit: cover;
    transition: opacity .5s linear;
}
.page.show .project-media {
    opacity: 1;
}

.project[data-style="A"] .project-media[data-index="2"] { transition-delay: .1s; }
.project[data-style="A"] .project-media[data-index="3"] { transition-delay: .2s; }
.project[data-style="A"] .project-media[data-index="1"] { transition-delay: .3s; }
.project[data-style="A"] .project-media[data-index="0"] { transition-delay: .4s; }

.project[data-style="B"] .project-media[data-index="0"] { transition-delay: .1s; }
.project[data-style="B"] .project-media[data-index="1"] { transition-delay: .2s; }
.project[data-style="B"] .project-media[data-index="2"] { transition-delay: .3s; }
.project[data-style="B"] .project-media[data-index="3"] { transition-delay: .4s; }
.project[data-style="B"] .project-media[data-index="4"] { transition-delay: .5s; }
.project[data-style="B"] .project-media[data-index="5"] { transition-delay: .6s; }
.project[data-style="B"] .project-media[data-index="6"] { transition-delay: .7s; }

.project[data-style="C"] .project-media[data-index="3"] { transition-delay: .1s; }
.project[data-style="C"] .project-media[data-index="1"] { transition-delay: .2s; }
.project[data-style="C"] .project-media[data-index="0"] { transition-delay: .3s; }
.project[data-style="C"] .project-media[data-index="2"] { transition-delay: .4s; }

@media (min-width: 801px) {
    .project[data-style="A"] .project-text {
        /* width: calc(100% - 34% - 19% - 3 * var(--section-side-padding)); */
        height: calc(45% - (2 * var(--section-title-padding) + var(--section-title-height)));
        top: calc(2 * var(--section-title-padding) + var(--section-title-height));
    }
    
    .project[data-style="A"] .project-title,
    .project[data-style="A"] .project-subtitle {
        width: calc(100vw - 34vw - 19vw - 3 * var(--section-side-padding));
    }
    
    .project[data-style="A"] .project-details-button {
        bottom: 43%;
        right: calc(100% - (var(--section-side-padding) + 31%));
    }
    
    .project[data-style="A"] .project-media[data-index="0"] {
        left: var(--section-side-padding);
        bottom: 10%;
        width: 31%;
        height: 33%;
    }
    .project[data-style="A"] .project-media[data-index="1"] {
        left: calc(var(--section-side-padding) + 31%);
        bottom: 0;
        width: 44%;
        height: 55%;
    }
    .project[data-style="A"] .project-media[data-index="2"] {
        right: var(--section-side-padding);
        top: 0;
        width: 34%;
        height: 45%;
    }
    .project[data-style="A"] .project-media[data-index="3"] {
        right: calc(var(--section-side-padding) + 34%);
        bottom: 55%;
        width: 19%;
        height: 17%;
    }
    
    .project[data-style="B"] .project-text {
        bottom: 82%;
        right: var(--section-side-padding);
        width: calc(3 * 22vw + 10vw + 3 * var(--project-style-b-gap));
    }
    
    /* .project[data-style="B"] .project-description {
        left: 15vw;
    } */
    
    .project[data-style="B"] .project-details-button {
        bottom: 37%;
        right: calc(var(--section-side-padding) + 3 * 22vw + 10vw + 3 * var(--project-style-b-gap));
        margin-bottom: 0;
        margin-right: var(--project-style-b-gap);
    }
    
    .project[data-style="B"] .project-media[data-index="0"],
    .project[data-style="B"] .project-media[data-index="1"],
    .project[data-style="B"] .project-media[data-index="2"],
    .project[data-style="B"] .project-media[data-index="3"] {
        top: 18%;
        height: 45%;
    }
    
    .project[data-style="B"] .project-media[data-index="0"] {
        width: 10vw;
        right: calc(var(--section-side-padding) + 3 * 22vw + 3 * var(--project-style-b-gap));
    }
    
    .project[data-style="B"] .project-media[data-index="1"] {
        width: 22vw;
        right: calc(var(--section-side-padding) + 2 * 22vw + 2 * var(--project-style-b-gap));
    }
    
    .project[data-style="B"] .project-media[data-index="2"] {
        width: 22vw;
        right: calc(var(--section-side-padding) + 22vw + var(--project-style-b-gap));
    }
    
    .project[data-style="B"] .project-media[data-index="3"] {
        width: 22vw;
        right: var(--section-side-padding);
    }
    
    .project[data-style="B"] .project-media[data-index="4"],
    .project[data-style="B"] .project-media[data-index="5"],
    .project[data-style="B"] .project-media[data-index="6"] {
        top: calc(63% + var(--project-style-b-gap));
        width: 25%;
        height: calc(37% - 2 * var(--project-style-b-gap));
    }
    
    .project[data-style="B"] .project-media[data-index="4"] {
        left: var(--section-side-padding);
    }
    
    .project[data-style="B"] .project-media[data-index="5"] {
        left: calc(var(--section-side-padding) + 25vw + var(--project-style-b-gap));
    }
    
    .project[data-style="B"] .project-media[data-index="6"] {
        left: calc(var(--section-side-padding) + 2 * 25vw + 2 * var(--project-style-b-gap));
    }

    .project[data-style="C"] .project-text {
        top: 0;
        height: 27%;
    }

    .project[data-style="C"] .project-subtitle {
        width: calc(36vw - 2 * var(--section-side-padding));
    }
    
    .project[data-style="C"] .project-details-button {
        bottom: 73%;
        right: 65vw;
    }
    
    .project[data-style="C"] .project-media[data-index="0"] {
        width: 18vw;
        height: 30%;
        left: 0;
        top: 57%;
    }

    .project[data-style="C"] .project-media[data-index="1"] {
        width: 24vw;
        height: 30%;
        bottom: 43%;
        right: 65vw;
    }

    .project[data-style="C"] .project-media[data-index="2"] {
        width: 17vw;
        height: 43%;
        top: 57%;
        right: 65vw;
    }

    .project[data-style="C"] .project-media[data-index="3"] {
        width: 65vw;
        right: 0;
        top: 14%;
    }
}

/* Manifesto */

#manifesto-blocks {
    display: flex;
    height: var(--vh);
    align-items: center;
    gap: calc(2 * var(--section-side-padding));
    padding: 0 calc(2 * var(--section-side-padding));
    box-sizing: border-box;
}

.manifesto-block {
    font-family: 'RobotoMedium';
    font-size: 24px;
    line-height: 32px;
    opacity: 0;
    transform: translateX(var(--text-translate-x));
    transition: all .5s ease;
}
.manifesto-block:nth-child(1) { transition-delay: .2s; }
.manifesto-block:nth-child(2) { transition-delay: .4s; }
.manifesto-block:nth-child(3) { transition-delay: .6s; }
.page.show .manifesto-block {
    opacity: 1;
    transform: none;
}

/* Services */

#services-wrapper {
    width: 100vw;
    height: var(--vh);
    padding: 0 calc(2 * var(--section-side-padding));
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
}

#services {
    display: flex;
    align-items: center;
    gap: var(--section-side-padding);
}

.services-column {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--section-side-padding);
}

.service {
    font-family: 'RobotoBold';
    font-size: 30px;
    line-height: 36px;
    height: 36px;
    opacity: 0;
    transform: translateX(var(--text-translate-x));
    transition: all .5s ease;
}
.page.show .service {
    opacity: 1;
    transform: none;
}


/* Awards */

#section-awards {
    padding: 0 calc(2 * var(--section-side-padding));
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 80px;
    box-sizing: border-box;
}

#awards-title {
    font-family: 'RobotoBold';
    font-size: var(--section-title-height);
    text-align: center;
    line-height: calc(1.3 * var(--section-title-height));
    opacity: 0;
    transition: all .5s ease;
}
.page.show #awards-title {
    opacity: 1;
}

#awards-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    --service-width: calc((100vw - 4 * var(--section-side-padding)) / 3);
    box-sizing: border-box;
}

#awards {
    display: flex;
    align-items: center;
    gap: var(--section-side-padding);
}

.awards-column {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.award {
    width: var(--service-width);
    font-family: 'RobotoRegular';
    font-size: 20px;
    line-height: 24px;
    height: 28px;
    opacity: 0;
    transform: translateX(var(--text-translate-x));
    transition: all .5s ease;
}
.page.show .award {
    opacity: 1;
    transform: none;
}

/* Footer */

#footer {
    width: 100vw;
    height: var(--vh);
    display: flex;
    background-color: black;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 80px;
    text-align: center;
}

#footer-title {
    font-family: 'RobotoBold';
    font-size: var(--section-title-height);
    text-align: center;
}

#footer-text {
    gap: 40px;
    padding: 0 20vw;
    font-family: 'RobotoMedium';
    font-size: 32px;
    color: white;
}

#footer a {
    font-family: 'RobotoBold';
    font-size: 26px;
    letter-spacing: 1px;
    text-decoration: none;
    color: #ab65f8;
    padding-bottom: 2px;
    transition: box-shadow .25s, opacity .5s ease;
    opacity: 0;
}
#footer.show a {
    transition: box-shadow .25s, opacity .5s ease .5s;
    opacity: 1;
 }
#footer a:hover {
    box-shadow: 0 3px 0px 0 #ab65f8;
}

/* Logo */

#iad-logo-container {
    position: fixed;
    width: 1920px;
    height: 792px;
    left: 50vw;
    top: 32px;
    transform-origin: center;
    transform: translate3d(-50%, calc(-50% + .5 * var(--vh) - 32px), 0) scale(var(--home-logo-scale));
    opacity: 0;
    transition: opacity 1s ease-in;
    pointer-events: none;
    z-index: 3;
}
#iad-logo-container.show {
    opacity: 1;
}
#iad-logo-container.small {
    transition: all 1s ease;
    transform: translate3d(-50%, -50%, 0) scale(.06);
}
#iad-logo-container.left {
    left: 80px;
}
#iad-logo-container.right {
    left: calc(100vw - 80px);
}

#iad-logo-acronym-container,
#iad-logo-acronym,
.iad-logo-word-container,
.iad-logo-word {
    position: absolute;
    top: 0;
    left: 0;
    transition: all .5s ease;
}

#iad-logo-acronym-container, #iad-logo-acronym {
    width: 1077px;
    height: 792px;
}

.iad-logo-word-container, .iad-logo-word {
    width: 720px;
    height: 264px;
}

.iad-logo-word-container {
    left: 1200px;
    overflow: hidden;
}

#iad-logo-acronym, .iad-logo-word {
    -webkit-mask-size: cover;
    mask-size: cover;
    background-color: black;
}

#iad-logo-container.white #iad-logo-acronym,
#iad-logo-container.white .iad-logo-word {
    background-color: white;
}

#iad-logo-acronym {
    -webkit-mask-image: url(../assets/images/iad_logo_acronym.png);
    mask-image: url(../assets/images/iad_logo_acronym.png);
}

/* #iad-logo-inspired-container {
} */

#iad-logo-action-container {
    top: 264px;
}

#iad-logo-design-container {
    top: 528px;
}

.iad-logo-word,
#iad-logo-container.acronym .iad-logo-word {
    transform: translateX(-100%);
}
#iad-logo-container.show .iad-logo-word {
    transform: none;
}

#iad-logo-inspired {
    -webkit-mask-image: url(../assets/images/iad_logo_inspired.png);
    mask-image: url(../assets/images/iad_logo_inspired.png);
    transition-delay: .5s;
}

#iad-logo-action {
    -webkit-mask-image: url(../assets/images/iad_logo_action.png);
    mask-image: url(../assets/images/iad_logo_action.png);
    transition-delay: .75s;
}

#iad-logo-design {
    -webkit-mask-image: url(../assets/images/iad_logo_design.png);
    mask-image: url(../assets/images/iad_logo_design.png);
    transition-delay: 1s;
}

/* Mobile */

@media (max-width: 800px) {
    :root {
        --text-translate-x: -20px;
        --section-vertical-padding: 20px;
        --section-side-padding: 8px;
        --section-vertical-gap: 80px;
    }

    #mobile-title-bar {
        position: fixed;
        left: 0;
        top: 0;
        width: 100vw;
        height: 64px;
        background: white;
        opacity: 0;
        transition: all .5s ease;
        z-index: 1;
    }
    #mobile-title-bar.show {
        opacity: 1;
    }

    #iad-logo-container.small {
        transform: translate3d(calc(50vw - 16px - 50%), -50%, 0) scale(.06);
    }

    #iad-logo-container.small .iad-logo-word-container {
        opacity: 0;
        transition: transform .5s ease, opacity 1s linear;
    }

    #background-particles {
        transition: opacity 2s ease;
    }
    html.active #background-particles.extra-dim {
        opacity: .2;
    }

    #intro-headline-1 {
        top: unset;
        display: inline-block;
        font-size: 40px;
        line-height: 48px;
        height: fit-content;
        transform: translateX(var(--text-translate-x));
        transition: all .5s;
    }
    #intro-headline-1.show {
        transform: none;
    }

    #intro-headline-1 .line {
        transition-delay: 0s;
    }

    #intro-headline-2 {
        font-size: 22px;
    }

    #intro-headline-2 .line {
        transform: translateX(calc(-1 * var(--text-translate-x)));
    }
    #intro-headline-2.show .line {
        transform: none;
    }
    #intro-headline-2 .line:nth-child(1),
    #intro-headline-2 .line:nth-child(2),
    #intro-headline-2 .line:nth-child(3) {
        text-align: right;
    }
    #intro-headline-2.show .line:nth-child(2) {
        transition: all var(--line-intro-duration) ease .15s;
    }
    #intro-headline-2.show .line:nth-child(3) {
        transition: all var(--line-intro-duration) ease .3s;
    }

    .project {
        position: static;
        height: unset;
        padding: var(--section-side-padding);
        margin-top: var(--section-vertical-padding);
        display: flex;
        flex-direction: column;
        box-sizing: border-box;
        gap: 8px;
    }

    .project-details-button {
        display: none;
    }

    .project-details-background {
        display: none;
    }

    .project-text {
        position: static;
    }

    .project-media {
        position: static;
        width: calc(100vw - 2 * var(--section-side-padding));
        height: auto;
    }

    .project[data-style="A"] .project-media[data-index="0"] { transition-delay: .1s; }
    .project[data-style="A"] .project-media[data-index="1"] { transition-delay: .2s; }
    .project[data-style="A"] .project-media[data-index="2"] { transition-delay: .3s; }
    .project[data-style="A"] .project-media[data-index="3"] { transition-delay: .4s; }
    
    .project[data-style="C"] .project-media[data-index="0"] { transition-delay: .1s; }
    .project[data-style="C"] .project-media[data-index="1"] { transition-delay: .2s; }
    .project[data-style="C"] .project-media[data-index="2"] { transition-delay: .3s; }
    .project[data-style="C"] .project-media[data-index="3"] { transition-delay: .4s; }

    .project-description {
        position: static;
        padding-right: 0;
        color: black;
        opacity: 1;
    }

    #section-manifesto,
    #manifesto-blocks {
        height: unset;
    }

    #section-manifesto {
        margin-top: var(--section-vertical-gap);
    }

    #section-manifesto .section-title {
        position: static;
    }

    #manifesto-blocks {
        margin-top: var(--section-vertical-padding);
        flex-direction: column;
    }

    .manifesto-block {
        font-family: 'RobotoMedium';
        font-size: 20px;
        line-height: 28px;
    }

    #section-services,
    #services-wrapper {
        height: unset;
    }

    #section-services {
        margin-top: var(--section-vertical-gap);
    }
    
    #section-services .section-title {
        position: static;
    }

    #services-wrapper {
        padding: var(--section-vertical-padding);
        padding-left: calc(2 * var(--section-vertical-padding) + var(--section-side-padding));
    }

    #services {
        flex-direction: column;
        align-items: flex-start;
    }

    .service {
        height: unset;
        font-size: 20px;
        line-height: 28px;
    }

    #section-awards {
        padding: var(--section-vertical-padding) var(--section-side-padding);
        gap: 40px;
        justify-content: flex-start;
        height: unset;
    }

    #awards-title {
        font-size: 28px;
        line-height: 34px;
    }

    #awards-title br {
        display: none;
    }

    #awards-wrapper {
        padding-left: calc(2 * var(--section-vertical-padding));
    }

    #awards {
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
    }

    .award {
        width: unset;
        height: unset;
        line-height: 28px;
        padding-left: 20px;
        text-indent: -20px;
    }

    #footer {
        margin-top: var(--section-vertical-padding);
    }

    #footer-title {
        font-size: 32px;
    }

    #footer-text {
        padding: 0 5vw;
        font-size: 22px;
    }

    #footer a {
        font-size: 20px;
    }
}