body,form,figure{margin:0;padding:0}img{border:0}header,footer,nav,section,aside,article,figure,figcaption{display:block}body{font-size:100.01%}select,input,textarea{font-size:99%}#container,.inside{position:relative}#main,#left,#right{float:left;position:relative}#main{width:100%}#left{margin-left:-100%}#right{margin-right:-100%}#footer{clear:both}#main .inside{min-height:1px}.ce_gallery>ul,.content-gallery>ul{margin:0;padding:0;overflow:hidden;list-style:none}.ce_gallery>ul li,.content-gallery>ul li{float:left}.ce_gallery>ul li.col_first,.content-gallery>ul li.col_first{clear:left}.float_left,.media--left>figure{float:left}.float_right,.media--right>figure{float:right}.block{overflow:hidden}.media{display:flow-root}.clear,#clear{height:.1px;font-size:.1px;line-height:.1px;clear:both}.invisible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.custom{display:block}#container:after,.custom:after{content:"";display:table;clear:both}
@media (max-width:767px){#wrapper{margin:0;width:auto}#container{padding-left:0;padding-right:0}#main,#left,#right{float:none;width:auto}#left{right:0;margin-left:0}#right{margin-right:0}}img{max-width:100%;height:auto}.audio_container audio{max-width:100%}.video_container video{max-width:100%;height:auto}.aspect,.responsive{position:relative;height:0}.aspect iframe,.responsive iframe{position:absolute;top:0;left:0;width:100%;height:100%}.aspect--16\:9,.responsive.ratio-169{padding-bottom:56.25%}.aspect--16\:10,.responsive.ratio-1610{padding-bottom:62.5%}.aspect--21\:9,.responsive.ratio-219{padding-bottom:42.8571%}.aspect--4\:3,.responsive.ratio-43{padding-bottom:75%}.aspect--3\:2,.responsive.ratio-32{padding-bottom:66.6666%}
@font-face {
    font-family: "Inter";
    font-weight: 200;
    font-style: normal;
    font-display: swap;
    src: url("../../files/fonts/Inter-ExtraLight.woff2") format("woff2"),
         url("../../files/fonts/Inter-ExtraLight.ttf") format("truetype");
}

@font-face {
    font-family: "Inter";
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    src: url("../../files/fonts/Inter-Regular.woff2") format("woff2"),
         url("../../files/fonts/Inter-Regular.ttf") format("truetype");
}

@font-face {
    font-family: "Inter";
    font-weight: 900;
    font-style: normal;
    font-display: swap;
    src: url("../../files/fonts/Inter-Black.woff2") format("woff2"),
         url("../../files/fonts/Inter-Black.ttf") format("truetype");
}
html {
    scroll-behavior: smooth;
}

body {
    background-color: black;
    color: #FFF;
    font-family: 'Inter', Helvetica, Arial, sans-serif;
    font-size: 16px;
}

.block {
    overflow: visible !important;
}


/* Text */

h1 {
    font-size: 5em;
    margin: 0 0 40px 0;
    line-height: 1em;
}

h2 {
    font-size: 3em;
    margin: 0 0 40px 0;
}

h3 {
    font-size: 1.6em;
    margin: 0 0 40px 0;
}

h4 {
    font-size: 1em;
    margin: 0 0 20px 0;
}

p {
    font-size: 1.6em;
    margin: 0 0 20px 0;
}

.content-text li {
    font-size: 1.6em;
    margin: 0 0 20px 0;
}

a {
    color: #FFF;
}

em {
    font-weight: 200;
}


/* Buttons */

.primaryButton {
    display: inline-block;
    border: 2px solid #FFF;
    border-radius: 50px;
    text-decoration: none;
    padding: 15px 25px;
    transition: all 0.25s ease-in-out;
    color: #000;
    background-color: #FFF;
}

.secondaryButton {
    display: inline-block;
    border: 2px solid #FFF;
    border-radius: 50px;
    text-decoration: none;
    padding: 15px 25px;
    transition: all 0.25s ease-in-out;
}

.secondaryButton:hover {
    color: #000;
    background-color: #FFF;
}

.secondaryButton+.primaryButton {
    margin-left: 20px;
}


/* Navigation */

#header {
    position: fixed;
    width: 100%;
    z-index: 100;
    top: 0;
    left: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, .5) 0%, rgba(0, 0, 0, 0) 100%);
}

