/* Progressive Associates — brand palette (teal + accent green) */
:root {
    /* —— Brand primitives —— */
    --brand-teal-deep: #0f7c8a;
    --brand-teal-bright: #1fa2c1;
    --brand-green: #4caf50;
    --brand-green-light: #81c784;
    --neutral-soft: #eaf6f7;
    --neutral-mist: #f0fafc;
    --text-brand-dark: #1e2a2e;

    /* RGB tuples for rgba(var(--rgb-*), alpha) — names kept for compatibility */
    --rgb-text-dark: 30, 42, 46;
    --rgb-teal-deep: 15, 124, 138;
    --rgb-teal-bright: 31, 162, 193;
    --rgb-green: 76, 175, 80;
    --rgb-brand-ink: 4, 28, 32;

    /* —— Gradients —— */
    --gradient-brand-primary: linear-gradient(135deg, var(--brand-teal-deep) 0%, var(--brand-teal-bright) 100%);
    --gradient-brand-secondary: linear-gradient(135deg, var(--brand-teal-bright) 0%, var(--brand-green-light) 100%);
    --gradient-brand-cta: linear-gradient(135deg, var(--brand-teal-bright) 0%, #2a9eb8 52%, var(--brand-green-light) 100%);

    /* —— Chrome / footer (legacy token names) —— */
    --footer-navy: #0a4a52;
    --footer-blue: var(--brand-teal-bright);
    --footer-blue-hover: #5dd5e5;
    --footer-blue-active: var(--brand-teal-deep);
    --footer-blue-glow: rgba(var(--rgb-teal-bright), 0.35);
    --footer-gradient-deep: #041f24;

    /* —— Semantic theme tokens —— */
    --primary-color: var(--brand-teal-deep);
    --secondary-color: var(--brand-teal-bright);
    --accent-color: var(--brand-green);
    --accent-color-dark: #0d5c66;

    /* Light surfaces */
    --text-primary: var(--text-brand-dark);
    --text-muted: #546068;
    --text-heading: #1e2a2e;
    --text-subtle: #7a8a8f;
    --text-link: var(--brand-teal-deep);
    --text-link-hover: var(--brand-teal-bright);

    /* Dark surfaces */
    --text-on-dark: #f0fafc;
    --text-on-dark-muted: rgba(255, 255, 255, 0.86);
    --text-on-dark-soft: rgba(255, 255, 255, 0.74);
    --link-on-dark-hover: #a8ecf5;

    /* Surfaces */
    --color-bg: var(--neutral-soft);
    --color-surface: #ffffff;
    --color-border: rgba(var(--rgb-teal-deep), 0.14);

    /* Legacy aliases */
    --color-ink: var(--text-primary);
    --color-ink-muted: var(--text-muted);
    --color-accent: var(--accent-color);
    --color-accent-dark: var(--accent-color-dark);
    --color-teal: var(--brand-teal-bright);
    --color-teal-dark: var(--brand-teal-deep);

    --font-display: "Poppins", system-ui, -apple-system, sans-serif;
    --font-body: "Inter", system-ui, -apple-system, sans-serif;

    /* —— Typography scale (corporate) —— */
    --type-h1: clamp(2.5rem, 4.5vw + 0.5rem, 3.5rem);
    --type-h2: clamp(1.75rem, 2.5vw + 0.35rem, 2.25rem);
    --type-h3: clamp(1.125rem, 1.1vw + 0.9rem, 1.375rem);
    --type-body: 1rem;
    --type-lead: clamp(1rem, 0.35vw + 0.94rem, 1.0625rem);
    --type-small: 0.8125rem;
    --type-label: 0.75rem;
    --type-space-heading-body: clamp(0.75rem, 0.8vw + 0.4rem, 1rem);
    --type-space-paragraph: clamp(0.625rem, 0.5vw + 0.45rem, 0.875rem);
    --radius-sm: 8px;
    --radius-md: 14px;
    --radius-lg: 24px;
    --shadow-sm: 0 1px 2px rgba(var(--rgb-teal-deep), 0.07);
    --shadow-md: 0 12px 40px rgba(var(--rgb-teal-deep), 0.1);
    --shadow-glow: 0 0 80px rgba(var(--rgb-teal-bright), 0.14);
    --shadow-glow-green: 0 0 48px rgba(var(--rgb-green), 0.2);
    --space-section: clamp(5rem, 11vw, 7.5rem);
    --max-width: 1180px;

    --duration-text: 0.3s;
    --ease-text: cubic-bezier(0.22, 1, 0.36, 1);

    /* —— Button system (corporate / minimal) —— */
    --btn-primary-bg: #0f7c8a;
    --btn-primary-hover: #0c6672;
    --btn-primary-active: #0a5560;
    --btn-radius: 12px;
    --btn-border: 1.5px solid var(--btn-primary-bg);
    --btn-transition: 0.28s ease;
    --btn-shadow-hover: 0 6px 18px rgba(var(--rgb-teal-deep), 0.22);
    --btn-letter: 0.04em;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font-body);
    font-size: var(--type-body);
    font-weight: 400;
    line-height: 1.7;
    color: var(--text-primary);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-feature-settings: "kern" 1, "liga" 1;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* —— Default heading & prose rhythm (main) —— */
.main-content h1 {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: var(--type-h1);
    line-height: 1.12;
    letter-spacing: -0.02em;
    color: var(--text-heading);
    margin: 0 0 var(--type-space-heading-body);
}

.main-content h2:not([class]) {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: var(--type-h2);
    line-height: 1.2;
    letter-spacing: -0.015em;
    color: var(--text-heading);
    margin: 0 0 var(--type-space-heading-body);
}

.main-content h3:not([class]) {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: var(--type-h3);
    line-height: 1.35;
    letter-spacing: -0.01em;
    color: var(--text-heading);
    margin: 0 0 0.65rem;
}

.main-content h4:not([class]) {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 1.0625rem;
    line-height: 1.4;
    color: var(--text-heading);
    margin: 0 0 0.5rem;
}

.main-content > .section .container > p + p,
.main-content .section .container p + p {
    margin-top: var(--type-space-paragraph);
}

.text-accent {
    color: var(--primary-color);
    font-weight: 600;
}

.text-accent--green {
    color: var(--accent-color);
    font-weight: 600;
}

.text-lead-emphasis {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: var(--type-lead);
    line-height: 1.65;
    color: var(--text-heading);
    margin-top: 1.25rem;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
}

a {
    color: var(--text-link);
    text-decoration: none;
    transition:
        color var(--duration-text) var(--ease-text),
        opacity var(--duration-text) var(--ease-text),
        background-size var(--duration-text) var(--ease-text);
}

a:hover {
    color: var(--text-link-hover);
}

/* Prose links: teal underline animates L→R; hover shifts to accent green */
.main-content a:not([class*="btn"]):not(.logo):not(.fab):not(.insight-card__link) {
    color: var(--btn-primary-bg);
    background-image: linear-gradient(currentColor, currentColor);
    background-position: 0 100%;
    background-repeat: no-repeat;
    background-size: 0% 2px;
    padding-bottom: 2px;
}

.main-content a:not([class*="btn"]):not(.logo):not(.fab):not(.insight-card__link):hover {
    color: var(--accent-color);
    background-size: 100% 2px;
}

.main-content strong,
.main-content b {
    color: var(--text-heading);
    font-weight: 600;
}

.container {
    width: min(100% - 2rem, var(--max-width));
    margin-inline: auto;
}

/* Top bar */
.top-bar {
    background: var(--footer-navy);
    color: rgba(255, 255, 255, 0.92);
    font-family: var(--font-body);
    font-size: var(--type-small);
    letter-spacing: 0.02em;
    padding: 0.5rem 0;
}

.top-bar__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem 1rem;
}

.top-bar__contact {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem 1.25rem;
}

.top-bar__link {
    color: #fff;
    font-weight: 500;
}

.top-bar__link:hover {
    color: var(--link-on-dark-hover);
}

.top-bar__social {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.2rem;
    margin-left: auto;
}

.top-bar__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.82);
    transition:
        color 0.3s ease,
        transform 0.3s ease,
        filter 0.3s ease,
        background 0.3s ease;
}

.top-bar__social-link:hover {
    color: #fff;
    transform: scale(1.1);
}

.top-bar__social-link:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.85);
    outline-offset: 2px;
}

@media (hover: hover) and (pointer: fine) {
    .top-bar__social-link--facebook:hover {
        color: #1877f2;
        filter: drop-shadow(0 0 8px rgba(24, 119, 242, 0.45));
    }

    .top-bar__social-link--instagram:hover {
        color: #e4405f;
        filter: drop-shadow(0 0 8px rgba(228, 64, 95, 0.4));
    }

    .top-bar__social-link--linkedin:hover {
        color: #0a66c2;
        filter: drop-shadow(0 0 8px rgba(10, 102, 194, 0.45));
    }

    .top-bar__social-link--whatsapp:hover {
        color: #25d366;
        filter: drop-shadow(0 0 8px rgba(37, 211, 102, 0.45));
    }
}

@media (prefers-reduced-motion: reduce) {
    .top-bar__social-link:hover {
        transform: none;
    }
}

.top-bar__muted {
    opacity: 0.85;
}

/* Header */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: color-mix(in srgb, var(--color-bg) 92%, transparent);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-border);
}

@supports not (background: color-mix(in srgb, white 50%, transparent)) {
    .site-header {
        background: rgba(230, 242, 245, 0.94);
    }
}

/* Division-aware header (infrastructure vs management consulting) */
body.infra-theme {
    --header-nav-accent: #f59e0b;
    --header-underline: #d97706;
    --header-bg-mix: color-mix(in srgb, var(--color-bg) 58%, #0c2f36 42%);
}

body.consulting-theme {
    --header-nav-accent: #14b8a6;
    --header-underline: #0f7c8a;
    --header-bg-mix: color-mix(in srgb, #ffffff 82%, #e8f7f9 18%);
}

body.infra-theme .site-header {
    background: var(--header-bg-mix);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom-color: rgba(245, 158, 11, 0.28);
    box-shadow:
        0 12px 40px rgba(0, 0, 0, 0.14),
        0 2px 14px rgba(0, 0, 0, 0.07);
}

@supports not (background: color-mix(in srgb, white 50%, transparent)) {
    body.infra-theme .site-header {
        background: rgba(196, 222, 228, 0.96);
    }
}

body.consulting-theme .site-header {
    background: var(--header-bg-mix);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom-color: rgba(var(--rgb-teal-deep), 0.09);
    box-shadow: 0 6px 28px rgba(var(--rgb-teal-deep), 0.07);
}

@supports not (background: color-mix(in srgb, white 50%, transparent)) {
    body.consulting-theme .site-header {
        background: rgba(252, 253, 253, 0.94);
    }
}

body.infra-theme .nav-main__list a.nav-link:hover,
body.infra-theme .nav-main__dropdown-toggle.nav-link:hover {
    color: var(--header-nav-accent);
}

body.consulting-theme .nav-main__list a.nav-link:hover,
body.consulting-theme .nav-main__dropdown-toggle.nav-link:hover {
    color: var(--header-nav-accent);
}

body.infra-theme .nav-main__list a.nav-link.is-active,
body.infra-theme .nav-main__dropdown-toggle.nav-link.is-active {
    color: var(--text-heading);
}

body.consulting-theme .nav-main__list a.nav-link.is-active,
body.consulting-theme .nav-main__dropdown-toggle.nav-link.is-active {
    color: var(--text-heading);
}

body.infra-theme .nav-main__list a.nav-link::after,
body.infra-theme .nav-main__dropdown-toggle.nav-link::after {
    background-color: var(--header-underline);
}

body.consulting-theme .nav-main__list a.nav-link::after,
body.consulting-theme .nav-main__dropdown-toggle.nav-link::after {
    background-color: var(--header-underline);
}

body.infra-theme .nav-main__list a.nav-link.is-active::after,
body.infra-theme .nav-main__dropdown-toggle.nav-link.is-active::after {
    background-color: var(--header-underline);
}

body.consulting-theme .nav-main__list a.nav-link.is-active::after,
body.consulting-theme .nav-main__dropdown-toggle.nav-link.is-active::after {
    background-color: var(--header-underline);
}

.site-header__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 0;
}

.logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    line-height: 0;
}

.logo:hover .logo__img {
    opacity: 0.92;
}

.logo__img {
    display: block;
    height: clamp(2rem, 5.5vw, 2.85rem);
    width: auto;
    max-width: min(100%, 220px);
    object-fit: contain;
    transition: opacity 0.2s ease;
}

.nav-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
}

.nav-toggle span {
    display: block;
    height: 2px;
    width: 100%;
    background: var(--text-heading);
    border-radius: 1px;
    transition: transform 0.2s, opacity 0.2s;
}

@media (min-width: 1024px) {
    .nav-toggle {
        display: none;
    }
}

.nav-main {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    padding: 1rem 1rem 1.5rem;
    flex-direction: column;
    gap: 1rem;
    box-shadow: var(--shadow-md);
}

.nav-main.is-open {
    display: flex;
}

@media (min-width: 1024px) {
    .nav-main {
        display: flex;
        position: static;
        flex-direction: row;
        align-items: center;
        flex: 1 1 auto;
        min-width: 0;
        justify-content: flex-end;
        gap: 1rem;
        padding: 0;
        background: transparent;
        border: none;
        box-shadow: none;
    }
}

.nav-main__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

@media (min-width: 1024px) {
    .nav-main__list {
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        gap: 0.15rem 0.85rem;
    }
}

.nav-main__list a.nav-link {
    display: block;
    padding: 0.45rem 0 0.55rem;
    font-family: var(--font-body);
    color: var(--text-heading);
    font-weight: 500;
    font-size: var(--type-body);
    letter-spacing: 0.01em;
    position: relative;
    background: none;
    transition:
        color 0.3s ease,
        transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.nav-main__list a.nav-link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -4px;
    width: 0;
    height: 2px;
    border-radius: 1px;
    background-color: var(--brand-teal-deep);
    transition:
        width 0.3s cubic-bezier(0.22, 1, 0.36, 1),
        height 0.2s ease,
        background-color 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
    .nav-main__list a.nav-link:hover {
        color: var(--text-link);
        transform: translateY(-2px);
    }

    .nav-main__list a.nav-link:hover::after {
        width: 100%;
    }
}

.nav-main__list a.nav-link.is-active {
    color: var(--text-heading);
    font-weight: 600;
}

.nav-main__list a.nav-link.is-active::after {
    width: 100%;
    height: 2.5px;
    background-color: var(--brand-teal-deep);
}

.nav-main__list a.nav-link.is-active:hover {
    color: var(--text-link);
}

.nav-main__list a.nav-link:focus-visible {
    outline: 2px solid var(--btn-primary-bg);
    outline-offset: 4px;
    border-radius: 4px;
}

.nav-main__list a.nav-link:focus-visible::after {
    width: 100%;
}

