@font-face {
    font-family: 'Handjet';
    src: url('../fonts/Handjet.ttf') format('truetype');
}

@font-face {
    font-family: 'Iceberg';
    src: url('../fonts/Iceberg.ttf') format('truetype');
}

:root {
    --cor-azul-fundo: #0558A9;
    --cor-texto: #333333;
    --cor-preto: #000;
    --cor-branco: #fff;
    --cor-vermelho: #C20606;
    --cor-vermelho-hover: #aa0404;
    --cor-borda-marrom: #63220A;
    --cor-fundo-cinza: #D9D9D9;
    --cor-amarelo: #e0c050;
    --cor-cinza-hover: #1E1E1EAA;
    --cor-verde-fundo: #269733;
    --cor-verde-fundo-claro: #45b051;
    --cor-fundo-preto-opacity: #000000d2;
    --cor-button-gray: #B5B2B2;
    --cor-button-amarelo: #FECF02;
    --cor-fundo-button-amarelo: #5B4A01;
}

html,
body {
    margin: 0;
    padding: 0;
    width: 100vw;
    height: 100vh;
    /* overflow: hidden; */
}


/* Home */
* {
    box-sizing: border-box;
}

.container-tela-geral {
    background: url('../assets/fundo-tela-inicio.png') no-repeat center center;
    background-size: cover;
    min-height: 100dvh;
    min-height: 100vh;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0;
}

@keyframes shake {
    0% {
        transform: translateX(0);
    }

    25% {
        transform: translateX(-4px);
    }

    50% {
        transform: translateX(4px);
    }

    75% {
        transform: translateX(-4px);
    }

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

.error-login {
    background-color: var(--cor-vermelho);
    border: 0.2vw solid var(--cor-borda-marrom);
    box-shadow: 0 0 0.2vw var(--cor-vermelho);
    font-family: 'Handjet';
    color: var(--cor-branco);
    font-size: 1.5vw;
    padding: 0.8vh 2vw;
    position: absolute;
    top: 10vh;
    animation: shake 0.4s ease-in-out;
    z-index: 10;
}

.logo-tela-geral {
    width: 55vw;
    margin: 0vh 0 2vh 0;
}

.logo-tela-cad {
    width: 35vw;
    margin: 2vh 0 2vh 0;
}

.logo-tela-categoria {
    width: 30vw;
    margin-top: 2vh;
}

.div-button-tela-geral {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-top: 5vh;
}

.button-tela-geral {
    background-color: var(--cor-branco);
    color: var(--cor-texto) !important;
    font-size: 2vw;
    font-family: 'Handjet';
    letter-spacing: 1px;
    font-style: bold;
    width: 20vw;
    height: 7vh;
    border: 3px solid var(--cor-preto);
    box-shadow: 3px 3px 0px var(--cor-preto);
    cursor: pointer;
    position: relative;
    transition: 0.2s;
    color: var(--cor-fundo-cinza);
    margin-bottom: 1.2vh;
}

.button-tela-geral:hover {
    background-color: #e0c050;
    box-shadow: 2px 2px 0px var(--cor-preto);
    color: var(--cor-branco);
    transform: scale(1.2, 1.2);
}

.ini {
    text-decoration: none;
}

.button-jogar-inicio {
    position: relative;
    display: inline-block;
    margin: 20px;
}

.button-jogar-inicio span {
    color: var(--cor-branco);
    font-family: 'Handjet', Helvetica, sans-serif;
    font-weight: bold;
    font-size: 3.3vw;
    text-align: center;
    text-decoration: none;
    background-color: var(--cor-button-amarelo);
    display: block;
    width: 32vw;
    height: 11vh;
    line-height: 11vh;
    z-index: 10;

    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    text-shadow: 0px 1px 0px var(--cor-preto);

    box-shadow: inset 0 1px 0 #FFE5C4, 0 10px 0 var(--cor-fundo-button-amarelo);
    border-radius: 5px;
    position: relative;
}

.button-jogar-inicio span:active {
    top: 10px;
    background-color: var(--cor-button-amarelo);
    box-shadow: inset 0 1px 0 #FFE5C4, inset 0 -5px 0 var(--cor-fundo-button-amarelo);
}

.button-jogar-inicio:after {
    content: "";
    height: 100%;
    width: 100%;
    padding: 0.3vw;
    position: absolute;
    bottom: -2.5vh;
    left: -0.3vw;
    z-index: 1;
    background-color: #2b180065;
    border-radius: 5px;
}

.link-visitante,
.link-criar-conta {
    margin: 1vh 0 2vh 0;
    font-family: 'Handjet';
    font-size: 1.5vw;
    color: var(--cor-preto);
    text-decoration: underline;
    text-underline-offset: 0.2em;
    text-decoration-thickness: 0.12em;
    cursor: pointer;
}

.link-visitante:hover,
.link-criar-conta:hover {
    font-weight: bolder;
}

.label-redefinicao {
    font-size: 1.8rem;
    font-family: 'Handjet';
    font-weight: 650;
}

.tipo-user {
    justify-content: center;
    gap: 1.2rem !important;
}

.radio-cad {
    display: flex;
    gap: 1vw;
}

.radio-opt {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    user-select: none;
    font-weight: 500;
    color: var(--cor-preto);
    font-family: 'Handjet';
    font-size: 1.2vw;
    margin-bottom: 0.5vh;
}

.radio-opt input[type="radio"] {
    accent-color: var(--cor-preto);
    width: 1.1em;
    height: 1.1em;
    cursor: pointer;
    margin: 0;
}

.radio-opt:has(input[type="radio"]:checked) {
    font-weight: 800;
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.extras-vest {
    width: 100%;
    display: none;
}

.extras-vest-inner {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
}


/* LoginMaster */
.barra-master {
    width: 100vw;
    position: absolute;
    top: 0;
    height: 6vh;
    background-color: var(--cor-branco);
    font-family: 'Handjet';
    color: #aaaaaa;
    display: flex;
    align-items: center;
    padding-left: 20px;
    font-size: 1.8vw;
    letter-spacing: 0.2vw;
}

.form-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 20px;
}

.input-container {
    display: flex;
    align-items: center;
    background: var(--cor-branco);
    border: 3px solid var(--cor-preto);
    box-shadow: 3px 3px 0px var(--cor-preto);
    padding: 10px;
    width: 300px;
    margin-bottom: 10px;
}

.req {
    color: var(--cor-preto);
    font-weight: 900;
}

.cad-box {
    background: var(--cor-branco);
    border: .1vw solid var(--cor-preto);
    box-shadow: 3px 3px 0 var(--cor-preto);
    padding: 1.2rem;
    width: min(1100px, 92vw);
    margin: 0 auto 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cad-grid-4x2 {
    display: grid;
    grid-template-columns: repeat(4, minmax(220px, 1fr));
    gap: 1rem 1.2rem;
}

.col {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: .4rem;
    font-family: 'Handjet';
}

.fg-label {
    font-weight: 800;
    font-size: 1.1rem;
    color: var(--cor-preto);
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}

.badge-field {
    background: var(--cor-fundo-cinza);
    color: var(--cor-preto);
    border: 1px solid var(--cor-preto);
    padding: .05rem .4rem;
    font-size: .85em;
    line-height: 1
}

.input-container .input-icon {
    font-size: 1rem;
}

.select2-container--default .select2-selection--single,
.select2-results__option {
    font-family: 'Handjet';
    font-size: 1.2vw;
}

.select2-container--default .select2-selection--single {
    background-color: transparent !important;
    border: none !important;

}

.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--single {
    box-shadow: none !important;
    border: none !important;
}

@media (max-width: 980px) {
    .cad-grid-4x2 {
        grid-template-columns: repeat(2, minmax(220px, 1fr));
    }

    .logo-tela-categoria {
        margin-top: 8vh;
    }
}

@media (max-width: 720px) {
    .cad-grid-4x2 {
        grid-template-columns: 1fr;
    }

    .cad-box {
        padding: 1rem;
    }

    .radio-cad {
        margin-top: 2vh;
        display: flex;
        flex-direction: column;
        gap: 1vh;
    }

    .radio-opt {
        font-size: 5vw;
    }

    .form-group .input-container {
        width: 260px;
    }

    .logo-tela-cad {
        margin-top: 6vh;
    }

    .select2-container--default .select2-selection--single,
    .select2-results__option {
        font-family: 'Handjet';
        font-size: 4vw;
    }
}

.categoria-container {
    width: 90%;
    max-width: 900px;
    font-family: 'Handjet';
    margin: 0 auto;
}

.categoria-container h2 {
    text-align: center;
    font-size: 2.5rem;
    color: var(--cor-branco);
    margin-bottom: 0.5rem;
    margin-block-start: 0.5rem;
}



.card-materia {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    background-color: var(--cor-branco);
    border: 0.2rem solid var(--cor-fundo-cinza);
    padding: 1rem;

    text-align: center;
    font-family: 'Handjet';
    font-weight: bold;
    color: #444;
    font-size: 1.2rem;

    aspect-ratio: 1 / 1;

    cursor: pointer;
    transition: all 0.2s ease-in-out;
}

.card-materia i {
    font-size: 2.5rem;
    color: var(--cor-azul-fundo);
    margin-bottom: 15px;
}

.card-materia:hover {
    transform: scale(1.03);
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.07);
}


.logout-categoria {
    position: fixed;
    bottom: 1.5vh;
    right: 2.5vw;
    font-family: 'Handjet';
    font-size: 1.8vw;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    background-color: transparent;
    cursor: pointer;
    transition: 1.5s;
    color: var(--cor-preto);
    z-index: 1000;
}


.categoria-grid,
.categoria-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}


@media (min-width: 900px) {
    .categoria-grid-2 {
        grid-template-columns: repeat(5, 1fr);
    }

    .categoria-grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        width: 80%;
        margin-left: auto;
        margin-right: auto;
    }

    .card-materia {
        font-size: 1.2rem;
    }

    .card-materia i {
        font-size: 3.5rem;
    }
}

@media (max-width: 370px) {

    .categoria-grid,
    .categoria-grid-2 {
        grid-template-columns: 1fr;
    }
}

.input-session,
.input-container {
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
}


.input-icon {
    margin-right: 10px;
    color: var(--cor-preto);
}

.input-field {
    border: none;
    outline: none;
    font-family: 'Handjet';
    min-width: 0;
    width: 100%;
    flex: 1 1 auto;
    font-size: clamp(16px, 1.6vw, 24px);
    box-sizing: border-box;
}

.entrar {
    color: var(--cor-preto) !important;
    margin-top: 10px !important;
}

.icon-voltar {
    position: absolute;
    left: 1.8vw;
    bottom: 1.8vw;
    width: 2.2vw;
    transition: 500ms;
}

.icon-voltar:hover {
    width: 2.6vw;
    bottom: 1.7vw;
    left: 1.7vw;
    transition: 500ms;
}

/* Master */

.container-tela-master {
    height: 100vh;
    position: relative;
}

.popup-message {
    position: fixed;
    top: 5vh;
    right: 2.5vw;
    background-color: var(--cor-branco);
    border: 0.3vw solid;
    padding: 0.75vh 1.5vw;
    font-family: 'Handjet';
    font-size: 1.8vw;
    z-index: 9999;
    box-shadow: 0 0 0.4vw rgba(0, 0, 0, 0.2);
    min-width: 15vw;
    max-width: 30vw;
    overflow: hidden;
}

