/* Explain: Layout helpers for editorial bridal spacing and grids */
.section-shell {
    width: min(100% - 2rem, 1180px);
    margin-inline: auto;
}

.section-padding {
    padding-block: clamp(4rem, 8vw, 8rem);
}

.hero-height {
    min-height: calc(100vh - 82px);
}

.editorial-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(280px, 1.1fr) minmax(0, 0.7fr);
    gap: clamp(1rem, 3vw, 2.5rem);
    align-items: center;
}

.collection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
}

.product-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: clamp(2rem, 5vw, 4.5rem);
    align-items: start;
}

@media (max-width: 900px) {
    .editorial-grid,
    .product-detail-grid {
        grid-template-columns: 1fr;
    }

    .hero-height {
        min-height: calc(100svh - 80px);
    }
}
