html {
    margin: 0px;
    padding: 0px;
}

body {
    margin: 0px;
    padding: 0px;

    font-family: "Segoe UI";

    background-color: black;

    /* color: #462380; */
    color: #EA3560;
}

#loading {
    height: 100%;

    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: space-around;
}

#loading div {
    background-color: rgb(50, 50, 50);
    padding: 2em;
    border-radius: 1em;
}

#loading-logo {
    display: block;
    margin: auto;

    animation: loading-animation 1.5s linear infinite;
}

#loading h1 {
    text-align: center;
    font-size: 5em;
}

@keyframes loading-animation {
    0% {
        transform: scale(1)
    }
    10% {
        transform: scale(1.2);
    }
    20% {
        transform: scale(1);
    }
    30% {
        transform: scale(1.13);
    }
    40% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.1);
    }
    60% {
        transform: scale(1);
    }
}

#main {
    margin: 0px;
    padding: 0px;
}

#backgound {
    height: 100%;
    left: 0px;
    opacity: 0;
    position: fixed;
    top: 0px;
    width: 100%;
    margin: 0px;
    z-index: -10;
}

#bg {
    display: block;
    margin: 0px;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: -3;

    background-image: url("pictures/bg_1.jpg");
    background-attachment: fixed;
    background-size: cover;
    background-position: center;

    animation: fadein 1s ease-in-out;
}

#wrapper {
    position: absolute;
    top: 0px;
    left: 0px;

    animation: contentOnload 1.5s;

    width: 100%;
    margin: 0px;
    margin-bottom: 0px;
}

@keyframes contentOnload {
    0% {
        opacity: 0;
        transform: translateY(-2%);
    }
    50% {
        opacity: 0;
        transform: translateY(-2%);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

nav {
    background: linear-gradient(rgba(0, 0, 0, 0.65) 0%, rgba(0, 0, 0, 0.4) 50%, rgba(0, 0, 0, 0) 100%);
    padding-bottom: 4em;
    font-family: 'Ibarra Real Nova', serif;
}

h1, h2, h3, h4, h5, h6 {
    font-family: "Ibarra Real Nova";
}

#main-subtitle {
    /*color: #FFCE62;*/
    font-weight: bold;
}

.secondary-color {
    color: #FFCE62;
}

#festival-ad h2, #festival-ad h3, #festival-ad h4 {
    color: rgb(200, 200, 200);
    font-family: "Segoe UI";
}

.header-text {
    text-shadow:
		-3px -3px 7px rgba(0, 0, 0, 0.2),
		3px -3px 7px rgba(0, 0, 0, 0.2),
		-3px 3px 7px rgba(0, 0, 0, 0.2),
		3px 3px 7px rgba(0, 0, 0, 0.2);
}

#newsletter-subscribe {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#newsletter-email {
    display: block;
    width: 100%;
    font-size: 2em;
}

#newsletter-subscribe-button {
    margin: 1em;
    
    text-align: center;
    font-size: 2em;
    
    cursor: pointer;
    transition: 0.1s;
}

#newsletter-subscribe-button:hover {
    transform: scale(1.05);
}

#navigation {
    width: 60%;
    min-width: 800px;
    margin: auto;

    display: flex;
    justify-content: space-between;
}

#logo {
    font-size: 3em;
    font-weight: bold;
}

#links ul {
    list-style-type: none;
    display: flex;
    justify-content: space-between;
}

#links ul li {
    margin-left: 1.5em;

    font-size: 1.6em;
    font-weight: bolder;
}

#content {
    width: 80%;
    margin: auto;
    margin-bottom: 0px;

    padding-left: 1em;
    padding-right: 1em;
    padding-bottom: 5em;
}

.header {
    text-align: center;
}

.header h1 {
    font-size: 5em;
}

.header h2 {
    width: 60%;
    margin: auto;

    font-size: 2.5em;
    animation: fadein;
    animation-duration: 1s;
}

#main-container {
    animation: fadein;
    animation-duration: 3s;
}

.fade-in {
    animation: fadein 1s linear;
}

@keyframes fadein {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

#festival-ad {
    margin-top: 5em;

    background-color: rgba(0, 0, 0, 0.3);
    border: 1px solid #EA3560;
    border-radius: 1em;
}

#festival-ad h2 {
    font-size: 4em;
}

#festival-ad h1 {
    font-size: 6em;
    margin: 0.1em;
}

h3 {
    font-size: 3em;
}

h4 {
    font-size: 2em;
}

#teaser {
    margin-top: 5em;
    margin-bottom: 5em;
}

#video-container {
    position: relative;
    padding-bottom: 56.25%; /* 16:9 */
    padding-top: 25px;
    height: 0;
}

#teaser-youtube {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

p, #staff{
    color: rgb(220, 220, 220);
    font-size: 1.5em;
    text-align: left;
}

#about {
    margin-top: 10em;
}

.title-image {
    display: block;
    width: 100%;
    height: auto;
}

@media (min-width: 30cm) {
    #about-festival {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
}

#about-festival {
    margin-top: 2em;
}

#about-festival-text {
    max-width: 60%;
}

@media (max-width: 30cm) {
    #about-festival-text {
        max-width: 90%;
        margin: auto;
    }
}

#about-festival-text p {
    margin: 1em;
}

.page-header {
    padding: 2em;
    background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.8));

    display: flex;
    align-items: center;
    justify-content: space-between;
}

.page-header img {
    display: block;
    max-width: 10%;
}

.page-header h1 {
    margin: 0px;
}

#concert-displayer, #artist-displayer {
    background-color: rgba(0, 0, 0, 0.7);
}

#medias-content {
    background-color: rgba(0, 0, 0, 0.8);
}

#social-networks-list {
    padding-top: 2em;
    display: flex;
    justify-content: space-evenly;
}

.social-network {
    display: flex;
    align-items: center;

    text-decoration: none;
    color: #EA3560;
}

.network-logo {
    display: block;
    width: 7em;
    height: auto;
    margin-right: 2em;
}

#blog {
    padding-top: 5em;
}

footer {
    width: 100%;
    margin-top: 0px;

    background-color: rgb(51, 51, 51);
    color: white;
}

footer a {
    color: white;
    text-decoration: none;
}

#footer-content {
    padding: 3em;
    width: 60%;
    min-width: 800px;
    margin: auto;
}

#logos {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#logos img {
    display: block;
	max-height: 8em;
}

#footer-links {
    margin-top: 2em;
    text-align: center;
    font-size: 1.5em;
}

navigation-link {
    cursor: pointer;
    transition: 0.2s;

    border-bottom: 1px solid rgba(234, 53, 96, 0);
}

navigation-link:hover {
    border-bottom: 1px solid rgba(234, 53, 96, 1);
}
