* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Open Sans', sans-serif;
    background-color: #F2D8E1; 
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 2000 1500'%3E%3Cdefs%3E%3CradialGradient id='a' gradientUnits='objectBoundingBox'%3E%3Cstop offset='0' stop-color='%23FFFFFF'/%3E%3Cstop offset='1' stop-color='%23F2D8E1'/%3E%3C/radialGradient%3E%3ClinearGradient id='b' gradientUnits='userSpaceOnUse' x1='0' y1='750' x2='1550' y2='750'%3E%3Cstop offset='0' stop-color='%23f9ecf0'/%3E%3Cstop offset='1' stop-color='%23F2D8E1'/%3E%3C/linearGradient%3E%3Cpath id='s' fill='url(%23b)' d='M1549.2 51.6c-5.4 99.1-20.2 197.6-44.2 293.6c-24.1 96-57.4 189.4-99.3 278.6c-41.9 89.2-92.4 174.1-150.3 253.3c-58 79.2-123.4 152.6-195.1 219c-71.7 66.4-149.6 125.8-232.2 177.2c-82.7 51.4-170.1 94.7-260.7 129.1c-90.6 34.4-184.4 60-279.5 76.3C192.6 1495 96.1 1502 0 1500c96.1-2.1 191.8-13.3 285.4-33.6c93.6-20.2 185-49.5 272.5-87.2c87.6-37.7 171.3-83.8 249.6-137.3c78.4-53.5 151.5-114.5 217.9-181.7c66.5-67.2 126.4-140.7 178.6-218.9c52.3-78.3 96.9-161.4 133-247.9c36.1-86.5 63.8-176.2 82.6-267.6c18.8-91.4 28.6-184.4 29.6-277.4c0.3-27.6 23.2-48.7 50.8-48.4s49.5 21.8 49.2 49.5c0 0.7 0 1.3-0.1 2L1549.2 51.6z'/%3E%3Cg id='g'%3E%3Cuse href='%23s' transform='scale(0.12) rotate(60)'/%3E%3Cuse href='%23s' transform='scale(0.2) rotate(10)'/%3E%3Cuse href='%23s' transform='scale(0.25) rotate(40)'/%3E%3Cuse href='%23s' transform='scale(0.3) rotate(-20)'/%3E%3Cuse href='%23s' transform='scale(0.4) rotate(-30)'/%3E%3Cuse href='%23s' transform='scale(0.5) rotate(20)'/%3E%3Cuse href='%23s' transform='scale(0.6) rotate(60)'/%3E%3Cuse href='%23s' transform='scale(0.7) rotate(10)'/%3E%3Cuse href='%23s' transform='scale(0.835) rotate(-40)'/%3E%3Cuse href='%23s' transform='scale(0.9) rotate(40)'/%3E%3Cuse href='%23s' transform='scale(1.05) rotate(25)'/%3E%3Cuse href='%23s' transform='scale(1.2) rotate(8)'/%3E%3Cuse href='%23s' transform='scale(1.333) rotate(-60)'/%3E%3Cuse href='%23s' transform='scale(1.45) rotate(-30)'/%3E%3Cuse href='%23s' transform='scale(1.6) rotate(10)'/%3E%3C/g%3E%3C/defs%3E%3Cg transform='translate(1020 0)'%3E%3Cg transform='translate(0 75)'%3E%3Ccircle fill='url(%23a)' r='3000'/%3E%3Cg opacity='0.5'%3E%3Ccircle fill='url(%23a)' r='2000'/%3E%3Ccircle fill='url(%23a)' r='1800'/%3E%3Ccircle fill='url(%23a)' r='1700'/%3E%3Ccircle fill='url(%23a)' r='1651'/%3E%3Ccircle fill='url(%23a)' r='1450'/%3E%3Ccircle fill='url(%23a)' r='1250'/%3E%3Ccircle fill='url(%23a)' r='1175'/%3E%3Ccircle fill='url(%23a)' r='900'/%3E%3Ccircle fill='url(%23a)' r='750'/%3E%3Ccircle fill='url(%23a)' r='500'/%3E%3Ccircle fill='url(%23a)' r='380'/%3E%3Ccircle fill='url(%23a)' r='250'/%3E%3C/g%3E%3Cg transform='rotate(-165.6 0 0)'%3E%3Cuse href='%23g' transform='rotate(10)'/%3E%3Cuse href='%23g' transform='rotate(120)'/%3E%3Cuse href='%23g' transform='rotate(240)'/%3E%3C/g%3E%3Ccircle fill-opacity='0.27' fill='url(%23a)' r='3000'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    background-attachment: fixed;
    background-size: cover;
}