.popup-message.success {
    border-color: var(--cor-verde-fundo);
    color: var(--cor-verde-fundo);
}

.popup-message.error {
    border-color: var(--cor-vermelho);
    color: var(--cor-vermelho);
}

.popup-bar {
    height: 0.8vh;
    margin-top: 1vh;
    animation: shrinkBar 3s linear forwards;
}

.success-bar {
    background-color: var(--cor-verde-fundo);
}

.error-bar {
    background-color: var(--cor-vermelho);
}

@keyframes shrinkBar {
    from {
        width: 100%;
    }

    to {
        width: 0%;
    }
}

.container-cabecalho-adm {
    background-color: var(--cor-azul-fundo);
    width: 100%;
    height: 8.8vh;
    display: flex;
    align-items: center;
}

.container-left {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-grow: 1;
}

.perfil-adm {
    background-color: #e0c050;
    height: 8.8vh;
    width: 4.5vw;
    display: flex;
    border: 0.2vw solid var(--cor-amarelo);
    align-items: center;
    justify-content: center;
    text-align: center;
}

.perfil-adm a {
    text-decoration: none;
    color: var(--cor-preto);
}


.perfil-adm:hover {
    border-color: var(--cor-preto);
    box-shadow: inset 0.01vw 0.01vw 0.3vw rgba(0, 0, 0, 0.7);
}

.cabecalho-logo-adm {
    width: 10vw;
    margin-left: 0.8vw;
    transition: 500ms;
}

.cabecalho-logo-adm:hover {
    width: 10.5vw;
    transition: 500ms;
    cursor: pointer;
}

.cabecalho-quadrados-adm {
    width: 1.4vw;
}

.cabecalho-user {
    font-family: 'Handjet';
    color: var(--cor-branco);
    font-size: 1.8vw;
    font-weight: 550;
    letter-spacing: 4px;
}

.icon-user {
    font-size: 1.8vw;
    cursor: pointer;
}

.container-menu-adm {
    display: flex;
    justify-content: space-evenly;
    width: 100vw;
    position: absolute;
}

.menu-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 31vw;
    height: 4vw;
    background-color: var(--cor-branco);
    font-weight: bold;
    border: 2px solid var(--cor-preto);
    color: var(--cor-preto);
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: width 0.5s ease, height 0.3s ease, box-shadow 0.3s ease;
}

.menu-item span {
    font-size: 1.5vw;
    margin-left: 0.7vw;
    font-family: 'Handjet';
    color: var(--cor-preto);
}

.menu-icon {
    font-size: 2vw;
}

.menu-home {
    width: 7vw;
}

.menu-home:hover {
    width: 12vw !important;
}

.menu-item:hover {
    width: 35vw;
    height: 5.5vw;
    font-size: 5vw;
    transition: width 0.5s ease, height 0.3s ease;
    background-color: #e0c050;
    color: var(--cor-preto);
    box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.3);
}

.menu-active {
    background-color: #e0c050 !important;
}

.menu-active span {
    color: var(--cor-branco);
}

.menu-active .menu-icon {
    color: var(--cor-branco);
}

.menu-active .icon-user {
    color: var(--cor-branco);
}

.menu-item:hover .menu-icon {
    font-size: 2.8vw;
}

.menu-item:hover span {
    font-size: 1.9vw;
}

/* Dashboard */

.container-master {
    background-color: var(--cor-fundo-cinza);
    padding: 8.5vh 3vw;
    width: 100vw;
    height: 91.2vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.title-welcome-master {
    font-size: 2.5vw;
    color: var(--cor-preto);
    font-family: 'Handjet';
    font-weight: 600;
    letter-spacing: 0.15vw;
    margin-bottom: 1vh;
}

.container-dados-master {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(3, 1fr);
    gap: 0.6vw;
    grid-template-areas:
        "a b c d"
        "e e f d"
        "g g h i";
    width: 94vw;
    height: 65vh;
}

.box {
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    text-align: center;
    border: 0.1vw solid var(--cor-preto);
    font-family: 'Handjet';
    font-size: 2vw;
    flex-direction: column;
    align-items: center;
    height: 100%;
}

.span-box {
    font-size: 1.5vw;
    text-decoration: underline;
}

.ativos {
    grid-area: a;
}

.sessoes {
    grid-area: b;
}

.pontuacao {
    grid-area: c;
}

.high {
    grid-area: d;
}

.large {
    grid-area: e;
}

.info {
    grid-area: f;
}

.highlight {
    grid-area: g;
    font-size: 1.8vw;
}

.highlight p {
    margin: 0.5vw;
    text-align: start;
}

.dados-highlight {
    height: 75%;
    padding-left: 1.2vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: start;
}

.links {
    grid-area: h;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: start;
    text-align: start;
    padding-left: 1.2vw;
    font-size: 1.9vw;
}

.links a {
    position: relative;
    text-decoration: none;
    color: var(--cor-preto);
    transition: color 0.3s ease-in-out;
}

.links a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -0.1vw;
    width: 100%;
    height: 0.1vw;
    background-color: var(--cor-preto);
    transition: width 0.5s ease-in-out, opacity 0.5s ease-in-out;
}

.links a:hover::after {
    width: 0;
    opacity: 0;
}

.links a:hover {
    color: var(--cor-preto);
}

.box-title {
    width: 98, 5%;
    height: 25%;
    background-color: var(--cor-azul-fundo);
    border-bottom: solid 0.1vw var(--cor-preto);
    display: flex;
    text-align: start;
    align-items: center;
    font-size: 1.8vw;
    color: var(--cor-branco);
    padding-left: 0.4vw;
    font-weight: 550;
}


.box-content {
    display: flex;
    height: 100%;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.box-content-small {
    display: flex;
    height: 75%;
    flex-direction: column;
    font-size: 1.7vw;
    justify-content: center;
    align-items: start;
    padding-left: 1.2vw;
    line-height: 3.4vh;
}

.buttons {
    grid-area: i;
    display: flex;
    flex-direction: column;
    gap: 1vw;
}

button {
    border: none;
}

.button-master {
    background-color: var(--cor-preto);
    color: var(--cor-branco);
    height: 100%;
    font-family: 'Handjet';
    font-size: 2vw;
    position: relative;
    cursor: pointer;
    overflow: hidden;
    transition: color 0.3s ease-in-out, background-color 0.3s ease-in-out;
}

.button-master::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 0%;
    height: 0.2vw;
    background-color: var(--cor-azul-fundo);
    transition: width 0.3s ease-in-out;
}

.button-master::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    width: 0%;
    height: 0.2vw;
    background-color: var(--cor-azul-fundo);
    transition: width 0.3s ease-in-out 0.3s;
}

.button-master span:last-child {
    top: auto;
    bottom: 0;
    left: auto;
    right: 0;
    transition: height 0.3s ease-in-out 0.9s;
}


.button-master:hover::before {
    width: 100%;
}

.button-master:hover::after {
    width: 100%;
}


.button-master:hover {
    color: var(--cor-branco);
    background-color: var(--cor-preto);
}

.content {
    display: none;
}

.content.active {
    display: block;
}

/* Logout */

.logout {
    position: absolute;
    bottom: 1.5vh;
    right: 2.5vw;
    font-family: 'Handjet';
    font-size: 1.8vw;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    background-color: transparent;
    cursor: pointer;
    transition: 1.5s;
    color: var(--cor-preto);
}

.logout:hover,
.logout-questao:hover,
.logout-categoria:hover {
    color: var(--cor-vermelho);
    transition: 500ms;
    font-weight: 600;
    transform: scale(1.05, 1.05);
}

/* Modal */

.modal-logout {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    font-family: Handjet;
}

.modal-content-logout {
    width: 40vw;
    background-color: var(--cor-branco);
    border: 2px solid var(--cor-borda-marrom);
    box-shadow: 4px 4px 0px var(--cor-preto);
    padding: 0;
    animation: fadeInModal 0.3s ease-in-out;
}

.modal-header {
    background-color: var(--cor-vermelho);
    color: var(--cor-branco);
    font-weight: bold;
    padding: 5px 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 2.2vw;
    font-family: 'Handjet';
}

.modal-header .close-btn {
    background-color: var(--cor-vermelho);
    padding: 1vh 1vw;
    font-size: 1.5vw;
    text-align: center;
    cursor: pointer;
}

.modal-body {
    display: flex;
    align-items: center;
    padding: 20px;
    font-size: 1.8vw;
    color: var(--cor-preto);
    font-family: 'Handjet';
}

.modal-body img {
    width: 32px;
    height: 32px;
    margin-right: 15px;
}

.modal-buttons {
    padding: 10px;
    display: flex;
    justify-content: center;
}

.modal-buttons button {
    background-color: #e0e0e0;
    border: 2px solid #a0a0a0;
    padding: 2px 20px;
    font-size: 1.8vw;
    font-family: 'Handjet';
    cursor: pointer;
    box-shadow: inset -1px -1px 1px white, inset 1px 1px 1px gray;
}

.modal-buttons button:hover {
    background-color: #c0c0c0;
}

@keyframes fadeInModal {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 2;
        transform: scale(1);
    }
}

@keyframes fadeOutModal {
    from {
        opacity: 1;
        clip-path: inset(0% 0% 0% 0%);

    }

    to {
        opacity: 1;
        clip-path: inset(0% 0% 100% 0%);
    }
}

/* Relatório */
.container-relatorios {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;

}

/* Cada box do gráfico */
.grafico-box {
    background: #fff;
    padding: 25px;
    border-radius: 12px;
    min-height: 350px;       /* OBRIGATÓRIO */
    display: flex;
    flex-direction: column;
}

/* Área do gráfico – precisa ter altura fixa */
.grafico-area {
    flex: 1;
    min-height: 280px;       /* OBRIGATÓRIO */
}


.grafico-box h2 {
    font-family: 'Handjet', sans-serif;
    font-size: 1.8rem;
    margin-bottom: 10px;
}