#header .inside {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 2000px;
    margin: 0 auto;
}

#logo {
    font-size: 5em;
    display: block;
    color: #FFF;
    text-decoration: none;
    font-weight: 900;
    padding: 40px;
}

#mobile_menu {
    display: none;
}

#mobile_menu_logo {
    display: none;
}

.mod_navigation {

    ul {
        display: flex;
        align-items: flex-start;
        padding: 0;
        margin: 0;
    }

    li {
        display: block;
        position: relative;
        color: #FFF;
        text-decoration: none;
    }

    a,
    strong {
        display: block;
        color: #FFF;
        text-decoration: none;
        padding: 40px;
    }

    a.submenu::before,
    strong.submenu::before {
        content: "›";
        position: absolute;
        left: calc(100% - 30px);
        transform: rotate(90deg);
        transition: all 0.5s ease-in-out;
    }

    a::after {
        content: "";
        position: absolute;
        left: 40px;
        top: calc(50% + 14px);
        width: 0%;
        height: 4px;
        background-color: #FFF;
        transition: all 0.25s ease-in-out;
    }

    li.submenu:hover>a::after,
    a:hover::after {
        width: calc(100% - 80px);
    }

    strong,
    li.submenu a.trail {
        position: relative;
        font-weight: 400;
    }

    strong::after,
    li.submenu a.trail::after {
        content: "";
        position: absolute;
        left: 40px;
        top: calc(50% - 1px);
        width: calc(100% - 80px);
        height: 4px;
        background-color: #FFF;
    }

    li ul {

        display: block;

        position: absolute;
        background-color: #000;
        border-radius: 20px;
        padding: 5px 0px;


        visibility: hidden;
        opacity: 0;
        transition: visibility 0s, opacity 0.5s ease-in-out, background-color 0.5s ease-in-out;

        li {

            display: block;

            a,
            strong {
                display: inline-block;
                position: relative;
                padding: 20px 40px;
            }

        }

    }

    li:hover ul {
        visibility: visible;
        opacity: 1;
    }

    li:hover a.submenu::before,
    li:hover strong.submenu::before {
        transform: rotate(-90deg);
    }

}


/* Hero */

#hero {
    display: flex;
    align-items: flex-end;
    width: 100%;
    height: 100vh;
    padding: 0;
    overflow: hidden !important;
    position: relative;
}

#hero video {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -100;
    opacity: .8;
}

#hero .content-image {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    max-height: 100%;
    border-radius: 0;
    object-fit: cover;
    z-index: -100;
    opacity: .5;

    img {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        max-height: 100%;
        object-fit: cover;
    }
}

#hero .content-text {
    margin: 0 auto;

    .rte {
        max-width: 960px;
    }
}

/* Überschrift H1 im Hero */
#hero .content-text h1 {
    /* Fluid Typography: Passt sich flüssig an die Fensterbreite an */
    font-size: clamp(36px, 5vw, 80px);
    line-height: 1.1;
    margin-bottom: 20px;
    
    /* Verhindert, dass die Überschrift zu breit läuft */
    max-width: 85%; 
}

/* Subline (H2 oder p) */
#hero .content-text h2, 
#hero .content-text p {
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.4;
    max-width: 80%; /* Hier brichst du "Berlin & Graz" früher um */
    margin-top: 0;
    margin-bottom: 40px;
}

#hero .primaryButton {
    margin-bottom: 40px;
}

video::-webkit-media-controls {
    display: none;
}


/* General Elements */

.start-1 {
    grid-column-start: 1;
}

.start-2 {
    grid-column-start: 2;
}

.start-3 {
    grid-column-start: 3;
}

.start-4 {
    grid-column-start: 4;
}

.start-5 {
    grid-column-start: 5;
}

.span-2 {
    grid-column-end: span 2;
}

.span-3 {
    grid-column-end: span 3;
}

.span-4 {
    grid-column-end: span 4;
}

.span-5 {
    grid-column-end: span 5;
}

.span-6 {
    grid-column-end: span 6;
}

.span-h-2 {
    grid-row-end: span 2;
}

.center {
    text-align: center;
}

.vertical-center {
    align-self: center;
}

.add-padding {
    padding-bottom: 120px !important;
}

.add-padding:not(:first-child) {
    padding-top: 120px !important;
}

