@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');


/* GERAIS */

:root{
    --cor-primaria: #10367d;
    --cor-secundaria: #74b4da;
    --branco-a: #ebebeb;
    --branco-b: #fafafa;
    --branco-c: #fefefe;
    --cinza-a: #2a2a2b;
    --cinza-b: #2e2e2e;
    --cinza-c: #3b3b3b;
}

a, p, span{
    font-family: 'Montserrat', sans-serif;
}

a{
    text-decoration: none;
}

h1, h2, h3{
    color: var(--cor-primaria);
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
}

h1{
    font-size: 2.3rem;
}

h2{
    font-size: 1.9rem;
}

h4, h5, h6{
    color: var(--cinza-a);
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
}

ul{
    list-style: none;
}

/* REGRAS */

.only-desktop{
    display: flex;
}

.only-mobile{
    display: none;
}

body{
    background-color: #252b35;
    display: grid;
    grid-template-rows: 80px auto 1fr auto 50px;
    grid-template-columns: 1fr 4fr 1fr;
    height: 100vh;
    grid-template-areas: 
        "header     header      header"
        "sidebar    main        main"
        "footer     footer      footer";
    overflow-x: auto;
    margin: 0;
    padding: 0;
}

/* HEADER */

.header, .header-conteudo{
    align-items: center;
    background-color: #252b35;
    display: flex;
    grid-area: header;
    justify-content: center;
    padding: 0;
}

.header-logo{
    height: 50px;
    width: 50px;
    object-fit: cover;
    margin-right: 5vw;
}

.header-conteudo span{
    color: white;
    font-size: larger;
    font-weight: 600;
    margin-right: 5vw;
}

/* SIDEBAR */

.menu-list .menu-link{
    align-items: center;
    border-radius: 8px;
    color: #eef3f6;
    display: flex;
    font-size: 1.1rem;
    gap: 12px;
    padding: 12px 15px;
    text-decoration: none;
    transition: all 0.4s ease;
}

.menu-list .menu-link.active{
    background-color: #323945;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
    color: #eef3f6;
    transform: scale(1.02);
}

.menu-list .menu-link:hover{
    background-color: #323945;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
    color: #d6dfe5;
    transform: scale(1.02);
}

.sidebar{
    background-color: #252b35;
    display: flex;
    flex-direction: column;
    grid-area: sidebar;
    height: 100%;
    top: 0;
    transition: width 0.4s ease;
    width: 220px;
}

.sidebar .sidebar-conteudo{
    flex: 1;
    overflow: hidden auto;
    padding: 20px 18px;
    scrollbar-color: var(--cor-cinza-a);
    scrollbar-width: auto;
}

.sidebar-conteudo .menu-list{
    display: flex;
    flex-direction: column;
    gap: 4px;
    list-style: none;
    padding: 0;
}

.sidebar-header .header-sidebar-logo{
    display: block;
    height: 46px;
    object-fit: cover;
    width: 46px;
}

.sidebar .sidebar-header{
    align-items: center;
    border-bottom: 1px solid #323945;
    display: flex;
    padding: 20px 18px;
}

.sidebar i{
    font-size: 1.4rem;
}

/* CONTAINER */

.banner{
    border-radius: 18px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
    height: 270px;
    width: 480px;
}

.banner-b{
    border-radius: 18px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
    height: 216px;
    width: 384px;
}

.card-nav{
    transition: transform 0.4s ease-in-out;
}

.card-nav .card-body-a, .card-nav .card-body-b{
    border-radius: 15px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
    color: var(--branco-a);
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0.3rem;
}

.card-nav .card-body-a .card-title, .card-nav .card-body-b .card-title{
    margin-bottom: 1rem;
}

.card-nav .card-body-a p, .card-nav .card-body-b p{
    font-size: 0.8rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.card-nav .card-body-a i, .card-nav .card-body-b i{
    font-size: 3rem;
    padding: 1rem;
}

.card-body-a{
    background-color: var(--cor-primaria);
}

.card-body-b{
    background-color: var(--cor-secundaria);
    filter: contrast(1.1) brightness(0.95);
}

.container{
    border-radius: 30px;
    background: linear-gradient(to right, var(--branco-a), var(--branco-b));
    flex-direction: column;
    grid-area: main;
    padding-top: 1rem;
    padding-left: 1.6rem;
    padding-right: 1rem;
}

.row{
    align-items: center;
    flex-direction: row;
    justify-content: center;
}

.card-nav:hover{
    transform: scale(1.04);
}

/* FOOTER */

.footer{
    padding: 1rem;
    padding-top: 1.8rem;
    margin: 0;
    color: var(--branco-a);
    grid-area: footer;
    background-color: #252b35;
    font-size: smaller;
}

.footer a{
    text-decoration: none;
    color: #dddddd;
}

.footer a:hover{
    color: var(--cor-secundaria);
}

.footer h6{
    color: var(--branco-a);
}

#linha-divisoria-footer{
    border-left: 1px solid #323945;
    border-right: 1px solid #323945;
}

