:root {
    --color-navy: #062855;
    --color-navy-900: #031a39;
    --color-blue: #0b4ea2;
    --color-orange: #ff7900;
    --color-orange-dark: #d95f00;
    --color-white: #ffffff;
    --color-gray-50: #f7f9fc;
    --color-gray-100: #eef3f8;
    --color-gray-200: #dbe4ef;
    --color-gray-500: #64748b;
    --color-gray-700: #334155;
    --shadow-soft: 0 18px 45px rgba(8, 35, 74, 0.1);
    --shadow-card: 0 10px 26px rgba(8, 35, 74, 0.08);
    --radius: 8px;
    --container: 1280px;
}

/* Contact page */
.contact-page {
    color: var(--color-navy);
    background: var(--color-white);
}

.contact-page * {
    min-width: 0;
}

.contact-hero {
    color: var(--color-white);
    overflow: hidden;
    background:
        radial-gradient(circle at 30% 10%, rgba(20, 99, 203, 0.34), transparent 22rem),
        linear-gradient(90deg, #031631 0%, #062856 54%, #071b36 100%);
}

.contact-hero__grid {
    display: grid;
    grid-template-columns: minmax(360px, 0.82fr) minmax(460px, 1fr);
    min-height: clamp(360px, 29vw, 465px);
    align-items: stretch;
    gap: clamp(2rem, 4vw, 5rem);
}

.contact-hero__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(2.5rem, 4vw, 4.5rem) 0;
}

.contact-hero h1 {
    margin: 0;
    color: var(--color-white);
    font-size: clamp(2.7rem, 4vw, 4.6rem);
    font-weight: 900;
    line-height: 1;
}

.contact-hero__lead {
    margin: 0.6rem 0 0;
    color: var(--color-orange);
    font-size: clamp(1.55rem, 2.2vw, 2.65rem);
    font-weight: 900;
    line-height: 1.1;
}

.contact-hero__body {
    max-width: 620px;
    margin: 1.4rem 0 0;
    color: rgba(255, 255, 255, 0.9);
    font-size: clamp(0.95rem, 1.03vw, 1.12rem);
}

.contact-hero__items {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1rem, 2.4vw, 3rem);
    margin-top: clamp(2rem, 3vw, 3.4rem);
}

.contact-hero__items article span {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    margin-bottom: 0.7rem;
    color: var(--color-orange);
}

.contact-hero__items .icon {
    width: 2rem;
    height: 2rem;
}

.contact-hero__items h2 {
    margin: 0 0 0.35rem;
    color: var(--color-white);
    font-size: clamp(0.86rem, 0.98vw, 1.08rem);
    font-weight: 900;
}

.contact-hero__items p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: clamp(0.76rem, 0.82vw, 0.9rem);
    line-height: 1.45;
}

.contact-hero__image img {
    width: 100%;
    height: 100%;
    min-height: 360px;
    object-fit: cover;
    object-position: center;
}

.contact-main-section {
    padding: clamp(2rem, 3vw, 2.6rem) 0 1.2rem;
    background: #ffffff;
}

.contact-card {
    display: grid;
    grid-template-columns: minmax(420px, 1.12fr) minmax(320px, 0.88fr);
    gap: clamp(1.8rem, 4vw, 4.5rem);
    padding: clamp(1.6rem, 2.2vw, 2.3rem);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(8, 35, 74, 0.07);
}

.contact-form-panel {
    padding-right: clamp(1rem, 3vw, 3rem);
    border-right: 1px solid var(--color-gray-200);
}

.contact-form-panel h2,
.contact-direct-panel h2,
.contact-office-card h2,
.contact-process-intro h2,
.contact-bottom-cta h2 {
    position: relative;
    margin: 0 0 1rem;
    color: var(--color-navy);
    font-size: clamp(1.35rem, 1.6vw, 1.75rem);
    font-weight: 900;
}

.contact-form-panel h2::after,
.contact-direct-panel h2::after,
.contact-office-card h2::after,
.contact-process-intro h2::after {
    display: block;
    width: 42px;
    height: 2px;
    margin-top: 0.65rem;
    background: var(--color-orange);
    content: "";
}

.contact-form-panel > p {
    margin: 0 0 1.55rem;
    color: #2d4c71;
    font-size: 0.95rem;
}

.contact-page-form {
    display: grid;
    gap: 1rem;
}

.contact-page-form__row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.contact-page-form label {
    display: grid;
    gap: 0.35rem;
}

.contact-page-form label > span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
}

.contact-page-form input,
.contact-page-form select,
.contact-page-form textarea {
    width: 100%;
    min-height: 48px;
    padding: 0.85rem 1rem;
    color: var(--color-navy);
    background: #ffffff;
    border: 1px solid var(--color-gray-200);
    border-radius: 6px;
    outline: none;
    transition: border-color 160ms ease, box-shadow 160ms ease;
}

.contact-page-form textarea {
    min-height: 104px;
    resize: vertical;
}

.contact-page-form input:focus,
.contact-page-form select:focus,
.contact-page-form textarea:focus {
    border-color: var(--color-blue);
    box-shadow: 0 0 0 3px rgba(11, 78, 162, 0.12);
}

.contact-page-form .button {
    width: 100%;
}

.contact-form-note {
    display: flex;
    gap: 0.8rem;
    align-items: center;
    color: #4d6583;
    font-size: 0.78rem;
}

.contact-form-note .icon {
    width: 1.5rem;
    height: 1.5rem;
    color: #7a8ca3;
}

.contact-form-note p {
    margin: 0;
    line-height: 1.35;
}

.contact-form-note strong {
    color: var(--color-navy);
}

.contact-direct-list {
    display: grid;
}

.contact-direct-item {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 1.1rem;
    align-items: center;
    padding: 1.1rem 0;
    border-bottom: 1px solid var(--color-gray-200);
}

.contact-direct-item:last-child {
    border-bottom: 0;
}

.contact-direct-item > span {
    display: grid;
    place-items: center;
    width: 58px;
    height: 58px;
    color: var(--color-white);
    background: var(--color-navy);
    border-radius: 999px;
    box-shadow: 0 12px 25px rgba(6, 40, 85, 0.18);
}

.contact-direct-item .icon {
    width: 1.55rem;
    height: 1.55rem;
}

.contact-direct-item strong {
    display: block;
    color: var(--color-navy);
    font-size: 0.98rem;
    font-weight: 900;
}

.contact-direct-item p {
    margin: 0.12rem 0;
    color: var(--color-navy);
    font-size: clamp(1rem, 1.15vw, 1.18rem);
    font-weight: 800;
    line-height: 1.25;
}

.contact-direct-item small {
    color: #5d718c;
    font-size: 0.82rem;
}

.contact-map-section {
    position: relative;
    min-height: 295px;
    overflow: hidden;
    background: #eaf2fb url("/assets/images/contact/map-clean.png") center / cover no-repeat;
}

.contact-map-section iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    opacity: 0;
    pointer-events: none;
    filter: saturate(0.85) contrast(0.95);
}

.contact-map-section__inner {
    position: relative;
    z-index: 1;
    min-height: 295px;
    display: flex;
    align-items: center;
    pointer-events: none;
}

.contact-office-card {
    width: min(100%, 330px);
    padding: clamp(1.4rem, 2vw, 2rem);
    color: var(--color-white);
    background:
        radial-gradient(circle at 30% 10%, rgba(20, 99, 203, 0.28), transparent 12rem),
        linear-gradient(135deg, #031631 0%, #062856 100%);
    border-radius: 8px;
    box-shadow: 0 18px 38px rgba(8, 35, 74, 0.22);
    pointer-events: auto;
}

.contact-office-card h2 {
    color: var(--color-white);
}

.contact-office-card p {
    margin: 0 0 0.35rem;
    color: rgba(255, 255, 255, 0.88);
    line-height: 1.45;
}

.contact-office-card .button {
    margin-top: 1.1rem;
}

.contact-process-section {
    padding: clamp(2.5rem, 4vw, 4.5rem) 0;
    background: #ffffff;
}

.contact-process-grid {
    display: grid;
    grid-template-columns: minmax(260px, 0.95fr) repeat(4, minmax(130px, 1fr));
    gap: 0;
    align-items: center;
}

.contact-process-intro {
    padding-right: clamp(1rem, 3vw, 3rem);
}

.contact-process-intro p {
    max-width: 390px;
    margin: 0;
    color: #2d4c71;
    font-size: 0.92rem;
    line-height: 1.65;
}

.contact-process-item {
    min-height: 150px;
    padding: 0 clamp(1rem, 2vw, 2rem);
    border-left: 1px solid var(--color-gray-200);
    text-align: center;
}

.contact-process-item span {
    display: grid;
    place-items: center;
    width: 54px;
    height: 54px;
    margin: 0 auto 0.9rem;
    color: var(--color-navy);
}

.contact-process-item .icon {
    width: 2.5rem;
    height: 2.5rem;
}

.contact-process-item h3 {
    margin: 0 0 0.45rem;
    color: var(--color-navy);
    font-size: clamp(0.82rem, 0.9vw, 1rem);
    font-weight: 900;
}

.contact-process-item p {
    margin: 0;
    color: #2d4c71;
    font-size: clamp(0.74rem, 0.8vw, 0.88rem);
    line-height: 1.45;
}

.contact-bottom-cta {
    color: var(--color-white);
    background:
        linear-gradient(90deg, rgba(3, 22, 49, 0.97) 0%, rgba(6, 40, 86, 0.94) 48%, rgba(3, 22, 49, 0.82) 100%),
        url("/assets/images/development/benefits-team.png") center right / cover no-repeat,
        #031631;
}

.contact-bottom-cta__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(1.5rem, 4vw, 5rem);
    align-items: center;
    padding: clamp(2rem, 3.2vw, 3rem) 0;
}

.contact-bottom-cta h2 {
    color: var(--color-white);
    font-size: clamp(1.6rem, 2.3vw, 2.6rem);
}

.contact-bottom-cta p {
    max-width: 620px;
    margin: 0.4rem 0 0;
    color: rgba(255, 255, 255, 0.9);
    font-size: clamp(1rem, 1.35vw, 1.4rem);
}

.contact-bottom-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1.4rem;
    justify-content: flex-end;
}

.contact-bottom-cta__actions .button {
    min-width: 210px;
    text-transform: none;
}

@media (max-width: 1180px) {
    .contact-hero__grid,
    .contact-card,
    .contact-bottom-cta__grid {
        grid-template-columns: 1fr;
    }

    .contact-form-panel {
        padding-right: 0;
        border-right: 0;
    }

    .contact-process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.4rem;
    }

    .contact-process-intro {
        grid-column: 1 / -1;
        padding-right: 0;
    }

    .contact-process-item {
        border-left: 0;
        border-top: 1px solid var(--color-gray-200);
        padding-top: 1.4rem;
    }
}

@media (max-width: 780px) {
    .contact-hero__grid,
    .contact-page-form__row,
    .contact-hero__items,
    .contact-process-grid {
        grid-template-columns: 1fr;
    }

    .contact-hero__copy {
        padding-bottom: 1.4rem;
    }

    .contact-hero__image img {
        min-height: 240px;
        border-radius: 8px 8px 0 0;
    }

    .contact-card {
        padding: 1.2rem;
    }

    .contact-direct-item {
        grid-template-columns: 48px minmax(0, 1fr);
    }

    .contact-direct-item > span {
        width: 48px;
        height: 48px;
    }

    .contact-map-section__inner {
        align-items: flex-start;
        padding-top: 1rem;
    }

    .contact-bottom-cta__actions {
        justify-content: stretch;
        gap: 0.9rem;
    }

    .contact-bottom-cta__actions .button {
        width: 100%;
    }
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--color-navy);
    background: var(--color-gray-50);
    font-family: Arial, Helvetica, sans-serif;
    line-height: 1.6;
    overflow-x: hidden;
}

body.menu-open {
    overflow: hidden;
}

img {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea {
    font: inherit;
}

section {
    scroll-margin-top: 88px;
}

.container {
    width: min(calc(100% - 40px), var(--container));
    max-width: 100%;
    margin: 0 auto;
}

.icon {
    display: block;
    width: 1.35rem;
    height: 1.35rem;
    flex: 0 0 auto;
}

.eyebrow,
.section-heading__eyebrow {
    margin: 0 0 0.5rem;
    color: var(--color-orange);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: 44px;
    padding: 0.78rem 1.2rem;
    border: 1px solid transparent;
    border-radius: 6px;
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
    white-space: nowrap;
    transition: transform 160ms ease, box-shadow 160ms ease, background-color 160ms ease, border-color 160ms ease;
}

.button:hover,
.button:focus-visible {
    transform: translateY(-1px);
}

.button--primary {
    color: var(--color-white);
    background: var(--color-orange);
    box-shadow: 0 10px 20px rgba(255, 121, 0, 0.24);
}

.button--primary:hover,
.button--primary:focus-visible {
    background: var(--color-orange-dark);
}

.button--secondary {
    color: var(--color-navy);
    background: var(--color-white);
    border-color: rgba(6, 40, 85, 0.35);
}

.button--secondary:hover,
.button--secondary:focus-visible {
    border-color: var(--color-blue);
    box-shadow: 0 8px 18px rgba(8, 35, 74, 0.08);
}

.button--small {
    min-height: 38px;
    padding: 0.65rem 1rem;
    font-size: 0.75rem;
}

.button--whatsapp {
    width: 100%;
    color: var(--color-white);
    background: #19b35b;
}

.button--whatsapp:hover,
.button--whatsapp:focus-visible {
    background: #12944b;
}

.button--whatsapp .icon {
    width: 1.2rem;
    height: 1.2rem;
}

.text-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-top: auto;
    color: var(--color-blue);
    font-size: 0.84rem;
    font-weight: 800;
}

.text-link:hover,
.text-link:focus-visible {
    color: var(--color-orange);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(255, 255, 255, 0.96);
    border-bottom: 1px solid rgba(6, 40, 85, 0.08);
    box-shadow: 0 6px 24px rgba(6, 40, 85, 0.06);
}

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 78px;
    gap: 1rem;
    min-width: 0;
}

.site-header__brand {
    display: flex;
    align-items: center;
    gap: 1.1rem;
    min-width: 0;
    max-width: 44%;
}

.brand-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    color: var(--color-navy);
    flex: 0 0 auto;
}

.brand-logo__mark {
    display: grid;
    grid-template-columns: repeat(3, 30px);
    gap: 4px;
}

.brand-logo__mark span {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    color: var(--color-white);
    border-radius: 4px;
    font-size: 1.05rem;
    font-weight: 900;
    line-height: 1;
}

.brand-logo__mark span:nth-child(1),
.brand-logo__mark span:nth-child(3) {
    background: var(--color-orange);
}

.brand-logo__mark span:nth-child(2) {
    background: var(--color-blue);
}

.brand-logo__text {
    display: grid;
    gap: 0.05rem;
    line-height: 1;
    text-transform: uppercase;
}

.brand-logo__text strong {
    font-size: 0.95rem;
    letter-spacing: 0.04em;
}