@media (min-width: 1024px) {
    .nav-main__list a.nav-link {
        padding: 0.4rem 0 0.5rem;
        white-space: nowrap;
    }
}

@media (min-width: 1024px) and (max-width: 1240px) {
    .nav-main__list {
        gap: 0.15rem 0.55rem;
    }

    .nav-main__list a {
        font-size: 0.875rem;
    }

    .nav-main__dropdown-toggle {
        font-size: 0.875rem;
    }

    .nav-main__dropdown-panel .nav-main__dropdown-item {
        font-size: 0.875rem;
    }

    .logo__img {
        max-width: 180px;
    }

    .nav-main .btn--footer-book.btn--sm {
        padding: 0.45rem 0.75rem;
        font-size: 0.78rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .nav-main__list a.nav-link,
    .nav-main__list a.nav-link::after,
    .nav-main__dropdown-toggle.nav-link,
    .nav-main__dropdown-toggle.nav-link::after,
    .nav-main__dropdown-caret {
        transition-duration: 0.01ms;
    }

    .nav-main__list a.nav-link:hover,
    .nav-main__dropdown-toggle.nav-link:hover {
        transform: none;
    }

    .nav-main__list a.nav-link:hover::after,
    .nav-main__dropdown-toggle.nav-link:hover::after {
        width: 100%;
    }
}

/* Explore dropdown — desktop hover + focus; mobile tap to expand */
.nav-main__dropdown {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.25rem;
}

@media (min-width: 1024px) {
    .nav-main__dropdown::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        height: 14px;
        z-index: 199;
        pointer-events: auto;
    }
}

.nav-main__dropdown-toggle.nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem;
    width: 100%;
    padding: 0.45rem 0 0.55rem;
    margin: 0;
    border: none;
    background: transparent;
    cursor: pointer;
    font-family: var(--font-body);
    color: var(--text-heading);
    font-weight: 500;
    font-size: var(--type-body);
    letter-spacing: 0.01em;
    text-align: left;
    position: relative;
    transition:
        color 0.3s ease,
        transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.nav-main__dropdown-toggle.nav-link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -4px;
    width: 0;
    height: 2px;
    border-radius: 1px;
    background-color: var(--brand-teal-deep);
    transition:
        width 0.3s cubic-bezier(0.22, 1, 0.36, 1),
        height 0.2s ease,
        background-color 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
    .nav-main__dropdown-toggle.nav-link:hover {
        color: var(--text-link);
        transform: translateY(-2px);
    }

    .nav-main__dropdown-toggle.nav-link:hover::after {
        width: 100%;
    }
}

.nav-main__dropdown-toggle.nav-link.is-active {
    color: var(--text-heading);
    font-weight: 600;
}

.nav-main__dropdown-toggle.nav-link.is-active::after {
    width: 100%;
    height: 2.5px;
    background-color: var(--brand-teal-deep);
}

.nav-main__dropdown-toggle.nav-link:focus-visible {
    outline: 2px solid var(--btn-primary-bg);
    outline-offset: 4px;
    border-radius: 4px;
}

.nav-main__dropdown-toggle.nav-link:focus-visible::after {
    width: 100%;
}

.nav-main__dropdown.is-open .nav-main__dropdown-caret {
    transform: rotate(-180deg);
}

.nav-main__dropdown-caret {
    font-size: 0.65em;
    opacity: 0.75;
    line-height: 1;
    flex-shrink: 0;
    transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.nav-main__dropdown-panel {
    list-style: none;
    margin: 0;
    padding: 0;
    display: none;
    flex-direction: column;
    gap: 0.2rem;
    pointer-events: auto;
}

.nav-main__dropdown.is-open .nav-main__dropdown-panel {
    display: flex;
}

.nav-main__dropdown-item.dropdown-item {
    display: block;
    padding: 10px 16px;
    margin: 0;
    font-family: var(--font-body);
    color: var(--text-heading);
    font-weight: 500;
    font-size: var(--type-body);
    letter-spacing: 0.01em;
    text-decoration: none;
    border-radius: 8px;
    transition:
        color 0.2s ease,
        background-color 0.2s ease,
        transform 0.2s ease;
}

.nav-main__dropdown-item.dropdown-item.is-active {
    font-weight: 600;
    color: var(--text-heading);
}

.nav-main__dropdown-item.dropdown-item:focus-visible {
    outline: 2px solid var(--btn-primary-bg);
    outline-offset: 2px;
    border-radius: 8px;
}

@media (max-width: 1023px) {
    .nav-main__dropdown-panel {
        padding: 0.35rem 0 0.35rem 0.75rem;
        margin-top: 0.15rem;
        border-left: 2px solid rgba(var(--rgb-teal-deep), 0.18);
    }

    .nav-main__dropdown:not(.is-open) .nav-main__dropdown-panel {
        display: none;
    }

    .nav-main__dropdown.is-open .nav-main__dropdown-panel {
        display: flex;
    }
}

@media (min-width: 1024px) {
    .nav-main__dropdown {
        flex-direction: row;
        align-items: center;
        gap: 0;
    }

    .nav-main__dropdown-toggle.nav-link {
        display: inline-flex;
        width: auto;
        justify-content: flex-start;
        padding: 0.4rem 0 0.5rem;
        white-space: nowrap;
    }

    .nav-main__dropdown-panel {
        position: absolute;
        left: 0;
        top: calc(100% + 8px);
        min-width: 13.5rem;
        padding: 0.5rem;
        display: flex;
        flex-direction: column;
        gap: 0.2rem;
        background: rgba(255, 255, 255, 0.95);
        -webkit-backdrop-filter: blur(12px);
        backdrop-filter: blur(12px);
        border: 1px solid rgba(0, 0, 0, 0.06);
        border-radius: 12px;
        box-shadow:
            0 10px 30px rgba(0, 0, 0, 0.1),
            0 2px 10px rgba(0, 0, 0, 0.05),
            0 1px 0 rgba(255, 255, 255, 0.65) inset;
        z-index: 200;
        opacity: 0;
        visibility: hidden;
        transform: translate3d(0, 8px, 0);
        transform-origin: top center;
        transition:
            opacity 0.3s ease,
            visibility 0.3s ease,
            transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
        pointer-events: none;
    }

    .nav-main__dropdown-panel::before {
        content: "";
        position: absolute;
        top: -10px;
        left: 0;
        width: 100%;
        height: 10px;
        pointer-events: auto;
    }

    .nav-main__dropdown:hover .nav-main__dropdown-panel,
    .nav-main__dropdown:focus-within .nav-main__dropdown-panel,
    .nav-main__dropdown.is-open .nav-main__dropdown-panel {
        opacity: 1;
        visibility: visible;
        transform: translate3d(0, 0, 0);
        pointer-events: auto;
    }

    .nav-main__dropdown:not(:hover):not(:focus-within):not(.is-open) .nav-main__dropdown-panel {
        pointer-events: none;
    }

    .nav-main__list .nav-main__dropdown-item.dropdown-item::after {
        display: none;
    }

    @media (hover: hover) and (pointer: fine) {
        .nav-main__dropdown-item.dropdown-item:hover {
            background: rgba(20, 184, 166, 0.1);
            color: var(--text-link);
            transform: translateX(4px);
        }
    }

    .nav-main__dropdown-item.dropdown-item.is-active {
        background: rgba(15, 124, 138, 0.1);
    }
}

@media (prefers-reduced-motion: reduce) {
    .nav-main__dropdown-panel {
        transition-duration: 0.01ms;
        transform: none;
    }

    .nav-main__dropdown:hover .nav-main__dropdown-panel,
    .nav-main__dropdown:focus-within .nav-main__dropdown-panel,
    .nav-main__dropdown.is-open .nav-main__dropdown-panel {
        transform: none;
    }

    .nav-main__dropdown.is-open .nav-main__dropdown-caret {
        transform: none;
    }

    @media (min-width: 1024px) {
        .nav-main__dropdown-item.dropdown-item:hover {
            transform: none;
        }
    }
}

.nav-cta {
    flex-shrink: 0;
}

.nav-main .nav-cta.btn--footer-book {
    background: linear-gradient(135deg, #0f7c8a 0%, #14b8a6 52%, #0d9488 100%);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow:
        0 4px 16px rgba(var(--rgb-teal-deep), 0.28),
        0 1px 0 rgba(255, 255, 255, 0.2) inset;
    transition:
        transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.3s ease,
        filter 0.3s ease;
}

@media (hover: hover) and (pointer: fine) {
    .nav-main .nav-cta.btn--footer-book:hover {
        transform: translateY(-2px) scale(1.04);
        box-shadow:
            0 10px 32px rgba(20, 184, 166, 0.42),
            0 0 28px rgba(20, 184, 166, 0.22),
            0 1px 0 rgba(255, 255, 255, 0.25) inset;
        filter: brightness(1.06);
    }
}

body.infra-theme .nav-main .nav-cta.btn--footer-book {
    background: linear-gradient(135deg, #0c4a52 0%, #0f7c8a 50%, #b45309 100%);
    box-shadow:
        0 4px 18px rgba(0, 0, 0, 0.18),
        0 0 20px rgba(245, 158, 11, 0.15);
}

@media (hover: hover) and (pointer: fine) {
    body.infra-theme .nav-main .nav-cta.btn--footer-book:hover {
        box-shadow:
            0 12px 36px rgba(0, 0, 0, 0.2),
            0 0 32px rgba(245, 158, 11, 0.35);
    }
}

body.consulting-theme .nav-main .nav-cta.btn--footer-book {
    background: linear-gradient(135deg, #0f7c8a 0%, #2dd4bf 55%, #5eead4 130%);
    box-shadow: 0 4px 18px rgba(var(--rgb-teal-deep), 0.2);
}

@media (prefers-reduced-motion: reduce) {
    .nav-main .nav-cta.btn--footer-book:hover {
        transform: none;
    }
}

/* Buttons — solid primary, outline secondary, shared radius & motion */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.72rem 1.35rem;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.9375rem;
    letter-spacing: var(--btn-letter);
    line-height: 1.2;
    border-radius: var(--btn-radius);
    border: 1.5px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition:
        transform var(--btn-transition),
        box-shadow var(--btn-transition),
        background var(--btn-transition),
        color var(--btn-transition),
        border-color var(--btn-transition);
}

@media (hover: hover) and (pointer: fine) {
    .btn:hover {
        transform: translateY(-2px) scale(1.02);
    }
}

.btn:focus-visible {
    outline: 2px solid var(--btn-primary-bg);
    outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
    .btn:hover {
        transform: none;
    }
}

.btn--sm {
    padding: 0.52rem 1.05rem;
    font-size: 0.875rem;
}

.btn--primary {
    background: var(--btn-primary-bg);
    color: #fff;
    border-color: var(--btn-primary-bg);
    box-shadow: 0 1px 2px rgba(var(--rgb-teal-deep), 0.12);
}

@media (hover: hover) and (pointer: fine) {
    .btn--primary:hover {
        color: #fff;
        background: var(--btn-primary-hover);
        border-color: var(--btn-primary-hover);
        box-shadow: var(--btn-shadow-hover);
    }
}

.btn--primary:active {
    background: var(--btn-primary-active);
    border-color: var(--btn-primary-active);
}

.btn--outline {
    background: transparent;
    border: var(--btn-border);
    color: var(--btn-primary-bg);
}

@media (hover: hover) and (pointer: fine) {
    .btn--outline:hover {
        background: var(--btn-primary-bg);
        border-color: var(--btn-primary-bg);
        color: #fff;
        box-shadow: var(--btn-shadow-hover);
    }
}

.btn--light {
    background: #fff;
    color: var(--btn-primary-bg);
    border-color: rgba(var(--rgb-teal-deep), 0.35);
    box-shadow: 0 1px 2px rgba(var(--rgb-teal-deep), 0.08);
}

@media (hover: hover) and (pointer: fine) {
    .btn--light:hover {
        color: var(--btn-primary-hover);
        border-color: var(--btn-primary-bg);
        box-shadow: var(--btn-shadow-hover);
    }
}

.btn--ghost-light {
    background: transparent;
    border: 1.5px solid rgba(255, 255, 255, 0.55);
    color: #fff;
}

@media (hover: hover) and (pointer: fine) {
    .btn--ghost-light:hover {
        background: var(--btn-primary-bg);
        border-color: var(--btn-primary-bg);
        color: #fff;
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18);
    }
}

/* Text-style CTA: underline reveal, no fill */
.btn--text {
    padding: 0.4rem 0;
    border: none;
    border-radius: 0;
    background: transparent;
    color: var(--btn-primary-bg);
    font-weight: 600;
    letter-spacing: var(--btn-letter);
    box-shadow: none;
    position: relative;
}

.btn--text::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    border-radius: 1px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--btn-transition);
}

@media (hover: hover) and (pointer: fine) {
    .btn--text:hover {
        transform: none;
        color: var(--accent-color);
        box-shadow: none;
    }

    .btn--text:hover::after {
        transform: scaleX(1);
    }
}

@media (prefers-reduced-motion: reduce) {
    .btn--text::after {
        transition-duration: 0.01ms;
    }
}

/* Hero split — 50/50 divisions, footer palette (navy, blue, footer greys) */
.hero-split {
    color: #fff;
    overflow: hidden;
}

.hero-split__panels {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: min(72vh, 700px);
}

@media (max-width: 899px) {
    .hero-split__panels {
        grid-template-columns: 1fr;
        min-height: 0;
    }
}

.hero-split__panel {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(2.25rem, 6vw, 4rem) clamp(1.25rem, 4vw, 2.75rem);
    min-height: min(52vh, 480px);
}

@media (max-width: 899px) {
    .hero-split__panel {
        min-height: min(46vh, 420px);
    }
}

.hero-split__panel--left {
    border-right: 1px solid rgba(255, 255, 255, 0.2);
}

@media (max-width: 899px) {
    .hero-split__panel--left {
        border-right: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    }
}

.hero-split__media {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    z-index: 0;
}