.cabecalho-dashboard {
    width: 100%;
    height: 12vh;
    background-color: var(--cor-azul-fundo);
    border-bottom: 0.3vw solid var(--cor-preto);
    padding: 0 2vw;

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

.cabecalho-dashboard-left {
    display: flex;
    align-items: center;
    gap: 1vw;
    font-family: "Handjet";
    color: var(--cor-branco);
    font-size: 3vw;
    font-weight: bolder;
}

.btn-voltar-dashboard {
    background-color: var(--cor-preto);
    color: var(--cor-branco);
    padding: 0.5vh 1vw;
    font-family: "Handjet";
    font-size: 1.4vw;
    border: 0.2vw solid var(--cor-preto);
    box-shadow: 2px 3px 0px var(--cor-preto);
    text-decoration: none;
    cursor: pointer;
    transition: 0.3s;
}

.btn-voltar-dashboard:hover {
    background-color: var(--cor-button-amarelo);
    color: var(--cor-branco);
    box-shadow: 1px 1px 0px var(--cor-preto);
}

.dashboard-logo {
    width: 10vw;
}

.cabecalho-dashboard-right {
    font-family: "Handjet";
    color: var(--cor-branco);
    font-size: 2vw;
    font-weight: bolder;
}

.dashboard-content {
    width: 100%;
    height: calc(100vh - 12vh);
    padding: 2vw;
    overflow-y: auto;
    background-color: var(--cor-fundo-cinza);
}


@media (max-width: 800px) {
    .dashboard-logo {
        width: 25vw;
    }

    .btn-voltar-dashboard {
        font-size: 4vw;
    }

    .dashboard-content {
        padding: 4vw;
    }

    .cabecalho-dashboard-right {
        font-size: 4vw;
    }
}



/* Lista */

.container-lista {
    width: 94vw;
    height: 65vh;
}

.pesquisa-lista {
    width: 100%;
    border: 0.1vw solid var(--cor-preto);
    border-bottom: 0;
    display: flex;
    flex-direction: row;
    background-color: var(--cor-branco);
    align-items: center;
    justify-content: space-between;
}

.input-pesquisa-lista {
    width: 90%;
    height: 8vh;
    border-color: transparent;
    border-width: 0;
    padding-block: 0;
    padding-inline-start: 0.5vw;
    padding-inline-end: 0;
    font-size: 1.8vw;
    font-family: 'Handjet';
    box-sizing: border-box;
}

.input-pesquisa-lista:focus {
    outline: none;
    box-shadow: none;
}

.input-pesquisa-lista::placeholder {
    font-family: 'Handjet';
    font-weight: bold;
    color: var(--cor-fundo-cinza);
    font-size: 1.4vw;
}

.icon-pesquisa {
    font-size: 2.5vw;
    width: 5%;
    height: 8vh;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}

.add-inst-pesquisa {
    font-size: 2.5vw;
    width: 5%;
    background-color: var(--cor-verde-fundo-claro);
    color: var(--cor-branco);
    height: 8vh;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    border-left: solid 0.1vw var(--cor-preto);
    transition: 500ms;
    text-decoration: none;
}

.add-inst-pesquisa:hover {
    font-size: 3vw;
    font-weight: 900;
    transition: 500ms;
}

.itens-lista {
    background-color: var(--cor-branco);
    width: 100%;
    height: 57vh;
    border: 0.1vw solid var(--cor-preto);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    scrollbar-color: var(--cor-preto) transparent;
}

.itens-lista::-webkit-scrollbar {
    width: 0.7vw;
}

.itens-lista::-webkit-scrollbar-track {
    background: transparent;
}

.item-lista {
    width: 100%;
    height: 8vh;
    font-size: 2.5vw;
    position: relative;
    padding-left: 2%;
    font-family: 'Handjet';
    text-decoration: none;
    color: var(--cor-preto);
    display: flex;
    text-align: start;
    align-items: center;
    cursor: pointer;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-shrink: 0;
}

.item-lista:hover {
    background-color: var(--cor-cinza-hover);
    font-weight: bold;
}

.div-item-inst {
    width: 100%;
    height: 8vh;
    font-size: 2.5vw;
    position: relative;
    font-family: 'Handjet';
    text-decoration: none;
    color: var(--cor-preto);
    display: flex;
    text-align: start;
    align-items: center;
    cursor: pointer;
}

.status-instituicao {
    position: absolute;
    right: 2%;
    font-size: 1.5vw;
    font-weight: bold;
    padding: 0 1vw;
    text-transform: uppercase;
    font-family: 'Handjet';
    cursor: pointer;
    transition: 500ms;
}

.status-instituicao.ativo {
    background-color: var(--cor-verde-fundo);
    color: var(--cor-branco);
}

.status-instituicao.inativo {
    background-color: var(--cor-vermelho);
    color: var(--cor-branco);
}

.status-instituicao.inativo:hover {
    background-color: var(--cor-vermelho);
    color: var(--cor-branco);
    font-size: 1.9vw;
    right: 1.5%;
    transition: 500ms;
}

.container-title {
    display: flex;
    flex-direction: row;
    align-items: end;
    justify-content: space-between;
}

.filtros-pesquisa {
    font-size: 1.8vw;
    color: var(--cor-preto);
    font-family: 'Handjet';
    font-weight: 450;
    letter-spacing: 0.15vw;
    margin-bottom: 1vh;
    margin-right: 2vw;
}

.filtros-pesquisa a {
    font-family: 'Handjet';
    font-weight: 450;
    color: var(--cor-preto);
    text-decoration: none;
}

/* Cadastro */

.container-cadastro {
    width: 94vw;
    height: 65vh;
    background-color: var(--cor-branco);
    width: 100%;
    border: 0.1vw solid var(--cor-preto);
    display: flex;
    flex-direction: column;
}

.categoria-acesso {
    flex-direction: row;
    display: flex;
    align-items: center;
    justify-content: start;
    margin-top: 2vh;
    margin-bottom: 2vh;
}

.title-categoria {
    font-family: 'Handjet';
    font-size: 2.2vw;
    margin-left: 1.5vw;
    margin-top: 0;
    margin-bottom: 0;
}

.select-categoria {
    height: 7vh;
    width: 70%;
    margin-left: 1vw;
    color: var(--cor-preto);
    border-radius: 0;
    font-family: 'Handjet';
    font-size: 2vw;
    font-weight: bold;
    border: 0.2vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
}

.select-categoria:focus,
.input-text-form:focus,
.input-number-cadastro:focus,
.select-instituicao:focus,
.input-number-rodada:focus {
    outline: none;
    box-shadow: 0px 0px 8px var(--cor-preto);
}

.form-item {
    margin-left: 1.5vw;
    flex-direction: row;
    display: flex;
    align-items: center;
    justify-content: start;
    width: 100%;
}

.form-title {
    font-family: 'Handjet';
    font-size: 1.5vw;
    width: 8%;
}

.title-inst {
    margin-block-start: 0;
    margin-block-end: 0;
}

.div-input-form {
    width: 92%;
}


.input-text-form {
    height: 5vh;
    width: 40vw;
    font-family: 'Handjet';
    font-size: 1.5vw;
    font-weight: 400;
    padding-left: 0.4vw;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    border-radius: 0;
}

.input-number-cadastro {
    height: 5vh;
    width: 40vw;
    padding-left: 0.4vw;
    font-family: 'Handjet';
    font-size: 1.5vw;
    font-weight: 400;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    border-radius: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

::-webkit-calendar-picker-indicator {
    display: none !important;
}

.select-instituicao {
    height: 5vh;
    width: 40vw;
    padding-left: 0.4vw;
    font-family: 'Handjet';
    font-size: 1.5vw;
    font-weight: 400;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    border-radius: 0;
}

.cadastro-user {
    height: 100%;
}

.dados-form {
    display: flex;
    flex-direction: column;
    align-items: start;
    width: 100%;
}

.form {
    height: 100%;
    width: 100%;
}

.form-cad {
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
    width: 100%;
}

.button-cadastro {
    margin-top: auto;
    margin-bottom: 4vh;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 8vh;
    width: 40vw;
    background-color: var(--cor-preto);
    color: var(--cor-branco);
    transition: 1000ms;
    font-size: 2.2vw;
    font-family: 'Handjet';
    cursor: pointer;
}

.button-cadastro:hover {
    box-shadow: 0 0 0.8vw var(--cor-preto);
    width: 43vw;
    height: 9vh;
    transition: 500ms;
    font-size: 2.4vw;
}

.input-textarea-cadastro {
    height: 12vh;
    width: 45vw;
    font-family: 'Handjet';
    font-size: 1.5vw;
    font-weight: 400;
    padding-left: 0.4vw;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    cursor: pointer;
    resize: none;
    border-radius: 0;
}

/* Instituição */

.container-instituicao {
    width: 94vw;
    height: 65vh;
    background-color: var(--cor-branco);
    width: 100%;
    border: 0.1vw solid var(--cor-preto);
    display: flex;
    flex-direction: column;
    padding-top: 2vh;
}

.row {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 1.5vw;
    margin-left: 1.5vw;
    margin-bottom: 0.5vh;
}

.title-instituicao {
    font-family: 'Handjet';
    font-size: 1.6vw;
    font-weight: 500;
    font-family: 'Handjet';
    color: var(--cor-preto);
    margin: 0;
    line-height: 1.3;
}

.bolder {
    font-weight: 800;
}

.users-instituicao {
    display: flex;
    flex-direction: row;
    padding-top: 0.5vh;
    padding-left: 2.5%;
    padding-right: 2.5%;
    gap: 4%;
    width: 100%;
    flex-wrap: wrap;
}

.lista-users {
    flex: 1;
    max-width: 31%;
}

.lista-questoes-rodada {
    padding: 1rem;
    flex: 1;
}

.pesquisa-lista-instituicao {
    width: 100%;
    border: 0.1vw solid var(--cor-preto);
    border-bottom: 0;
    display: flex;
    flex-direction: row;
    background-color: var(--cor-branco);
    align-items: center;
}

.input-pesquisa-lista-inst {
    width: 98%;
    height: 4vh;
    border-color: transparent;
    border-width: 0;
    padding-block: 0;
    padding-inline-start: 0.2vw;
    padding-inline-end: 0;
    font-size: 1.4vw;
    font-family: 'Handjet';
    box-sizing: border-box;
}

.input-pesquisa-lista-inst:focus {
    outline: none;
    box-shadow: none;
}

.input-pesquisa-lista-inst::placeholder {
    font-family: 'Handjet';
    font-weight: bold;
    color: var(--cor-fundo-cinza);
    font-size: 1.3vw;
}

.add-user {
    background-color: var(--cor-verde-fundo);
    height: 4vh;
    width: 4vw;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--cor-branco);
    font-weight: 1000;
    font-size: 2.7vw;
    border-left: 0.1vw solid var(--cor-preto);
    transition: 500ms;
}

.add-user:hover {
    font-size: 2.8vw;
    font-weight: 1000;
    background-color: var(--cor-verde-fundo-claro);
    transition: 500ms;
}

.icon-pesquisa-inst {
    font-size: 1.8vw;
    margin-right: 1vw;
    margin-left: 1vw;
}

.itens-lista-inst {
    background-color: var(--cor-branco);
    width: 100%;
    height: 30vh;
    border: 0.1vw solid var(--cor-preto);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    scrollbar-color: var(--cor-preto) transparent;
}

.itens-lista-inst::-webkit-scrollbar {
    width: 0.4vw;
}

.itens-lista-inst::-webkit-scrollbar-track {
    background: transparent;
}

.item-lista-inst {
    width: 100%;
    font-size: 1.8vw;
    padding-left: 1%;
    font-family: 'Handjet';
    display: flex;
    justify-content: space-between;
    text-align: start;
    align-items: center;
    cursor: pointer;
}

.item-lista-inst a {
    color: var(--cor-preto);
    text-decoration: none;

}

.name-user-inst {
    width: 87%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.item-lista-inst:hover {
    background-color: var(--cor-cinza-hover);
    font-weight: bold;
}

.item-lista-inst:hover .icon-edit-user {
    font-size: 1.6vw;
    padding-right: 0.7vw;
}

/* Edição Instituição */

.icon-edit-user {
    padding-right: 1vw;
    font-size: 1.4vw;
}

.title-lista-inst {
    margin: 0;
    font-size: 1.8vw;
    font-family: 'Handjet';
    background-color: var(--cor-azul-fundo);
    color: var(--cor-branco);
    width: 100%;
    border: 0.1vw solid var(--cor-azul-fundo);
    text-align: center;
}

.buttons-edit {
    margin-top: auto;
    margin-bottom: 4vh;
    height: 8vh;
    display: flex;
    width: 100%;
    align-items: end;
    justify-content: center;
    flex-direction: row;
}

.button-black,
.button-red {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 6vh;
    width: 25vw;
    color: var(--cor-branco);
    transition: 500ms;
    font-size: 2.2vw;
    font-family: 'Handjet';
    cursor: pointer;
}

.button-black {
    background-color: var(--cor-preto) !important;
    margin-right: 5vw;
    text-decoration: none;
}

.button-black a {
    color: var(--cor-branco);
    text-decoration: none;
}

.button-red {
    background-color: var(--cor-vermelho) !important;
}

.button-black:hover,
.button-red:hover {
    transform: scale(1.15);
    font-size: 2.4vw;
    box-shadow: 0 0 0.8vw var(--cor-preto);
}

.cabecalho-insituicao {
    width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: end;
}

.edit-instituicao {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 6vh;
    width: 15vw;
    color: var(--cor-branco);
    background-color: var(--cor-preto);
    text-decoration: none;
    gap: 0.5vw;
    font-weight: 500;
    transition: 500ms;
    font-size: 2vw;
    font-family: 'Handjet';
    cursor: pointer;
    margin: 0 -0.1vw 0 0;
}

.edit-instituicao:hover {
    background-color: var(--cor-fundo-preto-opacity);
}

/* Questões */

.container-lista-small {
    width: 94vw;
    height: 50vh;
}

.itens-lista-small {
    height: 42vh !important;
}

.item-lista-small {
    height: 6vh !important;
    font-size: 2.2vw !important;
    text-decoration: none !important;
    color: var(--cor-preto) !important;
    width: 99%;
    height: 8vh;
    font-size: 2.5vw;
    padding-left: 1%;
    font-family: 'Handjet';
    text-decoration: none;
    color: var(--cor-preto);
    display: flex;
    text-align: start;
    align-items: center;
    cursor: pointer;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-shrink: 0;
}

.item-lista-small:hover {
    background-color: var(--cor-cinza-hover);
    font-weight: bold;
}

.select-categoria-filtro {
    height: 5vh;
    width: 26vw;
    color: var(--cor-preto);
    border-radius: 0;
    font-family: 'Handjet';
    font-size: 1.8vw;
    border: none;
    background-color: transparent;
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    font-weight: 450;
}

.select-categoria-filtro:focus,
.input-textarea-questao:focus {
    outline: none;
    box-shadow: none;
}

.buttons-q {
    margin-top: 4.5vh;
    height: 10vh;
    display: flex;
    width: 100%;
    align-items: end;
    justify-content: center;
    flex-direction: row;
    gap: 4%;
}

.button-cad-q {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 10vh;
    width: 48%;
    transition: 500ms;
    font-size: 2.8vw;
    font-family: 'Handjet';
    cursor: pointer;
    text-decoration: none;
}

.button-cad-q:hover {
    transform: scale(1.05);
    font-size: 3.2vw;
    box-shadow: 0 0 0.8vw var(--cor-preto);
}

.buttons-q .black {
    background-color: var(--cor-preto);
    color: var(--cor-branco);
    margin-right: 5vw;
}

.buttons-q .gray {
    background-color: var(--cor-button-gray);
    color: var(--cor-black);
}

#tooltip-hover {
    position: fixed;
    display: none;
    padding: 1vh 1vw;
    font-weight: bolder;
    background-color: rgba(236, 236, 236, 0.85);
    color: var(--cor-preto);
    font-family: 'Handjet';
    font-size: 1.3vw;
    max-width: 40vw;
    pointer-events: none;
    z-index: 99999;
    white-space: pre-line;
    border-radius: 0.3vw;
    transition: opacity 0.3s ease;
}

.container-questao {
    width: 94vw;
    height: 65vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.container-enunciado {
    width: 100%;
}

.title-enunciado {
    color: var(--cor-branco);
    margin: 0;
    background-color: var(--cor-azul-fundo);
    font-size: 1.8vw;
    height: 4.5vh;
    display: flex;
    align-items: center;
    width: 100%;
    border: solid 0.1vw var(--cor-preto);
    font-family: 'Handjet';
    box-sizing: border-box;
}

.title-enunciado span {
    padding-left: 1vw;
}

.content-enunciado {
    background-color: var(--cor-branco);
    margin: 0;
    width: 100%;
    border: solid 0.1vw var(--cor-preto);
    height: 12vh;
    overflow-y: auto;
    box-sizing: border-box;
    overflow-y: auto;
    box-sizing: border-box;
    position: relative;
    scrollbar-color: var(--cor-preto) transparent;
}

.content-enunciado .enunciado {
    display: inline-block;
    padding: 1vh 2.5vw;
    font-family: 'Handjet';
    font-size: 1.5vw;
    margin: 0;
    width: 100%;
    word-break: break-word;
    overflow-wrap: break-word;
    white-space: normal;
    hyphens: auto;
    box-sizing: border-box;
}

.container-alternativas {
    background-color: transparent;
    padding: 2vh 3vw 0 3vw;
    margin: 0;
    width: 100%;
    border: solid 0.2vw var(--cor-preto);
    height: 32vh;
    overflow-y: auto;
    box-sizing: border-box;
    position: relative;
    scrollbar-color: var(--cor-preto) transparent;
}

.container-alternativas::-webkit-scrollbar {
    width: 0.7vw;
}

.container-alternativas::-webkit-scrollbar-track {
    background: transparent;
}

.alternativa {
    font-family: 'Handjet';
    font-size: 2vw;
    font-weight: bolder;
    margin-bottom: 0.5vh;
    padding-right: 2vw;
}

.soma-alternativas {
    position: sticky;
    bottom: 0;
    padding: 1vh 2vw;
    font-family: 'Handjet';
    font-size: 2.2vw;
    font-weight: bolder;
    margin: 0;
    background-color: var(--cor-fundo-cinza);
}

.referencia-questao {
    position: sticky;
    bottom: 0;
    padding: 0.5vh 2vw;
    font-family: 'Handjet';
    font-size: 1.1vw;
    font-weight: bolder;
    margin: 0;
    background-color: var(--cor-branco);
    z-index: 1;
}

.margin-column-0 {
    margin-top: 0;
    margin-bottom: 0;
}

.filtros-pesquisa-anexo {
    font-size: 1.8vw;
    color: var(--cor-preto);
    font-family: 'Handjet';
    font-weight: 600;
    letter-spacing: 0.15vw;
    margin-bottom: 1vh;
    margin-right: 2vw;
}

.mostrar-anexo {
    color: var(--cor-preto);
    transition: 500ms;
    display: inline-block;
    text-decoration: underline;
    cursor: pointer;
}

.mostrar-anexo:hover {
    transform: scale(1.15);
    transition: 500ms;
}

.modal-anexo {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 10000;
    overflow: visible !important;
}


.modal-anexo-content {
    position: relative;
    width: 80vw;
    height: 80vh;
    background: var(--cor-branco);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 4.5vh;
    box-sizing: border-box;
    overflow: hidden;
    animation: fadeInModal 0.3s ease-in-out;
}

.imagem-anexo {
    max-width: 100%;
    height: 100%;
    object-fit: contain;
    box-shadow: 0px 0px 15px var(--cor-preto);
}

.close-modal-anexo {
    position: absolute;
    top: 0px;
    right: 0px;
    background-color: var(--cor-vermelho);
    color: var(--cor-branco);
    border: none;
    font-size: 2.5vw;
    cursor: pointer;
    padding: 0.5vw 1vw;
    font-weight: bold;
    z-index: 10;
}

/* Cadastrar Questão */

.select-categoria-questao {
    height: 5vh;
    width: 25vw;
    font-family: 'Handjet';
    font-size: 1.8vw;
    font-weight: bold;
    color: var(--cor-preto);
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    border-radius: 0;
}

.input-text-somatoria {
    height: 4.9vh;
    border-radius: 0;
    width: 10vw;
    font-family: 'Handjet';
    font-size: 1.8vw;
    padding: 0;
    padding-left: 0.3vw !important;
    padding-block: 0;
    padding-inline: 0;
    padding-inline-start: 0;
    padding-inline-end: 0;
    font-weight: 400;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
}

.input-text-somatoria::placeholder {
    padding-left: 0.2vw !important;
}

.custom-file-upload {
    display: flex;
    flex-direction: row;
    align-items: center;
    font-family: 'Handjet', sans-serif;
    height: 4.9vh;
}

.upload-label {
    background-color: var(--cor-preto);
    color: var(--cor-branco);
    height: 100%;
    padding: 0 1.5vw;
    font-size: 1.7vw;
    border: 0.1vw solid var(--cor-preto);
    font-weight: bold;
    cursor: pointer;
    transition: 0.3s;
    display: flex;
    align-items: center;
    gap: 0.8vw;
}

.upload-label:hover {
    background-color: var(--cor-amarelo);
    color: var(--cor-preto);
    box-shadow: 0 0 0.5vw var(--cor-preto);
}

.hidden-input {
    display: none;
}

.file-name {
    height: 100%;
    width: 28vw;
    font-size: 1.3vw;
    background-color: var(--cor-branco);
    border: 0.1vw solid var(--cor-preto);
    color: var(--cor-preto);
    font-weight: 600;
    margin: 0;
    padding: 0 0.5vw;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.file-name span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 100%;
    text-align: center;
}

.upload-icon {
    font-size: 1.5vw;
}

.container-cadastro-questao {
    width: 94vw;
    display: flex;
    flex-direction: column;
}

.row-cad-questao {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: 100%;
    gap: 2vw;
    margin-bottom: 1vh;
}

.icon-eye,
.icon-trash {
    cursor: pointer;
    font-size: 1.6vw;
    color: var(--cor-preto);
    transition: 0.3s;
    margin-left: 0.5vw;
}

.icon-eye:hover {
    color: var(--cor-branco);
}

.icon-trash:hover {
    color: var(--cor-vermelho);
}

.erro-selecao {
    color: var(--cor-vermelho);
    animation: tremer 0.4s;
}

@keyframes tremer {
    0% {
        transform: translateX(0);
        color: var(--cor-vermelho);
    }

    20% {
        transform: translateX(-2px);
        color: var(--cor-vermelho);
    }

    40% {
        transform: translateX(2px);
        color: var(--cor-vermelho);
    }

    60% {
        transform: translateX(-2px);
        color: var(--cor-vermelho);
    }

    80% {
        transform: translateX(2px);
        color: var(--cor-vermelho);
    }

    100% {
        transform: translateX(0);
        color: var(--cor-vermelho);
    }
}

.form-enunciado-questao {
    width: 100%;
}

.form-title-enunciado {
    color: var(--cor-branco);
    margin: 0;
    background-color: var(--cor-azul-fundo);
    font-size: 1.8vw;
    height: 4vh;
    padding-left: 0.8vw;
    display: flex;
    align-items: center;
    width: 100%;
    border: solid 0.1vw var(--cor-preto);
    border-bottom: none;
    font-family: 'Handjet';
    box-sizing: border-box;

}

.form-content-enunciado {
    background-color: var(--cor-branco);
    width: 100%;
    height: 10vh;
}

.input-textarea-questao {
    height: 10vh;
    width: 100%;
    font-family: 'Handjet';
    font-size: 1.4vw;
    font-weight: 400;
    padding: 0.5vh 0.4vw;
    border: 0.1vw solid var(--cor-preto);
    box-sizing: border-box;
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    resize: none;
    border-radius: 0;
}

.select-cor-questao {
    height: 4vh;
    width: 18vw;
    color: var(--cor-preto);
    border-radius: 0;
    font-family: 'Handjet';
    font-size: 1.5vw;
    font-weight: bold;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
}

.wrapper-alternativas {
    position: relative;
    width: 100%;
    height: 28vh;
    margin: 2vh 0 0vh 0;
}

.section-alternativa {
    width: 100%;
    height: 100%;
    background-color: var(--cor-branco);
    padding: 2vh 2vw;
    box-sizing: border-box;
    overflow-y: auto;
    scrollbar-color: var(--cor-preto) transparent;
    border: solid 0.1vw var(--cor-preto);
}

.section-alternativa::-webkit-scrollbar {
    width: 0.7vw;
}

.section-alternativa::-webkit-scrollbar-track {
    background: transparent;
}

.container-alternativa-cad {
    flex-direction: row;
    display: flex;
    align-items: center;
    justify-content: start;
    width: 100%;
    margin-bottom: 1vh;
}

.form-alternativa {
    flex-direction: column;
    display: flex;
    align-items: center;
    justify-content: start;
    width: 75%;
}

.title-enunciado-alternativa {
    color: var(--cor-branco);
    margin: 0;
    background-color: var(--cor-preto);
    font-size: 1.5vw;
    height: 4vh;
    display: flex;
    align-items: center;
    width: 100%;
    border: solid 0.1vw var(--cor-preto);
    font-family: 'Handjet';
    box-sizing: border-box;
}

.title-enunciado-alternativa span {
    padding-left: 1vw;
}

.title-alternativa-option {
    color: var(--cor-preto);
    margin: 0;
    background-color: var(--cor-fundo-cinza);
    font-size: 1.5vw;
    height: 4vh;
    display: flex;
    text-align: center;
    justify-content: center;
    align-items: center;
    width: 100%;
    border: solid 0.1vw var(--cor-preto);
    font-family: 'Handjet';
    box-sizing: border-box;
}

.content-alternativa {
    background-color: var(--cor-branco);
    margin: 0;
    width: 100%;
    height: 7.5vh;
}

.input-text-form-alternativa {
    height: 7.5vh;
    width: 100%;
    font-family: 'Handjet';
    font-size: 1.3vw;
    font-weight: 400;
    padding: 0 1%;
    resize: none;
    padding-top: 0.5vh;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    box-sizing: border-box;
    border-radius: 0;
}

.alternativa-escolha {
    flex-direction: column;
    display: flex;
    align-items: center;
    justify-content: start;
    width: 10%;
}

.input-wrapper {
    background-color: var(--cor-branco);
    margin: 0;
    width: 100%;
    height: 7.5vh;
}

.btn-excluir-alternativa {
    height: 11.5vh;
    width: 5%;
    background-color: var(--cor-vermelho);
    color: var(--cor-branco);
    font-size: 2vw;
    border: solid 0.15vw var(--cor-preto);
    transition: 500ms;
    cursor: pointer;
}

.btn-excluir-alternativa:hover {
    font-size: 2.5vw;
    transition: 500ms;
    background-color: var(--cor-vermelho-hover);
}

.btn-marcador {
    background-color: var(--cor-branco);
    margin: 0;
    width: 100%;
    height: 100%;
    border: solid 0.1vw var(--cor-preto);
    font-size: 2vw;
    font-weight: 900;
    color: var(--cor-preto);
}

.titulo-alternativas {
    position: absolute;
    width: 8.5vw;
    padding: 0 1vw;
    height: 4vh;
    top: -2.5vh;
    left: 1vw;
    background-color: var(--cor-branco);
    border-bottom: none;
    font-family: 'Handjet';
    font-size: 1.8vw;
    font-weight: bold;
    color: var(--cor-preto);
    border: solid 0.1vw var(--cor-preto);
    z-index: 1;
    display: flex;
    text-align: center;
    align-items: center;
    justify-content: center;
}

.btn-adicionar-alternativa {
    width: 18vw;
    position: absolute;
    bottom: -4vh;
    left: 1vw;
    height: 5.8vh;
    font-size: 1.5vw;
    font-family: 'Handjet';
    background-color: var(--cor-preto);
    color: var(--cor-branco);
    cursor: pointer;
    transition: 500ms;
}

.btn-adicionar-alternativa:hover {
    font-size: 1.8vw;
    transition: 500ms;
    box-shadow: 0px 0px 8px var(--cor-preto);
}

.buttons-alternativa-cad {
    margin-top: auto;
    height: 8vh;
    display: flex;
    width: 100%;
    align-items: end;
    justify-content: end;
    flex-direction: row;
}

/* Perfil */
.container-perfil {
    width: 94vw;
    height: 65vh;
    padding-top: 3vh;
    background-color: var(--cor-branco);
    width: 100%;
    border: 0.1vw solid var(--cor-preto);
    display: flex;
    flex-direction: column;
    position: relative;
}

.title-perfil {
    font-family: 'Handjet';
    font-size: 2.5vw;
    font-weight: 500;
    font-family: 'Handjet';
    color: var(--cor-preto);
    margin: 0;
    line-height: 1.3;
}

.bolder {
    font-weight: bolder;
}

.icon-bin-trash {
    position: absolute;
    bottom: 2vh;
    right: 1vw;
    background: transparent;
    border: none;
    color: var(--cor-vermelho);
    font-size: 1.5vw;
    cursor: pointer;
    transition: 500ms;
}

.icon-bin-trash:hover {
    color: var(--cor-vermelho-hover);
    font-size: 1.8vw;
    bottom: 1.7vh;
    transition: 500ms;
}


/* Sessão Jogo */

.input-session {
    display: flex;
    align-items: center;
    background: var(--cor-branco);
    border: 3px solid var(--cor-preto);
    box-shadow: 3px 3px 0px var(--cor-preto);
    padding: 12px;
    width: 350px;
    margin: 2vh 0;
}



.entrar-sessao {
    color: var(--cor-black);
    margin-top: 1vh;
    font-size: 2.2vw !important;
    width: 24vw !important;
    height: 7.5vh !important;
}

/* Cadastro de Rodada */

.col-cad-rodada {
    font-size: 2.2vw;
    font-family: 'Handjet';
    font-weight: 700;
    display: flex;
    align-items: center;
}

.col-cad-rodada label {
    margin-right: 0.5vw;
}


.checkbox-diario {
    appearance: none;
    width: 2.2vw;
    height: 2.2vw;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    cursor: pointer;
    position: relative;
}

.checkbox-diario:checked {
    background-color: var(--cor-preto);
}

.checkbox-diario:checked::after {
    content: '';
    position: absolute;
    top: 0.1vw;
    left: 0.65vw;
    width: 0.5vw;
    height: 1.1vw;
    border: solid var(--cor-branco);
    border-width: 0 0.2vw 0.2vw 0;
    transform: rotate(45deg);
}

.input-number-rodada {
    height: 4.9vh;
    width: 10vw;
    font-family: 'Handjet';
    font-size: 1.8vw;
    padding: 0;
    margin-left: 0.5vw !important;
    padding-block: 0;
    padding-inline: 0;
    padding-inline-start: 0;
    padding-inline-end: 0;
    font-weight: 400;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    color: var(--cor-preto);
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    text-align: center;
}

.rodada-nome {
    height: 5vh !important;
}

.title-escolher-questao {
    font-size: 1.5vw;
    color: var(--cor-preto);
    font-family: 'Handjet';
    font-weight: 700;
    letter-spacing: 0.15vw;
    margin-block-start: 2vh;
    margin-block-end: 1vh;
}

.container-lista-questoes {
    width: 94vw;
    height: 29vh;
}

.pesquisa-lista {
    width: 100%;
    border: 0.1vw solid var(--cor-preto);
    border-bottom: 0;
    display: flex;
    flex-direction: row;
    background-color: var(--cor-branco);
    align-items: center;
    justify-content: space-between;
}

.input-pesquisa-lista-questoes {
    width: 90%;
    height: 4vh;
    border-color: transparent;
    border-width: 0;
    padding-block: 0;
    padding-inline-start: 0.5vw;
    padding-inline-end: 0;
    font-size: 1.4vw;
    font-family: 'Handjet';
    box-sizing: border-box;
}

.input-pesquisa-lista-questoes:focus {
    outline: none;
    box-shadow: none;
}

.input-pesquisa-lista-questoes::placeholder {
    font-family: 'Handjet';
    font-weight: bold;
    color: var(--cor-fundo-cinza);
    font-size: 1vw;
}

.icon-pesquisa-questoes {
    font-size: 1.5vw;
    width: 5%;
    height: 5vh;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}

.itens-lista-questoes {
    background-color: var(--cor-branco);
    width: 100%;
    height: 25vh;
    border: 0.1vw solid var(--cor-preto);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    scrollbar-color: var(--cor-preto) transparent;
}

.itens-lista-questoes::-webkit-scrollbar {
    width: 0.7vw;
}

.itens-lista-questoes::-webkit-scrollbar-track {
    background: transparent;
}

.item-lista-questoes {
    width: 98%;
    height: 4vh;
    font-size: 1.6vw;
    position: relative;
    padding-left: 2%;
    font-family: 'Handjet';
    text-decoration: none;
    color: var(--cor-preto);
    display: flex;
    text-align: start;
    align-items: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-shrink: 0;
}

.item-lista-questoes:hover {
    background-color: var(--cor-cinza-hover);
    font-weight: bold;
}

.item-lista-questoes label {
    cursor: pointer;
}

.checkbox-questao {
    appearance: none;
    width: 1.5vw;
    height: 1.5vw;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    cursor: pointer;
    position: relative;
}

.checkbox-questao:checked {
    background-color: var(--cor-preto);
}

.checkbox-questao:checked::after {
    content: '';
    position: absolute;
    top: 0.2vw;
    left: 0.45vw;
    width: 0.3vw;
    height: 0.7vw;
    border: solid var(--cor-branco);
    border-width: 0 0.15vw 0.15vw 0;
    transform: rotate(45deg);
}


/* Responsividade */

@media screen and (max-width: 800px) {
    .button-jogar-inicio span {
        font-size: 10vw;
        width: 55vw;
        height: 12vh;
    }

    .button-tela-geral {
        font-size: 5vw;
        width: 35vw;
        height: 8vh;
        box-shadow: 3px 3px 0px var(--cor-preto);
        margin-bottom: 10px;
    }

    .button-jogar-inicio:after {
        padding: 1.8vw;
        left: -1.8vw;
    }

    .link-visitante,
    .link-criar-conta {
        margin-top: 1.5vh;
        font-size: 4.8vw;
    }

    .icon-voltar {
        left: 4vw;
        bottom: 10vw;
        width: 15vw;
        transition: 500ms;
    }

    .icon-voltar:hover {
        width: 18vw;
        bottom: 9vw;
        left: 3.5vw;
    }

    .barra-master {
        height: 6.5vh;
        font-size: 5.5vw;
        letter-spacing: 0.2vw;
    }

    .input-field {
        font-size: 5vw;
    }

    .cabecalho-logo-adm {
        width: 16vw;
        margin-left: 0.8vw;
    }

    .cabecalho-logo-adm:hover {
        width: 17vw;
    }

    .cabecalho-quadrados-adm {
        width: 2.5vw;
    }

    .cabecalho-user {
        font-size: 4vw;
        letter-spacing: 0.2px;
    }

    .icon-user {
        font-size: 4vw;
    }

    .menu-item {
        height: 4vh;
        border: 1.5px solid var(--cor-preto);
    }

    .menu-item span {
        font-size: 3.5vw;
    }

    .menu-icon {
        font-size: 4vw;
    }

    .menu-home {
        width: 8vw;
    }

    .menu-item:hover {
        height: 5vh;
        font-size: 4vw;
    }

    .menu-item:hover .menu-icon {
        font-size: 4.8vw;
    }

    .menu-item:hover span {
        font-size: 5vw;
    }

    .entrar-sessao {
        margin-top: 1vh;
        font-size: 5vw !important;
        width: 34vw !important;
        height: 7.5vh !important;
    }

    .item-lista {
        font-size: 5.5vw;
    }

    #tooltip-hover {
        font-size: 3.8vw;
        max-width: 45vw;
    }

    .mostrar-anexo {
        font-size: 3.8vw;
    }

    .filtros-pesquisa {
        font-size: 4vw;
        margin-block-start: 0.67em;
        margin-bottom: 0.5vh;
    }

    .add-inst-pesquisa {
        font-size: 9vw;
        width: 12% !important;
    }

    .add-inst-pesquisa:hover {
        font-size: 10vw;
    }

    .status-instituicao {
        font-size: 5vw;
        padding: 0.5vw 1.5vw;
    }

    .status-instituicao.inativo:hover {
        font-size: 5.5vw;
    }

    .edit-instituicao {
        width: 25vw;
        font-size: 4.5vw;
    }

    .title-instituicao {
        font-size: 4vw;
    }

    .title-lista-inst {
        font-size: 4.5vw;
    }

    .input-pesquisa-lista-inst {
        height: 4vh;
        font-size: 3.5vw;
    }

    .add-user {
        width: 6vw;
        font-size: 4vw;
    }

    .add-user:hover {
        font-size: 4.5vw;
    }

    .item-lista-inst {
        font-size: 3.5vw;
        padding-top: 0.3vh;
        padding-bottom: 0.3vh;
    }

    .icon-edit-user {
        font-size: 2.5vw;
    }

    .item-lista-inst:hover .icon-edit-user {
        font-size: 2.7vw;
    }

    .input-pesquisa-lista-inst::placeholder {
        font-size: 3vw;
    }

    .form-title {
        font-size: 3vw;
        width: 20%;
    }

    .form-item {
        margin-bottom: 1.5vh;
    }

    .div-input-form {
        width: 88%;
    }

    .input-text-form,
    .input-number-cadastro,
    .select-instituicao {
        width: 50vw;
        font-size: 4vw;
    }

    .button-cad-q {
        font-size: 4.2vw;
    }

    .select-categoria-filtro {
        height: 3vh;
        width: 35vw;
        font-size: 3vw;
    }

    .title-enunciado {
        font-size: 4.5vw;
        height: 4.5vh;
    }

    .content-enunciado .enunciado {
        font-size: 4vw;
    }

    .referencia-questao {
        font-size: 2.2vw;
    }

    .alternativa {
        font-size: 4vw;
        margin-bottom: 1vh;
    }

    .soma-alternativas {
        font-size: 4.5vw;
    }

    .button-black,
    .button-red {
        width: 35vw;
        font-size: 4.2vw;
    }

    .select-categoria-questao {
        width: 28vw;
        font-size: 3vw;
    }

    .input-text-somatoria {
        width: 12vw;
        font-size: 2.8vw;
    }

    .upload-label {
        padding: 1vh 1.5vw;
        font-size: 2.5vw;
        display: flex;
        flex-direction: column;
    }

    .file-name {
        width: 22vw;
        font-size: 2.5vw;
    }

    .upload-icon {
        font-size: 2.5vw;
    }

    .icon-eye,
    .icon-trash {
        font-size: 4vw;
        margin-left: 0.8vw;
    }

    .form-title-enunciado {
        font-size: 4vw;
    }

    .input-textarea-questao {
        font-size: 3.5vw;
    }

    .select-cor-questao {
        width: 28vw;
        font-size: 3.5vw;
    }

    .titulo-alternativas {
        width: 20vw;
        font-size: 3.5vw;
    }

    .form-alternativa {
        width: 60%;
    }

    .alternativa-escolha {
        flex-direction: column;
        display: flex;
        align-items: center;
        justify-content: start;
        width: 15%;
    }

    .btn-excluir-alternativa {
        width: 10%;
        font-size: 5vw;
    }

    .title-enunciado-alternativa {
        font-size: 3vw;
    }

    .title-alternativa-option {
        font-size: 3vw;
    }

    .input-text-form-alternativa {
        font-size: 3vw;
    }

    .btn-adicionar-alternativa {
        width: 35vw;
        font-size: 3.5vw;
    }

    .btn-adicionar-alternativa:hover {
        font-size: 3.8vw;
    }

    .title-categoria {
        font-size: 3.2vw;
        margin-left: 1.5vw;
    }

    .select-categoria {
        font-size: 3.2vw;
    }

    .error-login {
        font-size: 5.5vw;
        padding: 1vh 2.2vw;
    }

    .popup-message {
        font-size: 4vw;
        padding: 1vh 2vw;
    }

    .input-session {
        width: 300px;
    }

    .perfil-adm {
        width: 10vw;
    }

    .container-cabecalho-adm {
        height: 6vh;
    }

    .title-welcome-master {
        margin-top: 0;
        margin-bottom: 0.5vh;
        font-size: 4vw;
    }

    .container-master {
        width: 100vw;
        height: 94vh;
        padding: 7vh 3vw;
        justify-content: center;
    }

    .container-dados-master {
        height: 72vh;
    }

    .box-title {
        height: 10%;
        font-size: 3.2vw;
    }

    .box {
        font-size: 3.2vw;
    }

    .box-content-small {
        height: 90%;
        font-size: 3.2vw;
    }

    .dados-highlight {
        height: 90%;
    }

    .logout,
    .logout-categoria {
        font-size: 5vw;
    }

    .button-master::before,
    .button-master::after {
        height: 0.6vw;
    }

    .input-pesquisa-lista {
        font-size: 5.5vw;
    }

    .input-pesquisa-lista::placeholder {
        font-size: 5.5vw;
    }

    .container-cadastro {
        height: 72vh;
    }

    .itens-lista {
        height: 60vh;
    }

    .dados-cadastro {
        height: 45vh;
    }

    .cadastro-item {
        margin-bottom: 1.25vh;
    }

    .cadastro-title {
        font-size: 2vw;
    }

    .input-text-cadastro {
        font-size: 2vw;
    }

    .input-textarea-cadastro {
        font-size: 2vw;
    }

    .button-cadastro {
        font-size: 4.5vw;
    }

    .button-cadastro:hover {
        font-size: 5vw;
    }

    .container-instituicao {
        height: 75vh;
    }


    .itens-lista-inst {
        height: 48vh;
    }

    .title-perfil {
        font-size: 4.5vw;
    }

    .container-lista-small {
        width: 94vw;
        height: 54vh;
    }

    .itens-lista-small {
        height: 48vh !important;
    }

    .item-lista-small {
        height: 4.5vh !important;
        font-size: 5vw !important;
    }

    .buttons-q {
        margin-top: 0;
        margin-bottom: 1.5vh;
    }

}

/* Jogo | Tela Inicial */

.container-tela-jogo {
    background-color: var(--cor-azul-fundo);
    background-size: cover;
    width: 100vw;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 0px;
}

.container-cabecalho-jogo {
    position: relative;
    z-index: 2;
    background-color: var(--cor-branco);
    width: 100vw;
    height: 8.8vh;
    display: flex;
    align-items: center;
}

.cabecalho-logo-jogo {
    width: 10vw;
    margin-left: 10px;
    transition: 500ms;
}

.cabecalho-logo-jogo:hover {
    width: 10.5vw;
    transition: 500ms;
    cursor: pointer;
}

.texto-sessao-jogo {
    font-family: 'Handjet';
    font-size: 2vw;
    font-weight: 550;
    letter-spacing: 4px;
    margin-right: 10px;
    color: var(--cor-button-gray);
}

.container-imagens-particulas {
    display: flex;
    width: 100%;
    height: calc(100vh - 12vh);
    margin-top: -22vh;
}

.img-particulas {
    width: 33.33%;
    height: 100%;
    object-fit: cover;
}

@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translate(-50%, 20%);
    }

    to {
        opacity: 1;
        transform: translate(-50%, -50%);
    }
}