.mod_article:not(#hero) {
    margin-top: 180px;

    .small {
        margin-top: 235px;
    }
}

.mod_article div:last-child.mod_newslist {
    margin-bottom: 0 !important;
}

.mod_article.grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 40px;
    max-width: 1920px;
    padding: 0 40px 0 40px;
    margin: 0 auto;
}

.content-text {
    width: calc(100% - 80px);
    max-width: 1920px;
    padding: 0 40px;
    margin: 0 auto 160px auto;
}

.mod_subscribe {
    width: 100%;
    margin-top: 50px;
    margin-bottom: 60px;
}

.mod_subscribe .formbody {
    display: flex;
}

.grid .content-text {
    align-self: center;
    padding: 0;
    margin: 0;
}

.content-image {
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    /* max-height: calc(100vh - 280px); */
}

.content-image figure,
.content-image img {
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.small {
    max-width: 960px;
}

.message {
    display: block;
    margin: 0;
    width: 100%;
    height: calc(100vh - 100px);
    display: flex;
    align-items: center;
    justify-content: center;
}

.message .content-text {
    max-width: 960px;
    text-align: center;
    margin: 0px;
    padding: 40px;
}


/* Kontakt */


p.social a {
    display: inline-block;
    padding: 5px 7px;
    position: relative;
    left: -7px;
}


/* Team */


.content-text.team {
    margin: 0;
    padding: 0;
    color: #000;

    figure img {
        width: 100%;
        object-fit: cover;
        border-radius: 20px;
        margin-bottom: 20px;
    }

    a {
        color: #000;
    }
}

.about {
    display: block;
    background-color: #FFF;
    margin: 160px auto 0 auto;
}

.about .inside {
    max-width: 1920px;
    padding: 160px 40px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
}



/* News */

.mod_newslist {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    padding: 0 40px;
    max-width: 1920px;
    margin: 0 auto 160px auto;
}

.mod_newslist p.more {
    text-align: center;
    margin-bottom: 0px;
}

/* --- Basis Container --- */
.layout_latest {
    height: 0px;
    padding-bottom: 56.25%; /* 16:9 */
    overflow: hidden !important;
    position: relative;
    border-radius: 20px;
    cursor: pointer;
    display: block;
    text-decoration: none;
    color: inherit;
    /* Bugfix für Webkit/Safari bei Border-Radius + Overflow */
    transform: translateZ(0); 
}

.layout_latest.span-h-2 {
    padding-bottom: calc(112.5% + 40px);
}

/* --- Der innere Container --- */
.layout_latest .inside {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    transition: all 0.5s ease-in-out;
    opacity: 0.8;
}

/* Hover-Effekt */
.layout_latest:hover .inside {
    opacity: 0.5;
    transform: scale(1.1);
}

/* --- NEU: Bild-Wrapper und Reset --- */
.layout_latest .inside .bg-image-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

/* WICHTIG: figure Reset, falls Contao einen generiert */
.layout_latest .inside .bg-image-wrapper figure,
.layout_latest .inside .bg-image-wrapper .image_container {
    margin: 0 !important;
    padding: 0 !important;
    width: 100%;
    height: 100%;
    display: block;
}

/* Das Bild selbst */
.layout_latest .inside img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    display: block;
}

/* --- Video --- */
.layout_latest video {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.01);
    z-index: 2; /* Über dem Bild */
}

/* --- Text Overlay --- */
.layout_latest .text {
    position: absolute;
    width: calc(100% - 40px);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    padding: 20px;
    z-index: 10;
    pointer-events: none;
}

.layout_latest .text .client {
    font-size: 0.8em;
    margin: 0;
    font-weight: bold;
}

.layout_latest .text h3 {
    margin: 0;
}

.layout_full {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 40px;
    max-width: 1920px;
    padding: 0 40px;
    margin: 220px auto 0 auto;
}

.layout_full .content-text {
    margin-top: 60px;
    margin-bottom: 60px;
    padding: 0;
    align-self: center;
    width: 100%;
}

.layout_full video {
    width: 100%;
}

/* Container sicherstellen */
#credits {
    margin-bottom: 120px;
    display: block !important;
}

/* Die Tabelle (Standard: zugeklappt) */
#credits table {
    display: block;
    overflow: hidden;
    opacity: 0;
    max-height: 0; /* Wir nutzen max-height statt height für die Animation */
    transition: all 0.5s ease-in-out;
    border-collapse: collapse;
    width: 100%;
}

