/* ============================================================
   PRODUCT HERO
============================================================ */
.product-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.product-hero__media {
    overflow: hidden;
    align-self: start;
}

.product-hero__image {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    display: block;
}

.product-hero__body {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: var(--spacing-lg);
    gap: var(--spacing-md);
}

.product-hero__heading {
    text-align: center;
}

.product-hero__title {
    font-size: var(--fs-heading);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 1;
    margin-bottom: 0.5rem;
}

.product-hero__specs {
    font-size: var(--fs-sm);
    color: var(--color-grey);
    letter-spacing: 0.06em;
}

.product-hero__description {
    font-size: var(--fs-base);
    line-height: 1.7;
    font-weight: 500;
}

/* Attributi */
.product-hero__attrs {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.product-hero__attr {
    display: flex;
    gap: var(--spacing-sm);
}

.product-hero__attr-label {
    font-size: var(--fs-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    min-width: 9rem;
    flex-shrink: 0;
}

.product-hero__attr-value {
    font-size: var(--fs-sm);
    color: var(--color-grey);
}

/* Link scheda prodotto */
.product-hero__datasheet {
    display: inline-flex;
    align-items: baseline;
    gap: 0.75rem;
    font-size: var(--fs-sm);
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: gap 0.2s;
}

.product-hero__datasheet__link {
    text-decoration: underline;
}

.product-hero__datasheet:hover {
    gap: 1.25rem;
}

.product-hero__datasheet__arrow {
    font-size: var(--fs-xl);
    line-height: 1;
}

/* Responsive */
@media (max-width: 768px) {
    .product-hero {
        grid-template-columns: 1fr;
    }

    .product-hero__body {
        gap: var(--spacing-sm);
        padding: var(--spacing-lg) var(--container-pad);
    }

    .product-hero__attr {
        flex-direction: column;
        gap: 0.125rem;
    }
}


/* ============================================================
   PRODUCT GALLERY
============================================================ */
.product-gallery__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.product-gallery__cell {
    overflow: hidden;
}

.product-gallery__cell--beige {
    background-color: var(--color-beige);
}

.product-gallery__cell--mint {
    background-color: var(--color-mint);
}

.product-gallery__cell--sage {
    background-color: var(--color-sage);
}

.product-gallery__cell--white {
    background-color: var(--color-bg);
}

.product-gallery__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Responsive */
@media (max-width: 768px) {
    .product-gallery__grid {
        grid-template-columns: 1fr;
    }

    .product-gallery__cell:not(.product-gallery__cell--image) {
        display: none;
    }

}


/* ============================================================
   CTA STRIP (hardcoded nel template prodotto)
============================================================ */
.cta-strip {
    padding: var(--spacing-lg) var(--container-pad);
    background-color: var(--color-bg);
}

.cta-strip--accent {
    background-color: var(--color-mint);
}

.cta-strip__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
}

.cta-strip__title {
    font-size: var(--fs-heading);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 1;
}

.cta-strip__link {
    display: inline-flex;
    align-items: baseline;
    gap: 0.75rem;
    font-size: var(--fs-sm);
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
    line-height: 1;
    transition: gap 0.2s;
}

.cta-strip__link:hover {
    gap: 1.25rem;
}

.cta-strip__link-text {
    text-decoration: underline;
}

.cta-strip__link-arrow {
    font-size: var(--fs-xl);
    line-height: 1;
}

@media (max-width: 768px) {
    .cta-strip__inner {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }
}


/* ============================================================
   PRODUCT GRID (hardcoded nel template prodotto)
============================================================ */
.product-grid {
    padding: var(--spacing-lg) var(--container-pad);
}

.product-grid__inner {
    max-width: var(--container-max);
    margin: 0 auto;
}

.product-grid__header {
    margin-bottom: var(--spacing-lg);
}

.product-grid__title {
    font-size: var(--fs-heading);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 1;
    text-align: center;
}

.product-grid__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-lg) var(--spacing-md);
}

.product-grid__link {
    display: block;
}

.product-grid__media {
    overflow: hidden;
    margin-bottom: var(--spacing-sm);
}

.product-grid__image {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.product-grid__link:hover .product-grid__image {
    transform: scale(1.03);
}

.product-grid__name {
    font-size: var(--fs-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.25rem;
}

.product-grid__specs {
    font-size: var(--fs-sm);
    color: var(--color-grey);
}

@media (max-width: 768px) {
    .product-grid__list {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }
}