.brand-logo__text small {
    color: var(--color-blue);
    font-size: 0.5rem;
    font-weight: 800;
    letter-spacing: 0.05em;
}

.brand-logo--light {
    color: var(--color-white);
}

.brand-logo--light .brand-logo__text small {
    color: #b7c8df;
}

.partner-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    color: var(--color-navy);
    font-size: 0.88rem;
    font-weight: 900;
    letter-spacing: -0.01em;
    white-space: nowrap;
}

.partner-badge__mark {
    width: 24px;
    height: 18px;
    background:
        linear-gradient(135deg, transparent 0 25%, var(--color-orange) 26% 42%, transparent 43%),
        linear-gradient(135deg, transparent 18%, var(--color-orange) 19% 36%, transparent 37%),
        linear-gradient(135deg, transparent 38%, var(--color-orange) 39% 56%, transparent 57%);
}

.partner-badge strong {
    color: var(--color-orange);
    font-size: 0.68rem;
    text-transform: uppercase;
}

.site-footer .partner-badge {
    color: var(--color-white);
}

.site-nav {
    display: flex;
    flex: 1 1 auto;
    align-items: center;
    justify-content: flex-end;
    gap: 0.9rem;
    margin-left: auto;
    min-width: 0;
}

.site-nav > a:not(.button) {
    position: relative;
    padding: 0.5rem 0;
    color: var(--color-navy);
    font-size: 0.75rem;
    font-weight: 800;
}

.site-nav > a:not(.button)::after {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    height: 2px;
    background: var(--color-orange);
    content: "";
    opacity: 0;
    transform: scaleX(0.5);
    transition: opacity 160ms ease, transform 160ms ease;
}

.site-nav > a:not(.button):hover::after,
.site-nav > a:not(.button):focus-visible::after {
    opacity: 1;
    transform: scaleX(1);
}

.menu-toggle {
    display: none;
    flex: 0 0 44px;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    gap: 4px;
    flex-direction: column;
    color: var(--color-navy);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 6px;
    cursor: pointer;
}

.menu-toggle span {
    width: 20px;
    height: 2px;
    background: currentColor;
    border-radius: 999px;
}

.hero-section {
    overflow: hidden;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.95) 0 40%, rgba(239, 245, 252, 0.7) 40% 100%),
        var(--color-gray-100);
}

.hero-section__grid {
    display: grid;
    grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
    min-height: 640px;
    align-items: center;
    gap: 2.5rem;
    padding: 4rem 0;
}

.hero-section__copy {
    position: relative;
    z-index: 2;
    min-width: 0;
}

.hero-section h1 {
    max-width: 620px;
    margin: 0;
    font-size: 3.35rem;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.08;
    text-transform: uppercase;
}

.hero-section h1 span {
    color: var(--color-orange);
}

.hero-section__copy > p:not(.eyebrow) {
    max-width: 560px;
    margin: 1.2rem 0 0;
    color: var(--color-gray-700);
    font-size: 1.08rem;
}

.hero-section__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    margin-top: 2rem;
}

.hero-section__media {
    position: relative;
    min-width: 0;
}

.hero-section__media img {
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    border: 1px solid rgba(6, 40, 85, 0.08);
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
}

.metrics-section {
    background: var(--color-white);
    border-top: 1px solid rgba(6, 40, 85, 0.06);
    border-bottom: 1px solid rgba(6, 40, 85, 0.06);
}

.metrics-section__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    padding: 1.35rem 0;
}

.metric-card {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    min-height: 76px;
    padding: 0.75rem;
}

.metric-card__icon {
    width: 2.2rem;
    height: 2.2rem;
    color: var(--color-navy);
}

.metric-card strong {
    display: block;
    color: var(--color-navy);
    font-size: 1.35rem;
    font-weight: 900;
    line-height: 1.1;
}

.metric-card span {
    display: block;
    color: var(--color-gray-700);
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1.2;
}

.section {
    padding: 4.8rem 0;
}

.section--white {
    background: var(--color-white);
}

.section--soft {
    background: linear-gradient(180deg, #f6f9fd 0%, #eef4fa 100%);
}

.section-heading {
    max-width: 760px;
    margin: 0 auto 2.2rem;
    text-align: center;
}

.section-heading--left {
    margin-right: 0;
    margin-left: 0;
    text-align: left;
}

.section-heading h2 {
    margin: 0;
    color: var(--color-navy);
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.15;
    text-transform: uppercase;
}

.section-heading p:not(.section-heading__eyebrow) {
    margin: 0.6rem 0 0;
    color: var(--color-gray-700);
    font-size: 1rem;
}

.service-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.3rem;
}

.service-card,
.software-card,
.solution-card {
    border: 1px solid rgba(6, 40, 85, 0.1);
    border-radius: var(--radius);
    background: var(--color-white);
    box-shadow: var(--shadow-card);
}

.service-card {
    display: flex;
    min-height: 248px;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.45rem;
}

.service-card__icon {
    display: grid;
    width: 58px;
    height: 58px;
    place-items: center;
    color: var(--color-white);
    background: var(--color-blue);
    border-radius: 50%;
}

.service-card:first-child .service-card__icon,
.service-card:nth-child(3) .service-card__icon,
.service-card:nth-child(5) .service-card__icon {
    color: var(--color-orange);
    background: #fff3e8;
}

.service-card__icon .icon {
    width: 2rem;
    height: 2rem;
}

.service-card h3,
.software-card h3,
.solution-card h3 {
    margin: 0;
    color: var(--color-navy);
    font-size: 0.95rem;
    font-weight: 900;
    line-height: 1.25;
    text-transform: uppercase;
}

.service-card p,
.software-card p,
.solution-card p {
    margin: 0;
    color: var(--color-gray-700);
    font-size: 0.88rem;
}

.microsip-section {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(360px, 1.25fr) minmax(240px, 0.8fr);
    align-items: center;
    gap: 2rem;
}

.microsip-section__copy h2 {
    margin: 0;
    color: var(--color-navy);
    font-size: 2rem;
    font-weight: 900;
    line-height: 1.15;
}

.microsip-section__copy > p {
    margin: 0.8rem 0 1.2rem;
    color: var(--color-gray-700);
}

.check-list {
    display: grid;
    gap: 0.52rem;
    margin: 0 0 1.5rem;
    padding: 0;
    list-style: none;
}

.check-list li {
    position: relative;
    padding-left: 1.35rem;
    color: var(--color-gray-700);
    font-size: 0.92rem;
    font-weight: 700;
}

.check-list li::before {
    position: absolute;
    left: 0;
    color: var(--color-orange);
    content: "✓";
    font-weight: 900;
}

.erp-orbit {
    display: grid;
    grid-template-columns: 1fr minmax(230px, 300px) 1fr;
    align-items: center;
    gap: 0.8rem;
    min-height: 370px;
}

.erp-orbit__modules {
    display: grid;
    gap: 1.05rem;
    color: var(--color-navy);
    font-size: 0.82rem;
    font-weight: 900;
}

.erp-orbit__modules--left {
    justify-items: end;
}

.erp-orbit__modules--right {
    justify-items: start;
}

.erp-orbit__modules span {
    position: relative;
    min-width: 106px;
}

.erp-orbit__center {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 300px;
}

.erp-orbit__ring {
    position: absolute;
    width: 250px;
    height: 250px;
    border: 1px dashed rgba(6, 40, 85, 0.32);
    border-radius: 50%;
}

.erp-orbit__node {
    position: absolute;
    display: grid;
    width: 48px;
    height: 48px;
    place-items: center;
    color: var(--color-blue);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 50%;
    box-shadow: var(--shadow-card);
}

.erp-orbit__node--top {
    top: -24px;
    left: calc(50% - 24px);
}

.erp-orbit__node--right {
    top: calc(50% - 24px);
    right: -24px;
}

.erp-orbit__node--bottom {
    bottom: -24px;
    left: calc(50% - 24px);
}

.erp-orbit__node--left {
    top: calc(50% - 24px);
    left: -24px;
}

.erp-orbit__logo {
    display: grid;
    width: 150px;
    height: 150px;
    place-items: center;
    color: var(--color-navy);
    background: var(--color-white);
    border-radius: 50%;
    box-shadow: var(--shadow-soft);
}

.erp-orbit__logo .icon {
    width: 3.2rem;
    height: 3.2rem;
    color: var(--color-orange);
}

.erp-orbit__logo strong {
    margin-top: -1.4rem;
    font-size: 1.25rem;
    font-weight: 900;
}

.microsip-section__cta {
    padding: 2rem;
    color: var(--color-white);
    background: linear-gradient(150deg, var(--color-navy) 0%, #0b3d7a 100%);
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
}

.microsip-section__cta h3 {
    margin: 0;
    font-size: 1.6rem;
    font-weight: 900;
    line-height: 1.18;
}

.microsip-section__cta p {
    margin: 1rem 0 1.4rem;
    color: #d9e5f5;
}

.software-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 1rem;
}

.software-card {
    min-height: 188px;
    padding: 1.25rem;
}

.software-card__icon {
    width: 2rem;
    height: 2rem;
    margin-bottom: 0.8rem;
    color: var(--color-blue);
}

.software-card h3 {
    min-height: 42px;
    margin-bottom: 0.65rem;
    font-size: 0.82rem;
}

.solution-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.4rem;
}

.solution-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.solution-card__heading {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.15rem 1.15rem 0.8rem;
}

.solution-card__icon {
    display: grid;
    width: 42px;
    height: 42px;
    place-items: center;
    color: var(--accent);
    background: color-mix(in srgb, var(--accent) 12%, white);
    border-radius: 8px;
}

.solution-card__image {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-block: 1px solid rgba(6, 40, 85, 0.08);
}

.solution-card p {
    padding: 1rem 1.15rem 0;
}

.solution-card .text-link {
    padding: 1rem 1.15rem 1.15rem;
}

.tech-section {
    padding: 3.2rem 0;
    color: var(--color-white);
    background: linear-gradient(135deg, var(--color-navy-900) 0%, var(--color-navy) 58%, #0b4b93 100%);
}

.tech-section .section-heading {
    margin-bottom: 1.6rem;
}

.tech-section .section-heading h2 {
    color: var(--color-white);
    font-size: 1.35rem;
}

.tech-section__badges {
    display: grid;
    grid-template-columns: repeat(10, minmax(0, 1fr));
    gap: 1rem;
}

.tech-badge {
    display: inline-flex;
    min-height: 58px;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.8rem 0.7rem;
    color: var(--color-white);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.06);
    font-size: 0.9rem;
    font-weight: 800;
    text-align: center;
}

.tech-badge__mark {
    display: grid;
    width: 28px;
    height: 28px;
    place-items: center;
    color: var(--color-orange);
    background: rgba(255, 255, 255, 0.12);
    border-radius: 6px;
    font-size: 0.85rem;
}

.about-contact-section {
    background: #f5f8fc;
}

.about-contact-section__grid {
    display: grid;
    grid-template-columns: 0.9fr 1.05fr 1fr;
    gap: 2rem;
    align-items: start;
}

.about-panel,
.team-panel,
.contact-panel {
    min-height: 100%;
}

.about-panel p {
    margin: 0 0 1.45rem;
    color: var(--color-gray-700);
}

.team-panel {
    text-align: center;
}

.team-panel h2 {
    margin: 0 0 1rem;
    color: var(--color-navy);
    font-size: 1.45rem;
    font-weight: 900;
    text-align: left;
    text-transform: uppercase;
}

.team-panel img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border: 1px solid rgba(6, 40, 85, 0.12);
    border-radius: var(--radius);
    box-shadow: var(--shadow-card);
}

.team-panel .button {
    margin-top: 1rem;
}

.contact-panel {
    padding-left: 1.4rem;
    border-left: 1px solid rgba(6, 40, 85, 0.12);
}

.contact-panel .section-heading {
    margin-bottom: 1rem;
}

.contact-panel__items {
    display: grid;
    gap: 0.8rem;
    margin-bottom: 1rem;
}

