/* Variables */

:root {
    --black: rgba(0, 0, 0, 1);
    --alto: #eaeaea;
    --licorice: rgba(21, 21, 21, 1);
    --red-ribbon: rgba(235, 0, 40, 1);
    --white: rgba(255, 255, 255, 1);

    --font-size-m: 18px;
    --font-size-l: 20px;
    --font-size-xl: 20.8px;
    --font-size-xxl: 22px;
    --font-size-xxxl: 35px;
    --font-size-xxxxl: 50px;
    --font-size-xxxxxl: 72.7px;

    --font-family-espa: "Espa";
    --font-family-helvetica-bold: "Helvetica75";
    --font-family-helvetica-light: "Helvetica-Light";
    --font-family-helvetica-regular: "Helvetica";
    --font-family-inter: "Inter";
}

html,
body {
    max-width: 100%;
    overflow-x: hidden;
}

body {
    color: var(--black);
    font-family: var(--font-family-helvetica-regular);
    background-color: var(--alto);
    font-weight: 400;
    font-size: var(--font-size-m);
    line-height: 133.49%;
    letter-spacing: 0.02em;
}

.fs-1 {
    font-weight: 400;
    font-size: 42px !important;
    line-height: 126.99%;
    letter-spacing: 0.04em;
}

@media (min-width: 768px) {
    .fs-1 {
        font-size: 89.504px !important;
        line-height: 126.99%;
    }
}

.fs-2 {
    font-size: 36px !important;
    line-height: 38px;
}

@media (min-width: 768px) {
    .fs-2 {
        text-align: left;
        font-size: 50px !important;
        line-height: 57px;
    }
}

.fs-3 {
    font-size: 26px !important;
    line-height: 26px;
}

@media (min-width: 768px) {
    .fs-3 {
        font-size: 35px !important;
        line-height: 40px;
    }
}

.fs-4 {
    font-size: 20.7777px !important;
    line-height: 126.99%;
    letter-spacing: 0.04em;
}

.fs-5 {
    font-size: 71px !important;
    line-height: 65px;
}

@media (min-width: 768px) {
    .fs-5 {
        font-size: 112.45px !important;
        line-height: 94.99%;
    }
}

.fs-6 {
    font-size: 36px !important;
    line-height: 50px;
}

@media (min-width: 768px) {
    .fs-6 {
        font-size: 86px !important;
        line-height: 99px;
    }
}

.gap-5 {
    gap: 4rem !important;
}

@media (min-width: 992px) {
    .gap-lg-5 {
        gap: 8rem !important;
    }
}

.mb-5 {
    margin-bottom: 4rem !important;
}

@media (min-width: 768px) {
    .mb-5 {
        margin-bottom: 8rem !important;
    }
}

.mb-80-i {
    margin-bottom: 50px;
}

.end-30 {
    right: 8%;
}

@media (min-width: 1200px) {
    .mb-80-i {
        margin-bottom: -80px;
    }
}

.py-4 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
}

.py-5 {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
}

@media (min-width: 996px) {
    .py-lg-5 {
        padding-top: 8rem !important;
        padding-bottom: 8rem !important;
    }
}

.pb-500 {
    padding-bottom: 500px !important;
}

.bg-preto {
    color: var(--white);
    background-color: var(--black);
}

.bg-vermelho {
    color: var(--white);
    background-color: var(--red-ribbon);
}

.fw-bolder {
    font-family: var(--font-family-helvetica-bold);
}

.c-vermelho {
    color: var(--red-ribbon);
}

.c-branco {
    color: var(--white) !important;
}

.c-preto {
    color: var(--black) !important;
}

.font-espa {
    font-family: var(--font-family-espa);
}

.text-over {
    position: relative;
}

.top-35 {
    top: 35%;
}

.start-35 {
    left: 35%;
}

.pr-180 {
    padding-right: 180px;
}

.pr-255 {
    padding-right: 255px;
}

.text-over span {
    display: none;
    position: absolute;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 1.5em;
    letter-spacing: 3px;
}

.btn-border {
    color: #fff;
    padding: 20px 30px;
    font-weight: 700;
    font-size: 18.2123px;
    line-height: 126.99%;
    letter-spacing: 0.08em;
    background-color:  #000;
    background-image: url("../images/btn-border.svg");
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    border: none;
    transition: all 400ms ease-in-out !important;  
    
}

.fixed-button {
    position: fixed;
    right: 20px;
    bottom: 40px;
    z-index: 99999;
}

.btn-border:hover {
    color: #000;
    background-color: #fff;
}

.btn-border span {
    position: relative;
    font-size: 33.0873px;
    line-height: 126.99%;
    color: var(--red-ribbon);
    margin-bottom: -15px;
    z-index: 9;
}

.avatar-1 {
    position: relative;
    padding-bottom: 125%;
    width: 100%;
}

.avatar-2 {
    position: relative;
    height: 400px;
}

@media (max-width: 991px) {
    .avatar-2 {
        padding-bottom: 87%;
    }
}

.avatar-1 img,
.avatar-2 img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#hero {
    background-image: url("../images/hero.gif");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

@media (max-width: 767px) {
    #hero {
        padding-bottom: 45px !important;
        background-size: 200% auto;
    }

    #hero .date {
        margin-bottom: 100px;
    }
}

#sobre {
    background-image: url("../images/sobre-img-2.svg");
    background-repeat: no-repeat;
    background-position: bottom right;
}

footer a {
    color: var(--white);
    text-decoration: none;
    transition: all 400ms ease-in-out;
}

footer a:hover {
    color: var(--red-ribbon);
}

