:root{
    --azul:#31329B;
    --verde:#00A84F;
    --cinza:#f5f7fa;
    --texto:#2d3748;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
    background:var(--cinza);
    font-family:Arial, Helvetica, sans-serif;
    color:var(--texto);
}

/* ===========================
   CONTEÚDO
=========================== */

.concursos-container{
    max-width:1200px;
    margin:50px auto;
    padding:0 20px;
}

/* ===========================
   FILTROS
=========================== */

.filtros-box{
    background:#fff;
    border-radius:18px;
    padding:30px;
    box-shadow:0 6px 20px rgba(0,0,0,.08);
    border-top:5px solid var(--verde);
    margin-bottom:35px;
}

.filtros-box h2{
    color:var(--azul);
    margin-bottom:8px;
}

.filtros-box p{
    color:#666;
    margin-bottom:20px;
}

#busca{
    width:100%;
    padding:16px;
    border:1px solid #ddd;
    border-radius:10px;
    font-size:1rem;
    outline:none;
}

#busca:focus{
    border-color:var(--azul);
}

/* ===========================
   CABEÇALHO LISTA
=========================== */

.lista-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:25px;
}

.lista-header h2{
    color:var(--azul);
}

#contador{
    color:var(--verde);
    font-weight:700;
}

/* ===========================
   LISTA
=========================== */

.concursos-lista{
    display:grid;
    gap:24px;
}

/* ===========================
   CARD
=========================== */

.concurso-card{
    background:#fff;
    border-radius:18px;
    padding:28px;
    border-left:6px solid var(--azul);
    box-shadow:0 6px 20px rgba(0,0,0,.08);
    transition:.25s;
}

.concurso-card:hover{
    transform:translateY(-3px);
}

.card-topo{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:18px;
}

.card-topo h3{
    color:var(--azul);
    font-size:1.45rem;
}

.badge{
    background:var(--verde);
    color:#fff;
    padding:6px 14px;
    border-radius:30px;
    font-size:.85rem;
    font-weight:700;
}

.card-info{
    display:flex;
    gap:30px;
    flex-wrap:wrap;
    margin-bottom:20px;
    color:#666;
}

.card-info strong{
    color:var(--texto);
}

.btn-concurso{
    display:inline-block;
    background:var(--azul);
    color:#fff;
    text-decoration:none;
    padding:12px 22px;
    border-radius:10px;
    font-weight:700;
    transition:.25s;
}

.btn-concurso:hover{
    background:var(--verde);
}

.mensagem{
    text-align:center;
    padding:50px;
    color:#666;
}

/* ===========================
   RESPONSIVO
=========================== */

@media(max-width:768px){

    .lista-header,
    .card-topo{
        flex-direction:column;
        align-items:flex-start;
        gap:12px;
    }

    .card-info{
        flex-direction:column;
        gap:10px;
    }

}