/* Grid Granizados */
.titleSeccion {
    display: block;
    width: min(100%, 1180px);
    margin: clamp(1.5rem, 4vw, 3rem) auto 1rem;
    padding: 0 clamp(1rem, 4vw, 2rem);
    color: #171717;
    font-size: clamp(2rem, 5vw, 4.4rem);
    font-weight: 900;
    line-height: .95;
    letter-spacing: 0;
}

.sectionGranizados {
    --granizado-ink: #172026;
    --granizado-muted: #5d6b78;
    --granizado-line: #dde8ee;
    --granizado-panel: #ffffff;
    --granizado-soft: #f3fbfd;
    --granizado-cold: #00a8c6;
    --granizado-fruit: #ff6b4a;
    --granizado-fresh: #22a86f;

    position: relative;
    width: 100%;
    padding: clamp(1rem, 5vw, 4rem);
    border-top: 1px solid var(--granizado-line);
    background:
        linear-gradient(180deg, #ffffff 0%, var(--granizado-soft) 36%, #ffffff 100%);
}

.sectionGranizados .containerGranizados {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(15.5rem, 1fr));
    gap: clamp(.8rem, 2vw, 1.15rem);
    width: min(100%, 1180px);
    margin: 0 auto;
}

.sectionGranizados .cardGranizado {
    display: grid;
    grid-template-areas:
        "image image"
        "name name"
        "description description"
        "price actions";
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto 1fr auto;
    min-width: 0;
    overflow: hidden;
    border: 1px solid rgba(23, 32, 38, .08);
    border-radius: .55rem;
    background: var(--granizado-panel);
    box-shadow: 0 .7rem 1.8rem rgba(15, 23, 42, .11);
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.sectionGranizados .cardGranizado:hover {
    transform: translateY(-.18rem);
    border-color: rgba(0, 168, 198, .42);
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, .16);
}

.sectionGranizados .imageGranizado {
    grid-area: image;
    display: block;
    width: 100%;
    height: clamp(12.5rem, 22vw, 16rem);
    object-fit: cover;
    object-position: center;
    background: #eef6f8;
}

.sectionGranizados .nameGranizado {
    grid-area: name;
    min-width: 0;
    margin: 0;
    padding: .85rem 1rem .3rem;
    color: var(--granizado-ink);
    font-size: clamp(1.05rem, 2vw, 1.32rem);
    font-weight: 900;
    line-height: 1.08;
    letter-spacing: 0;
}

.sectionGranizados .descriptionGranizado {
    grid-area: description;
    min-width: 0;
    margin: 0;
    padding: 0 1rem .9rem;
    color: var(--granizado-muted);
    font-size: clamp(.9rem, 1.6vw, .98rem);
    font-weight: 650;
    line-height: 1.45;
}

.sectionGranizados .priceCont {
    grid-area: price;
    display: flex;
    align-items: center;
    padding: 0 0 1rem 1rem;
}

.sectionGranizados .price {
    display: inline-flex;
    align-items: baseline;
    gap: .22rem;
    margin: 0;
    padding: .36rem .75rem;
    border: 1px solid rgba(0, 168, 198, .18);
    border-radius: 999px;
    background: #ecfbff;
    color: var(--granizado-cold);
    font-size: clamp(1.15rem, 2vw, 1.5rem);
    font-weight: 900;
    line-height: 1;
    box-shadow: 0 .45rem 1.1rem rgba(0, 168, 198, .13);
}

.sectionGranizados .symbol {
    color: var(--granizado-fruit);
    font-size: .85rem;
    font-weight: 900;
}

.sectionGranizados .btnsContainer {
    grid-area: actions;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .45rem;
    padding: 0 1rem 1rem .6rem;
}

.sectionGranizados .seeGranizado {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.45rem;
    min-width: 0;
    padding: .65rem .8rem;
    border: 1px solid var(--granizado-ink);
    border-radius: .48rem;
    background: var(--granizado-ink);
    color: #ffffff;
    font-size: .9rem;
    font-weight: 850;
    line-height: 1;
    cursor: pointer;
    transition: color .18s ease, background .18s ease, border-color .18s ease;
}

.sectionGranizados .seeGranizado:hover,
.sectionGranizados .seeGranizado:focus-visible {
    border-color: var(--granizado-fruit);
    background: var(--granizado-fruit);
    color: #ffffff;
}

@media (max-width: 720px) {
    .sectionGranizados {
        padding: 1rem;
    }

    .sectionGranizados .containerGranizados {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .65rem;
    }

    .sectionGranizados .cardGranizado {
        grid-template-areas:
            "image"
            "name"
            "description"
            "price"
            "actions";
        grid-template-columns: 1fr;
    }

    .sectionGranizados .imageGranizado {
        height: 10.5rem;
    }

    .sectionGranizados .nameGranizado {
        padding: .7rem .7rem .25rem;
        font-size: .95rem;
    }

    .sectionGranizados .descriptionGranizado {
        padding: 0 .7rem .7rem;
        font-size: .8rem;
    }

    .sectionGranizados .priceCont,
    .sectionGranizados .btnsContainer {
        padding-inline: .7rem;
    }

    .sectionGranizados .priceCont {
        padding-bottom: .7rem;
    }

    .sectionGranizados .btnsContainer {
        justify-content: stretch;
        padding-bottom: .75rem;
    }

    .sectionGranizados .seeGranizado {
        width: 100%;
    }
}

@media (max-width: 390px) {
    .sectionGranizados .containerGranizados {
        grid-template-columns: 1fr;
    }
}
