/* ── Fix: first child uniform ── */

.s-block--banners {
    padding-bottom: 48px !important;
}

.s-block--banners .banner-entry:first-child {
    grid-row: auto !important;
    padding: 0 !important;
}

/* ── Grid gap ── */

.two-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-flow: row;
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .two-row {
          gap: 1.5rem;
    }
}

/* ── Each box: zero padding, image fills everything ── */

.banner-entry.square-photos {
    padding: 0 !important;
    border-radius: 20px !important;
    overflow: hidden !important;
    position: relative !important;
    background: #e8edf5 !important;
    border: none !important;
    box-shadow:
      0 4px 16px rgba(0, 0, 0, 0.10),
          0 1px 4px rgba(0, 0, 0, 0.06) !important;
    transition: transform 0.35s cubic-bezier(.34,1.56,.64,1), box-shadow 0.35s ease !important;
    cursor: pointer !important;
}

/* ── Image fills the entire box ── */

.banner-entry.square-photos .lazy__bg {
    height: 200px !important;
    width: 100% !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 0 !important;
    transition: transform 0.5s ease !important;
}

/* ── Gradient overlay at bottom for depth ── */

.banner-entry.square-photos::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 50%;
    background: linear-gradient(to top, rgba(0,0,0,0.28), transparent);
    border-radius: 0 0 20px 20px;
    pointer-events: none;
}

/* ── Hover: lift + deepen shadow + zoom image ── */

.banner-entry.square-photos:hover {
    transform: translateY(-8px) scale(1.03) !important;
    box-shadow:
      0 20px 48px rgba(0, 0, 0, 0.18),
          0 4px 12px rgba(0, 0, 0, 0.10) !important;
}

.banner-entry.square-photos:hover .lazy__bg {
    transform: scale(1.10) !important;
}

/* ── MOBILE FIX: 2 columns on small screens ── */

@media (max-width: 639px) {
    .two-row {
          grid-template-columns: repeat(2, 1fr) !important;
          gap: 0.75rem !important;
    }
    .banner-entry.square-photos {
          border-radius: 14px !important;
    }
    .banner-entry.square-photos .lazy__bg {
          height: 160px !important;
    }
}

/* ── Dark Mode: White icons and buttons in top nav bar ── */

body.color-mode-dark header svg,
body.color-mode-dark header button,
body.color-mode-dark header a,
body.color-mode-dark header i,
body.color-mode-dark .store-header svg,
body.color-mode-dark .store-header button,
body.color-mode-dark .store-header a,
body.color-mode-dark .store-header i,
body.color-mode-dark .main-nav-container svg,
body.color-mode-dark .main-nav-container button,
body.color-mode-dark .main-nav-container a,
body.color-mode-dark .main-nav-container i {
    color: #ffffff !important;
    fill: #ffffff !important;
    stroke: #ffffff !important;
}

/* — Top nav bar: full screen width — */
.store-header .main-nav-container,
.store-header .main-nav-container .inner,
.store-header .main-nav-container .container {
    max-width: 100% !important;
    width: 100% !important;
}
.store-header .main-nav-container .container {
    padding-left: 0 !important;
    padding-right: 0 !important;
}