.hero-split__scrim {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.hero-split__panel--left .hero-split__scrim {
    background: linear-gradient(
        155deg,
        rgba(var(--rgb-text-dark), 0.94) 0%,
        rgba(108, 122, 137, 0.86) 48%,
        rgba(var(--rgb-text-dark), 0.92) 100%
    );
}

.hero-split__panel--right .hero-split__scrim {
    background: linear-gradient(
        155deg,
        rgba(var(--rgb-text-dark), 0.9) 0%,
        rgba(149, 165, 166, 0.82) 52%,
        rgba(var(--rgb-text-dark), 0.93) 100%
    );
}

/* Decorative SVGs + subtle motion (respects reduced-motion) */
.hero-split__deco {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    overflow: hidden;
}

.hero-split__deco-svg {
    position: absolute;
    width: min(72vw, 340px);
    height: auto;
    color: rgba(255, 255, 255, 0.35);
    opacity: 0.55;
}

.hero-split__deco-svg--infra {
    right: -8%;
    bottom: 6%;
    animation: hero-split-drift 18s ease-in-out infinite;
}

.hero-split__deco-svg--consult {
    left: -6%;
    bottom: 4%;
    animation: hero-split-drift 22s ease-in-out infinite reverse;
}

.hero-split__deco-line {
    stroke: currentColor;
    stroke-width: 1.1;
    fill: none;
    vector-effect: non-scaling-stroke;
}

.hero-split__deco-fill {
    fill: currentColor;
    opacity: 0.35;
}

.hero-split__deco-node {
    fill: currentColor;
    opacity: 0.45;
    transform-box: fill-box;
    transform-origin: center;
    animation: hero-split-pulse 4s ease-in-out infinite;
}

.hero-split__deco-node--d {
    animation-delay: 0.6s;
}

.hero-split__deco-node--e {
    animation-delay: 1.2s;
}

@keyframes hero-split-drift {
    0%,
    100% {
        transform: translate(0, 0) rotate(0deg);
    }
    33% {
        transform: translate(-10px, 6px) rotate(-1deg);
    }
    66% {
        transform: translate(6px, -8px) rotate(1deg);
    }
}

@keyframes hero-split-pulse {
    0%,
    100% {
        opacity: 0.35;
        transform: scale(1);
    }
    50% {
        opacity: 0.65;
        transform: scale(1.08);
    }
}

@media (prefers-reduced-motion: reduce) {
    .hero-split__deco-svg--infra,
    .hero-split__deco-svg--consult,
    .hero-split__deco-node,
    .hero-split__deco-node--d,
    .hero-split__deco-node--e {
        animation: none;
    }

    .hero-split__deco-svg {
        opacity: 0.35;
    }
}

.hero-split__content {
    position: relative;
    z-index: 3;
    width: 100%;
    max-width: 26rem;
    margin-inline: auto;
}

.hero-split__label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 0.45rem;
    font-family: var(--font-display);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: rgba(200, 235, 242, 0.92);
}

.hero-split__label-icon {
    flex-shrink: 0;
    color: var(--footer-blue);
    opacity: 0.95;
    animation: hero-split-icon-nudge 5s ease-in-out infinite;
}

.hero-split__label-icon--b {
    animation-delay: 1.2s;
}

@keyframes hero-split-icon-nudge {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-3px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .hero-split__label-icon,
    .hero-split__label-icon--b {
        animation: none;
    }
}

@media (max-width: 899px) {
    .hero-split__label {
        justify-content: center;
    }
}

.hero-split__eyebrow {
    margin: 0 0 0.85rem;
    padding: 0 0 0.55rem 0.8rem;
    border-left: 3px solid var(--footer-blue);
    font-family: var(--font-body);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.94);
    line-height: 1.45;
}

@media (max-width: 899px) {
    .hero-split__eyebrow {
        border-left: none;
        border-bottom: 2px solid var(--footer-blue);
        padding-left: 0;
        padding-bottom: 0.5rem;
        text-align: center;
    }
}

.hero-split__title {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(1.65rem, 3vw + 0.5rem, 2.65rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 var(--type-space-heading-body);
    color: #fff;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.18);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    .hero-split__title {
        background: linear-gradient(165deg, #ffffff 0%, #eef4f7 45%, #ffffff 100%);
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
        text-shadow: none;
        -webkit-text-fill-color: transparent;
        filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.14));
    }

    @media (prefers-reduced-motion: no-preference) {
        .hero-split__title {
            background-size: 200% 100%;
            animation: hero-title-shimmer 20s ease-in-out infinite;
        }
    }
}

@keyframes hero-title-shimmer {
    0%,
    100% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .hero-split__title {
        animation: none !important;
        color: #fff !important;
        -webkit-text-fill-color: unset !important;
        background: none !important;
        -webkit-background-clip: unset !important;
        background-clip: unset !important;
        filter: none;
        text-shadow: 0 2px 20px rgba(0, 0, 0, 0.2);
    }
}

@media (max-width: 899px) {
    .hero-split__title {
        text-align: center;
    }
}

.hero-split__lead {
    font-family: var(--font-body);
    font-size: clamp(0.9375rem, 1.1vw + 0.85rem, 1.0625rem);
    font-weight: 400;
    line-height: 1.7;
    color: var(--text-on-dark-muted);
    margin: 0 0 1.35rem;
}

@media (max-width: 899px) {
    .hero-split__lead {
        text-align: center;
    }
}

.hero-split__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

@media (max-width: 899px) {
    .hero-split__actions {
        justify-content: center;
    }
}

.btn--hero-split-ghost {
    background: transparent;
    color: #fff;
    border: 1.5px solid rgba(255, 255, 255, 0.55);
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.8125rem;
    letter-spacing: var(--btn-letter);
    padding: 0.52rem 1.05rem;
    border-radius: var(--btn-radius);
    box-shadow: none;
}

@media (hover: hover) and (pointer: fine) {
    .btn--hero-split-ghost:hover {
        background: var(--btn-primary-bg);
        border-color: var(--btn-primary-bg);
        color: #fff;
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
    }
}

.hero-split__stats {
    background: var(--footer-navy);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1.65rem 0 1.35rem;
}

.hero-split__stats-inner {
    text-align: center;
}

.hero-split__stats-head {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    margin: 0 0 1.15rem;
}

.hero-split__stats-icon {
    flex-shrink: 0;
    color: var(--footer-blue);
    opacity: 0.88;
    animation: hero-stats-icon-breathe 5.5s ease-in-out infinite;
}

.hero-split__stats-draw {
    stroke-linecap: round;
    stroke-linejoin: round;
}

@keyframes hero-stats-icon-breathe {
    0%,
    100% {
        opacity: 0.65;
        transform: scale(1);
    }
    50% {
        opacity: 1;
        transform: scale(1.06);
    }
}

@media (prefers-reduced-motion: reduce) {
    .hero-split__stats-icon {
        animation: none;
        opacity: 0.85;
    }
}

.hero-split__stats-heading {
    margin: 0;
    font-family: var(--font-display);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: rgba(200, 235, 242, 0.92);
}

.hero-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.15rem 1.5rem;
}

.hero-stats--split {
    max-width: 52rem;
    margin-inline: auto;
}

@media (min-width: 640px) {
    .hero-stats--split {
        grid-template-columns: repeat(4, 1fr);
    }
}

.hero-stat__value {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3.5vw, 2.05rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.1;
}

.hero-stat__label {
    font-family: var(--font-body);
    font-size: var(--type-small);
    font-weight: 500;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.78);
    margin-top: 0.25rem;
}

.hero-split__scroll {
    margin: 1.25rem 0 0;
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.42);
}

/* Sections */
.section {
    padding: var(--space-section) 0;
}

.section--alt {
    background: var(--color-surface);
}

.section__header {
    max-width: 40rem;
    margin-bottom: 2.5rem;
}

.section__eyebrow {
    font-family: var(--font-display);
    font-size: var(--type-label);
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--secondary-color);
    margin: 0 0 0.5rem;
}

.section__title {
    font-family: var(--font-display);
    font-size: var(--type-h2);
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0 0 var(--type-space-heading-body);
    line-height: 1.22;
    color: var(--text-heading);
}

.section__intro {
    color: var(--text-muted);
    margin: 0;
    font-size: var(--type-lead);
    font-weight: 400;
    line-height: 1.7;
    max-width: 42rem;
}

/* Cards grid */
.cards-2 {
    display: grid;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .cards-2 {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* —— Divisions: light section, footer palette, creative vs professional cards —— */
.section--divisions {
    --division-banner-h: clamp(170px, 28vw, 236px);
    position: relative;
    background: linear-gradient(180deg, var(--neutral-mist) 0%, var(--neutral-soft) 100%);
    overflow: hidden;
}

.section--divisions::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 70% 45% at 92% 8%, rgba(var(--rgb-teal-deep), 0.07), transparent),
        radial-gradient(ellipse 50% 40% at 8% 95%, rgba(var(--rgb-text-dark), 0.05), transparent);
    pointer-events: none;
}

.section--divisions .container {
    position: relative;
    z-index: 1;
}

.divisions-intro {
    max-width: 38rem;
}

.section__eyebrow--divisions {
    color: var(--footer-blue);
    letter-spacing: 0.24em;
}

.section__title--divisions {
    font-family: var(--font-display);
    color: var(--footer-navy);
    font-weight: 700;
    letter-spacing: -0.02em;
}

/* Scroll reveal — CSS fallback; GSAP drives motion when .sx-scroll-ready */
[data-reveal] {
    opacity: 0;
    transform: translateY(26px);
    transition:
        opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

html.sx-scroll-ready [data-reveal] {
    transition: none;
}

[data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}

.cards-2--divisions [data-reveal]:nth-child(1) {
    transition-delay: 0.08s;
}

.cards-2--divisions [data-reveal]:nth-child(2) {
    transition-delay: 0.18s;
}

@media (prefers-reduced-motion: reduce) {
    [data-reveal] {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

.cards-2--divisions {
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: stretch;
}

@media (min-width: 768px) {
    .cards-2--divisions {
        grid-template-columns: 1.05fr 0.95fr;
    }
}

/* Shared card base */
.card-division {
    position: relative;
}

/* —— Division hybrid banner: photo + scrim + SVG —— */
.card-division__media {
    position: relative;
    z-index: 1;
    width: 100%;
    height: var(--division-banner-h);
    overflow: hidden;
    isolation: isolate;
    background: var(--footer-navy);
}

.card-division--creative .card-division__media {
    border-radius: 21px 21px 0 0;
}

.card-division--pro .card-division__media {
    border-radius: 0;
}

.card-division__media-parallax {
    position: absolute;
    inset: 0;
    overflow: hidden;
}

.card-division__media-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform-origin: center center;
    opacity: 0.88;
    transform: scale(1.09) translate3d(0, 6px, 0);
    filter: saturate(0.92) contrast(1.05);
    transition:
        opacity 1s cubic-bezier(0.22, 1, 0.36, 1),
        transform 1.15s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.5s ease;
    will-change: transform, opacity;
}

.card-division__media.is-division-inview .card-division__media-img {
    opacity: 1;
    transform: scale(1) translate3d(0, 0, 0);
}

.card-division__media-scrim {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.card-division__media-scrim--teal {
    background: linear-gradient(
        180deg,
        rgba(6, 32, 38, 0.82) 0%,
        rgba(var(--rgb-teal-deep), 0.5) 42%,
        rgba(var(--rgb-teal-deep), 0.12) 72%,
        rgba(255, 255, 255, 0.06) 100%
    );
}

.card-division__media-scrim--consult {
    background: linear-gradient(
        165deg,
        rgba(10, 50, 58, 0.78) 0%,
        rgba(var(--rgb-teal-deep), 0.38) 45%,
        rgba(76, 175, 80, 0.22) 78%,
        rgba(255, 255, 255, 0.08) 100%
    );
}

.card-division__media-noise {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    opacity: 0.045;
    mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 180px 180px;
}

.card-division__media-vignette {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.06),
        inset 0 -32px 48px rgba(0, 0, 0, 0.18),
        inset 0 24px 56px rgba(0, 0, 0, 0.22);
}

.card-division__media-svg-wrap {
    position: absolute;
    inset: 0;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0.65rem 1.1rem 0.85rem;
    pointer-events: none;
}

.card-division__media-svg-wrap .card-division__creative-svg,
.card-division__media-svg-wrap .card-division__pro-svg {
    width: 100%;
    max-width: min(300px, 92%);
    height: auto;
    max-height: 92%;
    margin-left: auto;
    display: block;
    color: rgba(240, 250, 252, 0.92);
    filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.2));
}

.card-division__media [data-division-draw] {
    transition: stroke-dashoffset 1.55s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) and (pointer: fine) {
    .card-division:hover .card-division__media-img {
        transform: scale(1.06) translate3d(0, 0, 0);
        filter: saturate(1) contrast(1.06);
    }

    .card-division--creative:hover .card-division__creative-svg,
    .card-division--pro:hover .card-division__pro-svg {
        filter: drop-shadow(0 3px 16px rgba(0, 0, 0, 0.28));
    }
}

@media (prefers-reduced-motion: reduce) {
    .card-division__media-img {
        opacity: 1;
        transform: none;
        filter: none;
        transition: none;
    }

    .card-division:hover .card-division__media-img {
        transform: none;
    }
}

.card-division__title {
    font-family: var(--font-display);
    font-size: clamp(1.2rem, 2.2vw, 1.45rem);
    font-weight: 700;
    color: var(--footer-navy);
    margin: 0 0 0.65rem;
    line-height: 1.25;
}

.card-division__title--pro {
    font-size: clamp(1.15rem, 2vw, 1.35rem);
    font-weight: 600;
    letter-spacing: -0.02em;
    margin-bottom: 0;
}

.card-division__text {
    color: var(--text-muted);
    margin: 0 0 var(--type-space-paragraph);
    font-size: var(--type-body);
    line-height: 1.7;
}

.card-division__text--pro {
    font-size: var(--type-body);
    margin-bottom: 1.25rem;
}

/* Creative — infrastructure */
.card-division--creative {
    background: #fff;
    border-radius: 22px;
    border: 1px solid rgba(var(--rgb-text-dark), 0.09);
    box-shadow:
        0 20px 50px rgba(var(--rgb-text-dark), 0.08),
        0 0 0 1px rgba(255, 255, 255, 0.8) inset;
    overflow: hidden;
    transition:
        transform 0.45s cubic-bezier(0.34, 1.3, 0.64, 1),
        box-shadow 0.4s ease;
}

.card-division--creative:hover {
    transform: translateY(-10px) rotate(-0.35deg);
    box-shadow:
        0 28px 64px rgba(var(--rgb-text-dark), 0.12),
        0 0 0 1px rgba(255, 255, 255, 0.9) inset;
}

.card-division--creative:hover .card-division__cv-line--anim {
    animation-duration: 9s;
}

@media (prefers-reduced-motion: reduce) {
    .card-division--creative:hover {
        transform: none;
    }
}

.card-division__blob {
    position: absolute;
    top: -35%;
    right: -25%;
    width: 75%;
    height: 75%;
    background: radial-gradient(
        circle,
        rgba(var(--rgb-text-dark), 0.14) 0%,
        rgba(var(--rgb-teal-deep), 0.12) 42%,
        transparent 70%
    );
    pointer-events: none;
    z-index: 0;
    animation: divisions-blob-shift 12s ease-in-out infinite;
}

.card-division--creative .card-division__blob {
    opacity: 0.55;
}

@keyframes divisions-blob-shift {
    0%,
    100% {
        transform: translate(0, 0) scale(1);
    }
    50% {
        transform: translate(-6%, 4%) scale(1.05);
    }
}

@media (prefers-reduced-motion: reduce) {
    .card-division__blob {
        animation: none;
    }
}