@keyframes arcadeBounce {

    0%,
    100% {
        transform: translate(-50%, -50%) scale(1);
    }

    50% {
        transform: translate(-50%, -55%) scale(1.05);
    }
}

@keyframes pulseText {

    0%,
    100% {
        transform: translate(-50%, -50%) scale(1);
    }

    50% {
        transform: translate(-50%, -50%) scale(1.1);
    }
}


.mensagem-central {
    position: absolute;
    top: 17%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    font-size: 3vw;
    font-family: 'Handjet', sans-serif;
    text-align: center;
    font-weight: 500;
    letter-spacing: 0.25vw;
    color: var(--cor-branco);
}

.mensagem-preparese {
    position: absolute;
    top: 27%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    font-size: 2vw;
    font-family: 'Handjet', sans-serif;
    text-align: center;
    font-weight: 550;
    letter-spacing: 0.25vw;
    color: var(--cor-branco);
}

.mensagem-conteudo-jogo {
    position: absolute;
    top: 37%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    font-size: 2vw;
    font-family: 'Handjet';
    text-align: center;
    font-weight: 550;
    letter-spacing: 0.35vw;
    color: var(--cor-preto);
    background-color: var(--cor-branco);
    width: 45%;
    height: 12%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 3px solid var(--cor-button-gray);
}