.contact-item {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.contact-item__icon {
    display: grid;
    width: 40px;
    height: 40px;
    place-items: center;
    color: var(--color-blue);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
}

.contact-item span:not(.contact-item__icon) {
    display: block;
    color: var(--color-gray-500);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.contact-item strong {
    display: block;
    color: var(--color-navy);
    font-size: 0.96rem;
}

.contact-form {
    display: grid;
    gap: 0.85rem;
    margin-top: 1rem;
}

.contact-form label {
    display: grid;
    gap: 0.32rem;
    color: var(--color-navy);
    font-size: 0.82rem;
    font-weight: 900;
    text-transform: uppercase;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    border: 1px solid var(--color-gray-200);
    border-radius: 6px;
    background: var(--color-white);
    color: var(--color-navy);
    font-size: 0.95rem;
    font-weight: 500;
    padding: 0.78rem 0.85rem;
    outline: none;
    text-transform: none;
}

.contact-form textarea {
    min-height: 122px;
    resize: vertical;
}

.contact-form input:focus,
.contact-form textarea:focus {
    border-color: var(--color-blue);
    box-shadow: 0 0 0 3px rgba(11, 78, 162, 0.12);
}

.form-success,
.form-errors {
    margin-top: 1rem;
    padding: 0.85rem 1rem;
    border-radius: 6px;
    font-size: 0.9rem;
    font-weight: 800;
}

.form-success {
    color: #0f6b3d;
    background: #e8f8ef;
    border: 1px solid #b7e8cb;
}

.form-errors {
    color: #9f1d1d;
    background: #fff0f0;
    border: 1px solid #f2c2c2;
}

.site-footer {
    padding: 3.2rem 0;
    color: var(--color-white);
    background: var(--color-navy-900);
}

.site-footer__grid {
    display: grid;
    grid-template-columns: 1.25fr 0.9fr 0.9fr 1fr;
    gap: 2rem;
}

.site-footer__brand,
.site-footer__partner {
    display: grid;
    align-content: start;
    gap: 1rem;
}

.site-footer p {
    max-width: 280px;
    margin: 0;
    color: #bfd0e6;
    font-size: 0.9rem;
}

.site-footer h2 {
    margin: 0 0 0.8rem;
    color: var(--color-white);
    font-size: 0.88rem;
    font-weight: 900;
    text-transform: uppercase;
}

.site-footer__links {
    display: grid;
    gap: 0.45rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.site-footer__links a {
    color: #bfd0e6;
    font-size: 0.9rem;
}

.site-footer__links a:hover,
.site-footer__links a:focus-visible {
    color: var(--color-white);
}

@media (max-width: 1140px) {
    .site-nav {
        gap: 0.72rem;
    }

    .site-nav > a:not(.button) {
        font-size: 0.72rem;
    }

    .service-grid,
    .software-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .microsip-section {
        grid-template-columns: 1fr;
    }

    .erp-orbit {
        max-width: 720px;
        margin: 0 auto;
    }

    .microsip-section__cta {
        max-width: 720px;
        margin: 0 auto;
    }

    .tech-section__badges {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .about-contact-section__grid {
        grid-template-columns: 1fr 1fr;
    }

    .contact-panel {
        grid-column: 1 / -1;
        padding: 1.6rem 0 0;
        border-top: 1px solid rgba(6, 40, 85, 0.12);
        border-left: 0;
    }
}

@media (max-width: 1180px) {
    .site-header__brand {
        max-width: calc(100% - 58px);
    }

    .menu-toggle {
        display: inline-flex;
        margin-left: auto;
    }

    .site-nav {
        position: fixed;
        top: 78px;
        right: 0;
        left: 0;
        display: none;
        max-height: calc(100vh - 78px);
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        overflow-y: auto;
        padding: 0.8rem 20px 1.2rem;
        background: var(--color-white);
        border-bottom: 1px solid var(--color-gray-200);
        box-shadow: 0 20px 35px rgba(6, 40, 85, 0.12);
    }

    .site-nav.is-open {
        display: flex;
    }

    .site-nav > a:not(.button) {
        padding: 0.9rem 0;
        font-size: 0.88rem;
        border-bottom: 1px solid var(--color-gray-100);
    }

    .site-nav .button {
        margin-top: 0.9rem;
    }

    .partner-badge {
        display: none;
    }

    .hero-section__grid {
        grid-template-columns: 1fr;
        min-height: auto;
        padding: 3.2rem 0;
    }

    .hero-section h1 {
        font-size: 2.65rem;
    }

    .metrics-section__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .solution-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .site-footer__grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 720px) {
    .container {
        width: min(calc(100% - 28px), var(--container));
    }

    .site-header__inner {
        min-height: 68px;
    }

    .site-nav {
        top: 68px;
        max-height: calc(100vh - 68px);
    }

    .brand-logo__mark {
        grid-template-columns: repeat(3, 26px);
    }

    .brand-logo__mark span {
        width: 26px;
        height: 26px;
        font-size: 0.92rem;
    }

    .brand-logo__text strong {
        font-size: 0.82rem;
    }

    .brand-logo__text small {
        font-size: 0.45rem;
    }

    .section {
        padding: 3.3rem 0;
    }

    .hero-section__grid {
        padding: 2.5rem 0;
    }

    .hero-section h1 {
        font-size: 2.1rem;
    }

    .hero-section__copy > p:not(.eyebrow) {
        font-size: 1rem;
    }

    .hero-section__actions {
        display: grid;
    }

    .metrics-section__grid,
    .service-grid,
    .software-grid,
    .solution-grid,
    .tech-section__badges,
    .about-contact-section__grid,
    .site-footer__grid {
        grid-template-columns: 1fr;
    }

    .metric-card {
        padding: 0.5rem 0;
    }

    .section-heading h2 {
        font-size: 1.55rem;
    }

    .erp-orbit {
        grid-template-columns: 1fr;
        min-height: auto;
        gap: 1.2rem;
    }

    .erp-orbit__modules {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        justify-items: stretch;
        order: 2;
    }

    .erp-orbit__modules span {
        min-width: 0;
        padding: 0.55rem 0.7rem;
        background: var(--color-white);
        border: 1px solid var(--color-gray-200);
        border-radius: 6px;
        text-align: center;
    }

    .erp-orbit__center {
        min-height: 280px;
        order: 1;
    }

    .erp-orbit__modules--right {
        order: 3;
    }

    .microsip-section__cta {
        padding: 1.5rem;
    }

    .microsip-section__cta h3 {
        font-size: 1.35rem;
    }
}

@media (max-width: 430px) {
    .brand-logo__text {
        display: none;
    }

    .hero-section h1 {
        font-size: 1.82rem;
    }

    .metrics-section__grid {
        gap: 0.2rem;
    }

    .metric-card strong {
        font-size: 1.15rem;
    }

    .service-card {
        min-height: auto;
    }

    .tech-badge {
        justify-content: flex-start;
    }
}

/* Reference mockup alignment */
:root {
    --container: 790px;
    --color-navy: #06265a;
    --color-blue: #0755a6;
    --color-orange: #ff7900;
}

.site-header {
    background: #ffffff;
    box-shadow: none;
}

.site-header__inner {
    min-height: 70px;
}

.brand-logo {
    align-items: flex-start;
    flex-direction: column;
    gap: 0.14rem;
}

.brand-logo__mark {
    grid-template-columns: repeat(3, 28px);
    gap: 4px;
}

.brand-logo__mark span {
    width: 28px;
    height: 28px;
    font-size: 1rem;
}

.brand-logo__text {
    gap: 0;
}

.brand-logo__text strong {
    font-size: 0.77rem;
    letter-spacing: 0.035em;
}

.brand-logo__text small {
    font-size: 0.38rem;
}

.partner-badge {
    font-size: 0.68rem;
}

.partner-badge strong {
    font-size: 0.48rem;
}

    .site-nav {
        gap: 0.95rem;
    }

    .site-nav > a:not(.button) {
        font-size: 0.54rem;
    }

.button {
    min-height: 28px;
    padding: 0.52rem 1rem;
    border-radius: 4px;
    font-size: 0.62rem;
}

.button--small {
    min-height: 28px;
    padding: 0.48rem 0.8rem;
    font-size: 0.58rem;
}

.hero-section {
    background: linear-gradient(90deg, #f7fbff 0 46%, #eef5fb 46% 100%);
}

.hero-section h1,
.section-heading h2,
.microsip-section__copy h2,
.team-panel h2 {
    letter-spacing: 0;
}

.metrics-section {
    position: relative;
    z-index: 2;
}

.metric-card__icon-img,
.software-card__icon-img {
    object-fit: contain;
}

.service-card__icon img,
.solution-card__icon img {
    display: block;
    max-width: 100%;
    height: auto;
}

.tech-section .section-heading,
.tech-section__badges {
    display: none;
}

.tech-section {
    padding: 0;
    background: #001f4d;
}

.tech-section .container {
    width: 100%;
    max-width: none;
}

.tech-section__strip {
    width: 100%;
    min-height: 88px;
    object-fit: cover;
}

@media (min-width: 781px) {
    .container {
        width: min(calc(100% - 78px), var(--container));
    }

    .menu-toggle {
        display: none;
    }

    .site-header__brand {
        max-width: none;
        flex: 0 0 315px;
        gap: 1.3rem;
    }

    .site-nav {
        position: static;
        display: flex;
        max-height: none;
        flex: 1 1 auto;
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        overflow: visible;
        padding: 0;
        background: transparent;
        border: 0;
        box-shadow: none;
    }

    .site-nav > a:not(.button) {
        padding: 0.8rem 0;
        border-bottom: 0;
    }

    .partner-badge {
        display: inline-flex;
    }

    .hero-section__grid {
        grid-template-columns: 355px minmax(0, 1fr);
        min-height: 320px;
        align-items: stretch;
        gap: 0;
        padding: 0;
    }

    .hero-section__copy {
        padding-top: 52px;
        padding-left: 5px;
    }

    .eyebrow {
        display: none;
    }

    .hero-section h1 {
        max-width: 340px;
        font-size: 1.8rem;
        line-height: 1.18;
    }

    .hero-section__copy > p:not(.eyebrow) {
        max-width: 330px;
        margin-top: 1rem;
        font-size: 0.78rem;
        line-height: 1.55;
    }

    .hero-section__actions {
        gap: 1rem;
        margin-top: 1.15rem;
    }

    .hero-section__media img {
        width: 100%;
        height: 320px;
        border: 0;
        border-radius: 0;
        box-shadow: none;
        object-fit: cover;
    }

    .metrics-section {
        margin-top: -60px;
        background: transparent;
        border: 0;
    }

    .metrics-section__grid {
        grid-template-columns: repeat(4, 82px);
        justify-content: flex-start;
        gap: 0.55rem;
        padding: 0 0 22px 4px;
    }

    .metric-card {
        width: 82px;
        min-height: 42px;
        gap: 0.45rem;
        padding: 0;
    }

    .metric-card__icon {
        width: 26px;
        height: 28px;
    }

    .metric-card strong {
        font-size: 1rem;
    }

    .metric-card span {
        max-width: 48px;
        font-size: 0.48rem;
        line-height: 1.05;
    }

    .section {
        padding: 25px 0;
    }

    .section-heading {
        margin-bottom: 1.35rem;
    }

    .section-heading h2 {
        font-size: 1.03rem;
    }

    .section-heading p:not(.section-heading__eyebrow) {
        margin-top: 0.25rem;
        font-size: 0.58rem;
    }

    .service-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 1rem;
    }

    .service-card {
        min-height: 149px;
        gap: 0.55rem;
        padding: 1rem 1rem 0.85rem;
    }

    .service-card__icon,
    .service-card:first-child .service-card__icon,
    .service-card:nth-child(3) .service-card__icon,
    .service-card:nth-child(5) .service-card__icon {
        width: 58px;
        height: 42px;
        place-items: start;
        background: transparent;
        color: inherit;
        border-radius: 0;
    }

    .service-card__icon img {
        max-height: 58px;
        object-fit: contain;
    }

    .service-card h3,
    .software-card h3,
    .solution-card h3 {
        font-size: 0.54rem;
    }

    .service-card p,
    .software-card p,
    .solution-card p {
        font-size: 0.53rem;
        line-height: 1.55;
    }

    .text-link {
        gap: 0.35rem;
        font-size: 0.55rem;
    }

    .microsip-section {
        grid-template-columns: 210px minmax(0, 1fr) 180px;
        gap: 1.35rem;
        min-height: 206px;
    }

    .section-heading__eyebrow {
        margin-bottom: 0.2rem;
        font-size: 0.76rem;
    }

    .microsip-section__copy h2 {
        font-size: 1.15rem;
    }

    .microsip-section__copy > p {
        display: none;
    }

    .check-list {
        gap: 0.25rem;
        margin-bottom: 0.75rem;
    }

    .check-list li {
        padding-left: 0.95rem;
        font-size: 0.55rem;
    }

    .erp-orbit {
        grid-template-columns: 72px 190px 82px;
        min-height: 205px;
        gap: 0.35rem;
    }

    .erp-orbit__modules {
        gap: 0.7rem;
        font-size: 0.5rem;
    }

    .erp-orbit__modules span {
        min-width: 66px;
    }

    .erp-orbit__center {
        min-height: 195px;
    }

    .erp-orbit__ring {
        width: 178px;
        height: 178px;
    }

    .erp-orbit__node {
        width: 36px;
        height: 36px;
    }

    .erp-orbit__node--top,
    .erp-orbit__node--bottom {
        left: calc(50% - 18px);
    }

    .erp-orbit__node--top {
        top: -18px;
    }

    .erp-orbit__node--bottom {
        bottom: -18px;
    }

    .erp-orbit__node--right {
        right: -18px;
    }

    .erp-orbit__node--left {
        left: -18px;
    }

    .erp-orbit__logo {
        width: 100px;
        height: 100px;
    }

    .erp-orbit__logo .icon {
        width: 2.15rem;
        height: 2.15rem;
    }

    .erp-orbit__logo strong {
        margin-top: -0.95rem;
        font-size: 0.9rem;
    }

    .microsip-section__cta {
        padding: 1.45rem 1.2rem;
    }

    .microsip-section__cta h3 {
        font-size: 1rem;
    }

    .microsip-section__cta p {
        margin: 0.65rem 0 1rem;
        font-size: 0.65rem;
    }

    .software-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
        gap: 0.9rem;
    }

    .software-card {
        min-height: 96px;
        padding: 0.8rem 0.75rem;
    }

    .software-card__icon {
        width: 23px;
        height: 25px;
        margin-bottom: 0.45rem;
    }

    .software-card h3 {
        min-height: 20px;
        margin-bottom: 0.35rem;
    }

    .solution-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 1rem;
    }

    .solution-card:nth-child(n + 5) {
        display: none;
    }

    .solution-card__heading {
        gap: 0.5rem;
        padding: 0.85rem 0.85rem 0.35rem;
    }

    .solution-card__icon {
        width: 28px;
        height: 28px;
        background: transparent;
        border-radius: 0;
    }

    .solution-card__image {
        width: calc(100% - 1.7rem);
        margin: 0 auto;
        aspect-ratio: 163 / 55;
        border: 0;
        object-fit: cover;
    }

    .solution-card p {
        padding: 0.7rem 0.85rem 0;
    }

    .solution-card .text-link {
        padding: 0.6rem 0.85rem 0.85rem;
    }

    .about-contact-section {
        padding: 27px 0;
    }

    .about-contact-section__grid {
        grid-template-columns: 245px 300px 1fr;
        gap: 1.45rem;
    }

    .about-panel p {
        margin-bottom: 1rem;
        font-size: 0.62rem;
        line-height: 1.8;
    }

    .team-panel h2 {
        margin-bottom: 0.7rem;
        font-size: 0.95rem;
    }

    .team-panel img {
        aspect-ratio: 255 / 84;
        object-fit: cover;
    }

    .contact-panel {
        grid-column: auto;
        padding-left: 1.35rem;
        padding-top: 0;
        border-top: 0;
        border-left: 1px solid rgba(6, 40, 85, 0.12);
    }

    .contact-item {
        gap: 0.65rem;
    }

    .contact-item__icon {
        width: 22px;
        height: 22px;
        background: transparent;
        border: 0;
    }

    .contact-item strong {
        font-size: 0.62rem;
    }

    .contact-item span:not(.contact-item__icon) {
        display: none;
    }

    .button--whatsapp {
        width: auto;
        min-height: 30px;
        margin-top: 0.75rem;
        padding-inline: 0.9rem;
        font-size: 0.56rem;
    }

    .contact-form {
        display: none;
    }

    .site-footer {
        padding: 34px 0 36px;
    }

    .site-footer__grid {
        grid-template-columns: 185px 230px 1fr 160px;
        gap: 1.4rem;
    }

    .site-footer p,
    .site-footer__links a {
        font-size: 0.58rem;
    }

    .site-footer h2 {
        font-size: 0.62rem;
    }
}

@media (max-width: 780px) {
    .site-header__inner {
        min-height: 68px;
    }

    .site-header__brand {
        max-width: calc(100% - 58px);
    }

    .menu-toggle {
        display: inline-flex;
        margin-left: auto;
    }

    .brand-logo__text {
        display: none;
    }

    .hero-section__grid {
        padding: 2.5rem 0 2rem;
        overflow: hidden;
    }

    .hero-section__media img {
        width: 100%;
        border-radius: 6px;
        box-shadow: var(--shadow-card);
    }

    .metrics-section {
        background: #ffffff;
    }

    .service-card__icon {
        background: transparent !important;
        color: inherit !important;
    }

    .service-card__icon img {
        max-height: 58px;
    }

    .tech-section__strip {
        width: 866px;
        max-width: none;
        transform: translateX(calc((100vw - 866px) / 2));
    }

    .contact-form {
        display: grid;
    }
}

/* Full-width responsive layout */
:root {
    --container: 1680px;
}

@media (min-width: 781px) {
    .container {
        width: min(calc(100% - clamp(48px, 6vw, 120px)), var(--container));
    }

    .site-header__inner {
        min-height: 72px;
    }

    .site-header__brand {
        flex: 0 0 auto;
        gap: clamp(1.2rem, 2vw, 2.3rem);
    }

    .site-nav {
        gap: clamp(0.8rem, 1.35vw, 1.6rem);
    }

    .site-nav > a:not(.button) {
        font-size: clamp(0.6rem, 0.72vw, 0.78rem);
    }

    .site-nav .button {
        margin-left: clamp(0.4rem, 1.2vw, 1.3rem);
    }

    .hero-section {
        background: linear-gradient(90deg, #f7fbff 0 46%, #eef5fb 46% 100%);
    }

    .hero-section__grid {
        grid-template-columns: minmax(360px, 0.82fr) minmax(520px, 1.18fr);
        min-height: clamp(430px, 32vw, 590px);
        align-items: center;
        gap: clamp(2rem, 4vw, 5.2rem);
        padding: clamp(2.2rem, 4vw, 4.4rem) 0;
    }

    .hero-section__copy {
        padding: 0;
    }

    .hero-section h1 {
        max-width: 640px;
        font-size: clamp(2.55rem, 3.4vw, 4.45rem);
        line-height: 1.12;
    }

    .hero-section__copy > p:not(.eyebrow) {
        max-width: 620px;
        font-size: clamp(0.95rem, 1vw, 1.18rem);
    }

    .hero-section__actions {
        margin-top: clamp(1.35rem, 1.8vw, 2rem);
    }

    .hero-section__media {
        align-self: stretch;
    }

    .hero-section__media img {
        width: 100%;
        height: 100%;
        min-height: 390px;
        object-fit: cover;
        border-radius: 0;
    }

    .metrics-section {
        margin-top: 0;
        background: #ffffff;
        border-top: 1px solid rgba(6, 40, 85, 0.06);
        border-bottom: 1px solid rgba(6, 40, 85, 0.06);
    }

    .metrics-section__grid {
        grid-template-columns: repeat(4, minmax(170px, 1fr));
        justify-content: stretch;
        gap: clamp(1rem, 2vw, 2.5rem);
        padding: 1.2rem 0;
    }

    .metric-card {
        width: auto;
        min-height: 64px;
        gap: 0.75rem;
        padding: 0;
    }

    .metric-card__icon {
        width: 2.1rem;
        height: 2.1rem;
    }

    .metric-card strong {
        font-size: clamp(1.15rem, 1.35vw, 1.55rem);
    }

    .metric-card span {
        max-width: 120px;
        font-size: 0.75rem;
        line-height: 1.15;
    }

    .section {
        padding: clamp(2.5rem, 4vw, 4.5rem) 0;
    }

    .section-heading h2 {
        font-size: clamp(1.35rem, 1.8vw, 2.1rem);
    }

    .service-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: clamp(1rem, 1.8vw, 2rem);
    }

    .service-card {
        min-height: 240px;
        padding: clamp(1.2rem, 1.6vw, 1.8rem);
    }

    .service-card h3,
    .software-card h3,
    .solution-card h3 {
        font-size: clamp(0.72rem, 0.85vw, 0.95rem);
    }

    .service-card p,
    .software-card p,
    .solution-card p {
        font-size: clamp(0.72rem, 0.8vw, 0.9rem);
    }

    .service-card__icon,
    .service-card:first-child .service-card__icon,
    .service-card:nth-child(3) .service-card__icon,
    .service-card:nth-child(5) .service-card__icon {
        width: 70px;
        height: 62px;
    }

    .microsip-section {
        grid-template-columns: minmax(250px, 0.85fr) minmax(430px, 1.35fr) minmax(260px, 0.8fr);
        gap: clamp(1.5rem, 3vw, 4rem);
    }

    .microsip-section__copy h2 {
        font-size: clamp(1.45rem, 1.8vw, 2.1rem);
    }

    .check-list li {
        font-size: clamp(0.78rem, 0.8vw, 0.94rem);
    }

    .erp-orbit {
        grid-template-columns: minmax(90px, 0.55fr) minmax(250px, 320px) minmax(100px, 0.55fr);
        min-height: 320px;
    }

    .erp-orbit__ring {
        width: clamp(230px, 17vw, 305px);
        height: clamp(230px, 17vw, 305px);
    }

    .erp-orbit__logo {
        width: clamp(130px, 9vw, 165px);
        height: clamp(130px, 9vw, 165px);
    }

    .microsip-section__cta {
        padding: clamp(1.6rem, 2.2vw, 2.6rem);
    }

    .microsip-section__cta h3 {
        font-size: clamp(1.25rem, 1.7vw, 1.9rem);
    }

    .software-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
        gap: clamp(0.9rem, 1.4vw, 1.5rem);
    }

    .software-card {
        min-height: 165px;
        padding: clamp(1rem, 1.2vw, 1.35rem);
    }

    .solution-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: clamp(1rem, 1.7vw, 2rem);
    }

    .solution-card {
        min-height: 260px;
    }

    .solution-card__image {
        width: calc(100% - 2rem);
    }

    .about-contact-section__grid {
        grid-template-columns: minmax(260px, 0.9fr) minmax(360px, 1.15fr) minmax(260px, 0.85fr);
        gap: clamp(1.5rem, 3vw, 4rem);
    }

    .about-panel p {
        font-size: 0.9rem;
    }

    .team-panel h2 {
        font-size: 1.25rem;
    }

    .contact-item strong,
    .site-footer p,
    .site-footer__links a {
        font-size: 0.86rem;
    }

    .site-footer h2 {
        font-size: 0.86rem;
    }
}