a.qualitare {
    display: inline-block;
    margin: 26px 0 0;
    width: 23px;
    height: 22px;
    background-image: url("../images/logo-qualitare.svg");
    background-repeat: no-repeat;
    background-position: right center;
    transition: all 400ms ease-in-out;
}

a.qualitare:hover {
    width: 98px;
}

#menu {
    z-index: 99;
}

#menu .btn-toggle {
    position: fixed;
    top: 35px;
    right: 15px;
    padding: 0;
    width: 57px;
    height: 30px;
    background-color: transparent;
    z-index: 999;
    border: none;
}

@media (min-width: 768px) {
    #menu .btn-toggle {
        top: 80px;
        right: 80px;
    }
}

#menu .btn-toggle span {
    display: block;
    margin-bottom: 6px;
    width: 100%;
    height: 6px;
    background-color: var(--red-ribbon);
    transition: all 400ms ease-in-out;
    opacity: 1;
}

#menu .btn-toggle span:nth-child(2) {
    width: 40px;
    margin-left: auto;
    margin-right: 0;
}

#menu .btn-toggle span:nth-child(3) {
    margin-bottom: 0;
}

#menu.open .btn-toggle span {
    transform: rotate(45deg) translate(0, 17.5px);
}

#menu.open .btn-toggle span:nth-child(2) {
    width: 0;
    opacity: 0;
}

#menu.open .btn-toggle span:nth-child(3) {
    transform: rotate(-45deg) translate(0, -17.5px);
}

#menu.open .menu-container {
    opacity: 1;
    pointer-events: auto;
}

.menu-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 99;
    transition: all 400ms ease-in-out;
    opacity: 0;
    pointer-events: none;
}

.menu-container .logo {
    width: 100%;
}

@media (max-width: 767px) {
    .menu-container .logo {
        max-width: 75%;
        margin-bottom: 5rem;
    }
}

.menu-container .nav a {
    color: var(--white);
    font-weight: 300;
    font-size: 30px;
    line-height: 126.99%;
    text-decoration: none;
}

@media (min-width: 768px) {
    .menu-container .nav a {
        font-size: 50px;
        line-height: 126.99%;
    }
}

.menu-container .nav a:hover {
    color: var(--red-ribbon);
}

@media (max-width: 767px) {
    .menu-container button {
    }
}

.adesivo-1,
.adesivo-2 {
    position: relative;
}

.adesivo-1:after {
    content: "";
    display: block;
    width: 75px;
    height: 85px;
    position: absolute;
    left: 20%;
    bottom: -55px;
    background-image: url("../images/adesivo-1.svg");
    background-size: contain;
    background-repeat: no-repeat;
}

@media (min-width: 768px) {
    .adesivo-1:after {
        width: 146px;
        height: 109px;
    }
}

.adesivo-2:after {
    content: "";
    display: block;
    width: 200px;
    height: 100px;
    position: absolute;
    left: -10%;
    bottom: -35px;
    background-image: url("../images/adesivo-2.svg");
    background-size: contain;
    background-repeat: no-repeat;
}

@media (min-width: 768px) {
    .adesivo-2:after {
        width: 358px;
        height: 172px;
    }
}

.mapa {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url("../images/mapa.jpg");
    background-position: center;
    background-size: cover;
}

#contato {
    background-size: auto 100%;
    background-repeat: no-repeat;
}

@media (min-width: 992px) {
    .mb-lg-0 {
        margin-bottom: 0 !important;
    }

    #contato {
        background-image: url("../images/contato-bg.jpg");
        background-position: -40% 100%;
    }

    .position-lg-absolute {
        position: absolute;
    }
}

.speaker-1 {
    position: relative;
}

.speaker-1:after {
    content: "";
    display: none;
    width: 168px;
    height: 174px;
    position: absolute;
    top: 60px;
    right: -90px;
    background-image: url("../images/speaker-1.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
}

.speaker-2:after {
    content: "";
    display: block;
    width: 224px;
    height: 224px;
    position: absolute;
    top: -100px;
    left: -70px;
}

.speaker-3:after {
    content: "";
    display: block;
    width: 258px;
    height: 258px;
    position: absolute;
    top: -120px;
    left: -120px;
}

.speaker-4:after {
    content: "";
    display: block;
    width: 201px;
    height: 132px;
    position: absolute;
    bottom: 100px;
    right: -120px;
}

@media (max-width: 991px) {
    #sticker-1 {
        width: 250px;
        height: auto;
    }

    #sticker-2 {
        width: 250px;
        height: auto;
        left: auto;
        right: -120px !important;
        top: 68%;
    }

    #sticker-3 {
        width: 280%;
        left: -150%;
    }

    #sticker-5 {
        top: auto !important;
        bottom: 20px;
        right: -25px !important;
        width: 70px;
    }

    #sticker-6 {
        width: 110px;
        right: 110px !important;
        bottom: -20px !important;
    }

    .speaker-1:after {
        width: 100px;
        top: 10px;
        right: -40px;
    }

    .speaker-2:after {
        height: 164px;
        top: -70px;
    }

    .speaker-3:after {
        height: 190px;
        top: -100px;
        left: -110px;
    }

    .speaker-4:after {
        bottom: -10px;
        right: -40px;
        width: 111px;
    }

    #atracoes .infos,
    #organizacao .infos {
        padding-left: 30px;
    }

    #organizacao .infos.order-0 {
        padding-left: 0 !important;
        padding-right: 30px;
    }
}

.p-atracoes {
    font-size: 16px;
}

@media (max-width: 767px) {
    .p-atracoes {
        font-size: 12px;
        line-height: 146%;
        margin-top: -14px;
        font-weight: 600;
    }
}