.mensagem-informacoes {
    position: absolute;
    top: 54%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    font-size: 2vw;
    font-family: 'Handjet';
    text-align: center;
    font-weight: 550;
    letter-spacing: 0.35vw;
    color: var(--cor-branco);
    width: 100%;
}

.mensagem-pronto {
    visibility: hidden;
    position: absolute;
    top: 70%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    font-size: 2vw;
    font-family: 'Handjet';
    text-align: center;
    font-weight: 800;
    letter-spacing: 0.35vw;
    color: var(--cor-preto);
    animation: pulseText 1.5s infinite ease-in-out;
}

.informacoes-decoration {
    color: var(--cor-button-amarelo);
    font-size: 2.5vw;
    font-weight: 600;
    text-decoration: underline;
}

.button-jogar-inicio {
    position: relative;
    display: inline-block;
    margin: 20px;
}

.wrapper-jogar {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 78%;
    left: 50%;
    text-decoration: none;
    transform: translate(-50%, -50%);
}

.ini-jogo {
    text-decoration: none;
}

.button-jogar-jogo {
    position: relative;
    display: inline-block;
    text-align: center;
    margin: 0 auto;
}


.button-jogar-jogo span {
    color: var(--cor-branco);
    font-family: 'Handjet';
    font-weight: bold;
    font-size: 2.5vw;
    text-align: center;
    text-decoration: none;
    background-color: var(--cor-button-amarelo);
    display: block;
    width: 25vw;
    height: 8vh;
    line-height: 8vh;

    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    text-shadow: 0px 1px 0px var(--cor-preto);

    box-shadow: inset 0 1px 0 #FFE5C4, 0 10px 0 var(--cor-fundo-button-amarelo);
    border-radius: 5px;
    position: relative;
}