@media (min-width: 781px) and (max-width: 1180px) {
    .hero-section__grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .hero-section__media img {
        height: auto;
        min-height: 0;
        border-radius: 8px;
    }

    .service-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .microsip-section,
    .about-contact-section__grid {
        grid-template-columns: 1fr;
    }

    .software-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .solution-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .contact-panel {
        padding-left: 0;
        border-left: 0;
    }
}

/* Balanced corporate header */
@media (min-width: 1181px) {
    .site-header__inner {
        display: grid;
        grid-template-columns: auto minmax(720px, 1fr);
        column-gap: clamp(2rem, 4vw, 5rem);
        min-height: 90px;
    }

    .site-header__brand {
        justify-self: start;
        flex: initial;
        gap: clamp(1.6rem, 2.4vw, 3rem);
    }

    .site-nav {
        width: 100%;
        margin-left: 0;
        justify-content: space-between;
        gap: clamp(0.75rem, 1.15vw, 1.45rem);
    }

    .site-nav > a:not(.button) {
        flex: 0 0 auto;
        text-align: center;
        font-size: clamp(0.72rem, 0.78vw, 0.9rem);
    }

    .site-nav .button {
        flex: 0 0 auto;
        margin-left: clamp(1rem, 2vw, 2.5rem);
        padding-inline: clamp(1.1rem, 1.6vw, 1.8rem);
    }
}

@media (min-width: 1181px) and (max-width: 1380px) {
    .site-header__inner {
        grid-template-columns: auto minmax(640px, 1fr);
        column-gap: 2rem;
    }

    .brand-logo__text {
        display: none;
    }

    .site-header__brand {
        gap: 1.2rem;
    }

    .site-nav > a:not(.button) {
        font-size: 0.72rem;
    }
}

@media (max-width: 1180px) {
    .site-header__inner {
        display: flex;
    }

    .menu-toggle {
        display: inline-flex;
        margin-left: auto;
    }

    .site-nav {
        position: fixed;
        top: 72px;
        right: 0;
        left: 0;
        display: none;
        max-height: calc(100vh - 72px);
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        overflow-y: auto;
        padding: 0.8rem 24px 1.2rem;
        background: #ffffff;
        border-bottom: 1px solid var(--color-gray-200);
        box-shadow: 0 20px 35px rgba(6, 40, 85, 0.12);
    }

    .site-nav.is-open {
        display: flex;
    }

    .site-nav > a:not(.button) {
        padding: 0.9rem 0;
        border-bottom: 1px solid var(--color-gray-100);
        font-size: 0.9rem;
        text-align: left;
    }

    .site-nav .button {
        margin-top: 0.9rem;
        margin-left: 0;
    }
}

/* Development page */
.site-nav > a.is-active:not(.button) {
    color: var(--color-orange);
}

.site-nav > a.is-active:not(.button)::after {
    opacity: 1;
    transform: scaleX(1);
}

.button--ghost-light {
    color: var(--color-white);
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.72);
}

.button--ghost-light:hover,
.button--ghost-light:focus-visible {
    color: var(--color-white);
    background: rgba(255, 255, 255, 0.14);
    border-color: var(--color-white);
}

.development-page {
    color: var(--color-navy);
    background: var(--color-white);
}

.development-page .button {
    min-height: 48px;
    text-transform: none;
}

.development-hero {
    color: var(--color-white);
    overflow: hidden;
    background:
        radial-gradient(circle at 74% 4%, rgba(20, 99, 203, 0.5), transparent 23rem),
        linear-gradient(115deg, #031631 0%, #061f45 46%, #03142c 100%);
}

.development-hero__grid {
    display: grid;
    grid-template-columns: minmax(320px, 0.82fr) minmax(520px, 1.18fr);
    align-items: center;
    gap: clamp(1.5rem, 3.2vw, 4.5rem);
    min-height: clamp(410px, 34vw, 545px);
    padding: clamp(2.6rem, 4.7vw, 5rem) 0 2rem;
}

.development-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: clamp(1.5rem, 2.8vw, 3rem);
    color: rgba(255, 255, 255, 0.78);
    font-size: clamp(0.78rem, 0.88vw, 0.94rem);
    font-weight: 700;
}

.development-breadcrumb a:hover,
.development-breadcrumb a:focus-visible {
    color: var(--color-orange);
}

.development-hero__copy {
    position: relative;
    z-index: 2;
    max-width: 620px;
}

.development-hero__copy h1 {
    margin: 0;
    color: var(--color-white);
    font-size: clamp(3rem, 5.2vw, 6rem);
    font-weight: 900;
    line-height: 0.96;
}

.development-hero__copy h1 span {
    color: var(--color-orange);
}

.development-hero__lead {
    max-width: 620px;
    margin: 1.1rem 0 0;
    color: var(--color-white);
    font-size: clamp(1.25rem, 1.65vw, 2rem);
    font-weight: 800;
    line-height: 1.25;
}

.development-hero__body {
    max-width: 590px;
    margin: 1rem 0 0;
    color: rgba(255, 255, 255, 0.84);
    font-size: clamp(0.95rem, 1vw, 1.12rem);
}

.development-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1.7rem;
}

.development-hero__visual {
    align-self: stretch;
    display: flex;
    align-items: center;
    min-width: 0;
}

.development-hero__visual img {
    width: 100%;
    height: clamp(300px, 26vw, 430px);
    object-fit: cover;
    object-position: center;
    border-radius: 0;
    box-shadow: -24px 22px 50px rgba(0, 0, 0, 0.2);
}

.development-hero__features {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    padding: 1.35rem 0 1.45rem;
    border-top: 1px solid rgba(255, 255, 255, 0.13);
}

.development-feature {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
    padding: 0.25rem clamp(1rem, 2vw, 2rem);
    border-right: 1px solid rgba(255, 255, 255, 0.13);
}

.development-feature:first-child {
    padding-left: 0;
}

.development-feature:last-child {
    padding-right: 0;
    border-right: 0;
}

.development-feature__icon {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    color: var(--color-white);
}

.development-feature:nth-child(4) .development-feature__icon {
    color: var(--color-orange);
}

.development-feature__icon .icon {
    width: 2rem;
    height: 2rem;
}

.development-feature h2 {
    margin: 0 0 0.3rem;
    color: var(--color-white);
    font-size: clamp(0.85rem, 0.92vw, 1rem);
    line-height: 1.25;
}

.development-feature p {
    margin: 0;
    color: rgba(255, 255, 255, 0.78);
    font-size: clamp(0.75rem, 0.82vw, 0.9rem);
    line-height: 1.45;
}

.development-section {
    padding: clamp(2.4rem, 4vw, 4.8rem) 0;
}

.development-section--platforms {
    background: var(--color-white);
}

.development-section__title {
    margin: 0 0 clamp(1.4rem, 2.4vw, 2.2rem);
    color: var(--color-navy);
    font-size: clamp(1.5rem, 2vw, 2.35rem);
    font-weight: 900;
    line-height: 1.14;
    text-align: center;
}

.development-platform-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(1rem, 1.5vw, 1.6rem);
}

.development-platform-card {
    display: flex;
    flex-direction: column;
    min-height: 400px;
    padding: clamp(1.25rem, 1.7vw, 1.75rem);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    box-shadow: 0 12px 35px rgba(8, 35, 74, 0.06);
}

.development-platform-card__heading {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin-bottom: 0.75rem;
}

.development-platform-card__heading span {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    color: var(--color-blue);
}

.development-platform-card__heading .icon {
    width: 1.75rem;
    height: 1.75rem;
}

.development-platform-card h3 {
    margin: 0;
    color: var(--color-navy);
    font-size: clamp(1rem, 1.06vw, 1.22rem);
    font-weight: 900;
    line-height: 1.2;
}

.development-platform-card p {
    margin: 0;
    color: var(--color-navy);
    font-size: clamp(0.84rem, 0.9vw, 0.98rem);
    line-height: 1.5;
}

.development-platform-card__image {
    display: grid;
    place-items: center;
    height: 150px;
    margin: 1.2rem 0 1rem;
}

.development-platform-card__image img {
    max-width: 92%;
    max-height: 132px;
    object-fit: contain;
}

.development-platform-card__tech {
    margin-top: auto !important;
    color: #173869 !important;
}

.development-platform-card__tech strong {
    display: block;
    margin-bottom: 0.25rem;
    color: var(--color-gray-500);
    font-weight: 700;
}

.development-tech-section {
    padding: 0 0 clamp(2.3rem, 3.4vw, 3.6rem);
    background: var(--color-white);
}

.development-tech-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: clamp(0.85rem, 1.6vw, 1.6rem);
    align-items: center;
}

.development-tech-list .tech-badge {
    justify-content: flex-start;
    min-height: 72px;
    gap: 0.75rem;
    padding: 0.9rem 1rem;
    color: var(--color-navy);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    box-shadow: 0 12px 30px rgba(8, 35, 74, 0.08);
    font-size: clamp(0.86rem, 0.92vw, 1rem);
    font-weight: 900;
    text-align: left;
}

.development-tech-list .tech-badge__mark {
    display: grid;
    place-items: center;
    width: 42px;
    min-width: 42px;
    height: 42px;
    color: var(--color-white);
    background: #ffffff;
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    box-shadow: 0 8px 20px rgba(8, 35, 74, 0.1);
}

.development-tech-list .tech-badge__mark img {
    width: 27px;
    height: 27px;
    object-fit: contain;
}

.development-tech-list .tech-badge__mark--stack {
    grid-template-columns: repeat(2, 1fr);
    gap: 2px;
    padding: 5px;
}

.development-tech-list .tech-badge__mark--stack img {
    width: 18px;
    height: 18px;
}

.development-tech-list .tech-badge--yellow .tech-badge__mark img {
    width: 32px;
}