/* Die Tabelle (Zustand: offen) - wird per JS hinzugefügt */
#credits .visible {
    opacity: 1;
    max-height: 2000px; /* Ein Wert, der größer ist als die Tabelle jemals wird */
    margin-top: 20px;
}

/* Styling für den Knopf, den wir gleich per JS erzeugen */
#toggleCredits {
    cursor: pointer;
    text-decoration: none; /* oder underline, wie du magst */
    font-weight: bold;
    display: inline-block;
    padding: 10px 0;
}

/* Tabellen-Styles behalten wir bei */
#credits th {
    padding-right: 40px;
    padding-bottom: 20px;
    text-align: left;
    vertical-align: top;
    opacity: 0.6;
    width: 40%;
}

#credits td {
    padding-bottom: 20px;
    vertical-align: top;
}


/* iPhone */

.iphone-container-wrapper {
    margin: 0 0 0 0;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 80vh;
    max-height: 720px;
}

.iphone-container {
    height: 80vh;
    max-height: 720px;
    aspect-ratio: 1 / 2;
    background-image: url('../../files/media/iphone.png');
    background-size: contain;
    background-repeat: no-repeat;
    position: relative;
}

.video-container {
    position: absolute;
    top: 2.25%;
    left: 5.85%;
    right: 5.85%;
    height: 95.5%;
    overflow: hidden;
    border-radius: 3.75vh;
    background-color: #000;
    cursor: pointer;
}

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

.hidden {
    display: none;
}

.progress-indicator {
    position: absolute;
    top: 4%;
    left: 12%;
    right: 12%;
    display: flex;
    justify-content: space-between;
}

.progress-segment {
    flex-grow: 1;
    height: 3px;
    background-color: rgba(255, 255, 255, 0.25);
    margin-right: 2px;
    border-radius: 5px;
}

.progress-segment:last-child {
    margin-right: 0;
}

.progress-segment.active {
    background-color: rgba(255, 255, 255, 0.5);
}

.mute-button {
    width: 40px;
    text-align: center;
    position: absolute;
    bottom: 5%;
    right: 10%;
    color: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    padding: 5px;
}

/* Video Player */

/* Video Player & CLS Fix (Die finale Lösung) */

/* 1. Basis-Container (.video) */
/* Hier definieren wir den Standard (16:9), damit der Player NIE unsichtbar ist */
.video {
    position: relative;
    display: block;
    width: 100%;
    height: 0; 
    padding-bottom: 56.25%; /* Standard-Fallback: 16:9 */
    overflow: hidden;
    border-radius: 25px;
}

/* 2. Explizite Formate */

/* Falls 'sechszehnneun' explizit im HTML steht -> Auch 16:9 */
.video.sechszehnneun {
    padding-bottom: 56.25%; 
}

/* Falls mal ein 4:3 Video kommt -> Überschreibt den Standard */
.video.vierdrei {
    padding-bottom: 75%;
}

/* Falls Hochformat (9:16) kommt */
.video.neunsechzehn {
    padding-bottom: 177.77%;
}


/* 3. Der innere Wrapper (Positionierung) */
/* Zwingt den Inhalt, das "Padding-Loch" komplett auszufüllen */
.video > div {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    margin: 0;
    padding: 0;
}

/* 4. Der Player selbst (Clappr Fix) */
/* Stellt sicher, dass auch tief verschachtelte Player-Elemente groß werden */
#player-wrapper,
[data-player] {
    width: 100% !important;
    height: 100% !important;
    position: absolute;
    top: 0;
    left: 0;
}

/* Clients Logos */


.clients {
    display: block;
    background-color: #FFF;
    margin: 0 auto 160px auto;
}

.clients .inside {
    max-width: 1920px;
    padding: 160px 40px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 80px;
}

.clients h2 {
    color: #000;
    text-align: center;
    margin: 0;
}

.clients .content-image {
    place-self: center;
    border-radius: 0;
}

.clients .content-image img {
    max-width: 150px;
    max-height: 60px;
    object-fit: contain;
}


/* Events */

.mod_eventlist {
    grid-column: span 6;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    margin-bottom: 100px;
}

