html {
    box-sizing: border-box;
    background-color: var(--colorfondo);
}

:root {
    --colorfondo: #f5a9dc;
    --colorprincipal: #5a0247;
    --colorsecundario: #801677;
    --colorfondo2: #f7f7ff;
    --negro: rgb(8, 1, 51);
    --blanco: white;
}

* {
    box-sizing: border-box;
}

body {
    background-color: var(--colorfondo);
    font-family: Arial, Helvetica, sans-serif;
    color: var(--colorprincipal);
    margin: 0px;
    width: 90vw;
    margin: auto;
    padding: 10px;
    

}

header {
    background-color: var(--colorprincipal);
    list-style: none;
    color: var(--blanco);
    height: 180px;
    display: grid;
    grid-template-columns: 8fr 4fr;
    justify-items: center;
    align-items: center;
}


header>div {
    display: none;
}

header ul {
    list-style: none;
    margin: 0px;
    padding: 0px;
}

header ul li {
    display: inline-block;
}

header ul li a {
    color: inherit;
    text-decoration: none;
    display: block;
    margin: 15px;
    font-size: 1.3em;
}

header form {
    width: 100%;
}

header form input {
    width: 55%;
    border: 0px;
    color: var(--colorprincipal);
    padding: 4px;
    border-radius: 4px;
    margin-left: 5px;
}

header form button {
    background-color: var(--colorprincipal);
    border: 0px;
    color: var(--blanco);
    font-size: 1.2em;
    margin-left: 20px;
}
main section article img{

    width: 30%; /* Ajusta el ancho de cada artículo según tus necesidades */
    margin-bottom: 5px; /* Espacio entre las filas de artículos */
    box-sizing: border-box; /* Incluye el padding y el borde en el ancho total */
    height: auto; /* Mantiene la proporción de las imágenes */
    max-height: 220px; /* Altura máxima para las imágenes */
    object-fit: cover; /* Cubre el área sin distorsionar la imagen */
    border-radius: 5px; /* Bordes redondeados */
    margin: 0px;
    padding: 0px;
    margin-top: 5%;
    padding-bottom: 15%;
    
}
main {
    display: flex;
    justify-content: space-between;
    max-width: 1800px;
    margin: auto;
    padding: 20px;
    background: var(--blanco);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}
section {
    margin-bottom: 20px;
}
 aside {
            flex: 1; /* Toma 1 parte del espacio */
            padding: 1px;
           
        }
article {
    margin-bottom: 20px;
    border-bottom: 1px solid #ddd;
    padding-bottom: 20px;
    flex: 3; /* Toma 3 partes del espacio */
    padding: 20px;
    flex: 1; /* Esto permite que el artículo ocupe el espacio disponible */
    margin-right: 20px; /* Espacio entre el artículo y el aside */
}


a {
    text-decoration: none;
    color: var(--colorprincipal);
}

a:hover {
    text-decoration: underline;
}
main section {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    margin: 10px;
    gap: 20px;
    background-color: var(--colorfondo2);
}

main section article {
    padding:5px;
}

main section article img {
    width: 100%;
}

main section article div {
    display: grid;
    grid-template-columns: 9fr 4fr;
    justify-items: center;
    align-items: center;
   display: flex; /* Usamos flexbox para alinear los elementos en una fila */
    align-items: center; /* Alinea todos los elementos al centro verticalmente */
    
}


main section article p {
    font-size: 0.9em;
    text-align: justify;
    line-height: 1.5; /* Mejora la legibilidad */
}

main section article div a {
    background-color: var(--colorprincipal);
    color: var(--blanco);
    padding: 10px;
    border-radius: 3px;
    text-decoration: none;
}

main aside {
    width: auto;
    background-color: var(--colorsecundario);
    color: var(--blanco);
}

main aside ul {
    list-style: none;
    margin-left: 6px;
    padding: 0px;
}

main aside ul li a {
    color: inherit;
    text-decoration: none;
    margin-top: 7px;
    display: block;
}

main aside ul li a:hover {
    color: var(--negro);
}


footer {
    background-color: var(--negro);
    color: var(--blanco);
    padding: 20px;
}


footer p {
    margin: 0px;
    text-align: center;
}

footer ul {
    list-style: none;
    padding: 0px;
    margin: 0px;
    text-align: center;
}

footer ul li {
    display: inline-block;
}


footer ul li a {
    color: inherit;
    text-decoration: none;
    display: block;
    margin: 15px;
    font-size: 1.3em;
}

@media (max-width: 850px) {
    body {
        width: 100vw;
    }

    header {
        height: auto;
        display: grid;
        grid-template-columns: 1fr;
        justify-items: left;
        align-items: center;
    }

    header>div {
        margin: 0px;
        display: grid
        grid-template-colums 80% auto;
        margin: 7px;
      
        font-size: 1.5em;
    }

    header nav,
    header form {
        display: none;
    }


    header nav {
        width: 100%;
    }

    header ul li {
        display: block;
        width: 100%;
        font-size: 1em;
    }

    header ul li a {
        border-bottom: 1px solid var(--colorsecundario);
        width: 100%;
        font-size: 1em;
        margin: 0px;
        margin-top: 8px;
        padding-left: 15px;
    }


    header form {
        margin: 25px;
    }

    header form input {
        margin: 0px;
    }

    main {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
        grid-template-areas: "categorias"
            "articulos";
    }

    main section {
        grid-template-columns: 1fr;
        grid-area: articulos;
    }

    main section article {
        border-bottom: 10px solid var(--blanco);
        padding-bottom: 15px;
    }

    main aside{
        grid-area: categorias;
    }

    main aside h3{
        text-align: right;
        margin-right: 15px;
    }

    main aside ul{
        display: none;
    }
}