.development-tech {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: 48px;
    color: var(--color-navy);
    font-size: clamp(0.88rem, 0.94vw, 1.05rem);
    font-weight: 800;
    white-space: nowrap;
}

.development-tech__mark {
    display: grid;
    place-items: center;
    min-width: 36px;
    height: 36px;
    padding: 0 0.35rem;
    color: var(--color-white);
    background: var(--color-blue);
    border-radius: 6px;
    font-size: 0.78rem;
    font-weight: 900;
}

.development-tech--red .development-tech__mark {
    background: #ef3f36;
}

.development-tech--blue .development-tech__mark {
    background: #1f7acb;
}

.development-tech--purple .development-tech__mark {
    background: #6b3fc6;
}

.development-tech--slate .development-tech__mark,
.development-tech--navy .development-tech__mark {
    background: var(--color-navy);
}

.development-tech--orange .development-tech__mark {
    background: var(--color-orange);
}

.development-tech--green .development-tech__mark {
    background: #169b58;
}

.development-tech--cyan .development-tech__mark {
    background: #2b91c6;
}

.development-process {
    background: linear-gradient(180deg, var(--color-gray-50), var(--color-white));
}

.development-process__list {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: clamp(0.9rem, 1.6vw, 1.5rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.development-process__item {
    position: relative;
    min-width: 0;
    padding-top: 0.15rem;
}

.development-process__item:not(:last-child)::after {
    position: absolute;
    top: 31px;
    left: calc(50% + 38px);
    width: calc(100% - 30px);
    height: 1px;
    background: #b8c5d5;
    content: "";
}

.development-process__icon {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    width: 62px;
    height: 62px;
    margin: 0 auto 1rem;
    color: var(--color-navy);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 999px;
    box-shadow: 0 9px 22px rgba(8, 35, 74, 0.08);
}

.development-process__icon .icon {
    width: 1.8rem;
    height: 1.8rem;
}

.development-process__item h3 {
    margin: 0 0 0.45rem;
    color: var(--color-navy);
    font-size: clamp(0.85rem, 0.95vw, 1.05rem);
    font-weight: 800;
    text-align: center;
}

.development-process__item p {
    margin: 0 auto;
    max-width: 180px;
    color: #1c3b67;
    font-size: clamp(0.76rem, 0.84vw, 0.9rem);
    line-height: 1.45;
    text-align: left;
}

.development-benefits {
    color: var(--color-white);
    background:
        radial-gradient(circle at 22% 30%, rgba(19, 91, 184, 0.42), transparent 23rem),
        linear-gradient(90deg, #031631 0%, #062856 48%, #041a38 100%);
    overflow: hidden;
}

.development-benefits__grid {
    display: grid;
    grid-template-columns: minmax(320px, 0.9fr) minmax(420px, 1.1fr);
    align-items: stretch;
    min-height: 255px;
}

.development-benefits__copy {
    align-self: center;
    padding: clamp(2rem, 3vw, 3.5rem) clamp(1rem, 3vw, 3rem) clamp(2rem, 3vw, 3.5rem) 0;
}

.development-benefits h2 {
    margin: 0 0 1.2rem;
    color: var(--color-white);
    font-size: clamp(1.45rem, 2vw, 2.25rem);
    font-weight: 900;
}

.development-benefits ul {
    display: grid;
    gap: 0.62rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.development-benefits li {
    position: relative;
    padding-left: 1.55rem;
    color: rgba(255, 255, 255, 0.9);
    font-size: clamp(0.9rem, 0.95vw, 1.05rem);
}

.development-benefits li::before {
    position: absolute;
    top: 0.15rem;
    left: 0;
    display: grid;
    place-items: center;
    width: 17px;
    height: 17px;
    color: #061f45;
    background: var(--color-orange);
    border-radius: 999px;
    content: "✓";
    font-size: 0.7rem;
    font-weight: 900;
    line-height: 1;
}

.development-benefits__image {
    min-width: 0;
}

.development-benefits__image img {
    width: 100%;
    height: 100%;
    min-height: 255px;
    object-fit: cover;
    object-position: center;
}

.development-industries {
    background: var(--color-white);
}

.development-industries__grid {
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: clamp(0.85rem, 1.6vw, 1.6rem);
}

.development-industry {
    display: grid;
    justify-items: center;
    align-content: start;
    gap: 0.65rem;
    min-height: 110px;
    color: var(--color-blue);
    text-align: center;
}

.development-industry span {
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
}

.development-industry .icon {
    width: 2rem;
    height: 2rem;
}

.development-industry h3 {
    margin: 0;
    color: var(--color-navy);
    font-size: clamp(0.76rem, 0.86vw, 0.95rem);
    font-weight: 800;
    line-height: 1.18;
}

.development-cta {
    color: var(--color-white);
    background:
        radial-gradient(circle at 75% 20%, rgba(20, 99, 203, 0.28), transparent 22rem),
        linear-gradient(90deg, #031631 0%, #062856 100%);
}

.development-cta__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(1.5rem, 4vw, 5rem);
    align-items: center;
    padding: clamp(2rem, 3.6vw, 3.4rem) 0;
}

.development-cta h2 {
    margin: 0 0 0.35rem;
    color: var(--color-white);
    font-size: clamp(1.75rem, 2.5vw, 3rem);
    font-weight: 900;
    line-height: 1.1;
}

.development-cta p {
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: clamp(1rem, 1.25vw, 1.45rem);
}

.development-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1.4rem;
    justify-content: flex-end;
}

.development-cta__actions .button {
    min-width: 210px;
}

.development-cta__actions .icon {
    width: 1.25rem;
    height: 1.25rem;
}

@media (min-width: 1480px) {
    .development-hero__grid {
        grid-template-columns: minmax(420px, 0.76fr) minmax(700px, 1.24fr);
    }

    .development-platform-card {
        min-height: 430px;
    }
}

@media (max-width: 1180px) {
    .development-hero__grid {
        grid-template-columns: 1fr;
        min-height: 0;
        padding-top: 2.5rem;
    }

    .development-hero__copy {
        max-width: 720px;
    }

    .development-hero__visual img {
        height: auto;
        min-height: 0;
    }

    .development-hero__features {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .development-feature:nth-child(2) {
        border-right: 0;
    }

    .development-feature:nth-child(n + 3) {
        padding-top: 1.2rem;
        border-top: 1px solid rgba(255, 255, 255, 0.13);
    }

    .development-platform-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .development-tech-list {
        grid-template-columns: repeat(5, minmax(120px, 1fr));
    }

    .development-process__list {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        row-gap: 2rem;
    }

    .development-process__item:nth-child(3)::after,
    .development-process__item:nth-child(6)::after {
        display: none;
    }

    .development-industries__grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 780px) {
    .development-page .button,
    .development-cta__actions .button {
        width: 100%;
        min-width: 0;
    }

    .development-hero__grid {
        gap: 1.6rem;
        padding-bottom: 1.5rem;
    }

    .development-hero__copy h1 {
        max-width: 100%;
        font-size: clamp(2.25rem, 10vw, 3rem);
    }

    .development-hero__lead {
        font-size: clamp(1.05rem, 5vw, 1.28rem);
    }

    .development-hero__actions {
        flex-direction: column;
    }

    .development-hero__features,
    .development-platform-grid,
    .development-benefits__grid,
    .development-cta__grid {
        grid-template-columns: 1fr;
    }

    .development-feature,
    .development-feature:first-child,
    .development-feature:last-child {
        padding: 1rem 0;
        border-right: 0;
        border-top: 1px solid rgba(255, 255, 255, 0.13);
    }

    .development-feature:first-child {
        border-top: 0;
    }

    .development-platform-card {
        min-height: 0;
    }

    .development-tech-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .development-tech {
        justify-content: flex-start;
        white-space: normal;
    }

    .development-process__list {
        grid-template-columns: 1fr;
    }

    .development-process__item {
        display: grid;
        grid-template-columns: 62px minmax(0, 1fr);
        column-gap: 1rem;
        align-items: start;
    }

    .development-process__item:not(:last-child)::after {
        top: 62px;
        bottom: -1.5rem;
        left: 31px;
        width: 1px;
        height: auto;
    }

    .development-process__icon {
        grid-row: span 2;
        margin: 0;
    }

    .development-process__item h3,
    .development-process__item p {
        max-width: none;
        text-align: left;
    }

    .development-benefits__copy {
        padding-right: 0;
    }

    .development-benefits__image img {
        min-height: 210px;
    }

    .development-industries__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .development-cta__actions {
        justify-content: stretch;
        gap: 0.9rem;
    }
}

@media (max-width: 440px) {
    .development-tech-list,
    .development-industries__grid {
        grid-template-columns: 1fr;
    }

    .development-industry {
        min-height: 86px;
    }
}

/* Polished technology showcase */
.tech-showcase {
    position: relative;
    padding: clamp(2.3rem, 4vw, 4rem) 0;
    color: var(--color-white);
    background:
        radial-gradient(circle at 18% 20%, rgba(255, 121, 0, 0.16), transparent 18rem),
        radial-gradient(circle at 82% 10%, rgba(30, 113, 210, 0.28), transparent 22rem),
        linear-gradient(135deg, #031631 0%, #062856 54%, #0a4486 100%);
    border-top: 1px solid rgba(6, 40, 85, 0.14);
    border-bottom: 1px solid rgba(6, 40, 85, 0.14);
}

.tech-showcase .container {
    width: min(calc(100% - clamp(32px, 6vw, 112px)), var(--container));
    max-width: var(--container);
}

.tech-showcase .section-heading {
    display: block;
    margin-bottom: clamp(1.3rem, 2.4vw, 2.2rem);
}

.tech-showcase .section-heading h2 {
    color: var(--color-white);
    font-size: clamp(1.25rem, 1.7vw, 2.1rem);
    letter-spacing: 0;
}

.tech-showcase .section-heading h2::after {
    background: var(--color-orange);
}

.tech-showcase__grid,
.tech-section.tech-showcase .tech-section__badges {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(138px, 1fr));
    gap: clamp(0.75rem, 1.3vw, 1.1rem);
}

.tech-showcase .tech-badge {
    justify-content: flex-start;
    min-height: 76px;
    gap: 0.75rem;
    padding: 0.95rem 1rem;
    color: var(--color-white);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.055));
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 8px;
    box-shadow: 0 16px 28px rgba(0, 0, 0, 0.16);
    font-size: clamp(0.86rem, 0.9vw, 1rem);
    font-weight: 900;
    text-align: left;
    backdrop-filter: blur(8px);
}

.tech-showcase .tech-badge__mark {
    display: grid;
    place-items: center;
    width: 42px;
    min-width: 42px;
    height: 42px;
    color: var(--color-white);
    background: var(--tech-color, var(--color-blue));
    border-radius: 8px;
    box-shadow: inset 0 -8px 14px rgba(0, 0, 0, 0.12);
    font-size: 0.78rem;
}

.tech-showcase .tech-badge__mark--logo {
    background: #ffffff;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.16);
}

.tech-showcase .tech-badge__mark img {
    width: 27px;
    height: 27px;
    object-fit: contain;
}

.tech-showcase .tech-badge__mark--stack {
    grid-template-columns: repeat(2, 1fr);
    gap: 2px;
    padding: 5px;
}

.tech-showcase .tech-badge__mark--stack img {
    width: 18px;
    height: 18px;
}

.tech-showcase .tech-badge--yellow .tech-badge__mark img {
    width: 32px;
}

.tech-showcase .tech-badge--github .tech-badge__mark img,
.tech-showcase .tech-badge--navy .tech-badge__mark img {
    width: 28px;
    height: 28px;
}

.tech-showcase .tech-badge--red {
    --tech-color: #ef4444;
}

.tech-showcase .tech-badge--blue {
    --tech-color: #1f7acb;
}

.tech-showcase .tech-badge--purple {
    --tech-color: #6b3fc6;
}

.tech-showcase .tech-badge--slate,
.tech-showcase .tech-badge--navy {
    --tech-color: #0b2c5f;
}

.tech-showcase .tech-badge--orange {
    --tech-color: var(--color-orange);
}

.tech-showcase .tech-badge--green {
    --tech-color: #169b58;
}

.tech-showcase .tech-badge--cyan {
    --tech-color: #2b91c6;
}

.tech-showcase .tech-badge--yellow {
    --tech-color: #d79a00;
}

.tech-showcase__grid + .tech-section__strip,
.tech-showcase .tech-section__strip {
    display: none;
}

@media (max-width: 780px) {
    .tech-showcase {
        padding: 2.4rem 0;
    }

    .tech-showcase__grid,
    .tech-section.tech-showcase .tech-section__badges {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tech-showcase .tech-badge {
        min-height: 68px;
        padding: 0.8rem;
    }
}

@media (max-width: 430px) {
    .tech-showcase__grid,
    .tech-section.tech-showcase .tech-section__badges {
        grid-template-columns: 1fr;
    }
}

/* About page */
.about-page {
    color: var(--color-navy);
    background: var(--color-white);
}

.about-page * {
    min-width: 0;
}

.about-hero {
    color: var(--color-white);
    overflow: hidden;
    background:
        radial-gradient(circle at 32% 14%, rgba(12, 85, 171, 0.32), transparent 20rem),
        linear-gradient(90deg, #031631 0%, #062856 56%, #0b2b54 100%);
}

.about-hero__grid {
    display: grid;
    grid-template-columns: minmax(380px, 0.86fr) minmax(420px, 1fr);
    min-height: clamp(430px, 33vw, 560px);
    align-items: stretch;
    gap: clamp(2rem, 4vw, 5.5rem);
}

.about-hero__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(2.3rem, 4vw, 4.5rem) 0;
}

.about-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: clamp(1.4rem, 2vw, 2.3rem);
    color: rgba(255, 255, 255, 0.82);
    font-size: clamp(0.8rem, 0.9vw, 0.95rem);
    font-weight: 700;
}

.about-breadcrumb a:hover,
.about-breadcrumb a:focus-visible {
    color: var(--color-orange);
}

.about-hero h1 {
    margin: 0;
    color: var(--color-white);
    font-size: clamp(3rem, 4.7vw, 5.2rem);
    font-weight: 900;
    line-height: 1;
}

.about-hero__lead {
    max-width: 680px;
    margin: 0.95rem 0 0;
    color: var(--color-white);
    font-size: clamp(1.3rem, 1.7vw, 2rem);
    font-weight: 900;
    line-height: 1.2;
}

.about-hero__lead span {
    color: var(--color-orange);
}

.about-hero__body {
    max-width: 650px;
    margin: 1.1rem 0 0;
    color: rgba(255, 255, 255, 0.9);
    font-size: clamp(0.94rem, 1vw, 1.08rem);
}

.about-hero__image {
    min-width: 0;
}

.about-hero__image img {
    width: 100%;
    height: 100%;
    min-height: 430px;
    object-fit: cover;
    object-position: center;
}

.about-pillars {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1rem, 2.4vw, 3rem);
    margin-top: clamp(1.8rem, 3vw, 3rem);
}

.about-pillar span {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    margin-bottom: 0.75rem;
    color: var(--color-orange);
}

.about-pillar .icon {
    width: 2rem;
    height: 2rem;
}

.about-pillar h2 {
    margin: 0 0 0.4rem;
    color: var(--color-white);
    font-size: clamp(1rem, 1.1vw, 1.22rem);
    font-weight: 900;
}

.about-pillar p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: clamp(0.75rem, 0.82vw, 0.9rem);
    line-height: 1.45;
}