.layout_list .image_container {
    position: relative;
    width: 100%;
    height: 0px;
    padding-bottom: 56.25%;
    overflow: hidden !important;
    border-radius: 20px;
    margin-bottom: 20px;

    img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center center;
    }
}

.layout_list h3 {
    margin-bottom: 20px;
}

.mod_eventreader .layout_full .content-text {
    margin: 0;
}

.mod_eventreader .image_container {
    position: relative;
    width: 100%;
    height: calc(100vh - 320px);
    overflow: hidden;

    img {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
}

.mod_eventreader table td {
    vertical-align: top;

    i {
        font-size: 1.6em;
        width: 30px;
        text-align: center;
        padding-top: 2px;
        padding-right: 10px;
    }
}

.mod_eventreader table {
    margin-bottom: 25px;
}

.enclosure {
    margin: 0;
    padding: 0;
}

.enclosure li {
    font-size: 1.6em;
    display: block;

    i {
        margin-left: 5px;
        margin-right: 10px;
    }
}

/* Rent */

.rent {
    background: rgb(255, 255, 255);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.09) 0%, rgba(255, 255, 255, 0.06) 100%);
    border-radius: 20px;
    overflow: hidden !important;

    .text {
        padding: 40px;
    }

    h3 {
        margin: 0 0 5px 0;
    }

    p {
        margin: 0;
    }
}

/* Form */

input[type=text],
input[type=email] {
    padding: 17px 20px;
    font-size: 1.6em;
    border-radius: 20px;
    outline: none;
    border: 0;
    display: inline-block;
    margin-right: 20px;
}

button {
    background: none;
    display: inline-block;
    border: 2px solid #FFF;
    border-radius: 50px;
    text-decoration: none;
    padding: 15px 25px;
    transition: all 0.25s ease-in-out;
    color: #FFF;
    font-size: 1.6em;
    cursor: pointer;
    outline: none;
}

button:hover {
    color: #000;
    background-color: #FFF;
}


/* Footer */

footer .inside {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    opacity: 0.6; /* Footer ist standardmäßig sehr blass */
    max-width: 1920px;
    margin: 0 auto;
    padding: 40px;
    transition: opacity 0.3s ease; /* Macht das Einblenden weich */
}

/* WICHTIG: Damit man den Footer gut sieht, wenn man mit der Maus drüber fährt */
footer .inside:hover {
    opacity: 1;
}

footer .social {
    text-align: center;
}

footer .social a {
    padding: 0 10px;
    text-decoration: none; /* Verhindert Unterstriche bei den Icons */
    display: inline-block; /* Wichtig für saubere Ausrichtung */
}

/* --- NEU: Styling für die SVG Icons --- */
footer .social svg {
    width: 20px;          /* Entspricht ca. der FontAwesome Standardgröße */
    height: 20px;
    fill: currentColor;   /* Das Icon erbt die Textfarbe */
    vertical-align: middle;
    transition: transform 0.2s ease;
}

/* Optional: Kleiner Zoom-Effekt beim Drüberfahren */
footer .social a:hover svg {
    transform: scale(1.2);
}
/* -------------------------------------- */

footer .language {
    text-align: right;
}

footer .language ul {
    padding: 0;
    margin: 0;
}

footer .language li {
    display: inline-block;
}

/* Klasse zum Verstecken von Elementen (nur für SEO/Screenreader sichtbar) */
.visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* =========================================
   CLIENT LOGOS
   ========================================= */

/* Section spacing */
.mod_article.client-logo-section {
    margin: 120px 0;
    padding: 0 40px;
}

.mod_article.client-logo-section + .mod_article {
    margin-top: 120px;
}


/* =========================================
   DESKTOP – FLEX (centers uneven rows)
   ========================================= */

.custom-client-grid ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 40px 80px;
    list-style: none;
    padding: 0;
    margin: 0 auto;
    max-width: 1400px;
}

.custom-client-grid li {
    display: flex;
    justify-content: center;
    align-items: center;
}

.custom-client-grid figure {
    margin: 0;
}


/* Logo styling */
.custom-client-grid img {
    display: block;
    max-width: 150px;
    max-height: 60px;
    width: auto;
    height: auto;
    object-fit: contain;

    filter: brightness(0) invert(1);
    opacity: 1;
    transition: opacity 0.3s ease;
}

.custom-client-grid img:hover {
    opacity: 1;
}


