/**
 * Product grid block — front-end grid layout styles.
 *
 * @package SunmaintainV2
 */

/* ── Block wrapper ── */
.sm-product-grid-block {
    width: 100%;
    margin: 0 auto;
}

/* ── Section header ── */
.sm-product-grid__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: clamp(1.15rem, 2vw, 1.65rem);
}

.sm-product-grid__title {
    margin: 0;
    color: #2f2b27;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.95rem, 3.1vw, 2.45rem);
    font-weight: 800;
    line-height: 1.08;
}

.sm-product-grid__header-link {
    color: #083d8f;
    font-family: "Avenir Next", "Segoe UI", sans-serif;
    font-size: 0.98rem;
    font-weight: 850;
    text-decoration: none;
    white-space: nowrap;
}

.sm-product-grid__header-link:hover {
    text-decoration: underline;
    text-underline-offset: 0.22em;
}

/* ── Grid layout ── */
.sm-product-grid__container--grid {
    display: grid;
    grid-template-columns: repeat(var(--sm-grid-cols, 3), 1fr);
    gap: 24px;
}

/* ── Rail layout (horizontal scroll, for homepage-like use) ── */
.sm-product-grid__container--rail {
    display: flex;
    gap: 24px;
    align-items: stretch;
    max-width: 100%;
    overflow-x: auto;
    contain: layout paint;
    padding: 2px 0 18px;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
}

.sm-product-grid__container--rail .sm-product-card {
    flex: 0 0 300px;
    scroll-snap-align: start;
}

/* ── Pagination ── */
.sm-product-grid__pagination-wrap {
    display: flex;
    justify-content: center;
    margin-top: 2rem;
}

.sm-product-grid__pagination-wrap .sm-product-grid__pagination,
.sm-product-grid__pagination-wrap .page-numbers {
    display: flex;
    gap: 6px;
    list-style: none;
    padding: 0;
    margin: 0;
    flex-wrap: wrap;
    justify-content: center;
}

.sm-product-grid__pagination-wrap .page-numbers li {
    margin: 0;
}

.sm-product-grid__pagination-wrap .page-numbers a,
.sm-product-grid__pagination-wrap .page-numbers span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border: 1px solid #d7cfc3;
    border-radius: 6px;
    color: #2f2b27;
    font-size: 0.88rem;
    font-weight: 700;
    text-decoration: none;
    transition: background 120ms ease, border-color 120ms ease;
}

.sm-product-grid__pagination-wrap .page-numbers a:hover {
    background: #f0ebe3;
    border-color: #b8b0a5;
}

.sm-product-grid__pagination-wrap .page-numbers.current {
    background: #083d8f;
    border-color: #083d8f;
    color: #ffffff;
}

/* ── Responsive ── */
@media (max-width: 960px) {
    .sm-product-grid__container--grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 18px;
    }

    .sm-product-grid__container--rail .sm-product-card {
        flex-basis: 260px;
    }
}

@media (max-width: 600px) {
    .sm-product-grid__container--grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .sm-product-grid__header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.45rem;
    }
}