.wrap {
    max-width: 1100px;
    width: 95%;
    margin: auto;
}

.wrap > h1 {
    color: #0a0a08;
    font-family: ailerons;
    font-size: 50px;
    display: flex;
    flex-direction: column;
    text-align: center;
    margin: 15px 0px;
    text-shadow: 3px 3px 2px rgba(0, 0, 0, 0.2);
}

.wrap > h1:after {
    content: '';
    width: 100%;
    height: 1px;
    background: #C7C7C7;
    margin: 20px 0;
}


/* PRODUCTOS */
.products-list {
    width: 82%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 25px;
    margin-left: auto;
    margin-right: auto;
}

.products-list .product-item {
    width: calc(25% - 19px);
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.22);
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: all 0.4s;
    border-radius: .5em;
    overflow: hidden;
}

.products-list .product-item img {
    width: 100%;
    border-radius: .5em .5em 0 0;
}

.products-list .product-item a {
    display: block;
    width: 100%;
    padding: 8px 0;
    background: #2D3E50;
    color: #fff;
    text-align: center;
    text-decoration: none;
    border-radius: 0 0 .5em .5em;
}

/* RESPONSIVE */
@media screen and (max-width: 1100px) {
    .products-list .product-item {
        width: calc(33.33% - 17px);
    }
}

@media screen and (max-width: 900px) {
    .products-list .product-item {
        width: calc(30% - 16px);
    }
}

@media screen and (max-width: 700px) {
}

@media screen and (max-width: 600px) {
    .products-list .product-item {
        width: calc(48% - 13px);
    }
}

@media screen and (max-width: 350px) {
    .products-list .product-item {
        width: 100%;
    }
}

/* CATEGORÍAS */
.category-list-desktop {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
    justify-content: center;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.category-list-desktop .category-item-desktop {
    display: block;
    padding: 12px 20px;
    margin: 0 10px 10px 0;
    background: #E84C3D;
    border-radius: .5em;
    text-align: center;
    color: #fff;
    cursor: pointer;
    transition: background 0.3s ease, transform 0.2s ease;
    white-space: nowrap;
}

.category-list-desktop .category-item-desktop:hover {
    background: #c0392b; 
    transform: translateY(-2px); 
}

.category-list-desktop .category-item-desktop.active-category {
    background: #2D3E50; 
    box-shadow: 0 0.0625em 0.1875em rgba(0, 0, 0, 1);
}

/* Menú de categorías para pantallas pequeñas (select) */
.category-list-mobile {
    display: block; 
    width: 100%;
    margin-bottom: 20px;
    text-align: center;
}

.category-list-mobile .category_item { 
    width: 80%;
    max-width: 350px; 
    margin: 0 auto;
    padding: 12px 15px;
    font-size: 16px;
    border: 1px solid #ccc;
    border-radius: .5em;
    background-color: #f9f9f9;
    color: #333;
    cursor: pointer;
    appearance: none; 
    -webkit-appearance: none;
    -moz-appearance: none;
    
    background-image: url('data:image/svg+xml;utf8,<svg fill="#333" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/><path d="M0 0h24v24H0z" fill="none"/></svg>');
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 20px;
}

/* --- Media Queries para el menú de categorías --- */

@media screen and (min-width: 901px) {
    .category-list-desktop {
        display: flex; 
        flex-direction: row;
        width: 100%;
        justify-content: center;
    }
    .category-list-mobile {
        display: none;
    }

    .products-list {
        width: 100%;
        justify-content: center;
    }
}

@media screen and (max-width: 900px) {
    .category-list-desktop {
        display: none;
    }
    .category-list-mobile {
        display: block;
    }

    .store-wrapper {
        flex-direction: column;
        align-items: center;
    }

    .products-list {
        width: 100%;
        justify-content: center;
    }
}