.card-division__media-svg-wrap .card-division__creative-svg {
    animation: divisions-svg-drift 9s ease-in-out infinite;
}

@keyframes divisions-svg-drift {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-6px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .card-division__media-svg-wrap .card-division__creative-svg {
        animation: none;
    }
}

.card-division__cv-line--anim {
    stroke-dasharray: 8 6;
    animation: divisions-dash-flow 14s linear infinite;
}

@keyframes divisions-dash-flow {
    to {
        stroke-dashoffset: -120;
    }
}

.card-division__cv-orbit {
    animation: divisions-ring-pulse 5s ease-in-out infinite;
}

@keyframes divisions-ring-pulse {
    0%,
    100% {
        opacity: 0.22;
    }
    50% {
        opacity: 0.42;
    }
}

@media (prefers-reduced-motion: reduce) {
    .card-division__cv-line--anim,
    .card-division__cv-orbit {
        animation: none;
    }
}

.card-division__creative-head {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.25rem 1.5rem 0;
}

.card-division__badge-creative {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.1rem;
    height: 3.1rem;
    border-radius: 12px;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1rem;
    color: #fff;
    background: var(--footer-navy);
    box-shadow: 0 6px 18px rgba(var(--rgb-text-dark), 0.22);
    transform: rotate(-7deg);
    transition:
        transform 0.35s cubic-bezier(0.34, 1.4, 0.64, 1),
        background 0.3s ease,
        box-shadow 0.3s ease;
}

.card-division--creative:hover .card-division__badge-creative {
    transform: rotate(0deg) scale(1.05);
    background: var(--footer-blue);
    box-shadow: 0 8px 22px rgba(var(--rgb-teal-deep), 0.3);
}

.card-division__spark {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-accent);
    box-shadow: 0 0 0 6px rgba(var(--rgb-green), 0.2);
    animation: divisions-spark 2.4s ease-in-out infinite;
}

@keyframes divisions-spark {
    0%,
    100% {
        transform: scale(1);
        opacity: 1;
    }
    50% {
        transform: scale(1.15);
        opacity: 0.85;
    }
}

@media (prefers-reduced-motion: reduce) {
    .card-division__spark {
        animation: none;
    }
}

.card-division--creative .card-division__title {
    position: relative;
    z-index: 2;
    padding: 0.35rem 1.5rem 0;
}

.card-division--creative .card-division__text {
    position: relative;
    z-index: 2;
    padding: 0 1.5rem;
}

.card-division__chips {
    position: relative;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0.35rem 1.5rem 0;
}

.card-division__chip {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(var(--rgb-teal-deep), 0.12);
    color: var(--footer-navy);
    border: 1px solid rgba(var(--rgb-teal-deep), 0.18);
    transition:
        background 0.25s ease,
        transform 0.25s ease;
}

.card-division--creative:hover .card-division__chip {
    background: rgba(var(--rgb-text-dark), 0.1);
    border-color: rgba(var(--rgb-text-dark), 0.2);
}

.card-division--creative:hover .card-division__chip:nth-child(2) {
    transform: translateY(-2px);
    transition-delay: 0.04s;
}

.card-division--creative:hover .card-division__chip:nth-child(3) {
    transform: translateY(-2px);
    transition-delay: 0.08s;
}

@media (prefers-reduced-motion: reduce) {
    .card-division--creative:hover .card-division__chip:nth-child(2),
    .card-division--creative:hover .card-division__chip:nth-child(3) {
        transform: none;
    }
}

/* Professional — ISO / consulting (visually aligned with creative card) */
.card-division--pro {
    background: #fff;
    border-radius: 20px;
    border: 1px solid rgba(var(--rgb-text-dark), 0.09);
    box-shadow:
        0 18px 48px rgba(var(--rgb-text-dark), 0.07),
        0 0 0 1px rgba(255, 255, 255, 0.85) inset;
    padding: 0;
    overflow: hidden;
    transition:
        transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.card-division--pro:hover {
    transform: translateY(-6px);
    box-shadow:
        0 26px 56px rgba(var(--rgb-text-dark), 0.11),
        0 0 0 1px rgba(255, 255, 255, 0.9) inset;
    border-color: rgba(var(--rgb-teal-deep), 0.2);
}

@media (prefers-reduced-motion: reduce) {
    .card-division--pro:hover {
        transform: none;
    }
}

.card-division__pro-accent-bar {
    height: 4px;
    width: 100%;
    background: var(--footer-navy);
    transition: background 0.35s ease;
}

.card-division--pro:hover .card-division__pro-accent-bar {
    background: var(--footer-blue);
}

.card-division__pro-wash {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(4px + var(--division-banner-h));
    bottom: 0;
    background: radial-gradient(ellipse 95% 80% at 100% 0%, rgba(var(--rgb-teal-deep), 0.1), transparent 58%);
    pointer-events: none;
    z-index: 0;
}

.card-division__media .card-division__pro-grid {
    position: absolute;
    top: 0.55rem;
    right: 0.5rem;
    width: 5.5rem;
    height: 5.5rem;
    color: rgba(240, 250, 252, 0.55);
    pointer-events: none;
    opacity: 0.9;
    z-index: 2;
}

.card-division__pro-grid-svg {
    width: 100%;
    height: 100%;
}

.card-division__media-svg-wrap .card-division__pro-svg {
    animation: divisions-pro-svg 10s ease-in-out infinite;
}

@keyframes divisions-pro-svg {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-5px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .card-division__media-svg-wrap .card-division__pro-svg {
        animation: none;
    }
}

.card-division__pro-doc--a,
.card-division__pro-doc--b,
.card-division__pro-doc--c {
    transform-origin: center;
    animation: pro-doc-nudge 7s ease-in-out infinite;
}

.card-division__pro-doc--b {
    animation-delay: 0.25s;
}

.card-division__pro-doc--c {
    animation-delay: 0.5s;
}

@keyframes pro-doc-nudge {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-3px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .card-division__pro-doc--a,
    .card-division__pro-doc--b,
    .card-division__pro-doc--c {
        animation: none;
    }
}

.card-division__pro-seal {
    animation: divisions-ring-pulse 4.5s ease-in-out infinite;
}

.card-division__pro-head {
    position: relative;
    z-index: 2;
    display: flex;
    gap: 0.85rem;
    align-items: center;
    padding: 0.35rem 1.5rem 0;
    margin-bottom: 0.85rem;
}

.card-division__badge-pro {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.1rem;
    height: 3.1rem;
    border-radius: 12px;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1rem;
    color: #fff;
    background: var(--footer-navy);
    box-shadow: 0 6px 18px rgba(var(--rgb-text-dark), 0.22);
    transition:
        background 0.3s ease,
        box-shadow 0.3s ease,
        transform 0.3s ease;
}

.card-division--pro:hover .card-division__badge-pro {
    background: var(--footer-blue);
    box-shadow: 0 8px 22px rgba(var(--rgb-teal-deep), 0.3);
    transform: translateY(-2px);
}

@media (prefers-reduced-motion: reduce) {
    .card-division--pro:hover .card-division__badge-pro {
        transform: none;
    }
}

.card-division__pro-meta {
    flex: 1;
    min-width: 0;
}

.card-division__pro-icon {
    flex-shrink: 0;
    width: 2.85rem;
    height: 2.85rem;
    display: grid;
    place-items: center;
    border-radius: 10px;
    color: var(--footer-navy);
    background: rgba(var(--rgb-text-dark), 0.06);
    border: 1px solid rgba(var(--rgb-text-dark), 0.12);
    transition:
        background 0.3s ease,
        border-color 0.3s ease,
        color 0.3s ease,
        transform 0.3s ease;
}

.card-division--pro:hover .card-division__pro-icon {
    background: rgba(var(--rgb-teal-deep), 0.12);
    border-color: rgba(var(--rgb-teal-deep), 0.28);
    color: var(--footer-blue);
    transform: scale(1.04);
}

@media (prefers-reduced-motion: reduce) {
    .card-division--pro:hover .card-division__pro-icon {
        transform: none;
    }
}

.card-division__pro-label {
    margin: 0 0 0.2rem;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--footer-blue);
}

.card-division__pro-list {
    position: relative;
    z-index: 2;
    list-style: none;
    margin: 0 0 1rem;
    padding: 0 1.5rem;
}

.card-division__pro-list li {
    display: flex;
    gap: 0.65rem;
    align-items: flex-start;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--color-ink-muted);
    margin-bottom: 0.55rem;
}

.card-division__pro-list li:last-child {
    margin-bottom: 0;
}

.card-division__pro-check {
    flex-shrink: 0;
    margin-top: 0.12rem;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 50%;
    color: #fff;
    background: var(--footer-blue);
    display: grid;
    place-items: center;
}

.card-division__pro-check svg {
    width: 10px;
    height: 10px;
}

.card-division--pro .card-division__text--pro {
    position: relative;
    z-index: 2;
    padding: 0 1.5rem;
}

/* Division CTAs */
.btn-division {
    position: relative;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    cursor: pointer;
    transition:
        transform var(--btn-transition),
        box-shadow var(--btn-transition),
        background var(--btn-transition),
        color var(--btn-transition),
        border-color var(--btn-transition);
}

.btn-division--creative,
.btn-division--pro {
    padding: 0.72rem 1.35rem;
    border-radius: var(--btn-radius);
    letter-spacing: var(--btn-letter);
    color: #fff;
    background: var(--btn-primary-bg);
    border: 1.5px solid var(--btn-primary-bg);
    box-shadow: 0 1px 2px rgba(var(--rgb-teal-deep), 0.12);
}

.btn-division--creative {
    margin: 1.1rem 1.5rem 1.5rem;
}

.btn-division--pro {
    margin: 0 1.5rem 1.5rem;
}

@media (hover: hover) and (pointer: fine) {
    .btn-division--creative:hover,
    .btn-division--pro:hover {
        color: #fff;
        background: var(--btn-primary-hover);
        border-color: var(--btn-primary-hover);
        box-shadow: var(--btn-shadow-hover);
        transform: translateY(-2px) scale(1.02);
    }
}

.btn-division--creative:active,
.btn-division--pro:active {
    background: var(--btn-primary-active);
    border-color: var(--btn-primary-active);
}

@media (prefers-reduced-motion: reduce) {
    .btn-division--creative:hover,
    .btn-division--creative:active,
    .btn-division--pro:hover,
    .btn-division--pro:active {
        transform: none;
    }
}

/* Stats strip */
.stats-strip {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    padding: 2rem;
    border-radius: var(--radius-lg);
    background: var(--gradient-brand-primary);
    color: var(--text-on-dark);
    text-align: center;
    box-shadow: var(--shadow-md);
}

@media (min-width: 640px) {
    .stats-strip {
        grid-template-columns: repeat(4, 1fr);
    }
}

.stats-strip__value {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
}

.stats-strip__label {
    font-size: 0.8125rem;
    color: var(--text-on-dark-muted);
    margin-top: 0.35rem;
}

/* Capability cards */
.cap-grid {
    display: grid;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .cap-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* —— How we deliver: dual timeline / process —— */
.section--deliver {
    position: relative;
    overflow: hidden;
}

.section--deliver .sx-deliver-bg {
    pointer-events: none;
    position: absolute;
    inset: -15% -8% -12%;
    background:
        radial-gradient(ellipse 55% 45% at 12% 20%, rgba(var(--rgb-teal-deep), 0.1) 0%, transparent 55%),
        radial-gradient(ellipse 50% 42% at 92% 75%, rgba(var(--rgb-text-dark), 0.07) 0%, transparent 48%),
        linear-gradient(178deg, rgba(255, 255, 255, 0.55) 0%, rgba(248, 250, 252, 0.92) 100%);
}

.section--deliver .sx-deliver-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.5;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cpath d='M50 0 L100 50 L50 100 L0 50 Z' fill='none' stroke='%235f7d95' stroke-opacity='0.04' stroke-width='0.75'/%3E%3C/svg%3E");
    background-size: 100px 100px;
}

.sx-deliver-inner {
    position: relative;
    z-index: 1;
}

.deliver-heading {
    font-family: var(--font-display);
    font-size: var(--type-h2);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: var(--text-heading);
}

.sx-deliver__intro {
    max-width: 40rem;
    font-size: var(--type-lead);
    line-height: 1.7;
    color: var(--text-muted);
}

.deliver-columns {
    display: grid;
    gap: clamp(2rem, 5vw, 3.25rem);
    margin-top: clamp(2rem, 4vw, 2.75rem);
}

@media (min-width: 900px) {
    .deliver-columns {
        grid-template-columns: 1fr 1fr;
        align-items: start;
        gap: clamp(1.75rem, 3.5vw, 2.75rem);
    }
}

.deliver-column {
    --deliver-accent: var(--footer-blue);
    --deliver-accent-mid: color-mix(in srgb, var(--footer-blue) 75%, var(--footer-navy));
    --deliver-accent-deep: var(--footer-navy);
    --deliver-glow: var(--footer-blue-glow);
    border-radius: clamp(18px, 2.5vw, 22px);
    padding: clamp(1.25rem, 3vw, 1.65rem);
    border: 1px solid rgba(var(--rgb-text-dark), 0.09);
    background: rgba(255, 255, 255, 0.55);
    box-shadow: 0 8px 36px rgba(var(--rgb-text-dark), 0.05);
}

.deliver-column--consulting {
    --deliver-accent: #5a7a96;
    --deliver-accent-mid: #3d5a73;
    --deliver-accent-deep: var(--footer-navy);
    --deliver-glow: rgba(90, 122, 150, 0.32);
    border-color: rgba(61, 90, 115, 0.12);
    background: linear-gradient(165deg, rgba(255, 255, 255, 0.72) 0%, rgba(244, 248, 252, 0.65) 100%);
}

.deliver-column__head {
    margin-bottom: 1.35rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(var(--rgb-text-dark), 0.08);
}

.deliver-column__title {
    font-family: var(--font-display);
    font-size: var(--type-h3);
    font-weight: 600;
    margin: 0 0 var(--type-space-heading-body);
    color: var(--text-heading);
    letter-spacing: -0.015em;
    line-height: 1.35;
}

.deliver-column__lede {
    margin: 0;
    font-size: var(--type-body);
    line-height: 1.7;
    color: var(--text-muted);
}

.deliver-track {
    display: grid;
    grid-template-columns: 0.875rem 1fr;
    gap: clamp(1rem, 2.5vw, 1.35rem);
    align-items: stretch;
}

.deliver-track__rail {
    position: relative;
    border-radius: 4px;
    min-height: 100%;
}

.deliver-track__line-bg {
    position: absolute;
    inset: 0;
    border-radius: 4px;
    background: linear-gradient(
        180deg,
        rgba(var(--rgb-text-dark), 0.08) 0%,
        rgba(var(--rgb-text-dark), 0.04) 100%
    );
}