.footer .btn{
    background-color: transparent;
    border: 1px solid var(--branco-a);
    border-radius: 8px;
    transition: all 0.4 ease-in-out;
}

.footer .btn:hover{
    background-color: var(--cor-primaria);
    color: var(--branco-a);
    border: 1px solid var(--cor-primaria);
    transform: scale(1.02);
}

.secao-materiais{
    border-radius: 15px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
    padding: 1rem;
    display: flex;
    flex-direction: column;
}

.button{
    border-radius: 8px;
    background-color: var(--cor-primaria);
    text-transform: uppercase;
    padding: 0.55rem;
    color: white;
    font-weight: 600;
    transition: all 0.4s ease-in-out;
    width: 20%;
    align-items: center;
    text-align: center;
}

.button:hover{
    transform: scale(1.02);
}

#noticia-1, #noticia-2, #noticia-3, #noticia-4{
    padding: 1rem;
    border-radius: 18px;
}

#noticia-1{
    background:
        linear-gradient(to right, #252b35, rgba(0, 0, 0, 0.705)),
        url('https://editalconcursosbrasil.com.br/wp-content/uploads/2017/04/concurso-ribeiraodasneves.jpg');
    background-position: center;
    background-size: cover;
    color: white;
}

#noticia-2{
    background:
        linear-gradient(to right, #252b35, rgba(0, 0, 0, 0.705)),
        url('https://blog.unis.edu.br/hubfs/shutterstock_318001037.jpg');
    background-position: center;
    background-size: cover;
    color: white;
}

#noticia-3{
    background:
        linear-gradient(to right, #252b35, rgba(0, 0, 0, 0.705)),
        url('https://www.camara.leg.br/midias/image/2025/04/img20230523102312132-768x576.jpg');
    background-position: center;
    background-size: cover;
    color: white;
}

#noticia-4{
    background:
        linear-gradient(to right, #252b35, rgba(0, 0, 0, 0.705)),
        url('https://irp.cdn-website.com/7d3dbd26/dms3rep/multi/M%C3%A9dico+obstetra+de+cl%C3%ADnica+geral+participando+de+consulta+com+uma+paciente+e+tomando+notas..jpg');
    background-position: center;
    background-size: cover;
    color: white;
}

.card-material{
    justify-content: center;
    align-items: center;
    padding: 1rem;
    gap: 1rem;
    display: flex;
    border-radius: 15px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
}

.img-card img{
    border-radius: 16px !important;
}

#quiz-content{
    justify-content: center;
    align-items: center;
    padding: 1rem;
    gap: 1rem;
    border-radius: 15px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
}

#resultado{
    font-size: larger;
}

.quiz-card {
      max-width: 600px;
      margin: 50px auto;
      padding: 20px;
}

.quiz-option {
      margin-bottom: 10px;
}

.progress {
      height: 8px;
}

@media screen and (max-width: 900px){
    .only-desktop{
        display: none;
    }
    .only-mobile{
        display: flex;
    }

    .button{
        width: 100%;
    }

    #grafico3-a {
        height: 400px;
    }

    body{
        margin: 0;
        padding: 0;
        box-sizing: border-box;
        overflow: auto;
        background-color: #eef3f6;
        display: flex;
        flex-direction: column;
    }

    .content{
        width: 100vw;
        padding: 5vw;
        margin: 0;
        background-color: #eef3f6;
        display: flex;
        flex-direction: column;
    }

    .banner, .banner-b{
        width: 320px;
        height: 180px;
        margin-bottom: 4vh;
        margin-top: 3vh;
    }

    .tab-content{
        padding: 0 !important;
        overflow: auto;
    }

    .img{
        align-items: center;
        display: flex;
        text-align: center;
        justify-content: center;
    }

    .secao-materiais{
        font-size: smaller;
    }

    .secao-materiais .button{
        width: 100%;
    }

    .footer{
        display: flex;
        padding-bottom: 18vh;
    }

    .footer #linha-divisoria-footer{
        border: none
    }

    .bottom-bar{
        background-color: #323945;
        width: 96vw;
        position: fixed;
        height: 11vh;
        padding: 0.8vh;
        text-align: center;
        border-radius: 55px;
        z-index: 300;
        top: 85vh;
        left: 2vw;
        justify-content: center;
        align-items: center;
    }

    .bottom-bar ul{
        display: flex;
        justify-content: center;
        margin: 0;
        padding: 6px;
        list-style: none;
    }

    .bottom-bar a{
        text-decoration: none;
        color: #eef3f6;
    }

    .bottom-bar i{
        font-size: 1.8rem;
    }

    .bottom-bar span{
        font-size: 0.85rem;
    }

    .nav-link.active{
        color: #74b4da;
        font-weight: 700;
    }

    .header{
        border-radius: 0 0 30px 30px;
    }

    .header-conteudo{
        display: flex;
        flex-direction: row;
        height: 10vh;
    }

    .header-conteudo span{
        font-size: smaller;
    }

    .card-nav{
        font-size: smaller;
        text-align: center;
    }

    .card-body-a i, .card-body-b i{
        font-size: 0.8rem;
    }

    .menor{
        font-size: smaller;
    }
}