.button-jogar-jogo span:active {
    top: 10px;
    background-color: var(--cor-button-amarelo);
    box-shadow: inset 0 1px 0 #FFE5C4, inset 0 -5px 0 var(--cor-fundo-button-amarelo);
}

.button-jogar-jogo:after {
    content: "";
    height: 100%;
    width: 100%;
    padding: 0.3vw;
    position: absolute;
    bottom: -2.5vh;
    left: -0.3vw;
    z-index: -1;
    background-color: #2b180065;
    border-radius: 5px;
}

body.font-loaded .mensagem-pronto {
    visibility: visible;
}

.mensagem-sobre-nos {
    position: absolute;
    top: 90%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 5;
    font-size: 1.2vw;
    font-family: 'Handjet';
    text-align: center;
    font-weight: 700;
    letter-spacing: 0.1vw;
    color: var(--cor-preto);
    background-color: var(--cor-branco);
    padding: 5px 30px;
    border: 3px solid var(--cor-preto);
    box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.3);
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
    image-rendering: pixelated;
    width: auto;
}

.mensagem-sobre-nos:hover {
    background-color: #F5B800;
    box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.4);
}

.mensagem-sobre-nos:active {
    background-color: #FFDA44;
    box-shadow: 0px 3px 8px rgba(0, 0, 0, 0.2);
}