.deliver-track__progress {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 0%;
    border-radius: 4px;
    background: linear-gradient(
        180deg,
        var(--deliver-accent) 0%,
        var(--deliver-accent-mid) 55%,
        var(--deliver-accent-deep) 100%
    );
    box-shadow: 0 0 20px var(--deliver-glow);
    will-change: height;
}

html.sx-motion-static .deliver-track__progress {
    height: 100%;
    opacity: 0.42;
}

.deliver-track__steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: clamp(0.85rem, 2vw, 1.1rem);
}

.deliver-step__card {
    position: relative;
    display: grid;
    grid-template-columns: auto 2.75rem minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: 0.65rem;
    row-gap: 0.35rem;
    align-items: start;
    padding: clamp(1rem, 2.2vw, 1.2rem) clamp(1rem, 2.5vw, 1.25rem);
    border-radius: clamp(16px, 2vw, 18px);
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(var(--rgb-text-dark), 0.1);
    box-shadow: 0 4px 20px rgba(var(--rgb-text-dark), 0.06);
    transition:
        transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.35s ease,
        border-color 0.3s ease,
        background 0.3s ease;
}

.deliver-step__badge {
    grid-column: 1;
    grid-row: 1 / -1;
    align-self: start;
    font-family: var(--font-display);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    color: var(--deliver-accent);
    opacity: 0.85;
    line-height: 1;
    padding-top: 0.25rem;
}

.deliver-step__icon {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    color: var(--deliver-accent);
    transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), color 0.3s ease;
}

.deliver-step__title {
    grid-column: 3;
    grid-row: 1;
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(1rem, 1.08vw, 1.0625rem);
    font-weight: 700;
    color: var(--text-heading);
    letter-spacing: -0.02em;
    line-height: 1.25;
}

.deliver-step__desc {
    grid-column: 2 / -1;
    grid-row: 2;
    margin: 0;
    font-size: clamp(0.875rem, 0.98vw, 0.9375rem);
    line-height: 1.55;
    color: var(--color-ink-muted);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.deliver-step:hover .deliver-step__card {
    transform: scale(1.02) translateY(-2px);
    border-color: color-mix(in srgb, var(--deliver-accent) 45%, transparent);
    box-shadow:
        0 14px 40px rgba(var(--rgb-text-dark), 0.1),
        0 0 0 1px color-mix(in srgb, var(--deliver-accent) 22%, transparent);
}

.deliver-step.is-active .deliver-step__card {
    border-color: color-mix(in srgb, var(--deliver-accent) 55%, transparent);
    background: color-mix(in srgb, var(--deliver-accent) 7%, white);
    box-shadow:
        0 16px 44px rgba(var(--rgb-text-dark), 0.11),
        0 0 28px var(--deliver-glow);
}

@media (prefers-reduced-motion: reduce) {
    .deliver-step:hover .deliver-step__card {
        transform: none;
    }

    .deliver-track__progress {
        height: 100%;
        opacity: 0.45;
    }
}

.cap-card {
    padding: 1.75rem;
    border-radius: var(--radius-md);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
}

.cap-card h3 {
    font-family: var(--font-display);
    font-size: var(--type-h3);
    margin: 0 0 var(--type-space-heading-body);
    color: var(--text-heading);
    font-weight: 600;
    line-height: 1.35;
    letter-spacing: -0.01em;
}

.cap-card p {
    color: var(--text-muted);
    font-size: var(--type-body);
    line-height: 1.7;
    margin: 0 0 var(--type-space-paragraph);
}

.cap-card ul {
    margin: 0;
    padding-left: 1.1rem;
    color: var(--color-ink-muted);
    font-size: 0.9rem;
}

.cap-card__tag {
    display: inline-block;
    margin-top: 1rem;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-accent-dark);
}

