.nsi-hero.nsi-hero--services {
    --hero-image: url('../res/meet.webp');
}

/* Hero: match other sector pages (title + subtitle) */
.nsi-hero.nsi-hero--services .nsi-hero__inner {
    min-height: clamp(240px, 34vh, 330px) !important;
    flex-direction: column;
    gap: var(--spacing-md);
}

.nsi-hero.nsi-hero--services .nsi-hero__subtitle {
    margin: 0;
    color: var(--color-bg-primary);
    font-weight: var(--font-weight-medium);
    font-size: clamp(1.1rem, 2.2vw, 1.6rem);
    line-height: 1.25;
    max-width: 60ch;
    opacity: 0.95;
}

/* Keep the page focused and consistent with existing tiles */
main.nsi-all-services {
    min-height: unset;
    padding: var(--spacing-2xl) 0;
}

.nsi-all-services__header {
    text-align: center;
    max-width: 75ch;
    margin: 0 auto var(--spacing-xl);
}

.nsi-all-services__title {
    margin: 0;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.nsi-all-services__subtitle {
    margin: var(--spacing-sm) 0 0 0;
    color: var(--color-text-secondary);
}

/* Make the tiles feel like large “image buttons” */
.nsi-all-services__tiles .nsi-service-tile {
    min-height: clamp(240px, 24vw, 340px);
}

.nsi-all-services__tiles .nsi-service-tile__desc {
    margin: var(--spacing-sm) 0 0 0;
    max-width: 48ch;
    opacity: 0.92;
    line-height: 1.45;
}

@media (max-width: 700px) {
    main.nsi-all-services {
        padding: var(--spacing-xl) 0;
    }

    .nsi-all-services__header {
        margin-bottom: var(--spacing-lg);
    }
}