.mensagem-como-jogar {
    position: absolute;
    top: 90%;
    right: 8%;
    z-index: 5;
    font-size: 1.2vw;
    font-family: 'Handjet', sans-serif;
    text-align: center;
    font-weight: 700;
    letter-spacing: 0.1vw;
    color: var(--cor-branco);
    background-color: #142e8c;
    padding: 5px 30px;
    border: 3px solid #031c60;
    box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.3);
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
    image-rendering: pixelated;
    width: auto;
}

.mensagem-como-jogar:hover {
    transform: scale(1.05);
    background-color: #031c60;
    box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.4);
}

.mensagem-como-jogar:active {
    background-color: #142e8c;
    box-shadow: 0px 3px 8px rgba(0, 0, 0, 0.2);
}

.mensagem-ranking {
    position: absolute;
    top: 90%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 5;
    font-size: 1.2vw;
    font-family: 'Handjet', sans-serif;
    text-align: center;
    font-weight: 700;
    letter-spacing: 0.1vw;
    color: var(--cor-preto);
    background-color: #FFDA44;
    padding: 5px 30px;
    border: 3px solid #F5B800;
    box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.3);
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
    image-rendering: pixelated;
    width: auto;
}

.mensagem-ranking:hover {
    background-color: #F5B800;
    box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.4);
}

.mensagem-ranking:active {
    background-color: #FFDA44;
    box-shadow: 0px 3px 8px rgba(0, 0, 0, 0.2);
}

.mensagem-sair {
    position: absolute;
    top: 90%;
    left: 8%;
    z-index: 5;
    font-size: 1.2vw;
    font-family: 'Handjet';
    text-align: center;
    display: flex;
    align-items: center;
    font-weight: 700;
    letter-spacing: 0.1vw;
    color: var(--cor-branco);
    background-color: var(--cor-vermelho);
    padding: 5px 45px;
    border: 3px solid var(--cor-vermelho-hover);
    box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.3);
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
    image-rendering: pixelated;
    width: auto;
}

.mensagem-sair:hover {
    transform: scale(1.05);
    background-color: var(--cor-vermelho-hover);
    box-shadow: 0px 8px 20px rgba(0, 0, 0, 0.4);
}

.como-jogar-link {
    text-decoration: none;
    color: inherit;
    display: block;
    width: 100%;
    height: 100%;
}

.como-jogar-link:hover {
    text-decoration: none;
    color: inherit;
}

.como-jogar-link p {
    margin: 0;
    padding: 0;
}

/* Modal Jogo */

/* Modal Encerramento de Sessão - Estilos exclusivos */
.modal-logout-session-bg {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.7);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    font-family: 'Handjet', sans-serif;
}

.modal-logout-session-box {
    background: var(--cor-branco);
    border: 3px solid var(--cor-preto);
    box-shadow: 4px 4px 0px var(--cor-preto);
    width: 32vw;
    min-width: 340px;
    max-width: 100vw;
    border-radius: 4px;
    padding: 0;
    display: flex;
    flex-direction: column;
    animation: fadeInModal 0.3s ease-in-out;
}

.modal-logout-session-header {
    background: #C20606;
    color: var(--cor-branco);
    font-size: 2vw;
    font-family: 'Handjet', sans-serif;
    font-weight: bold;
    padding: 1.2vw 1vw 0.7vw 1vw;
    border-radius: 4px 4px 0 0;
    letter-spacing: 1px;
}

.modal-logout-session-body {
    padding: 2vw 2vw 1vw 2vw;
    color: var(--cor-preto);
    font-size: 1.8vw;
    font-family: 'Handjet', sans-serif;
    text-align: center;
}

.modal-logout-session-input {
    width: 90%;
    margin: 1vw auto 0.5vw auto;
    display: block;
    font-size: 1.5vw;
    font-family: 'Handjet', sans-serif;
    border: 2px solid var(--cor-preto);
    border-radius: 3px;
    padding: 0.5vw 0.7vw;
    text-align: center;
    outline: none;
}

.modal-logout-session-buttons {
    display: flex;
    justify-content: space-between;
    gap: 1vw;
    padding: 1vw 2vw 2vw 2vw;
}

.modal-logout-session-cancel {
    background: #B5B2B2;
    color: var(--cor-preto);
    font-family: 'Handjet', sans-serif;
    font-size: 1.3vw;
    border: none;
    border-radius: 2px;
    padding: 0.7vw 2vw;
    font-weight: bold;
    cursor: pointer;
    box-shadow: 2px 2px 0px #888;
    transition: background 0.2s;
}

.modal-logout-session-cancel:hover {
    background: #a0a0a0;
}

.modal-logout-session-end {
    background: #C20606;
    color: var(--cor-branco);
    font-family: 'Handjet', sans-serif;
    font-size: 1.3vw;
    border: none;
    border-radius: 2px;
    padding: 0.7vw 2vw;
    font-weight: bold;
    cursor: pointer;
    box-shadow: 2px 2px 0px #888;
    transition: background 0.2s;
}

.modal-logout-session-end:hover {
    background: #a00000;
}

.modal-logout-session-end:disabled {
    background: #e0b3b3 !important;
    color: var(--cor-branco) !important;
    cursor: not-allowed !important;
    opacity: 0.7;
    box-shadow: none;
}

@media (max-width: 600px) {
    .modal-logout-session-box {
        width: 95vw;
        min-width: unset;
        font-size: 4vw;
    }

    .modal-logout-session-header,
    .modal-logout-session-body,
    .modal-logout-session-cancel,
    .modal-logout-session-end {
        font-size: 3vw !important;
    }

    .modal-logout-session-input {
        font-size: 3vw;
    }
}

/* Questão Jogo */
.container-tela-questao-jogo {
    width: 100%;
    height: 100%;
}