/* Quote block */
.quote-block {
    position: relative;
    padding: clamp(2rem, 5vw, 3.5rem);
    padding-top: clamp(2.5rem, 5vw, 3.75rem);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.quote-block::before {
    content: "\201C";
    position: absolute;
    top: 1.25rem;
    left: 1.5rem;
    font-family: var(--font-display);
    font-size: clamp(2.75rem, 6vw, 3.5rem);
    font-weight: 700;
    font-style: normal;
    line-height: 1;
    color: var(--btn-primary-bg);
    opacity: 0.2;
    pointer-events: none;
}

.quote-block blockquote {
    margin: 0;
    font-family: var(--font-body);
    font-size: clamp(1.125rem, 2vw, 1.35rem);
    font-weight: 500;
    font-style: italic;
    line-height: 1.65;
    color: var(--text-heading);
}

.quote-block cite {
    display: block;
    margin-top: var(--type-space-heading-body);
    font-style: normal;
    font-family: var(--font-body);
    font-size: var(--type-small);
    color: var(--text-muted);
}

.quote-block cite strong {
    display: block;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: var(--type-body);
    color: var(--primary-color);
}

/* Insights */
.insights-grid {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .insights-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.insight-card {
    padding: 1.5rem;
    border-radius: var(--radius-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    min-height: 180px;
    display: flex;
    flex-direction: column;
}

.insight-card__cat {
    font-family: var(--font-display);
    font-size: var(--type-label);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-teal);
    margin-bottom: 0.65rem;
}

.insight-card h4 {
    font-family: var(--font-display);
    font-size: var(--type-h3);
    margin: 0 0 auto;
    line-height: 1.35;
    color: var(--text-heading);
    font-weight: 600;
    letter-spacing: -0.01em;
}

.insight-card a {
    margin-top: 1rem;
    font-weight: 600;
    font-size: 0.875rem;
}

.section__actions {
    margin-top: 1.5rem;
}

/* Why us */
.why-grid {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .why-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .why-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.why-card {
    text-align: center;
    padding: 1.5rem 1rem;
    border-radius: var(--radius-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
}

.why-card__icon {
    width: 3rem;
    height: 3rem;
    margin: 0 auto 1rem;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: rgba(var(--rgb-text-dark), 0.1);
    font-size: 1.25rem;
}

.why-card h4 {
    font-family: var(--font-display);
    font-size: 1.0625rem;
    margin: 0 0 var(--type-space-heading-body);
    color: var(--text-heading);
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1.35;
}

.why-card p {
    margin: 0;
    font-size: var(--type-body);
    line-height: 1.7;
    color: var(--text-muted);
}

/* Testimonials — base grid (legacy) */
.testimonials {
    display: grid;
    gap: 1.5rem;
}

@media (min-width: 900px) {
    .testimonials {
        grid-template-columns: repeat(2, 1fr);
    }
}

.testimonial {
    margin: 0;
    padding: 1.75rem;
    border-radius: var(--radius-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
}

.testimonial__stars {
    color: var(--color-accent);
    letter-spacing: 0.15em;
    font-size: 0.9rem;
    margin-bottom: 0.75rem;
}

.testimonial p {
    margin: 0 0 var(--type-space-paragraph);
    color: var(--text-muted);
    font-size: var(--type-body);
    line-height: 1.7;
}

.testimonial footer {
    font-size: var(--type-small);
    color: var(--text-subtle);
}

.testimonial footer strong {
    color: var(--text-heading);
    font-weight: 600;
}

/* —— Client voices: premium section —— */
.section.sx-voices-scene {
    position: relative;
    overflow: hidden;
    padding-block: clamp(5rem, 11vw, 5.5rem);
}

.sx-voices-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse 70% 45% at 50% 0%, rgba(var(--rgb-teal-deep), 0.07), transparent 55%),
        radial-gradient(ellipse 50% 40% at 12% 100%, rgba(76, 175, 80, 0.05), transparent 50%),
        linear-gradient(180deg, #eef8fa 0%, #ffffff 42%, #f7fcfd 100%);
    opacity: 1;
}

.sx-voices-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.35;
    background-image: url("data:image/svg+xml,%3Csvg width='48' height='48' viewBox='0 0 48 48' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M48 0v48H0' fill='none' stroke='%230f7c8a' stroke-width='0.4' opacity='0.07'/%3E%3C/svg%3E");
    background-size: 48px 48px;
}

.sx-voices-inner {
    position: relative;
    z-index: 1;
}

.sx-voices__header {
    /* Matches other centered section headers (FAQ, capabilities): width + rhythm from .section__header + page-home overrides */
    max-width: 44rem;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.sx-voices__header .section__intro {
    margin-inline: auto;
}

.voices-slider-block {
    margin-top: clamp(1.5rem, 3.5vw, 2.25rem);
}

.voices-slider-shell {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    grid-template-areas:
        "view view"
        "prev next";
    gap: 1rem 0.75rem;
    align-items: center;
    max-width: min(72rem, 100%);
    margin-inline: auto;
}

.voices-slider__viewport {
    grid-area: view;
    min-width: 0;
    position: relative;
}

.voices-slider__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    padding: 0;
    border-radius: 50%;
    border: 1px solid rgba(var(--rgb-text-dark), 0.12);
    background: rgba(255, 255, 255, 0.95);
    color: var(--footer-navy);
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(var(--rgb-teal-deep), 0.08);
    transition:
        background 0.25s ease,
        color 0.25s ease,
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.2s ease;
}

.voices-slider__btn:hover {
    background: var(--btn-primary-bg);
    color: #fff;
    border-color: var(--btn-primary-bg);
    box-shadow: 0 6px 18px rgba(var(--rgb-teal-deep), 0.22);
}

.voices-slider__btn:focus-visible {
    outline: 2px solid var(--footer-blue);
    outline-offset: 3px;
}

.voices-slider__btn--prev {
    grid-area: prev;
    justify-self: end;
}

.voices-slider__btn--next {
    grid-area: next;
    justify-self: start;
}

@media (min-width: 768px) {
    .voices-slider-shell {
        grid-template-columns: auto minmax(0, 1fr) auto;
        grid-template-rows: auto;
        grid-template-areas: "prev view next";
        gap: 0 0.65rem;
        max-width: min(72rem, 100%);
    }

    .voices-slider__btn--prev,
    .voices-slider__btn--next {
        justify-self: center;
    }
}

@media (min-width: 640px) {
    .voices-slider__viewport {
        mask-image: linear-gradient(to right, transparent, #000 4%, #000 96%, transparent);
        -webkit-mask-image: linear-gradient(to right, transparent, #000 4%, #000 96%, transparent);
    }
}

.voices-swiper {
    overflow: visible;
    padding-block: 0.35rem;
}

.voices-swiper .swiper-wrapper {
    align-items: stretch;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.voices-swiper .swiper-slide {
    height: auto;
    display: flex;
    justify-content: center;
    align-items: stretch;
    box-sizing: border-box;
    opacity: 0.8;
    filter: blur(0.4px);
    transition:
        opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1),
        filter 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}

.voices-swiper .swiper-slide-active {
    opacity: 1;
    filter: none;
    z-index: 2;
}

.voices-swiper .swiper-slide .testimonial--slide {
    width: 100%;
    max-width: 22.5rem;
    margin-inline: auto;
    transition:
        transform 0.45s cubic-bezier(0.4, 0, 0.2, 1),
        box-shadow 0.45s cubic-bezier(0.4, 0, 0.2, 1),
        border-color 0.45s ease;
    transform: scale(0.96);
    box-shadow:
        0 6px 24px rgba(var(--rgb-teal-deep), 0.06),
        0 2px 8px rgba(0, 0, 0, 0.04);
}

.voices-swiper .swiper-slide-active .testimonial--slide {
    transform: scale(1.05);
    box-shadow:
        0 18px 48px rgba(var(--rgb-teal-deep), 0.14),
        0 8px 24px rgba(0, 0, 0, 0.06),
        0 0 0 1px rgba(var(--rgb-teal-bright), 0.12);
    border-color: rgba(var(--rgb-teal-deep), 0.1);
}

@media (max-width: 639px) {
    .voices-slider__viewport {
        mask-image: none;
        -webkit-mask-image: none;
    }

    .voices-swiper .swiper-slide {
        opacity: 1;
        filter: none;
    }

    .voices-swiper .swiper-slide .testimonial--slide,
    .voices-swiper .swiper-slide-active .testimonial--slide {
        transform: none;
        max-width: min(22.5rem, 100%);
        box-shadow:
            0 8px 32px rgba(var(--rgb-teal-deep), 0.08),
            0 2px 8px rgba(0, 0, 0, 0.04);
    }
}

@media (prefers-reduced-motion: reduce) {
    .voices-swiper .swiper-slide,
    .voices-swiper .swiper-slide .testimonial--slide,
    .voices-swiper .swiper-slide-active .testimonial--slide {
        transition: none;
    }

    .voices-swiper .swiper-slide {
        opacity: 1;
        filter: none;
    }

    .voices-swiper .swiper-slide .testimonial--slide,
    .voices-swiper .swiper-slide-active .testimonial--slide {
        transform: none;
    }
}

.voices-slider__pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0.4rem;
    min-height: 1.5rem;
    margin-top: clamp(1rem, 2.5vw, 1.35rem);
    margin-bottom: 0;
}

.voices-slider__pagination .swiper-pagination-bullet {
    width: 7px;
    height: 7px;
    margin: 0 4px !important;
    background: var(--brand-teal-deep);
    opacity: 0.3;
    transition:
        opacity 0.3s ease,
        transform 0.3s ease,
        background 0.3s ease;
}

.voices-slider__pagination .swiper-pagination-bullet-active {
    opacity: 1;
    transform: scale(1.25);
    background: var(--brand-teal-bright);
}

.client-logos-marquee {
    position: relative;
    margin-top: clamp(2rem, 4.5vw, 2.75rem);
    padding-block: clamp(0.65rem, 2vw, 1rem);
}

.client-logos-marquee__viewport {
    overflow: hidden;
    margin-inline: calc(-1 * var(--container-padding, 1.25rem));
    mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
    -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}

.client-logos-marquee__track {
    display: flex;
    width: max-content;
    animation: client-logos-marquee 48s linear infinite;
    will-change: transform;
}

.client-logos-marquee:hover .client-logos-marquee__track,
.client-logos-marquee:focus-within .client-logos-marquee__track {
    animation-play-state: paused;
}

@keyframes client-logos-marquee {
    0% {
        transform: translate3d(0, 0, 0);
    }

    100% {
        transform: translate3d(-50%, 0, 0);
    }
}

.client-logos-marquee__list {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    list-style: none;
    margin: 0;
    padding: 0 clamp(1rem, 2.5vw, 1.75rem);
    gap: clamp(1.75rem, 4vw, 3.5rem);
}

.client-logos-marquee__item {
    flex-shrink: 0;
}

.client-logos-marquee__mark {
    display: block;
    max-width: 11rem;
    font-family: var(--font-display);
    font-size: clamp(0.75rem, 1.05vw, 0.875rem);
    font-weight: 700;
    letter-spacing: 0.02em;
    line-height: 1.3;
    text-align: center;
    color: rgba(15, 56, 62, 0.88);
    filter: grayscale(1);
    opacity: 0.72;
    transition:
        filter 0.35s ease,
        opacity 0.35s ease,
        transform 0.3s ease,
        color 0.3s ease;
}

@media (hover: hover) and (pointer: fine) {
    .client-logos-marquee__item:hover .client-logos-marquee__mark {
        filter: grayscale(0);
        opacity: 1;
        transform: scale(1.06);
        color: var(--brand-teal-deep);
    }
}

@media (max-width: 767px) {
    .client-logos-marquee__viewport {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        overscroll-behavior-x: contain;
        mask-image: none;
        -webkit-mask-image: none;
        margin-inline: calc(-1 * var(--container-padding, 1.25rem));
        padding-inline: var(--container-padding, 1.25rem);
    }

    .client-logos-marquee__track {
        animation: none;
        padding-inline: 0.25rem;
    }

    .client-logos-marquee__list[aria-hidden="true"] {
        display: none;
    }

    .client-logos-marquee__item {
        scroll-snap-align: center;
    }
}

@media (prefers-reduced-motion: reduce) {
    .client-logos-marquee__track {
        animation: none;
        flex-wrap: wrap;
        justify-content: center;
        width: 100%;
        max-width: 52rem;
        margin-inline: auto;
        row-gap: 0.75rem;
    }

    .client-logos-marquee__list[aria-hidden="true"] {
        display: none;
    }

    .client-logos-marquee__viewport {
        overflow: visible;
        mask-image: none;
        -webkit-mask-image: none;
        margin-inline: 0;
        padding-inline: 0;
    }

    .client-logos-marquee__list {
        flex-wrap: wrap;
        justify-content: center;
        gap: 1rem 1.5rem;
        padding-inline: 0;
        width: 100%;
        max-width: 44rem;
        margin-inline: auto;
    }
}

.testimonial--premium {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: clamp(1.65rem, 3vw, 2.1rem);
    border-radius: clamp(16px, 2.5vw, 20px);
    background: rgba(255, 255, 255, 0.78);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border: 1px solid rgba(var(--rgb-text-dark), 0.08);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
    transition:
        transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.35s cubic-bezier(0.22, 1, 0.36, 1),
        border-color 0.35s ease;
}

.testimonial--premium.testimonial--slide {
    width: 100%;
    max-width: 100%;
    min-height: 100%;
    margin-inline: auto;
    padding: clamp(1.5rem, 3vw, 1.75rem);
    border-radius: clamp(16px, 2vw, 20px);
    background: #fff;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    border: 1px solid rgba(var(--rgb-text-dark), 0.06);
    box-shadow:
        0 8px 32px rgba(var(--rgb-teal-deep), 0.08),
        0 2px 8px rgba(0, 0, 0, 0.04);
}

.testimonial__deco-quote {
    position: absolute;
    top: 0.65rem;
    right: 0.85rem;
    width: clamp(72px, 14vw, 100px);
    height: auto;
    color: var(--footer-navy);
    pointer-events: none;
    z-index: 0;
}

.testimonial--premium .testimonial__stars {
    position: relative;
    z-index: 1;
    margin: 0 0 1rem;
    letter-spacing: 0.18em;
    font-size: 0.95rem;
    line-height: 1;
}

.testimonial--slide .testimonial__stars {
    margin-bottom: 0.85rem;
    letter-spacing: 0.14em;
    font-size: 0.7rem;
}

.testimonial__stars-inner {
    display: inline-block;
    color: var(--accent-color);
    transition: transform 0.3s ease;
}

.testimonial--slide .testimonial__stars-inner {
    color: #ffc107;
    text-shadow: none;
    filter: none;
}

.testimonial__body {
    position: relative;
    z-index: 1;
    margin: 0 0 1.25rem;
    padding: 0;
    border: none;
}

.testimonial__body p {
    margin: 0;
    font-family: var(--font-body);
    font-size: var(--type-body);
    font-weight: 400;
    line-height: 1.7;
    color: var(--text-primary);
}

.testimonial__body p::before {
    content: "“";
    font-family: var(--font-display);
    font-size: 1.35em;
    font-weight: 700;
    color: rgba(var(--rgb-teal-deep), 0.35);
    line-height: 0;
    margin-right: 0.08em;
    vertical-align: -0.12em;
}

.testimonial--slide .testimonial__body p::before {
    content: none;
}

@media (hover: hover) and (pointer: fine) {
    html.sx-scroll-ready .testimonial--premium:not(.testimonial--slide):hover {
        transform: translateY(-5px);
        box-shadow: 0 20px 48px rgba(var(--rgb-text-dark), 0.12);
        border-color: rgba(var(--rgb-teal-deep), 0.18);
    }

    html.sx-scroll-ready .testimonial--premium:not(.testimonial--slide):hover .testimonial__stars-inner {
        transform: scale(1.04);
    }
}

@media (hover: hover) and (pointer: fine) and (min-width: 640px) {
    html.sx-scroll-ready .voices-swiper .swiper-slide-active .testimonial--slide:hover {
        transform: scale(1.05) translateY(-2px);
        box-shadow:
            0 20px 52px rgba(var(--rgb-teal-deep), 0.16),
            0 10px 28px rgba(0, 0, 0, 0.07),
            0 0 0 1px rgba(var(--rgb-teal-bright), 0.14);
        border-color: rgba(var(--rgb-teal-deep), 0.14);
    }

    html.sx-scroll-ready .voices-swiper .swiper-slide:not(.swiper-slide-active) .testimonial--slide:hover {
        transform: scale(0.96) translateY(-2px);
        box-shadow:
            0 12px 36px rgba(var(--rgb-teal-deep), 0.09),
            0 4px 14px rgba(0, 0, 0, 0.05);
        border-color: rgba(var(--rgb-teal-deep), 0.1);
    }
}

@media (hover: hover) and (pointer: fine) and (max-width: 639px) {
    html.sx-scroll-ready .voices-swiper .swiper-slide .testimonial--slide:hover {
        transform: translateY(-2px);
        box-shadow:
            0 14px 40px rgba(var(--rgb-teal-deep), 0.1),
            0 2px 10px rgba(0, 0, 0, 0.05);
        border-color: rgba(var(--rgb-teal-deep), 0.12);
    }
}

.testimonial__meta {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-top: auto;
    padding-top: 0.25rem;
    border-top: 1px solid rgba(var(--rgb-text-dark), 0.08);
}

.testimonial__dash {
    color: rgba(var(--rgb-teal-deep), 0.55);
    font-weight: 500;
    line-height: 1.5;
}

.testimonial__by {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.testimonial__name {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-heading);
    letter-spacing: -0.02em;
}

.testimonial__company {
    font-size: 0.8125rem;
    color: var(--text-muted);
    line-height: 1.45;
}

@media (prefers-reduced-motion: reduce) {
    .testimonial--premium {
        transition: none;
    }

    .testimonial--premium:hover {
        transform: none;
    }

    .testimonial--slide:hover {
        transform: none;
    }

    .testimonial__stars-inner {
        transition: none;
    }
}

/* FAQ — premium card accordion (homepage) */
.faq-list {
    max-width: 48rem;
    margin: 0 auto;
}

.sx-faq-scene {
    position: relative;
    overflow: hidden;
}

.sx-faq-bg {
    pointer-events: none;
    position: absolute;
    inset: -20% -10% -15%;
    background:
        radial-gradient(ellipse 70% 55% at 18% 35%, rgba(var(--rgb-teal-deep), 0.09) 0%, transparent 55%),
        radial-gradient(ellipse 60% 50% at 88% 70%, rgba(var(--rgb-text-dark), 0.06) 0%, transparent 50%),
        linear-gradient(165deg, rgba(248, 250, 252, 0.95) 0%, rgba(255, 255, 255, 0.88) 100%);
    opacity: 0.9;
}

.sx-faq-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%235f7d95' stroke-opacity='0.06'%3E%3Cpath d='M0 40h80M40 0v80'/%3E%3C/g%3E%3C/svg%3E");
    background-size: 80px 80px;
}

.sx-faq-inner {
    position: relative;
    z-index: 1;
}

.sx-faq__intro {
    max-width: 36rem;
    margin-inline: auto;
    margin-top: 0.75rem;
}

.faq-list--premium {
    display: flex;
    flex-direction: column;
    gap: clamp(1rem, 2vw, 1.25rem);
    margin-top: clamp(1.75rem, 4vw, 2.5rem);
}

.faq-list--premium .faq-item--card {
    list-style: none;
    border-radius: clamp(14px, 2vw, 18px);
    border: 1px solid rgba(var(--rgb-text-dark), 0.1);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: 0 4px 24px rgba(var(--rgb-text-dark), 0.06);
    overflow: hidden;
    border-left: 4px solid transparent;
    display: grid;
    grid-template-rows: auto 0fr;
    transition:
        grid-template-rows 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.32s ease,
        box-shadow 0.32s ease,
        background 0.32s ease,
        border-left-color 0.32s ease;
}

.faq-list--premium .faq-item--card[open] {
    grid-template-rows: auto 1fr;
    background: rgba(var(--rgb-teal-deep), 0.08);
    border-left-color: var(--footer-blue, #1fa2c1);
    box-shadow: 0 12px 40px rgba(var(--rgb-text-dark), 0.1);
}

.faq-list--premium .faq-item--card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(var(--rgb-text-dark), 0.09);
    border-color: rgba(var(--rgb-text-dark), 0.14);
}

.faq-list--premium .faq-item--card[open]:hover {
    box-shadow: 0 14px 44px rgba(var(--rgb-text-dark), 0.11);
}

.faq-item__summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: clamp(1.05rem, 2.5vw, 1.35rem) clamp(1.1rem, 3vw, 1.35rem);
    min-height: 3.25rem;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(1.02rem, 1.1vw, 1.125rem);
    line-height: 1.35;
    color: var(--text-heading);
    transition: color 0.28s ease;
}

.faq-item__summary::-webkit-details-marker {
    display: none;
}

.faq-item__summary:hover,
.faq-item__summary:focus-visible {
    color: var(--footer-blue, #1fa2c1);
}

.faq-item__summary:focus-visible {
    outline: 2px solid var(--footer-blue, #1fa2c1);
    outline-offset: 2px;
}

.faq-item__icon {
    flex-shrink: 0;
    display: flex;
    color: var(--footer-blue, #1fa2c1);
    opacity: 0.92;
    transition: color 0.28s ease, transform 0.28s ease;
}

.faq-item__summary:hover .faq-item__icon:not(.ui-icon-3d) {
    color: var(--secondary-color, #1fa2c1);
    transform: scale(1.04);
}

.faq-item__question {
    flex: 1;
    text-align: start;
}

.faq-item__toggle {
    flex-shrink: 0;
    width: 1.125rem;
    height: 1.125rem;
    position: relative;
    transition: transform 0.38s cubic-bezier(0.22, 1, 0.36, 1);
}

.faq-item__toggle::before,
.faq-item__toggle::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    background: var(--footer-blue, #1fa2c1);
    border-radius: 1px;
    transform: translate(-50%, -50%);
    transition: background 0.28s ease;
}

.faq-item__toggle::before {
    width: 2px;
    height: 14px;
}

.faq-item__toggle::after {
    width: 14px;
    height: 2px;
}

.faq-item--card[open] .faq-item__toggle {
    transform: rotate(45deg);
}

.faq-item__summary:hover .faq-item__toggle::before,
.faq-item__summary:hover .faq-item__toggle::after {
    background: var(--secondary-color, #1fa2c1);
}

.faq-item__panel {
    overflow: hidden;
    min-height: 0;
}

.faq-item__body {
    padding: 0 clamp(1.1rem, 3vw, 1.35rem) clamp(1.1rem, 3vw, 1.35rem);
    padding-top: 0;
    opacity: 0;
    transform: translateY(-6px);
    transition:
        opacity 0.35s ease 0.05s,
        transform 0.38s cubic-bezier(0.22, 1, 0.36, 1) 0.05s;
}

.faq-item--card[open] .faq-item__body {
    opacity: 1;
    transform: translateY(0);
}

.faq-item__body p {
    margin: 0 0 1rem;
    font-size: clamp(0.9375rem, 1.05vw, 1rem);
    line-height: 1.75;
    color: var(--color-ink-muted);
}

.faq-item__body p:last-child {
    margin-bottom: 0;
}

.faq-item__hl {
    color: var(--footer-blue, #1fa2c1);
    font-weight: 600;
}

.faq-item__body a {
    color: var(--footer-blue, #1fa2c1);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.faq-item__body a:hover {
    color: var(--secondary-color, #0f7c8a);
}

.faq-item__steps,
.faq-item__bullets {
    margin: 0 0 1rem;
    padding-left: 1.15rem;
    color: var(--color-ink-muted);
    font-size: clamp(0.9375rem, 1.05vw, 1rem);
    line-height: 1.75;
}

.faq-item__steps li,
.faq-item__bullets li {
    margin-bottom: 0.65rem;
}

.faq-item__steps li:last-child,
.faq-item__bullets li:last-child {
    margin-bottom: 0;
}

.faq-item__bullets--cols {
    columns: 2;
    column-gap: 1.5rem;
}

@media (max-width: 520px) {
    .faq-item__bullets--cols {
        columns: 1;
    }
}

.faq-item__note {
    font-size: clamp(0.875rem, 1vw, 0.9375rem) !important;
    line-height: 1.65 !important;
    font-style: italic;
    opacity: 0.92;
    padding-top: 0.25rem;
    border-top: 1px solid rgba(var(--rgb-text-dark), 0.08);
    margin-top: 0.5rem !important;
}

@media (prefers-reduced-motion: reduce) {
    .faq-list--premium .faq-item--card {
        transition: none;
    }

    .faq-item__body {
        transition: none;
        opacity: 1;
        transform: none;
    }

    .faq-item__toggle {
        transition: none;
    }

    .faq-list--premium .faq-item--card:hover {
        transform: none;
    }
}

#industries-we-serve {
    scroll-margin-top: clamp(4.5rem, 12vw, 6rem);
}

/* CTA band — legacy (pages without --premium) */
.cta-band:not(.cta-band--premium) {
    padding: clamp(2.5rem, 6vw, 4rem);
    border-radius: var(--radius-lg);
    background: linear-gradient(120deg, var(--footer-navy) 0%, var(--footer-gradient-deep) 100%);
    color: var(--text-on-dark);
    text-align: center;
}

.cta-band:not(.cta-band--premium) h2 {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3vw, 2rem);
    margin: 0 0 0.5rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: #fff;
}

.cta-band:not(.cta-band--premium) p {
    margin: 0 0 1.5rem;
    color: var(--text-on-dark-muted);
    max-width: 36rem;
    margin-inline: auto;
    line-height: 1.65;
}

.cta-band:not(.cta-band--premium) .cta-band__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
}

/* CTA — full-width cinematic band */
.section--cta {
    padding-top: 0;
    padding-bottom: 0;
    background: transparent;
}

.section--cta.section--alt {
    background: transparent;
}

.sx-cta-wave {
    display: block;
    width: 100%;
    height: clamp(2.25rem, 5vw, 3.5rem);
    margin-bottom: -1px;
    color: var(--footer-navy);
    line-height: 0;
}

.sx-cta-wave__svg {
    display: block;
    width: 100%;
    height: 100%;
}

.sx-cta-wave__path {
    fill: currentColor;
}

.cta-band--premium {
    position: relative;
    overflow: hidden;
    width: 100%;
    margin: 0;
    padding: clamp(4.5rem, 10vw, 6.25rem) 0 clamp(4.25rem, 9vw, 5.75rem);
    border-radius: 0;
    text-align: center;
    color: var(--text-on-dark);
    background: linear-gradient(
        125deg,
        var(--footer-gradient-deep) 0%,
        var(--footer-navy) 38%,
        color-mix(in srgb, var(--footer-navy) 70%, var(--footer-blue)) 72%,
        var(--footer-navy) 100%
    );
    isolation: isolate;
}

.cta-band__layers {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}

.cta-band__aurora {
    position: absolute;
    inset: -45% -20% -35%;
    background:
        radial-gradient(ellipse 55% 42% at 22% 35%, rgba(var(--rgb-teal-deep), 0.38) 0%, transparent 55%),
        radial-gradient(ellipse 45% 38% at 78% 65%, rgba(var(--rgb-green), 0.14) 0%, transparent 50%),
        radial-gradient(ellipse 50% 40% at 50% 100%, rgba(255, 255, 255, 0.06) 0%, transparent 45%);
    animation: cta-aurora-drift 22s ease-in-out infinite alternate;
}

@keyframes cta-aurora-drift {
    0% {
        transform: translate(-3%, -2%) scale(1);
    }
    100% {
        transform: translate(4%, 3%) scale(1.06);
    }
}

.cta-band__mesh {
    position: absolute;
    inset: 0;
    opacity: 0.35;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Ccircle cx='60' cy='60' r='52' fill='none' stroke='%23ffffff' stroke-opacity='0.04' stroke-width='0.75'/%3E%3Cpath d='M0 60h120M60 0v120' stroke='%23ffffff' stroke-opacity='0.03'/%3E%3C/svg%3E");
    background-size: 120px 120px;
}

.cta-band__spotlight {
    position: absolute;
    left: 50%;
    top: 18%;
    width: min(90vw, 52rem);
    height: min(55vw, 22rem);
    transform: translate(-50%, -50%);
    background: radial-gradient(ellipse closest-side, rgba(255, 255, 255, 0.12) 0%, transparent 72%);
    pointer-events: none;
    z-index: 0;
}

.cta-band__inner {
    position: relative;
    z-index: 1;
    max-width: 46rem;
    margin: 0 auto;
}

.cta-band__title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw + 0.5rem, 3.25rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 var(--type-space-heading-body);
    color: #fff;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.28);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    .cta-band__title {
        background: linear-gradient(180deg, #ffffff 0%, #e8eef2 100%);
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
        text-shadow: none;
        filter: drop-shadow(0 2px 18px rgba(0, 0, 0, 0.35));
    }
}

.cta-band__lede {
    margin: 0 auto 2rem;
    max-width: 38rem;
    font-family: var(--font-body);
    font-size: var(--type-lead);
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.82);
    font-weight: 400;
}

.cta-band--premium .cta-band__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
    align-items: center;
}

.cta-band__trust {
    margin: 2rem 0 0;
    font-size: clamp(0.8125rem, 1vw, 0.875rem);
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.48);
    letter-spacing: 0.02em;
}

.cta-band__trust-stat {
    color: rgba(255, 255, 255, 0.62);
    font-weight: 600;
}

.cta-band--premium .btn--cta-primary {
    padding: 0.85rem 1.75rem;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: var(--btn-letter);
    border-radius: var(--btn-radius);
    border: 1.5px solid var(--btn-primary-bg);
    color: #fff;
    background: var(--btn-primary-bg);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12);
}

.cta-band--premium .btn--cta-primary .pa-cta-free {
    text-decoration-color: rgba(255, 255, 255, 0.5);
}

@media (hover: hover) and (pointer: fine) {
    .cta-band--premium .btn--cta-primary:hover {
        background: var(--btn-primary-hover);
        border-color: var(--btn-primary-hover);
        box-shadow: var(--btn-shadow-hover);
    }
}

.cta-band--premium .btn--cta-ghost {
    padding: 0.85rem 1.65rem;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: var(--btn-letter);
    border-radius: var(--btn-radius);
    background: transparent;
    border: 1.5px solid rgba(255, 255, 255, 0.55);
    color: #fff;
    box-shadow: none;
}

@media (hover: hover) and (pointer: fine) {
    .cta-band--premium .btn--cta-ghost:hover {
        background: var(--btn-primary-bg);
        border-color: var(--btn-primary-bg);
        color: #fff;
        box-shadow: 0 6px 22px rgba(0, 0, 0, 0.22);
    }
}

@media (max-width: 540px) {
    .cta-band--premium .cta-band__actions {
        flex-direction: column;
        width: 100%;
    }

    .cta-band--premium .btn--cta-primary,
    .cta-band--premium .btn--cta-ghost {
        width: 100%;
        max-width: 22rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cta-band__aurora {
        animation: none;
    }

    .cta-band--premium .btn--cta-primary,
    .cta-band--premium .btn--cta-ghost {
        transition-duration: 0.01ms;
    }

    .cta-band--premium .btn--cta-primary:hover,
    .cta-band--premium .btn--cta-ghost:hover {
        transform: none;
    }
}

/* Page hero (inner pages) */
.page-hero {
    padding: clamp(2.5rem, 6vw, 4rem) 0;
    background: linear-gradient(180deg, rgba(var(--rgb-text-dark), 0.08) 0%, transparent 100%);
    border-bottom: 1px solid var(--color-border);
}

.page-hero h1 {
    font-family: var(--font-display);
    font-size: var(--type-h1);
    margin: 0 0 var(--type-space-heading-body);
    letter-spacing: -0.02em;
    color: var(--text-heading);
    font-weight: 800;
    line-height: 1.12;
}

.page-hero p {
    margin: 0;
    color: var(--text-muted);
    max-width: 42rem;
    font-size: var(--type-lead);
    line-height: 1.7;
}

/* Process steps */
.process {
    display: grid;
    gap: 1rem;
    counter-reset: step;
}

@media (min-width: 768px) {
    .process {
        grid-template-columns: repeat(4, 1fr);
    }
}

.process-step {
    position: relative;
    padding: 1.5rem;
    border-radius: var(--radius-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
}

.process-step::before {
    counter-increment: step;
    content: counter(step);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background: var(--color-teal);
    color: #fff;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 0.875rem;
    margin-bottom: 0.75rem;
}

.process-step h4 {
    font-family: var(--font-display);
    font-size: 1rem;
    margin: 0 0 0.35rem;
    color: var(--text-heading);
    font-weight: 600;
}

.process-step p {
    margin: 0;
    font-size: var(--type-small);
    line-height: 1.65;
    color: var(--text-muted);
}

/* Service list / accordions */
.service-accordions details {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    margin-bottom: 0.5rem;
    background: var(--color-surface);
    overflow: hidden;
}

.service-accordions summary {
    padding: 1rem 1.25rem;
    font-family: var(--font-display);
    font-weight: 600;
    cursor: pointer;
    list-style: none;
    color: var(--text-heading);
    transition: color var(--duration-text) var(--ease-text);
}

.service-accordions summary:hover {
    color: var(--secondary-color);
}

.service-accordions summary::-webkit-details-marker {
    display: none;
}

.service-accordions details[open] summary {
    border-bottom: 1px solid var(--color-border);
    background: rgba(var(--rgb-text-dark), 0.04);
}

.service-accordions .detail-body {
    padding: 1rem 1.25rem 1.25rem;
    color: var(--color-ink-muted);
    font-size: 0.925rem;
}

/* Case study */
.case-study {
    display: grid;
    gap: 2rem;
    align-items: center;
    padding: 2rem;
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
}

@media (min-width: 768px) {
    .case-study {
        grid-template-columns: 1fr 1fr;
    }
}

.case-study__badge {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    color: var(--color-accent-dark);
    margin-bottom: 0.5rem;
}

.case-study h3 {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    margin: 0 0 var(--type-space-heading-body);
    color: var(--text-heading);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.25;
}

.case-metrics {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
}

.case-metrics div {
    font-family: var(--font-display);
}

.case-metrics strong {
    display: block;
    font-size: 1.5rem;
    color: var(--color-teal);
}

/* Tech stack */
.tech-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (min-width: 640px) {
    .tech-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.tech-pill {
    padding: 1rem;
    text-align: center;
    border-radius: var(--radius-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.9rem;
}

/* Technology slider (homepage) */
.sx-tech-scene {
    position: relative;
    overflow: hidden;
}

.sx-tech-bg {
    pointer-events: none;
    position: absolute;
    inset: -10% -8%;
    background:
        radial-gradient(ellipse 55% 45% at 20% 30%, rgba(var(--rgb-teal-deep), 0.08) 0%, transparent 55%),
        radial-gradient(ellipse 48% 40% at 85% 75%, rgba(var(--rgb-text-dark), 0.05) 0%, transparent 50%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.5) 0%, rgba(248, 250, 252, 0.98) 100%);
}

.sx-tech-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.4;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='96' height='96' viewBox='0 0 96 96'%3E%3Cpath d='M48 0 L96 48 L48 96 L0 48 Z' fill='none' stroke='%235f7d95' stroke-opacity='0.05' stroke-width='0.8'/%3E%3C/svg%3E");
    background-size: 96px 96px;
}

.sx-tech-inner {
    position: relative;
    z-index: 1;
}

.sx-tech__intro {
    max-width: 40rem;
}

.tech-slider-shell {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    grid-template-areas:
        "view view"
        "prev next";
    gap: 1rem 0.75rem;
    align-items: center;
    margin-top: clamp(1.75rem, 4vw, 2.5rem);
}

.tech-slider__viewport {
    grid-area: view;
    min-width: 0;
}

.tech-slider__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    border-radius: 50%;
    border: 1px solid rgba(var(--rgb-text-dark), 0.15);
    background: rgba(255, 255, 255, 0.9);
    color: var(--footer-navy);
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(var(--rgb-text-dark), 0.08);
    transition:
        background 0.25s ease,
        color 0.25s ease,
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.2s ease;
}

.tech-slider__btn:hover {
    background: var(--btn-primary-bg);
    color: #fff;
    border-color: var(--btn-primary-bg);
    box-shadow: 0 6px 18px rgba(var(--rgb-teal-deep), 0.2);
}

.tech-slider__btn:focus-visible {
    outline: 2px solid var(--footer-blue);
    outline-offset: 3px;
}

.tech-slider__btn--prev {
    grid-area: prev;
    justify-self: end;
}

.tech-slider__btn--next {
    grid-area: next;
    justify-self: start;
}

@media (min-width: 768px) {
    .tech-slider-shell {
        grid-template-columns: auto minmax(0, 1fr) auto;
        grid-template-rows: auto;
        grid-template-areas: "prev view next";
        gap: 0 0.65rem;
    }

    .tech-slider__btn--prev,
    .tech-slider__btn--next {
        justify-self: center;
    }
}

.tech-swiper {
    padding-bottom: 2.75rem;
    overflow: visible;
}

.tech-swiper .swiper-wrapper {
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.tech-swiper .swiper-slide {
    height: auto;
    display: flex;
    box-sizing: border-box;
}

.tech-swiper .swiper-pagination {
    bottom: 0 !important;
    left: 0;
    right: 0;
}

.tech-swiper .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    background: var(--footer-blue);
    opacity: 0.35;
    transition:
        opacity 0.25s ease,
        transform 0.25s ease;
}

.tech-swiper .swiper-pagination-bullet-active {
    opacity: 1;
    transform: scale(1.2);
}

.tech-card {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 11.5rem;
    padding: clamp(1.15rem, 2.5vw, 1.35rem);
    border-radius: clamp(14px, 2vw, 18px);
    background: linear-gradient(165deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.92) 100%);
    border: 1px solid rgba(var(--rgb-text-dark), 0.1);
    box-shadow: 0 6px 24px rgba(var(--rgb-text-dark), 0.07);
    transition:
        transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.32s ease,
        border-color 0.3s ease;
}

.tech-card:hover {
    transform: translateY(-4px) scale(1.03);
    border-color: color-mix(in srgb, var(--footer-blue) 35%, transparent);
    box-shadow:
        0 16px 40px rgba(var(--rgb-text-dark), 0.12),
        0 0 0 1px color-mix(in srgb, var(--footer-blue) 12%, transparent);
}

.tech-card--featured {
    background: linear-gradient(
        165deg,
        rgba(255, 255, 255, 1) 0%,
        color-mix(in srgb, var(--footer-blue) 9%, white) 55%,
        rgba(248, 252, 255, 0.95) 100%
    );
    border: 2px solid color-mix(in srgb, var(--footer-blue) 55%, transparent);
    box-shadow:
        0 8px 32px rgba(var(--rgb-text-dark), 0.1),
        0 0 40px var(--footer-blue-glow);
}

.tech-card--featured:hover {
    box-shadow:
        0 18px 48px rgba(var(--rgb-text-dark), 0.14),
        0 0 48px var(--footer-blue-glow);
}

.tech-card__badge {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    padding: 0.2rem 0.55rem;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--footer-navy);
    background: linear-gradient(135deg, rgba(var(--rgb-green), 0.35) 0%, rgba(var(--rgb-green), 0.15) 100%);
    border-radius: 999px;
    border: 1px solid rgba(var(--rgb-green), 0.45);
}

.tech-card__icon:not(.ui-icon-3d) {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    margin-bottom: 0.85rem;
    border-radius: 14px;
    background: color-mix(in srgb, var(--footer-blue) 11%, white);
    color: var(--footer-blue);
}

.tech-card__icon.ui-icon-3d {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.85rem;
}

.tech-card__name {
    font-family: var(--font-display);
    font-size: clamp(1.05rem, 1.12vw, 1.15rem);
    font-weight: 700;
    margin: 0 0 0.2rem;
    color: var(--text-heading);
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.tech-card--featured .tech-card__name {
    padding-right: 4.75rem;
}

.tech-card__meta {
    margin: 0 0 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--footer-blue);
    opacity: 0.9;
}

.tech-card__desc {
    margin: 0;
    font-size: clamp(0.8125rem, 0.95vw, 0.875rem);
    line-height: 1.55;
    color: var(--color-ink-muted);
    flex: 1;
}

@media (prefers-reduced-motion: reduce) {
    .tech-card:hover {
        transform: none;
    }

    .tech-card--featured:hover {
        transform: none;
    }
}

/* Industries */
.industries-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
}