/* Remove Contao clearfix artifacts safely */
.custom-client-grid ul::before,
.custom-client-grid ul::after {
    display: none;
}


/* =========================================
   MOBILE – GRID
   ========================================= */

@media (max-width: 768px) {

    .mod_article.client-logo-section {
        margin: 60px 0;
        padding: 0 20px;
    }

    .mod_article.client-logo-section + .mod_article {
        margin-top: 60px;
    }

    /* Switch container to grid */
    .custom-client-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 30px 10px;
        align-items: center;
        justify-items: center;
    }

    /* Remove UL/LI layout only on mobile */
    .custom-client-grid ul,
    .custom-client-grid li {
        display: contents;
    }

    .custom-client-grid img {
        max-width: 85px;
        max-height: 40px;
        opacity: 1;
    }
}
@media (max-width: 1280px) {

    /* Text */

    h1 {
        font-size: 2.5em;
        line-height: 1.1em;
        margin-bottom: 20px;
    }

    h2 {
        font-size: 2em;
        line-height: 1.1em;
        margin-bottom: 20px;
    }

    h3 {
        font-size: 1.5em;
        line-height: 1.1em;
        margin-bottom: 20px;
    }

    h4 {
        font-size: 1em;
        margin-bottom: 20px;
    }

    p {
        font-size: 1em;
    }

    .content-text li {
        font-size: 1em;
    }

    /* General Elements */

    #hero {
        height: calc(100vh - 150px);
    }

    .mod_article:not(#hero) {
        margin-top: 70px !important;
    }

    .mod_newslist {
        grid-template-columns: 100%;
        width: calc(100% - 40px);
        padding: 0 20px;
        margin-bottom: 80px;
        gap: 20px;
    }

    .social {
        margin-bottom: 0px;
    }

    .mod_article.grid {
        grid-template-columns: repeat(1, minmax(0, 1fr));
        gap: 20px;
        padding: 0 20px;
        width: calc(100% - 40px);

        .content-text {
            padding-left: 0px !important;
            padding-right: 0px !important;
        }
    }

    .content-text {
        width: calc(100% - 40px);
        padding: 0 20px;
        margin: 0 auto 40px auto;
    }

    .mod_article:not(#hero)>.content-text {
        margin: 0;
        padding: 40px 20px 60px 20px;
    }

    .clients {
        margin-bottom: 80px;
    }

    .clients .inside {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 40px;
        padding: 80px 20px;
    }

    .clients h2 {
        grid-column-end: span 3;
    }

    .start-1 {
        grid-column-start: 1;
    }

    .start-2 {
        grid-column-start: 1;
    }

    .start-3 {
        grid-column-start: 1;
    }

    .start-4 {
        grid-column-start: 1;
    }

    .start-5 {
        grid-column-start: 1;
    }

    .span-2 {
        grid-column-end: span 1;
    }

    .span-3 {
        grid-column-end: span 1;
    }

    .span-4 {
        grid-column-end: span 1;
    }

    .span-5 {
        grid-column-end: span 1;
    }

    .span-6 {
        grid-column-end: span 1;
    }

    .span-h-2 {
        grid-row-end: span 1;
    }

    /* Menu */

    #header .inside {
        display: block;
        position: relative;
    }

    #menu,
    #menu_logo {
        display: none;
    }

    #mobile_menu {
        display: block;
        position: absolute;
        width: 100%;
        top: 0;
        left: 0;
        font-size: 1.5em;

        ul {
            display: block;
            width: 100%;
            background-color: #000;
            text-align: center;
            position: relative;
        }

        ul.level_1 {
            position: absolute;
            width: 100%;
            height: 0vh;
            background-color: #000;
            overflow: hidden;
            transition: .4s ease-in-out;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-direction: column;
        }

        input[type="checkbox"]:checked~label~ul.level_1 {
            height: 100vh;
        }

        input[type="checkbox"]:checked~label~ul.level_1 li {
            opacity: 1;
        }

        li {
            display: block;
            opacity: 0;
            transition: all 0.25s ease-in-out;
            text-align: center;
        }

        li a,
        li label {
            padding: 10px;
            position: relative;
            display: inline-block;
        }

        li ul {
            visibility: visible;
            opacity: 1;
            padding: 0;

            li {
                height: 0px;
                overflow: hidden;
                transition: all 0.25s ease-in-out;
            }
        }

        li input[type=checkbox]:checked~ul {
            li {
                height: 49px;
            }
        }

        li.submenu>label {
            display: flex;
            justify-content: center;
            gap: 10px;
            padding-left: 20px;
        }

        li .chevron {
            position: relative;
            transform: rotate(90deg);
            transition: all 0.25s ease-in-out;
        }

        li input[type=checkbox]:checked~label .chevron {
            transform: rotate(-90deg);
        }

        a::after {
            left: 10px;
            top: calc(50% + 14px);
        }

        li.submenu:hover>a::after,
        a:hover::after {
            width: calc(100% - 20px);
        }

        label.active::after {
            content: "";
            position: absolute;
            left: 10px;
            top: calc(50% - 1px);
            width: calc(100% - 20px);
            height: 4px;
            background-color: #FFF;
        }

    }

    #mobile_menu_logo {
        display: block;
        padding: 20px;

        a {
            font-size: 1.5em;
            font-weight: 900;
            text-decoration: none;
        }
    }

    #mobile_menu input[type="checkbox"] {
        display: none;
    }

    /* Hamburger */

    #mobile_menu>label {
        position: absolute;
        right: 0px;
        display: flex;
        flex-direction: column;
        width: 30px;
        height: 30px;
        cursor: pointer;
        padding: 20px;
        z-index: 100;
    }

    #mobile_menu>label span {
        background: #fff;
        border-radius: 10px;
        height: 2px;
        margin: 3px 0;
        transition: .4s cubic-bezier(0.68, -0.6, 0.32, 1.6);
    }

    #mobile_menu>label span:nth-of-type(1) {
        width: 50%;
    }

    #mobile_menu>label span:nth-of-type(2) {
        width: 100%;
    }

    #mobile_menu>label span:nth-of-type(3) {
        width: 75%;
    }

    #mobile_menu input[type="checkbox"]:checked~label span:nth-of-type(1) {
        transform-origin: bottom;
        transform: rotatez(45deg) translate(4px, 1px);
    }

    #mobile_menu input[type="checkbox"]:checked~label span:nth-of-type(2) {
        transform-origin: top;
        transform: rotatez(-45deg);
    }

    #mobile_menu input[type="checkbox"]:checked~label span:nth-of-type(3) {
        transform-origin: bottom;
        width: 50%;
        transform: translate(12px, -3px) rotatez(45deg);

    }

    /* News */

    .layout_full {
        grid-template-columns: repeat(1, minmax(0, 1fr));
        gap: 20px;
        padding: 0 20px;
        width: calc(100% - 40px);
        margin-top: 120px;
    }

    .layout_full .content-text {
        width: 100%;
    }

    #credits {
        margin-bottom: 100px;
    }

    /* Events */

    .mod_eventlist {
        grid-template-columns: repeat(1, minmax(0, 1fr));
        padding: 0;
        width: 100%;
        margin-bottom: 80px;
    }

    .layout_full {

        margin-top: 0px;

        .content {
            grid-row-start: 2;
        }

        .image {
            grid-row-start: 1;

            img {
                object-fit: cover;
            }
        }

        .enclosure {
            margin-top: 40px;
        }

        .enclosure li {
            font-size: 1em;
        }

    }

    .mod_subscribe {
        margin: 20px 0 25px 0;
    }

    .mod_subscribe .formbody {
        width: 100%;
        display: flex;
        flex-direction: column;
        gap: 10px;
    }

    button {
        font-size: 1em;
    }

    .widtget-text {
        display: block;
        width: 100%;
    }

    input[type=text],
    input[type=email] {
        font-size: 1em;
        width: calc(100% - 40px);
    }

    /* About */

    .about {
        margin: 0 auto;

        .content-text.media {
            width: 100%;

            .rte p:last-of-type {
                font-size: 0.8em;
                margin: 0;
            }
        }

        .inside {
            padding: 80px 20px;
            width: calc(100% - 40px);
            grid-template-columns: repeat(2, minmax(0, 1fr));
            column-gap: 20px;
            row-gap: 40px;
        }

        figure img {
            min-width: 100%;
            padding: 0;
            margin: 0;
        }
    }

    /* Footer */

    footer .inside {

        font-size: 0.8em;

        grid-template-columns: 100%;
        gap: 20px;

        div {
            text-align: center !important;
        }
    }

}