.container-tela-jogo-questao {
    background-color: var(--cor-fundo-cinza);
    padding: 3vh 3vw;
    width: 100%;
    height: 91.2vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.cabecalho-jogo-questao {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5vw;
}

.container-right {
    margin-right: 0.8vw;
    display: flex;
    text-align: end;
    align-items: center;
}

.barra-tempo-container {
    align-items: center;
    background-color: var(--cor-branco);
    font-family: 'Handjet';
}

.barra-tempo-externa {
    background-color: var(--cor-branco);
    height: 3vh;
    padding: 0.5vh;
    flex-grow: 1;

    overflow: hidden;
}

.barra-tempo-interna {
    height: 100%;
    background-color: #f5c518;
    width: 100%;
    transition: width 1s linear;
}

.tempo-restante {
    white-space: nowrap;
    font-family: 'Handjet';
    font-weight: bold;
    font-size: 1.8vw;
    color: var(--cor-preto);
}

.logout-questao {
    padding-inline: 0;
    font-family: 'Handjet';
    font-size: 1.8vw;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    background-color: transparent;
    cursor: pointer;
    transition: 1.5s;
}

.barra-alerta {
    background-color: var(--cor-vermelho) !important;
    animation: piscar 0.5s infinite;
}

@keyframes piscar {
    0% {
        opacity: 1;
    }

    50% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.footer-jogo-questao {
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    text-align: center;
}

.somatoria-jogo-questao {
    font-family: 'Handjet';
    text-align: start;
    font-size: 1.5vw;
    font-weight: 550;
    margin-top: 0.4vw;
}

.somatoria-jogo-questao span {
    text-decoration: underline;
    font-weight: 800;
}

.count-questoes {
    font-family: 'Handjet';
    width: 12vw;
    text-align: start;
    font-size: 2vw;
    font-weight: 550;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
}

.count-questoes .qnt-questoes {
    font-size: 4.2vw;
    font-weight: 750;
}

.count-questoes .dois-pontos {
    font-size: 4vw;
    padding-right: 0.5vw;
    font-weight: 450;
}

.format-number {
    font-family: 'Iceberg';
    font-weight: 400;
    font-style: normal;
}

.div-button-questao-jogo-questao {
    display: flex;
    gap: 1.5vw;
}

.button-passar-questao,
.finalizar-rodada-jogo,
.button-reportar-erro {
    display: flex;
    color: var(--cor-preto);
    align-items: center;
    justify-content: center;
    height: 7vh;
    width: 18vw;
    font-size: 2vw;
    background-color: var(--cor-branco);
    font-family: 'Handjet';
    text-decoration: none;
    box-shadow: 0px 3px 8px var(--cor-preto);
    transition: 500ms;
}

.button-passar-questao:hover,
.finalizar-rodada-jogo:hover,
.button-reportar-erro {
    transform: scale(1.1, 1.1);
    transition: 500ms;
}

.finalizar-rodada-jogo {
    background-color: var(--cor-fundo-preto-opacity) !important;
    color: var(--cor-branco) !important;
    box-shadow: 0px 3px 10px var(--cor-fundo-preto-opacity) !important;
}

.button-reportar-erro {
    background-color: var(--cor-vermelho) !important;
    color: var(--cor-branco) !important;
    box-shadow: 0px 3px 10px var(--cor-fundo-preto-opacity) !important;
}

.button-reportar-erro i {
    margin-right: .3rem;
    font-size: 1.5rem;
}

.content-jogo-questao {
    border: 0.1vw solid var(--cor-preto);
    background-color: transparent;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    height: 70vh;
    padding: 2vh 2vh 1vh 2vh;
    box-sizing: border-box;
    overflow-x: hidden;
    overflow-y: auto;
    scrollbar-color: var(--cor-preto) transparent;
}

.content-jogo-questao.scroll-ativo {
    justify-content: flex-start;
}

.content-jogo-questao::-webkit-scrollbar-track {
    background: transparent;
}


.container-cabecalho-jogo-questao {
    margin-bottom: 1.5vh;
}

.cabecalho-content-questao {
    display: flex;
    align-items: center;
    font-size: 2.5vw;
    height: 6vh;
    letter-spacing: 0.2vw;
    font-family: 'Handjet';
    font-weight: 700;
    margin-bottom: 1vh;
}

.container-cabecalho-jogo {
    background-color: transparent;
    width: 100%;
    display: flex;
    align-items: center;
}


.content-enunciado-questao {
    font-family: 'Handjet';
    font-weight: bold;
}

.texto-curto {
    font-size: 1.85vw;
}

.texto-medio {
    font-size: 1.5vw;
}

.texto-longo {
    font-size: 1.25vw;
}

.content-comando-questao {
    width: 100%;
    font-size: 1.5vw;
    margin-bottom: 0.5vh;
    display: block;
    justify-content: start;
    font-family: 'Handjet';
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.content-referencia-questao {
    width: 100%;
    font-size: 0.8vw;
    display: block;
    justify-content: start;
    font-family: 'Handjet';
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.btn-arcade {
    background-color: transparent;
}

.btn-arcade span {
    color: var(--cor-branco);
    font-family: 'Handjet';
    font-weight: bold;
    margin-bottom: .5rem;
    font-size: clamp(16px, 2vw, 24px);
    background-color: var(--cor-button-amarelo);
    display: inline-block;
    padding: .5rem 1.2rem;
    line-height: 1;
    text-shadow: 0 1px 0 var(--cor-preto);
    box-shadow: inset 0 1px 0, 0 6px 0 var(--cor-fundo-button-amarelo);
    border-radius: 6px;
    border: 2px solid var(--cor-preto);
    cursor: pointer;
}

.btn-arcade span:active {
    position: relative;
    top: 4px;
    box-shadow: inset 0 1px 0, inset 0 -3px 0 var(--cor-fundo-button-amarelo);
}


.content-alternativas-jogo {
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    padding: 0 2vw;
    gap: 0.5vh;
}

.alternativa-jogo {
    display: flex;
    flex-direction: row;
    align-items: center;
    font-family: 'Handjet';
    font-size: 1.25vw;
    font-weight: 650;
    cursor: pointer;
    color: var(--cor-texto);
    gap: 0.8vw;
}

.alternativa-jogo-little {
    display: flex;
    flex-direction: row;
    align-items: center;
    font-family: 'Handjet';
    font-size: 1.55vw;
    gap: 0.8vw;
    font-weight: 650;
    cursor: pointer;
    color: var(--cor-texto);
    margin-bottom: 1vh;
}

.alternativa-jogo .check-x {
    width: 2vw;
    height: 3.5vh;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 1.2vw;
    user-select: none;
    flex-shrink: 0;
    color: var(--cor-preto);
}

.alternativa-jogo-little .check-x {
    width: 2.5vw;
    height: 4.38vh;
    border: 0.1vw solid var(--cor-preto);
    background-color: var(--cor-branco);
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 1.5vw;
    user-select: none;
    flex-shrink: 0;
    color: var(--cor-preto);
}

.check-x.checked {
    color: var(--cor-preto);
}

.color-black {
    color: var(--cor-preto) !important;
    font-weight: 850;
}

@media screen and (max-width: 500px) {
    .modal-content-logout {
        width: 80vw;
    }

    .logo-tela-geral {
        width: 90vw;
    }

    .logo-tela-cad {
        width: 80vw;
    }

    .alternativa-jogo .check-x {
        width: 8vw;
        font-size: 5vw;
    }

    .alternativa-jogo-little .check-x {
        width: 8vw;
        font-size: 5vw;
    }

    .content-alternativas-jogo {
        gap: 1vh;
    }

    .somatoria-jogo-questao {
        font-size: 5vw;
        margin-top: 0.8vh;
    }

    .button-passar-questao,
    .finalizar-rodada-jogo,
    .button-reportar-erro {
        font-size: 4.5vw;
    }

    .button-reportar-erro i {
        display: none;
    }

    .count-questoes {
        font-size: 3vw;
    }

    .count-questoes .qnt-questoes {
        font-size: 8vw;
    }

    .count-questoes .dois-pontos {
        font-size: 7vw;
    }

    .texto-curto {
        font-size: 4.5vw;
    }

    .texto-medio {
        font-size: 3.5vw;
    }

    .texto-longo {
        font-size: 3vw;
    }

    .cabecalho-content-questao {
        font-size: 5vw;
        height: 5vh;
        margin-bottom: 0.5vh;
    }


    .alternativa-jogo span {
        font-size: 4vw;
    }

    .alternativa-jogo-little span {
        font-size: 3.25vw;
    }

    .content-referencia-questao {
        font-size: 3vw;
    }

    .button-jogar-jogo span {
        font-size: 6vw;
        width: 45vw;
        height: 8vh;
        line-height: 8vh;
    }

    .button-jogar-jogo:after {
        bottom: -1.8vh;
        padding: 1vw;
        left: -0.9vw;
    }

    .texto-sessao-jogo {
        font-size: 3vw;
        letter-spacing: 2px;
    }

    .cabecalho-logo-jogo {
        width: 20vw;
    }

    .cabecalho-logo-jogo:hover {
        width: 22vw;
    }

    .modal-anexo-content {
        padding: 5vh 3vw;
    }

    .mensagem-central,
    .mensagem-preparese,
    .mensagem-conteudo-jogo,
    .mensagem-informacoes,
    .mensagem-pronto,
    .informacoes-decoration,
    .mensagem-como-jogar,
    .mensagem-ranking,
    .mensagem-sobre-nos,
    .mensagem-sair,
    .modal-header,
    .modal-header .close-btn,
    .modal-body,
    #modal-form button {
        font-size: 5vw;
    }

    .mensagem-conteudo-jogo {
        width: 55%;
        height: 13%;
    }

    .mensagem-como-jogar,
    .mensagem-sair {
        top: 86%;
    }

    .mensagem-ranking {
        top: 93%;
    }

}

/* ESTILIZAÇÃO TELA COMO JOGAR */

.como-jogar-container {
    min-height: 100vh;
    background: linear-gradient(135deg, #1a237e 0%, #0d47a1 50%, #1565c0 100%);
    padding: 0;
    margin: 0;
}

.como-jogar-header {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border-bottom: 3px solid #ffd700;
    padding: 3rem 0;
    text-align: center;
}

.header-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 2rem;
}

.main-title {
    font-size: 3.5rem;
    font-weight: bold;
    color: #ffd700;
    text-shadow: 3px 3px 6px rgba(0, 0, 0, 0.4);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}

.main-title .icon {
    font-size: 4rem;
}

.subtitle {
    font-size: 1.3rem;
    color: var(--cor-branco);
    opacity: 0.9;
    margin: 0;
}

.como-jogar-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 3rem 2rem;
}

.instructions-grid-vertical {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    margin-bottom: 3rem;
    align-items: stretch;
}

.instruction-card {
    background: rgba(255, 255, 255, 0.08);
    border: 2px solid #ffd700;
    border-radius: 20px;
    padding: 1.5rem;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
    position: relative;
    overflow: hidden;
    height: fit-content;
    min-height: 200px;
    display: flex;
    flex-direction: column;
}

.instruction-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, #ffd700, #ffed4e, #ffd700);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.instruction-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 15px 35px rgba(255, 215, 0, 0.2);
    background: rgba(255, 255, 255, 0.12);
}

.instruction-card:hover::before {
    transform: scaleX(1);
}

.card-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
    padding-bottom: 0.8rem;
    border-bottom: 1px solid rgba(255, 215, 0, 0.3);
    flex-shrink: 0;
}

.card-icon {
    font-size: 2rem;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 215, 0, 0.2);
    border-radius: 12px;
    border: 2px solid #ffd700;
    flex-shrink: 0;
}

.card-header h3 {
    color: #ffd700;
    font-size: 1.4rem;
    font-weight: bold;
    margin: 0;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3);
}

.card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.card-body h4 {
    color: #ffd700;
    font-size: 1.1rem;
    font-weight: bold;
    margin: 1rem 0 0.5rem 0;
}

.card-body p,
.card-body li {
    color: var(--cor-branco);
    line-height: 1.6;
    margin-bottom: 0.5rem;
    font-size: 1rem;
}

.instruction-list {
    padding-left: 1.2rem;
    margin: 0;
    flex: 1;
}

.instruction-list li {
    margin-bottom: 0.5rem;
    position: relative;
}

.instruction-list li::marker {
    color: #ffd700;
    font-weight: bold;
}

.action-buttons {
    display: flex;
    justify-content: center;
    gap: 2rem;
    margin-top: 3rem;
}

.btn {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1rem 2.5rem;
    font-size: 1.2rem;
    font-weight: bold;
    text-decoration: none;
    border-radius: 15px;
    border: 3px solid;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.btn:hover::before {
    left: 100%;
}

.btn:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}

.btn-secondary {
    background: rgba(255, 255, 255, 0.1);
    color: var(--cor-branco);
    border-color: var(--cor-branco);
}

.btn-secondary:hover {
    background: rgba(255, 255, 255, 0.2);
    color: var(--cor-branco);
}

.btn-primary {
    background: #ffd700;
    color: #1a237e;
    border-color: #ffd700;
}

.btn-primary:hover {
    background: #ffed4e;
    color: #1a237e;
    transform: translateY(-5px) scale(1.05);
}

.btn i {
    font-size: 1.3rem;
}

.personagem-gif-topo {
    width: 120px;
    height: 120px;
    display: block;
    margin: 0 auto 1.5rem auto;
}

.personagem-gif-inline {
    width: 140px;
    height: 140px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 32px;
}

/* Responsividade */
@media (max-width: 1024px) {
    .main-title {
        font-size: 2.8rem;
    }

    .main-title .icon {
        font-size: 3rem;
    }
}

@media (max-width: 768px) {
    .como-jogar-header {
        padding: 2rem 0;
    }

    .como-jogar-content {
        padding: 2rem 1rem;
    }

    .main-title {
        font-size: 2.2rem;
        flex-direction: column;
        gap: 0.5rem;
    }

    .main-title .icon {
        font-size: 2.5rem;
    }

    .subtitle {
        font-size: 1.1rem;
    }

    .action-buttons {
        flex-direction: column;
        align-items: center;
        gap: 1rem;
    }

    .btn {
        width: 100%;
        max-width: 300px;
        justify-content: center;
    }

    .instruction-card {
        padding: 1.2rem;
        min-height: auto;
    }

    .card-header h3 {
        font-size: 1.2rem;
    }

    .container-tela-jogo-questao {
        height: 94vh;
    }

    .tempo-restante {
        font-size: 3.5vw;
    }

    .logout-questao {
        font-size: 5vw;
    }

    .footer-jogo-questao {
        margin-top: 4vh;
    }

}

@media (max-width: 480px) {
    .main-title {
        font-size: 1.8rem;
    }

    .content-jogo-questao {
        height: 73vh;
        padding: 2vh 1.5vh 2vh 1.5vh;
    }

    .main-title .icon {
        font-size: 2rem;
    }

    .subtitle {
        font-size: 1rem;
    }

    .instruction-card {
        padding: 1rem;
    }

    .card-icon {
        width: 40px;
        height: 40px;
        font-size: 1.5rem;
    }

    .card-header h3 {
        font-size: 1.1rem;
    }

}