@media (min-width: 768px) {
    .industries-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .industries-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

.industry-pill {
    padding: 0.85rem 1rem;
    text-align: center;
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-muted);
}

/* Industries — minimal horizontal marquee (homepage) */
.sx-industries-scene {
    position: relative;
    overflow: hidden;
}

.sx-industries-inner {
    position: relative;
    z-index: 1;
}

.sx-industries__intro {
    max-width: 38rem;
    margin-inline: auto;
}

.industry-marquee {
    position: relative;
    margin-top: clamp(1.75rem, 4vw, 2.5rem);
    padding-block: clamp(0.75rem, 2vw, 1.25rem);
}

.industry-marquee__viewport {
    overflow: hidden;
    margin-inline: calc(-1 * var(--container-padding, 1.25rem));
    padding-block: 0.35rem;
    mask-image: linear-gradient(
        to right,
        transparent,
        #000 10%,
        #000 90%,
        transparent
    );
    -webkit-mask-image: linear-gradient(
        to right,
        transparent,
        #000 10%,
        #000 90%,
        transparent
    );
    mask-size: 100% 100%;
    -webkit-mask-size: 100% 100%;
}

.industry-marquee__track {
    display: flex;
    width: max-content;
    animation: industry-marquee-scroll 56s linear infinite;
    will-change: transform;
}