.about-section {
    padding: clamp(2.6rem, 4.2vw, 5rem) 0;
    background: var(--color-white);
}

.about-section__title {
    position: relative;
    margin: 0 0 clamp(1.5rem, 2.5vw, 2.4rem);
    color: var(--color-navy);
    font-size: clamp(1.55rem, 2vw, 2.35rem);
    font-weight: 900;
    line-height: 1.15;
    text-align: center;
}

.about-section__title::after {
    display: block;
    width: 44px;
    height: 2px;
    margin: 0.7rem auto 0;
    background: var(--color-orange);
    content: "";
}

.about-section__title--left {
    text-align: left;
}

.about-section__title--left::after {
    margin-left: 0;
}

.about-section__subtitle {
    max-width: 850px;
    margin: -1.2rem auto 1.8rem;
    color: #183863;
    font-size: clamp(0.86rem, 0.95vw, 1rem);
    text-align: center;
}

.about-who__grid {
    display: grid;
    grid-template-columns: minmax(320px, 0.9fr) minmax(440px, 1fr);
    gap: clamp(2rem, 5vw, 6rem);
    align-items: center;
}

.about-who__copy {
    max-width: 690px;
}

.about-who__copy p {
    margin: 0 0 1.45rem;
    color: #1b3861;
    font-size: clamp(0.94rem, 1vw, 1.08rem);
    line-height: 1.75;
}

.about-process-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.4rem 1.8rem;
}

.about-process-card {
    text-align: center;
}

.about-process-card img {
    width: 100%;
    aspect-ratio: 2.05 / 1;
    object-fit: cover;
    border: 1px solid rgba(6, 40, 85, 0.14);
    border-radius: 5px;
    box-shadow: 0 12px 26px rgba(8, 35, 74, 0.08);
}

.about-process-card h3 {
    margin: 0.65rem 0 0;
    color: var(--color-navy);
    font-size: clamp(0.9rem, 0.95vw, 1.05rem);
    font-weight: 900;
}

.about-metrics {
    color: var(--color-white);
    background:
        radial-gradient(circle at 18% 15%, rgba(30, 113, 210, 0.28), transparent 20rem),
        linear-gradient(90deg, #031631 0%, #062856 55%, #071b36 100%);
}

.about-metrics__grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    min-height: 116px;
    align-items: center;
}

.about-metric {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    column-gap: 1rem;
    align-items: center;
    padding: 1.45rem clamp(0.8rem, 1.8vw, 2.2rem);
    border-right: 1px solid rgba(255, 255, 255, 0.14);
}

.about-metric:last-child {
    border-right: 0;
}

.about-metric span {
    grid-row: span 2;
    color: rgba(255, 255, 255, 0.78);
}

.about-metric .icon {
    width: 2.3rem;
    height: 2.3rem;
}

.about-metric strong {
    color: var(--color-white);
    font-size: clamp(1.5rem, 2vw, 2.25rem);
    font-weight: 900;
    line-height: 1;
}

.about-metric p {
    margin: 0.2rem 0 0;
    color: rgba(255, 255, 255, 0.86);
    font-size: clamp(0.76rem, 0.85vw, 0.95rem);
    line-height: 1.22;
}

.about-team {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.about-team__grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: clamp(1rem, 1.6vw, 1.7rem);
}

.about-role-card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 230px;
    padding: clamp(1.1rem, 1.4vw, 1.35rem);
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.98)),
        var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 7px;
    box-shadow: 0 14px 35px rgba(8, 35, 74, 0.07);
    text-align: left;
}

.about-role-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 3px;
    background: linear-gradient(90deg, var(--color-orange), rgba(0, 86, 179, 0.9));
}

.about-role-card__icon {
    display: grid;
    place-items: center;
    width: 54px;
    height: 54px;
    margin-bottom: 1rem;
    color: var(--color-orange);
    background: #fff4eb;
    border: 1px solid rgba(255, 111, 0, 0.18);
    border-radius: 8px;
}

.about-role-card__icon .icon {
    width: 1.85rem;
    height: 1.85rem;
}

.about-role-card h3 {
    margin: 0;
    color: var(--color-navy);
    font-size: clamp(0.92rem, 0.98vw, 1.08rem);
    font-weight: 900;
    line-height: 1.18;
}

.about-role-card p {
    margin: 0.55rem 0 1rem;
    color: #24476f;
    font-size: clamp(0.72rem, 0.78vw, 0.86rem);
    line-height: 1.55;
}

.about-role-card__tag {
    display: inline-flex;
    width: max-content;
    margin-top: auto;
    padding: 0.28rem 0.62rem;
    color: #06336d;
    background: rgba(0, 86, 179, 0.08);
    border: 1px solid rgba(0, 86, 179, 0.12);
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0;
}

.about-footer__social a {
    display: inline-grid;
    place-items: center;
    width: 18px;
    height: 18px;
    color: var(--color-white);
    background: var(--color-navy);
    border-radius: 3px;
    font-size: 0.68rem;
    font-weight: 900;
}

.about-team__button {
    display: flex;
    width: max-content;
    margin: clamp(1.2rem, 2vw, 1.8rem) auto 0;
}

.about-proof {
    padding-top: 0;
}

.about-proof__grid {
    display: grid;
    grid-template-columns: minmax(320px, 0.9fr) minmax(420px, 1fr);
    gap: clamp(2rem, 5vw, 6rem);
    align-items: start;
}

.about-reasons {
    display: grid;
    gap: 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.about-reasons li {
    display: flex;
    gap: 0.9rem;
    align-items: center;
    color: #1b3861;
    font-size: clamp(0.88rem, 0.95vw, 1.02rem);
}

.about-reasons .icon {
    width: 1.35rem;
    height: 1.35rem;
    color: var(--color-navy);
}

.about-cert-title {
    font-size: clamp(1.05rem, 1.3vw, 1.45rem);
}

.about-cert-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.about-cert-card {
    display: flex;
    min-height: 100px;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    padding: 1.1rem;
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    box-shadow: 0 12px 30px rgba(8, 35, 74, 0.06);
    text-align: center;
}

.about-cert-card .partner-badge {
    transform: scale(1.35);
}

.about-cert-card small {
    display: block;
    margin-left: 0.7rem;
    color: var(--color-gray-500);
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
}

.about-cert-card .icon {
    width: 2.1rem;
    height: 2.1rem;
    color: #b91c1c;
}

.about-cert-card strong {
    color: var(--color-navy);
    font-size: clamp(1rem, 1.25vw, 1.35rem);
    font-weight: 900;
    line-height: 1.05;
}

.about-cert-card img {
    width: 60px;
    height: 44px;
    object-fit: contain;
}

.about-ms-logo {
    display: grid;
    grid-template-columns: repeat(2, 18px);
    gap: 3px;
}

.about-ms-logo i {
    display: block;
    width: 18px;
    height: 18px;
}

.about-ms-logo i:nth-child(1) { background: #f35325; }
.about-ms-logo i:nth-child(2) { background: #81bc06; }
.about-ms-logo i:nth-child(3) { background: #05a6f0; }
.about-ms-logo i:nth-child(4) { background: #ffba08; }

.about-cta {
    color: var(--color-white);
    background:
        linear-gradient(90deg, rgba(3, 22, 49, 0.95), rgba(6, 40, 86, 0.92)),
        linear-gradient(90deg, #031631, #062856);
}

.about-cta__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(1.5rem, 4vw, 5rem);
    align-items: center;
    padding: clamp(1.7rem, 2.6vw, 2.5rem) 0;
}

.about-cta h2 {
    max-width: 720px;
    margin: 0;
    color: var(--color-white);
    font-size: clamp(1.45rem, 2.1vw, 2.45rem);
    font-weight: 900;
    line-height: 1.15;
}

.about-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: flex-end;
}

.about-cta__actions .button {
    min-width: 210px;
    text-transform: none;
}

.about-footer {
    color: var(--color-navy);
    background: #ffffff;
    border-top: 1px solid var(--color-gray-200);
}

.about-footer__grid {
    display: grid;
    grid-template-columns: minmax(230px, 0.8fr) minmax(260px, 1fr) minmax(240px, 0.75fr) minmax(220px, 0.7fr);
    gap: clamp(1.6rem, 4vw, 5rem);
    align-items: center;
    padding: clamp(2rem, 3.5vw, 3.6rem) 0 1.3rem;
}

.about-footer h2 {
    margin: 0 0 0.9rem;
    color: var(--color-navy);
    font-size: 0.9rem;
    font-weight: 900;
}

.about-footer__brand,
.about-footer__links,
.about-footer__contact {
    min-height: 150px;
    padding-right: clamp(1rem, 2.5vw, 3rem);
    border-right: 1px solid var(--color-gray-200);
}

.about-footer__brand p {
    max-width: 230px;
    margin: 1rem 0 1rem;
    color: #315070;
    font-size: 0.86rem;
    line-height: 1.55;
}

.about-footer__social {
    display: flex;
    gap: 0.65rem;
}

.about-footer__links div {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.4rem 2rem;
}

.about-footer__links a {
    color: #24476f;
    font-size: 0.82rem;
    font-weight: 700;
}

.about-footer__links a:hover,
.about-footer__links a:focus-visible {
    color: var(--color-orange);
}

.about-footer__contact p {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    margin: 0 0 0.75rem;
    color: #24476f;
    font-size: 0.86rem;
    font-weight: 700;
}

.about-footer__contact .icon {
    width: 1.1rem;
    height: 1.1rem;
    color: var(--color-navy);
}

.about-footer__partner {
    display: grid;
    place-items: center;
}

.about-footer__partner .partner-badge {
    transform: scale(1.5);
}

.about-footer__copyright {
    margin: 0;
    padding: 0 1rem 1rem;
    color: #315070;
    font-size: 0.8rem;
    font-weight: 700;
    text-align: center;
}

@media (max-width: 1180px) {
    .about-hero__grid,
    .about-who__grid,
    .about-proof__grid {
        grid-template-columns: 1fr;
    }

    .about-hero__image img {
        min-height: 340px;
        border-radius: 8px 8px 0 0;
    }

    .about-metrics__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .about-team__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .about-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .about-footer__links {
        border-right: 0;
    }
}

@media (max-width: 780px) {
    .about-hero {
        overflow: visible;
    }

    .about-hero__copy {
        padding-bottom: 1.4rem;
    }

    .about-hero h1 {
        font-size: clamp(2.55rem, 13vw, 3.4rem);
    }

    .about-hero__lead {
        font-size: clamp(1.25rem, 6vw, 1.55rem);
        overflow-wrap: anywhere;
    }

    .about-hero__body,
    .about-who__copy p {
        overflow-wrap: anywhere;
    }

    .about-pillars,
    .about-process-grid,
    .about-metrics__grid,
    .about-team__grid,
    .about-cert-grid,
    .about-cta__grid,
    .about-footer__grid {
        grid-template-columns: 1fr;
    }

    .about-pillar {
        display: grid;
        grid-template-columns: 44px minmax(0, 1fr);
        gap: 0 1rem;
    }

    .about-pillar span {
        grid-row: span 2;
        margin-bottom: 0;
    }

    .about-hero__image img {
        min-height: 280px;
    }

    .about-metric {
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    }

    .about-metric:last-child {
        border-bottom: 0;
    }

    .about-cta__actions {
        justify-content: stretch;
        gap: 0.9rem;
    }

    .about-cta__actions .button {
        width: 100%;
    }

    .about-footer__brand,
    .about-footer__links,
    .about-footer__contact {
        min-height: 0;
        padding-right: 0;
        border-right: 0;
    }
}

/* Contact page final responsive guards */
.contact-page .contact-card,
.contact-page .contact-hero__grid,
.contact-page .contact-bottom-cta__grid,
.contact-page .contact-page-form,
.contact-page .contact-page-form__row {
    max-width: 100%;
}

.contact-page .contact-form-panel,
.contact-page .contact-direct-panel,
.contact-page .contact-page-form label,
.contact-page .contact-page-form input,
.contact-page .contact-page-form select,
.contact-page .contact-page-form textarea {
    min-width: 0;
}

@media (max-width: 1180px) {
    .contact-page .contact-hero__grid,
    .contact-page .contact-card,
    .contact-page .contact-bottom-cta__grid {
        grid-template-columns: minmax(0, 1fr) !important;
    }
}

@media (max-width: 780px) {
    .contact-page .container {
        width: min(calc(100% - 28px), var(--container));
    }

    .contact-page .contact-hero__grid,
    .contact-page .contact-hero__items,
    .contact-page .contact-page-form__row,
    .contact-page .contact-process-grid {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .contact-page .contact-card {
        padding: 1.2rem;
    }

    .contact-page .contact-hero__body,
    .contact-page .contact-form-panel > p,
    .contact-page .contact-process-intro p {
        overflow-wrap: anywhere;
    }
}

/* Microsip modules page */
.microsip-page {
    color: var(--color-navy);
    background: #ffffff;
}

.microsip-page * {
    min-width: 0;
}

.page-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
    margin-bottom: clamp(2rem, 3vw, 3.4rem);
    color: #345476;
    font-size: 0.78rem;
    font-weight: 800;
}

.page-breadcrumb a:hover,
.page-breadcrumb a:focus-visible {
    color: var(--color-orange);
}

.microsip-hero {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.94) 43%, rgba(239, 246, 253, 0.86) 100%),
        radial-gradient(circle at 78% 18%, rgba(11, 78, 162, 0.12), transparent 24rem);
    border-bottom: 1px solid rgba(6, 40, 85, 0.08);
}

.microsip-hero__grid {
    display: grid;
    grid-template-columns: minmax(470px, 0.86fr) minmax(540px, 1.14fr);
    gap: clamp(2rem, 4vw, 5rem);
    align-items: stretch;
    min-height: clamp(390px, 30vw, 470px);
}

.microsip-hero__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(1.6rem, 3vw, 3rem) 0;
}

.microsip-hero h1 {
    margin: 0;
    color: var(--color-navy);
    font-size: clamp(2.8rem, 3.6vw, 3.65rem);
    font-weight: 900;
    line-height: 0.98;
}

.microsip-hero h1 span {
    display: block;
    color: #0755b8;
}

.microsip-hero__copy > p {
    max-width: 590px;
    margin: clamp(1.2rem, 2vw, 1.8rem) 0 0;
    color: #163b66;
    font-size: clamp(1rem, 1.15vw, 1.2rem);
    font-weight: 700;
    line-height: 1.55;
}

.microsip-hero__points {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    max-width: 720px;
    margin-top: clamp(1.4rem, 2vw, 2rem);
}

.microsip-hero__points article {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 0.45rem;
    align-items: center;
    color: #113761;
    font-size: clamp(0.72rem, 0.86vw, 0.88rem);
    font-weight: 800;
    line-height: 1.25;
}

.microsip-hero__points .icon {
    width: 1.25rem;
    height: 1.25rem;
    color: #0755b8;
}

.microsip-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1.3rem;
    margin-top: clamp(2rem, 3vw, 3.2rem);
}

