/* ----- ESTILOS BASE ----- */

html, body {
    margin: 0;
    padding: 0;
    overflow-x: hidden; /* evita scroll horizontal */
    box-sizing: border-box;
}

header {
    
    background-color: #d90a10;
    justify-content: center;
    justify-items: center;

    margin: 0;
    padding: 0;
}

header > div > nav > ul {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    margin: 0;
    padding: 0;
    
}

header > div > nav > ul > li > a {
    color: white;
    text-decoration: none;
    display: block;
    padding: 10px 0;
    font-size: 1.2em;
}

/* MAIN */
main {
    display: grid;
    grid-template-columns: 3fr 1fr; /* contenido + menú lateral */
    gap: 20px;
    padding: 20px;
}

#secciones {
    margin-top: 20px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    justify-items: stretch;
    padding-left: 10%;
}

#articulos {
    margin-top: 20px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    justify-items: stretch;
    padding: 0 10%;
    color: #d90a10;
}

/* MENÚ LATERAL */
.menu-lateral > ul {
    display: grid;
    gap: 10px;
    background-color: #d90a10;
    list-style: none;
    color: white;
    padding: 10px;
    border-radius: 8px;
}

.menu-lateral > ul > li > a {
    color: white;
    text-decoration: none;
}

/* PIE DE PÁGINA */
#Piedepagina{
    
    display: grid; 
    grid-template-columns: repeat(3,1fr);
    background-color: #d90a10;
    padding:0px;
    margin:0px;
    justify-content: center;
    justify-items: center;
}

/* ----- MEDIA QUERY (responsive: menos de 500px) ----- */
@media (max-width: 500px) {

    header {
        grid-template-columns: 1fr;
        padding: 10px;
        text-align: center;
    }

    header > div > nav > ul {
        grid-template-columns: 1fr; /* el menú se apila */
        gap: 10px;
    }

    header > div > nav > ul > li > a {
        font-size: 1em;
        padding: 8px;
    }

    main {
        grid-template-columns: 1fr; /* el contenido y el menú lateral se apilan */
        padding: 10px;
    }

    #secciones, #articulos {
        grid-template-columns: 1fr; /* artículos en una sola columna */
        padding: 0;
    }

    .menu-lateral > ul {
        grid-template-columns: 1fr;
        text-align: center;
    }

    #Piedepagina {
        grid-template-columns: 1fr;
        gap: 10px;
    }
}