.industry-marquee:hover .industry-marquee__track,
.industry-marquee:focus-within .industry-marquee__track {
    animation-play-state: paused;
}

@keyframes industry-marquee-scroll {
    0% {
        transform: translate3d(0, 0, 0);
    }

    100% {
        transform: translate3d(-50%, 0, 0);
    }
}

.industry-marquee__list {
    display: flex;
    align-items: stretch;
    flex-shrink: 0;
    list-style: none;
    margin: 0;
    padding: 0 clamp(1rem, 3vw, 2rem);
    gap: clamp(1.5rem, 4vw, 3.25rem);
}

.industry-marquee__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    flex-shrink: 0;
    min-width: clamp(5.25rem, 11vw, 7rem);
    max-width: 8.5rem;
    padding: 0.25rem 0.35rem;
    cursor: default;
}

.industry-marquee__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    margin-bottom: 0.5rem;
    color: var(--brand-teal-deep, #0f7c8a);
    transition:
        transform 0.28s cubic-bezier(0.22, 1, 0.36, 1),
        color 0.28s ease,
        filter 0.28s ease;
    filter: drop-shadow(0 1px 2px rgba(var(--rgb-teal-deep), 0.12));
}

.industry-marquee__icon svg {
    width: 2.25rem;
    height: 2.25rem;
}

.industry-marquee__name {
    font-family: var(--font-display);
    font-size: clamp(0.8125rem, 1.1vw, 0.9375rem);
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: -0.01em;
    color: rgba(15, 56, 62, 0.72);
    transition: color 0.28s ease;
}

@media (hover: hover) and (pointer: fine) {
    .industry-marquee__item:hover .industry-marquee__icon {
        transform: scale(1.1);
        color: color-mix(in srgb, var(--brand-teal-bright) 75%, var(--brand-green));
    }

    .industry-marquee__item:hover .industry-marquee__name {
        color: var(--text-heading);
    }
}

@media (max-width: 767px) {
    .industry-marquee__viewport {
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        overscroll-behavior-x: contain;
        mask-image: none;
        -webkit-mask-image: none;
        margin-inline: calc(-1 * var(--container-padding, 1.25rem));
        padding-inline: var(--container-padding, 1.25rem);
    }

    .industry-marquee__track {
        animation: none;
        width: max-content;
        padding-inline: 0.25rem;
    }

    .industry-marquee__list[aria-hidden="true"] {
        display: none;
    }

    .industry-marquee__item {
        scroll-snap-align: center;
        min-width: 6.5rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .industry-marquee__track {
        animation: none;
        flex-wrap: wrap;
        justify-content: center;
        width: 100%;
        max-width: 52rem;
        margin-inline: auto;
        row-gap: 1rem;
    }

    .industry-marquee__list[aria-hidden="true"] {
        display: none;
    }

    .industry-marquee__viewport {
        overflow: visible;
        mask-image: none;
        -webkit-mask-image: none;
        margin-inline: 0;
        padding-inline: 0;
    }

    .industry-marquee__list {
        flex-wrap: wrap;
        justify-content: center;
        gap: 1rem 1.5rem;
        padding-inline: 0;
        width: 100%;
        max-width: 48rem;
        margin-inline: auto;
    }
}

.industry-card {
    position: relative;
    border: none;
    background: transparent;
    padding: 0;
    margin: 0;
    text-align: left;
    cursor: default;
    outline: none;
}

.industry-card__surface {
    position: relative;
    height: 100%;
    min-height: 9.5rem;
    padding: clamp(1.15rem, 2.5vw, 1.4rem);
    border-radius: clamp(16px, 2vw, 20px);
    background: linear-gradient(165deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.88) 100%);
    border: 1px solid rgba(var(--rgb-text-dark), 0.1);
    box-shadow: 0 6px 28px rgba(var(--rgb-text-dark), 0.07);
    transition:
        transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.32s ease,
        border-color 0.3s ease,
        background 0.32s ease;
}

.industry-card__icon-wrap:not(.ui-icon-3d) {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 0.85rem;
    border-radius: 14px;
    background: color-mix(in srgb, var(--footer-blue) 12%, white);
    color: var(--footer-blue);
    transition:
        transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
        background 0.3s ease,
        color 0.3s ease,
        box-shadow 0.3s ease;
}

.industry-card__icon {
    display: block;
}

.industry-card__title {
    font-family: var(--font-display);
    font-size: clamp(1.02rem, 1.08vw, 1.125rem);
    font-weight: 700;
    margin: 0 0 0.45rem;
    color: var(--text-heading);
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.industry-card__desc {
    margin: 0;
    font-size: clamp(0.8125rem, 0.95vw, 0.875rem);
    line-height: 1.55;
    color: var(--color-ink-muted);
}

.industry-card__peek {
    position: absolute;
    z-index: 4;
    left: 0.35rem;
    right: 0.35rem;
    bottom: calc(100% + 0.5rem);
    padding: 0.65rem 0.85rem;
    font-size: 0.78rem;
    line-height: 1.45;
    color: rgba(255, 255, 255, 0.94);
    background: linear-gradient(135deg, var(--footer-navy) 0%, color-mix(in srgb, var(--footer-navy) 85%, var(--footer-blue)) 100%);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 16px 40px rgba(var(--rgb-text-dark), 0.22);
    opacity: 0;
    transform: translateY(10px);
    pointer-events: none;
    transition:
        opacity 0.3s ease,
        transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) and (pointer: fine) {
    .industry-card:hover .industry-card__surface,
    .industry-card:focus-visible .industry-card__surface {
        transform: translateY(-6px) scale(1.02);
        border-color: color-mix(in srgb, var(--footer-blue) 42%, transparent);
        box-shadow:
            0 20px 48px rgba(var(--rgb-text-dark), 0.14),
            0 0 0 1px color-mix(in srgb, var(--footer-blue) 18%, transparent),
            0 0 36px var(--footer-blue-glow);
        background: linear-gradient(168deg, rgba(255, 255, 255, 1) 0%, rgba(240, 246, 252, 0.95) 100%);
    }

    .industry-card:hover .industry-card__icon-wrap:not(.ui-icon-3d),
    .industry-card:focus-visible .industry-card__icon-wrap:not(.ui-icon-3d) {
        transform: scale(1.1) rotate(4deg);
        background: color-mix(in srgb, var(--footer-blue) 22%, white);
        box-shadow: 0 6px 18px rgba(var(--rgb-teal-deep), 0.2);
    }

    .industry-card:hover .industry-card__peek,
    .industry-card:focus-visible .industry-card__peek {
        opacity: 1;
        transform: translateY(0);
    }
}

.industry-card:focus-visible .industry-card__surface {
    outline: 2px solid var(--footer-blue);
    outline-offset: 3px;
}

@media (hover: none) {
    .industry-card:active .industry-card__surface {
        transform: scale(0.99);
        transition-duration: 0.12s;
    }
}

@media (prefers-reduced-motion: reduce) {
    .industry-card__surface,
    .industry-card__icon-wrap,
    .industry-card__peek {
        transition: none;
    }

    .industry-card:hover .industry-card__surface,
    .industry-card:focus-visible .industry-card__surface {
        transform: none;
    }

    .industry-card:hover .industry-card__icon-wrap,
    .industry-card:focus-visible .industry-card__icon-wrap {
        transform: none;
    }

    .industry-card:active .industry-card__surface {
        transform: none;
    }
}

/* Contact form */
.contact-layout {
    display: grid;
    gap: 2.5rem;
}

@media (min-width: 900px) {
    .contact-layout {
        grid-template-columns: 1fr 1.1fr;
    }
}

.contact-card {
    padding: 2rem;
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
}

.contact-card h3 {
    font-family: var(--font-display);
    font-size: var(--type-h3);
    margin-top: 0;
    margin-bottom: var(--type-space-heading-body);
    color: var(--text-heading);
    font-weight: 600;
    letter-spacing: -0.01em;
}

.contact-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.contact-list li {
    margin-bottom: 1rem;
    padding-left: 0;
}

.contact-list a {
    font-weight: 600;
}

.form-group {
    margin-bottom: 1rem;
}

.form-group label {
    display: block;
    font-family: var(--font-display);
    font-size: var(--type-small);
    font-weight: 600;
    margin-bottom: 0.35rem;
    color: var(--text-heading);
    letter-spacing: 0.02em;
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: inherit;
    font-size: 1rem;
    background: #fff;
    color: var(--text-primary);
    transition:
        border-color var(--duration-text) var(--ease-text),
        box-shadow var(--duration-text) var(--ease-text);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--text-subtle);
    opacity: 1;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: rgba(var(--rgb-teal-deep), 0.55);
    box-shadow: 0 0 0 3px var(--footer-blue-glow);
}

.form-group textarea {
    min-height: 140px;
    resize: vertical;
}

/* Footer layout lives in assets/css/footer-premium.css */

.btn--footer-book {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.9375rem;
    letter-spacing: var(--btn-letter);
    padding: 0.65rem 1.35rem;
    border-radius: var(--btn-radius);
    background: var(--btn-primary-bg);
    color: #fff;
    border: 1.5px solid var(--btn-primary-bg);
    box-shadow: 0 1px 2px rgba(var(--rgb-teal-deep), 0.12);
}

@media (hover: hover) and (pointer: fine) {
    .btn--footer-book:hover {
        color: #fff;
        background: var(--btn-primary-hover);
        border-color: var(--btn-primary-hover);
        box-shadow: var(--btn-shadow-hover);
    }
}

.btn--footer-book:active {
    background: var(--btn-primary-active);
    border-color: var(--btn-primary-active);
}

.btn--footer-book.btn--sm {
    padding: 0.48rem 1rem;
    font-size: 0.8125rem;
}

/* Free consultation emphasis (site-wide CTAs) */
.pa-cta-free {
    font-weight: 600;
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 0.15em;
    text-decoration-color: rgba(15, 124, 138, 0.45);
}

.pa-cta-badge-free {
    display: inline-block;
    margin-left: 0.35rem;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1.2;
    vertical-align: middle;
    background: rgba(76, 175, 80, 0.14);
    color: #2e7d32;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
}

.infra-final-cta__ready {
    margin: 0.75rem 0 0.35rem;
    font-size: clamp(1.1rem, 2.2vw, 1.4rem);
    font-weight: 700;
    color: rgba(6, 58, 66, 0.95);
    letter-spacing: -0.02em;
}

.infra-final-cta__subline {
    margin: 0 0 0.25rem;
    font-size: 1rem;
    font-weight: 500;
    color: rgba(6, 58, 66, 0.72);
}

.cta-band__free-line {
    margin: 0.65rem 0 1rem;
    font-size: 1.05rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.92);
    text-align: center;
}

/* Floating action buttons */
.fab-stack {
    position: fixed;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 250;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
}

.fab {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #fff;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.22);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.fab:hover {
    transform: scale(1.06);
    color: #fff;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
}

.fab--whatsapp {
    background: #25d366;
}

.fab--chat {
    background: var(--brand-teal-deep);
}

@media (min-width: 1024px) {
    .fab-stack {
        right: 1.75rem;
        bottom: 1.75rem;
    }
}

/* Utilities */
.text-center {
    text-align: center;
}

.mb-0 {
    margin-bottom: 0;
}

.mt-lg {
    margin-top: 2.5rem;
}

/* —— First-visit preloader (sessionStorage; see header.php) —— */
html.preloader-skip #site-preloader {
    display: none !important;
}

.site-preloader__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.1rem;
    animation: site-preloader-in 0.42s ease forwards;
}

@keyframes site-preloader-in {
    from {
        opacity: 0;
        transform: translateY(6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.site-preloader__mark {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(2rem, 5vw, 2.65rem);
    letter-spacing: 0.08em;
    color: var(--btn-primary-bg);
    line-height: 1;
    user-select: none;
}

.site-preloader__bar {
    width: min(200px, 52vw);
    height: 3px;
    border-radius: 999px;
    background: rgba(var(--rgb-teal-deep), 0.12);
    overflow: hidden;
}

.site-preloader__bar-fill {
    display: block;
    height: 100%;
    width: 38%;
    border-radius: inherit;
    background: linear-gradient(
        90deg,
        var(--btn-primary-bg) 0%,
        var(--brand-teal-bright) 50%,
        var(--accent-color) 100%
    );
    animation: site-preloader-bar 1.1s ease-in-out infinite;
}

@keyframes site-preloader-bar {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(280%);
    }
}

@media (prefers-reduced-motion: reduce) {
    .site-preloader__inner {
        animation: none;
        opacity: 1;
    }

    .site-preloader__bar-fill {
        animation: none;
        width: 100%;
        opacity: 0.35;
    }
}

/* Site-wide toast (footer newsletter, etc.) */
.pa-site-toast {
    position: fixed;
    left: 50%;
    bottom: 1.5rem;
    z-index: 12000;
    max-width: min(92vw, 22rem);
    padding: 0.95rem 1.2rem;
    font-size: 0.9375rem;
    line-height: 1.45;
    font-weight: 500;
    color: #0f172a;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(20, 184, 166, 0.35);
    border-radius: 0.85rem;
    box-shadow:
        0 18px 44px rgba(15, 50, 60, 0.18),
        0 0 0 1px rgba(255, 255, 255, 0.8) inset;
    transform: translate3d(-50%, 120%, 0);
    opacity: 0;
    pointer-events: none;
    transition:
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.4s ease;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.pa-site-toast.is-open {
    visibility: visible;
    transform: translate3d(-50%, 0, 0);
    opacity: 1;
    pointer-events: auto;
}

.pa-site-toast:not(.is-open) {
    visibility: hidden;
}