.microsip-hero__actions .button {
    min-width: 190px;
}

.microsip-hero__visual {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    min-height: 100%;
}

.microsip-hero__visual img {
    width: min(100%, 920px);
    height: 100%;
    min-height: 360px;
    object-fit: cover;
    object-position: center;
}

.microsip-modules,
.microsip-process {
    padding: clamp(2.4rem, 4vw, 4.2rem) 0;
    background: #ffffff;
}

.microsip-section-heading {
    max-width: 900px;
    margin: 0 auto clamp(2rem, 3vw, 3rem);
    text-align: center;
}

.microsip-section-heading h2 {
    position: relative;
    margin: 0;
    color: var(--color-navy);
    font-size: clamp(1.65rem, 2.25vw, 2.3rem);
    font-weight: 900;
    line-height: 1.15;
}

.microsip-section-heading h2::after {
    display: block;
    width: 40px;
    height: 2px;
    margin: 0.75rem auto 0;
    background: var(--color-orange);
    content: "";
}

.microsip-section-heading p {
    margin: 0.8rem 0 0;
    color: #1f456d;
    font-size: clamp(0.9rem, 1vw, 1rem);
    font-weight: 700;
}

.microsip-modules__grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: clamp(1rem, 1.8vw, 1.4rem);
}

.microsip-module-card {
    display: flex;
    flex-direction: column;
    min-height: 255px;
    padding: clamp(1.35rem, 1.9vw, 1.8rem);
    background: #ffffff;
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    box-shadow: 0 12px 28px rgba(8, 35, 74, 0.05);
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.microsip-module-card:hover {
    transform: translateY(-3px);
    border-color: rgba(11, 78, 162, 0.22);
    box-shadow: 0 18px 36px rgba(8, 35, 74, 0.1);
}

.microsip-module-card__icon {
    display: grid;
    place-items: center;
    width: 54px;
    height: 54px;
    margin-bottom: 1.2rem;
}

.microsip-module-card__icon .icon {
    width: 2.8rem;
    height: 2.8rem;
}

.microsip-module-card h3 {
    margin: 0 0 0.7rem;
    color: var(--color-navy);
    font-size: clamp(1rem, 1.06vw, 1.18rem);
    font-weight: 900;
}

.microsip-module-card p {
    margin: 0 0 1.2rem;
    color: #1f3d62;
    font-size: clamp(0.84rem, 0.9vw, 0.96rem);
    line-height: 1.55;
}

.microsip-module-card--blue .microsip-module-card__icon,
.microsip-module-card--blue .text-link {
    color: #0b67d8;
}

.microsip-module-card--green .microsip-module-card__icon,
.microsip-module-card--green .text-link {
    color: #16a05c;
}

.microsip-module-card--orange .microsip-module-card__icon,
.microsip-module-card--orange .text-link {
    color: var(--color-orange);
}

.microsip-module-card--purple .microsip-module-card__icon,
.microsip-module-card--purple .text-link {
    color: #6744d9;
}

.microsip-module-card--cyan .microsip-module-card__icon,
.microsip-module-card--cyan .text-link {
    color: #0898c9;
}

.microsip-benefits {
    padding: clamp(2.1rem, 3.2vw, 3.2rem) 0;
    background: linear-gradient(180deg, #f8fbff 0%, #eef4fa 100%);
}

.microsip-benefits__grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 2.2rem);
    align-items: start;
}

.microsip-benefits__grid article {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr);
    gap: 0.75rem;
    align-items: center;
}

.microsip-benefits__grid .icon {
    width: 2rem;
    height: 2rem;
    color: #0b67d8;
}

.microsip-benefits__grid strong,
.microsip-benefits__grid span {
    display: block;
}

.microsip-benefits__grid strong {
    color: var(--color-navy);
    font-size: clamp(0.78rem, 0.86vw, 0.9rem);
    font-weight: 900;
    line-height: 1.2;
}

.microsip-benefits__grid span {
    color: #1f456d;
    font-size: clamp(0.72rem, 0.8vw, 0.86rem);
    font-weight: 700;
}

.microsip-process__grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: clamp(1.2rem, 3vw, 3.6rem);
    align-items: start;
}

.microsip-process-step {
    position: relative;
    text-align: center;
}

.microsip-process-step:not(:last-child)::after {
    position: absolute;
    top: 2.1rem;
    right: calc(-1 * clamp(1.6rem, 3vw, 3.8rem));
    color: #7186a2;
    font-size: 1.5rem;
    font-weight: 700;
    content: "→";
}

.microsip-process-step__icon {
    display: grid;
    place-items: center;
    width: 78px;
    height: 78px;
    margin: 0 auto 1rem;
    color: var(--color-navy);
    background: #ffffff;
    border: 1px solid var(--color-gray-200);
    border-radius: 999px;
    box-shadow: 0 12px 26px rgba(8, 35, 74, 0.07);
}

.microsip-process-step__icon .icon {
    width: 2.35rem;
    height: 2.35rem;
}

.microsip-process-step h3 {
    margin: 0 0 0.4rem;
    color: var(--color-navy);
    font-size: clamp(0.84rem, 0.95vw, 1rem);
    font-weight: 900;
}

.microsip-process-step p {
    max-width: 190px;
    margin: 0 auto;
    color: #2d4c71;
    font-size: clamp(0.72rem, 0.8vw, 0.86rem);
    line-height: 1.45;
}

.microsip-cta {
    color: #ffffff;
    background:
        radial-gradient(circle at 16% 40%, rgba(255, 255, 255, 0.15), transparent 14rem),
        linear-gradient(90deg, #0045b8 0%, #074db7 45%, #062856 100%);
}

.microsip-cta__grid {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr) auto;
    gap: clamp(1.2rem, 2.5vw, 3rem);
    align-items: center;
    padding: clamp(1.65rem, 2.6vw, 2.4rem) 0;
}

.microsip-cta__icon {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    color: #ffffff;
    border: 2px solid rgba(255, 255, 255, 0.74);
    border-radius: 8px;
}

.microsip-cta__icon .icon {
    width: 2rem;
    height: 2rem;
}

.microsip-cta h2 {
    margin: 0;
    color: #ffffff;
    font-size: clamp(1.45rem, 2vw, 2.2rem);
    font-weight: 900;
    line-height: 1.15;
}

.microsip-cta p {
    margin: 0.45rem 0 0;
    color: rgba(255, 255, 255, 0.9);
    font-size: clamp(0.95rem, 1.2vw, 1.25rem);
    font-weight: 700;
}

.microsip-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1.2rem;
    justify-content: flex-end;
}

.microsip-cta__actions .button {
    min-width: 220px;
    text-transform: none;
}

.microsip-footer {
    color: #ffffff;
    background:
        radial-gradient(circle at 72% 18%, rgba(11, 103, 216, 0.18), transparent 19rem),
        linear-gradient(90deg, #031631 0%, #062856 100%);
}

.microsip-footer__grid {
    display: grid;
    grid-template-columns: minmax(220px, 0.9fr) minmax(230px, 1.05fr) minmax(190px, 0.82fr) minmax(220px, 0.9fr) minmax(160px, 0.7fr);
    gap: clamp(1.4rem, 3vw, 3.5rem);
    padding: clamp(2rem, 3vw, 3rem) 0 1.2rem;
}

.microsip-footer__grid > * {
    min-height: 135px;
    padding-right: clamp(1rem, 2.2vw, 2.2rem);
    border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.microsip-footer__grid > *:last-child {
    padding-right: 0;
    border-right: 0;
}

.microsip-footer h2 {
    margin: 0 0 1rem;
    color: #ffffff;
    font-size: 0.9rem;
    font-weight: 900;
}

.microsip-footer p,
.microsip-footer li,
.microsip-footer a {
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.82rem;
    line-height: 1.6;
}

.microsip-footer__brand p {
    max-width: 260px;
    margin: 1rem 0 0;
}

.microsip-footer__social {
    display: flex;
    gap: 0.7rem;
    margin-top: 1.1rem;
}

.microsip-footer__social span {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    color: var(--color-navy);
    background: #ffffff;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 900;
}

.microsip-footer ul {
    columns: 2;
    gap: 2rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.microsip-footer__links:last-of-type ul {
    columns: 1;
}

.microsip-footer a:hover,
.microsip-footer a:focus-visible {
    color: #ffffff;
}

.microsip-footer__contact p {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    gap: 0.55rem;
    align-items: center;
    margin: 0 0 0.65rem;
}

.microsip-footer__contact .icon {
    width: 1rem;
    height: 1rem;
}

.microsip-footer__partner {
    display: grid;
    place-items: center;
}

.microsip-footer__partner .partner-badge {
    transform: scale(1.45);
}

.microsip-footer__copyright {
    margin: 0;
    padding: 0 1rem 1rem;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.8rem;
    font-weight: 700;
    text-align: center;
}

@media (max-width: 1280px) {
    .microsip-modules__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .microsip-benefits__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .microsip-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .microsip-footer__grid > * {
        min-height: 0;
        border-right: 0;
    }
}

@media (max-width: 1180px) {
    .microsip-hero__grid {
        grid-template-columns: minmax(0, 1fr);
        min-height: 0;
    }

    .microsip-hero__visual {
        justify-content: center;
    }

    .microsip-hero__visual img {
        width: 100%;
        min-height: 300px;
        border-radius: 8px 8px 0 0;
    }

    .microsip-process__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .microsip-process-step::after {
        display: none;
    }

    .microsip-cta__grid {
        grid-template-columns: 56px minmax(0, 1fr);
    }

    .microsip-cta__actions {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }
}

@media (max-width: 780px) {
    .microsip-page .container {
        width: min(calc(100% - 28px), var(--container));
    }

    .page-breadcrumb {
        margin-bottom: 1.8rem;
        font-size: 0.72rem;
    }

    .microsip-hero h1 {
        font-size: clamp(2.5rem, 13vw, 3.55rem);
    }

    .microsip-hero__points,
    .microsip-modules__grid,
    .microsip-benefits__grid,
    .microsip-process__grid,
    .microsip-cta__grid,
    .microsip-footer__grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .microsip-hero__actions,
    .microsip-cta__actions {
        gap: 0.9rem;
    }

    .microsip-hero__actions .button,
    .microsip-cta__actions .button {
        width: 100%;
    }

    .microsip-hero__visual img {
        min-height: 245px;
    }

    .microsip-module-card {
        min-height: 0;
    }

    .microsip-benefits__grid article {
        grid-template-columns: 34px minmax(0, 1fr);
    }

    .microsip-cta__actions {
        grid-column: auto;
    }

    .microsip-footer ul {
        columns: 1;
    }

    .microsip-footer__partner {
        place-items: start;
    }
}

/* AI and data page */
.ai-data-page {
    color: var(--color-navy);
    background: #ffffff;
}

.ai-data-page * {
    min-width: 0;
}

.ai-data-hero {
    overflow: hidden;
    color: #ffffff;
    background:
        radial-gradient(circle at 22% 20%, rgba(20, 99, 203, 0.28), transparent 23rem),
        radial-gradient(circle at 76% 46%, rgba(0, 133, 255, 0.16), transparent 20rem),
        linear-gradient(90deg, #031631 0%, #062856 52%, #031631 100%);
}

.ai-data-hero__grid {
    display: grid;
    grid-template-columns: minmax(450px, 0.95fr) minmax(520px, 1.05fr);
    gap: clamp(2rem, 4vw, 5rem);
    align-items: stretch;
    min-height: clamp(420px, 33vw, 500px);
}

.ai-data-hero__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(2.4rem, 4vw, 4rem) 0;
}

.ai-data-hero h1 {
    margin: 0;
    color: #ffffff;
    font-size: clamp(2.7rem, 4.1vw, 4.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.ai-data-hero h1 span {
    display: block;
    color: var(--color-orange);
}

.ai-data-hero__copy > p {
    max-width: 690px;
    margin: clamp(1.2rem, 2vw, 1.8rem) 0 0;
    color: rgba(255, 255, 255, 0.92);
    font-size: clamp(1rem, 1.14vw, 1.18rem);
    line-height: 1.65;
}

.ai-data-hero__points {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    margin-top: clamp(2rem, 3vw, 3rem);
}

.ai-data-hero__points article {
    min-height: 145px;
    padding: 0 clamp(1rem, 2vw, 1.8rem);
    border-right: 1px solid rgba(255, 255, 255, 0.28);
}

.ai-data-hero__points article:first-child {
    padding-left: 0;
}

.ai-data-hero__points article:last-child {
    border-right: 0;
}

.ai-data-hero__points span {
    display: grid;
    place-items: center;
    width: 48px;
    height: 48px;
    margin-bottom: 0.7rem;
    color: #ffffff;
}

.ai-data-hero__points .icon {
    width: 2.25rem;
    height: 2.25rem;
}

.ai-data-hero__points h2 {
    margin: 0 0 0.45rem;
    color: #ffffff;
    font-size: clamp(0.98rem, 1.08vw, 1.18rem);
    font-weight: 900;
    line-height: 1.18;
}

.ai-data-hero__points p {
    margin: 0;
    color: rgba(255, 255, 255, 0.86);
    font-size: clamp(0.78rem, 0.86vw, 0.92rem);
    line-height: 1.45;
}

.ai-data-hero__visual {
    display: flex;
    align-items: stretch;
    justify-content: flex-end;
}

.ai-data-hero__visual img {
    width: 100%;
    height: 100%;
    min-height: 420px;
    object-fit: cover;
    object-position: center;
}

.ai-data-tech,
.ai-data-case {
    padding: clamp(2.4rem, 4vw, 4.2rem) 0;
    background: #ffffff;
}

.ai-data-section-heading {
    max-width: 900px;
    margin: 0 auto clamp(2rem, 3vw, 3rem);
    text-align: center;
}

.ai-data-section-heading h2 {
    position: relative;
    margin: 0;
    color: var(--color-navy);
    font-size: clamp(1.65rem, 2.2vw, 2.3rem);
    font-weight: 900;
    line-height: 1.16;
}

.ai-data-section-heading h2::after {
    display: block;
    width: 40px;
    height: 2px;
    margin: 0.75rem auto 0;
    background: var(--color-orange);
    content: "";
}

.ai-data-section-heading--dark h2 {
    color: #ffffff;
}

.ai-data-tech__grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: clamp(1rem, 1.6vw, 1.4rem);
}

.ai-data-tech-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 260px;
    padding: clamp(1.3rem, 1.8vw, 1.7rem);
    text-align: center;
    background: #ffffff;
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    box-shadow: 0 12px 28px rgba(8, 35, 74, 0.05);
}

.ai-data-tech-card > span {
    display: grid;
    place-items: center;
    width: 82px;
    height: 82px;
    margin-bottom: 1rem;
}

.ai-data-tech-card img {
    width: 78px;
    max-height: 76px;
    object-fit: contain;
}

.ai-data-tech-card .icon {
    width: 4rem;
    height: 4rem;
    color: var(--color-navy);
}

.ai-data-tech-card h3 {
    margin: 0 0 0.7rem;
    color: var(--color-navy);
    font-size: clamp(1.02rem, 1.1vw, 1.2rem);
    font-weight: 900;
}

.ai-data-tech-card p {
    margin: 0;
    color: #1f3d62;
    font-size: clamp(0.8rem, 0.86vw, 0.92rem);
    line-height: 1.55;
}

.ai-data-solutions {
    padding: clamp(2.4rem, 4vw, 4.2rem) 0;
    color: #ffffff;
    background:
        radial-gradient(circle at 20% 10%, rgba(20, 99, 203, 0.22), transparent 22rem),
        linear-gradient(90deg, #031631 0%, #062856 55%, #031631 100%);
}

.ai-data-solutions__grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0;
}

.ai-data-solutions__grid article {
    min-height: 210px;
    padding: 0 clamp(1rem, 2vw, 1.8rem);
    text-align: center;
    border-right: 1px solid rgba(255, 255, 255, 0.22);
}

.ai-data-solutions__grid article:last-child {
    border-right: 0;
}

.ai-data-solutions__grid span {
    display: grid;
    place-items: center;
    width: 64px;
    height: 64px;
    margin: 0 auto 1rem;
    color: #ffffff;
}

.ai-data-solutions__grid .icon {
    width: 3.05rem;
    height: 3.05rem;
}

.ai-data-solutions__grid h3 {
    margin: 0 0 0.65rem;
    color: #ffffff;
    font-size: clamp(0.96rem, 1.06vw, 1.15rem);
    font-weight: 900;
    line-height: 1.18;
}

.ai-data-solutions__grid p {
    margin: 0;
    color: rgba(255, 255, 255, 0.84);
    font-size: clamp(0.76rem, 0.82vw, 0.88rem);
    line-height: 1.48;
}

.ai-data-case__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.8fr);
    gap: clamp(2rem, 4vw, 5rem);
    align-items: center;
}

.ai-data-case__grid .ai-data-section-heading {
    margin-bottom: clamp(1.8rem, 2.6vw, 2.6rem);
}

.ai-data-case__steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(1rem, 2.2vw, 2rem);
}

