.nsi-hero.nsi-hero--technology {
    --hero-image: url('../res/tech.jpg');
}

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

.nsi-hero.nsi-hero--technology .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;
}

main.nsi-technology {
    min-height: unset;
    padding: var(--spacing-2xl) 0;
}

.nsi-technology-tools {
    margin: var(--spacing-2xl) 0;
}

.nsi-technology-tools__header {
    text-align: center;
    max-width: 70ch;
    margin: 0 auto var(--spacing-xl);
}

.nsi-technology-tools__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-technology-tools__subtitle {
    margin: var(--spacing-sm) 0 0 0;
    color: var(--color-text-secondary);
}

.nsi-technology-tools__stack {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.nsi-tool-card {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-divider);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-md);
    overflow: hidden;
    display: grid;
    /* Media column narrower than text column */
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
    grid-template-areas: "media content";
}

.nsi-tool-card--reverse {
    /* Swap columns so the TEXT column stays the wider one */
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    grid-template-areas: "content media";
}

.nsi-tool-card__media {
    grid-area: media;
    background: var(--color-bg-secondary);
    border-right: 1px solid var(--color-divider);
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
}

.nsi-tool-card__img {
    width: 100%;
    height: 100%;
    max-width: 560px;
    max-height: 320px;
    object-fit: contain;
    border-radius: var(--radius-lg);
    display: block;
}

.nsi-tool-card--reverse .nsi-tool-card__media {
    border-right: 0;
    border-left: 1px solid var(--color-divider);
}

.nsi-tool-card__placeholder {
    width: min(520px, 92%);
    aspect-ratio: 16 / 9;
    border-radius: var(--radius-lg);
    border: 2px dashed var(--color-border);
    background: var(--color-bg-primary);
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--font-weight-semibold);
}

.nsi-tool-card__content {
    grid-area: content;
    padding: clamp(1.25rem, 3vw, 2rem);
}

.nsi-tool-card__title {
    margin: 0;
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
}

.nsi-tool-card__desc {
    margin: var(--spacing-sm) 0 0 0;
    color: var(--color-text-secondary);
    line-height: 1.6;
}

.nsi-tool-card__detail {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-divider);
}

.nsi-tool-card__detail-title {
    margin: 0;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.nsi-tool-card__detail-body {
    margin: var(--spacing-sm) 0 0 0;
    color: var(--color-text-secondary);
}

.nsi-tool-card__actions {
    margin-top: var(--spacing-md);
    display: flex;
    justify-content: flex-end;
}

.nsi-tool-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 0.95rem;
    border-radius: 999px;
    text-decoration: none;
    font-weight: var(--font-weight-semibold);
    color: var(--color-bg-primary);
    background: var(--color-accent);
}

.nsi-tool-card__cta:hover,
.nsi-tool-card__cta:focus-visible {
    text-decoration: none;
    filter: brightness(0.95);
}

@media (max-width: 900px) {
    .nsi-tool-card {
        grid-template-columns: 1fr;
        grid-template-areas:
            "media"
            "content";
    }

    .nsi-tool-card__media {
        border-left: 0;
        border-right: 0;
        border-bottom: 1px solid var(--color-divider);
    }
}

/* Full-width banner (Smart Cities / Healthcare style) */
.nsi-technology__banner {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.nsi-technology__banner--custom {
    margin-top: var(--spacing-2xl);
    margin-bottom: var(--spacing-lg);
}

.nsi-technology__banner--custom .nsi-technology__banner_div {
    padding: var(--spacing-2xl) 0;
}

.nsi-technology__banner--custom .nsi-banner-row {
    display: grid;
    grid-template-columns: 2fr 1fr;
    align-items: center;
    column-gap: var(--spacing-xl);
    row-gap: var(--spacing-md);
}

.nsi-technology__banner--custom .nsi-banner-text {
    min-width: 260px;
    text-align: left;
}

.nsi-technology__banner--custom .nsi-banner-cta {
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    justify-self: end;
}

@media (max-width: 700px) {
    .nsi-technology__banner--custom .nsi-banner-row {
        grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
    }

    .nsi-technology__banner--custom .nsi-banner-text {
        text-align: center;
    }

    .nsi-technology__banner--custom .nsi-banner-cta {
        justify-self: center;
    }
}

.nsi-technology__banner_div {
    background-color: var(--color-primary);
    padding: var(--spacing-md);
    text-align: center;
    color: var(--color-bg-primary);
}

.nsi-technology__banner_div h1,
.nsi-technology__banner_div h2 {
    margin: 0;
    color: inherit;
}

.nsi-technology__banner_div p {
    margin: var(--spacing-xs) 0 0;
    color: inherit;
    opacity: 0.9;
}

/* Section divider (subtle rule + centered accent) */
.nsi-section--divider {
    position: relative;
}

.nsi-section--divider::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    background: var(--color-divider);
}

.nsi-section--divider::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
    width: 86px;
    height: 4px;
    border-radius: var(--radius-full);
    background: var(--color-primary);
}

/* Profile section (shared pattern from Smart Cities / Infrastructure / Healthcare) */
.nsi-technology__profile {
    padding: var(--spacing-2xl) 0;
    overflow-x: hidden;
}

.nsi-profile-card {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: var(--spacing-xl);
    align-items: center;

    background: var(--color-bg-primary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-xl);
}

.nsi-profile-card__media {
    width: 100%;
}

.nsi-profile-card__img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: var(--radius-lg);
    display: block;
}

.nsi-profile-card__kicker {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: var(--spacing-xs);
}

.nsi-profile-card__name {
    margin: 0;
    color: var(--color-text-primary);
    font-weight: var(--font-weight-bold);
    font-size: clamp(1.4rem, 2.2vw, 1.9rem);
    line-height: 1.1;
}

.nsi-profile-card__title {
    margin-top: var(--spacing-xs);
    color: var(--color-text-secondary);
    font-size: var(--font-size-lg);
}

.nsi-profile-card__contacts {
    margin-top: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.nsi-profile-contact {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--color-text-secondary);
    text-decoration: none;
}

.nsi-profile-contact i {
    color: var(--color-primary);
    font-size: 1.1rem;
    line-height: 1;
}

.nsi-profile-contact:hover {
    color: var(--color-text-primary);
}

@media (max-width: 900px) {
    .nsi-profile-card {
        grid-template-columns: 1fr;
    }

    .nsi-profile-card__img {
        max-width: 320px;
        margin: 0 auto;
    }

    .nsi-profile-card__body {
        text-align: center;
    }

    .nsi-profile-card__contacts {
        align-items: center;
    }
}

@media (max-width: 700px) {
    .nsi-technology__profile {
        padding: var(--spacing-lg) 0;
    }
}