.ai-data-case__steps article {
    position: relative;
    text-align: center;
}

.ai-data-case__steps article:not(:last-child)::after {
    position: absolute;
    top: 2.1rem;
    right: calc(-1 * clamp(1rem, 2vw, 2rem));
    color: #7186a2;
    font-size: 1.4rem;
    content: "→";
}

.ai-data-case__steps span {
    display: grid;
    place-items: center;
    width: 72px;
    height: 72px;
    margin: 0 auto 1rem;
    color: var(--color-navy);
    background: #ffffff;
    border: 1px solid var(--color-gray-200);
    border-radius: 999px;
    box-shadow: 0 12px 25px rgba(8, 35, 74, 0.07);
}

.ai-data-case__steps .icon {
    width: 2.25rem;
    height: 2.25rem;
}

.ai-data-case__steps h3 {
    margin: 0 0 0.45rem;
    color: var(--color-navy);
    font-size: clamp(0.86rem, 0.92vw, 1rem);
    font-weight: 900;
    line-height: 1.25;
}

.ai-data-case__steps p {
    margin: 0;
    color: #2d4c71;
    font-size: clamp(0.72rem, 0.8vw, 0.86rem);
    line-height: 1.45;
}

.ai-data-benefits-card {
    padding: clamp(1.5rem, 2.5vw, 2.4rem);
    color: #ffffff;
    background:
        radial-gradient(circle at 20% 10%, rgba(20, 99, 203, 0.25), transparent 13rem),
        linear-gradient(135deg, #031631 0%, #062856 100%);
    border-radius: 8px;
    box-shadow: 0 18px 38px rgba(8, 35, 74, 0.18);
}

.ai-data-benefits-card h2 {
    position: relative;
    margin: 0 0 1.4rem;
    color: #ffffff;
    font-size: clamp(1.35rem, 1.7vw, 1.8rem);
    font-weight: 900;
}

.ai-data-benefits-card h2::after {
    display: block;
    width: 40px;
    height: 2px;
    margin-top: 0.72rem;
    background: var(--color-orange);
    content: "";
}

.ai-data-benefits-card ul {
    display: grid;
    gap: 0.8rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.ai-data-benefits-card li {
    position: relative;
    padding-left: 1.7rem;
    color: rgba(255, 255, 255, 0.92);
    font-size: clamp(0.86rem, 0.94vw, 1rem);
}

.ai-data-benefits-card li::before {
    position: absolute;
    left: 0;
    top: 0.1rem;
    display: grid;
    place-items: center;
    width: 1rem;
    height: 1rem;
    color: #ffffff;
    background: var(--color-orange);
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 900;
    content: "✓";
}

.ai-data-cta {
    color: #ffffff;
    background:
        radial-gradient(circle at 18% 35%, rgba(20, 99, 203, 0.25), transparent 18rem),
        linear-gradient(90deg, #031631 0%, #062856 100%);
}

.ai-data-cta__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(1.5rem, 4vw, 5rem);
    align-items: center;
    padding: clamp(1.8rem, 3vw, 2.6rem) 0;
}

.ai-data-cta h2 {
    max-width: 720px;
    margin: 0;
    color: #ffffff;
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 900;
    line-height: 1.18;
}

.ai-data-cta p {
    margin: 0.55rem 0 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: clamp(0.95rem, 1.12vw, 1.15rem);
}

.ai-data-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1.3rem;
    justify-content: flex-end;
}

.ai-data-cta__actions .button {
    min-width: 220px;
    text-transform: none;
}

.ai-data-footer {
    color: #ffffff;
    background:
        radial-gradient(circle at 72% 18%, rgba(11, 103, 216, 0.16), transparent 19rem),
        linear-gradient(90deg, #031631 0%, #062856 100%);
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.ai-data-footer__grid {
    display: grid;
    grid-template-columns: minmax(220px, 0.9fr) minmax(230px, 1.05fr) minmax(240px, 1fr) minmax(220px, 0.9fr) minmax(160px, 0.7fr);
    gap: clamp(1.4rem, 3vw, 3.5rem);
    padding: clamp(2rem, 3vw, 3rem) 0 1.2rem;
}

.ai-data-footer__grid > * {
    min-height: 135px;
    padding-right: clamp(1rem, 2.2vw, 2.2rem);
    border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.ai-data-footer__grid > *:last-child {
    padding-right: 0;
    border-right: 0;
}

.ai-data-footer h2 {
    margin: 0 0 1rem;
    color: #ffffff;
    font-size: 0.9rem;
    font-weight: 900;
}

.ai-data-footer p,
.ai-data-footer li,
.ai-data-footer a {
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.82rem;
    line-height: 1.6;
}

.ai-data-footer__brand p {
    max-width: 270px;
    margin: 1rem 0 0;
}

.ai-data-footer__social {
    display: flex;
    gap: 0.7rem;
    margin-top: 1.1rem;
}

.ai-data-footer__social span {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    color: var(--color-navy);
    background: #ffffff;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 900;
}

.ai-data-footer ul {
    columns: 2;
    gap: 2rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.ai-data-footer__links:last-of-type ul {
    columns: 1;
}

.ai-data-footer a:hover,
.ai-data-footer a:focus-visible {
    color: #ffffff;
}

.ai-data-footer__contact p {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    gap: 0.55rem;
    align-items: center;
    margin: 0 0 0.65rem;
}

.ai-data-footer__contact .icon {
    width: 1rem;
    height: 1rem;
}

.ai-data-footer__partner {
    display: grid;
    place-items: center;
}

.ai-data-footer__partner .partner-badge {
    transform: scale(1.45);
}

.ai-data-footer__copyright {
    margin: 0;
    padding: 0 1rem 1rem;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.8rem;
    font-weight: 700;
    text-align: center;
}

@media (max-width: 1280px) {
    .ai-data-tech__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .ai-data-solutions__grid,
    .ai-data-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ai-data-solutions__grid article,
    .ai-data-footer__grid > * {
        border-right: 0;
    }
}

@media (max-width: 1180px) {
    .ai-data-hero__grid,
    .ai-data-case__grid,
    .ai-data-cta__grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .ai-data-hero__points,
    .ai-data-case__steps {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.4rem;
    }

    .ai-data-hero__points article {
        min-height: 0;
        padding: 0;
        border-right: 0;
    }

    .ai-data-hero__visual img {
        min-height: 300px;
        border-radius: 8px 8px 0 0;
    }

    .ai-data-case__steps article::after {
        display: none;
    }

    .ai-data-cta__actions {
        justify-content: flex-start;
    }
}

@media (max-width: 780px) {
    .ai-data-page .container {
        width: min(calc(100% - 28px), var(--container));
    }

    .ai-data-hero h1 {
        font-size: clamp(2.5rem, 12vw, 3.45rem);
    }

    .ai-data-hero__copy > p {
        overflow-wrap: anywhere;
    }

    .ai-data-hero__points,
    .ai-data-tech__grid,
    .ai-data-solutions__grid,
    .ai-data-case__steps,
    .ai-data-footer__grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .ai-data-hero__visual img {
        min-height: 245px;
    }

    .ai-data-tech-card {
        min-height: 0;
    }

    .ai-data-solutions__grid article {
        min-height: 0;
        padding: 1.5rem 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.16);
    }

    .ai-data-solutions__grid article:last-child {
        border-bottom: 0;
    }

    .ai-data-cta__actions {
        gap: 0.9rem;
    }

    .ai-data-cta__actions .button {
        width: 100%;
    }

    .ai-data-footer ul {
        columns: 1;
    }

    .ai-data-footer__partner {
        place-items: start;
    }
}

/* Header menu readability */
@media (min-width: 1181px) {
    .site-nav {
        gap: clamp(1rem, 1.25vw, 1.75rem);
    }

    .site-nav > a:not(.button) {
        font-size: clamp(0.88rem, 0.9vw, 1rem);
        line-height: 1.2;
    }

    .site-nav .button.button--small {
        min-height: 40px;
        padding-inline: clamp(1.1rem, 1.45vw, 1.7rem);
        font-size: 0.82rem;
    }
}

@media (min-width: 1181px) and (max-width: 1380px) {
    .site-nav {
        gap: 0.9rem;
    }

    .site-nav > a:not(.button) {
        font-size: 0.84rem;
    }

    .site-nav .button.button--small {
        padding-inline: 1rem;
        font-size: 0.76rem;
    }
}

@media (max-width: 1180px) {
    .site-nav > a:not(.button) {
        font-size: 1rem;
    }

    .site-nav .button.button--small {
        font-size: 0.9rem;
    }
}

/* Contact submit loading state */
.contact-submit-button {
    position: relative;
    overflow: hidden;
}

.contact-submit-button .button-label,
.contact-submit-button .button-arrow,
.contact-submit-button .button-loader {
    position: relative;
    z-index: 1;
}

.contact-submit-button::before {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.22), transparent);
    transform: translateX(-120%);
    content: "";
}

.contact-submit-button.is-loading::before {
    animation: cti-button-shine 1.1s ease-in-out infinite;
}

.contact-submit-button.is-loading {
    cursor: progress;
    background: linear-gradient(90deg, #ff7900 0%, #ff9d28 54%, #ff7900 100%);
    box-shadow: 0 16px 30px rgba(255, 121, 0, 0.28);
}

.contact-submit-button:disabled {
    opacity: 1;
}

.button-loader {
    display: none;
    width: 17px;
    height: 17px;
    border: 2px solid rgba(255, 255, 255, 0.44);
    border-top-color: #ffffff;
    border-radius: 999px;
}

.contact-submit-button.is-loading .button-loader {
    display: block;
    animation: cti-spin 0.75s linear infinite;
}

.contact-submit-button.is-loading .button-arrow {
    opacity: 0.65;
}

.contact-page-form.is-submitting input,
.contact-page-form.is-submitting select,
.contact-page-form.is-submitting textarea,
.contact-form.is-submitting input,
.contact-form.is-submitting textarea {
    background: #f8fbff;
}

.contact-submit-loader {
    position: relative;
    display: flex;
    gap: 0.95rem;
    align-items: center;
    margin-top: 0.1rem;
    padding: 0.95rem 1rem;
    overflow: hidden;
    color: var(--color-navy);
    background:
        linear-gradient(90deg, rgba(255, 121, 0, 0.08), rgba(11, 78, 162, 0.08)),
        #ffffff;
    border: 1px solid rgba(11, 78, 162, 0.14);
    border-radius: 8px;
    box-shadow: 0 14px 32px rgba(8, 35, 74, 0.08);
}

.contact-submit-loader[hidden] {
    display: none;
}

.contact-submit-loader::after {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 40%;
    height: 3px;
    background: linear-gradient(90deg, var(--color-orange), #0b67d8, var(--color-orange));
    border-radius: 999px;
    animation: cti-loading-track 1.25s ease-in-out infinite;
    content: "";
}

.contact-submit-loader__orb {
    position: relative;
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
    background:
        radial-gradient(circle at 35% 35%, #ffffff 0 14%, transparent 15%),
        linear-gradient(135deg, var(--color-orange), #0b67d8);
    border-radius: 999px;
    box-shadow: 0 12px 24px rgba(8, 35, 74, 0.16);
}

.contact-submit-loader__orb::before,
.contact-submit-loader__orb::after {
    position: absolute;
    inset: -5px;
    border: 2px solid rgba(255, 121, 0, 0.28);
    border-top-color: rgba(11, 78, 162, 0.8);
    border-radius: 999px;
    animation: cti-spin 1s linear infinite;
    content: "";
}

.contact-submit-loader__orb::after {
    inset: -10px;
    border-color: rgba(11, 78, 162, 0.12);
    animation: cti-pulse 1.35s ease-in-out infinite;
}

.contact-submit-loader__copy {
    display: grid;
    gap: 0.1rem;
}

.contact-submit-loader__copy strong {
    color: var(--color-navy);
    font-size: 0.95rem;
    font-weight: 900;
}

.contact-submit-loader__copy small {
    color: #476484;
    font-size: 0.82rem;
    line-height: 1.35;
}

@keyframes cti-spin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes cti-pulse {
    0%,
    100% {
        opacity: 0.35;
        transform: scale(0.92);
    }

    50% {
        opacity: 0.95;
        transform: scale(1.03);
    }
}

@keyframes cti-loading-track {
    0% {
        transform: translateX(-105%);
    }

    55%,
    100% {
        transform: translateX(260%);
    }
}

@keyframes cti-button-shine {
    to {
        transform: translateX(120%);
    }
}

@media (prefers-reduced-motion: reduce) {
    .contact-submit-button.is-loading::before,
    .contact-submit-button.is-loading .button-loader,
    .contact-submit-loader::after,
    .contact-submit-loader__orb::before,
    .contact-submit-loader__orb::after {
        animation: none;
    }
}
