/* ============================================================
   CORPORATE TRAVEL PAGE  —  corporate-travel.css
   All colors via CSS custom properties (theme-safe).
   Namespace: ct-*
   ============================================================ */

/* ── Page shell ── */
.ct-page {
    position: relative;
    overflow-x: hidden;
}

/* ── Shared richtext ── */
.corporate-richtext > *:last-child {
    margin-bottom: 0;
}

.corporate-richtext p,
.corporate-richtext li {
    font-size: var(--fs-base);
    line-height: 1.85;
    color: var(--clr-text);
}

.corporate-richtext ul,
.corporate-richtext ol {
    padding-left: 1.25rem;
    margin-bottom: 0;
}

/* ── Shared wave dividers ── */
.ct-wave-top,
.ct-wave-btm {
    position: relative;
    z-index: 0;
    line-height: 0;
    pointer-events: none;
}

.ct-wave-top {
    margin-bottom: -1px;
}

.ct-wave-btm {
    margin-top: -1px;
}

    .ct-wave-top svg,
    .ct-wave-btm svg {
        display: block;
        width: 100%;
    }

/* ── Entrance animation override (base defined in site.css) ── */
.ct-anim-up {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 360ms ease-out, transform 360ms ease-out;
}

    .ct-anim-up.in-view,
    .ct-anim-up.ct-force-show {
        opacity: 1;
        transform: none;
    }

.ct-anim-delay-1 {
    transition-delay: 90ms;
}

.ct-anim-delay-2 {
    transition-delay: 160ms;
}

/* ── Section header helpers ── */
.ct-section-hd {
    margin-bottom: 52px;
}

.ct-section-hd--center {
    text-align: center;
}


/* ════════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════════ */

.ct-hero {
    position: relative;
    background-color: var(--clr-primary-dark);
    background-image:
        linear-gradient(
            120deg,
            var(--clr-primary-overlay-strong) 0%,
            color-mix(in srgb, var(--clr-primary) 82%, transparent) 52%,
            color-mix(in srgb, var(--clr-primary-dark) 74%, transparent) 100%
        ),
        var(--ct-hero-image);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden;
    padding-bottom: 0;
}

/* animated mesh background */
.ct-hero-mesh {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}

/* subtle dot grid - REMOVED */

/* ambient orbs */
.ct-orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(0px);
}

.ct-orb--a {
    top: -120px;
    right: -80px;
    width: 420px;
    height: 420px;
    background: radial-gradient(circle, color-mix(in srgb, var(--clr-accent) 28%, transparent) 0%, transparent 68%);
    animation: ct-orb-float 26s ease-in-out infinite alternate;
}

.ct-orb--b {
    bottom: 60px;
    left: -100px;
    width: 320px;
    height: 320px;
    background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%);
    animation: ct-orb-float 30s ease-in-out infinite alternate-reverse;
}

.ct-orb--c {
    top: 40%;
    right: 30%;
    width: 160px;
    height: 160px;
    background: radial-gradient(circle, color-mix(in srgb, var(--clr-accent) 12%, transparent) 0%, transparent 72%);
    animation: ct-orb-float 22s ease-in-out infinite alternate;
}

@keyframes ct-orb-float {
    from {
        transform: translateY(0) scale(1);
    }

    to {
        transform: translateY(10px) scale(1.02);
    }
}

.ct-hero-container {
    position: relative;
    z-index: 2;
}

/* two-column hero layout */
.ct-hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(300px, 460px);
    gap: 42px;
    align-items: start;
    padding: 124px 0 104px;
}

/* breadcrumb */
.ct-breadcrumb {
    background: none;
    padding: 0;
    margin-bottom: 28px;
    font-size: var(--fs-sm);
}

    .ct-breadcrumb .breadcrumb-item a {
        color: rgba(255,255,255,0.62);
        transition: color var(--t-base);
    }

        .ct-breadcrumb .breadcrumb-item a:hover {
            color: #fff;
        }

    .ct-breadcrumb .breadcrumb-item.active {
        color: #fff;
    }

    .ct-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
        color: rgba(255,255,255,0.35);
    }

/* eyebrow */
.ct-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--fs-xs);
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--clr-accent);
    margin-bottom: 16px;
}

.ct-eyebrow-dot {
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: var(--clr-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--clr-accent) 28%, transparent);
    animation: ct-dot-pulse 3.6s ease-in-out infinite;
}

@keyframes ct-dot-pulse {
    0%,100% {
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--clr-accent) 28%, transparent);
    }

    50% {
        box-shadow: 0 0 0 4px color-mix(in srgb, var(--clr-accent) 10%, transparent);
    }
}

.ct-hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.2rem, 4vw, var(--fs-4xl));
    font-weight: 700;
    color: #fff;
    line-height: 1.12;
    margin-bottom: 18px;
    max-width: 700px;
}

.ct-hero-title em {
    display: inline-block;
    position: relative;
    color: var(--clr-accent);
    font-style: normal;
}

.ct-hero-title em::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -4px;
    height: 3px;
    background: linear-gradient(90deg, var(--clr-accent), transparent);
    border-radius: var(--radius-sharp);
}

.ct-hero-sub {
    font-size: var(--fs-md);
    color: rgba(255,255,255,0.78);
    line-height: 1.72;
    max-width: 640px;
    margin-bottom: 24px;
}

/* anchor pills */
.ct-anchor-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 28px;
}

.ct-anchor-pill {
    display: inline-flex;
    align-items: center;
    height: 38px;
    padding: 0 16px;
    border-radius: var(--radius-capsule);
    border: 1px solid rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    color: rgba(255,255,255,0.88);
    font-size: var(--fs-sm);
    font-weight: 600;
    text-decoration: none;
    transition: background-color var(--t-base), border-color var(--t-base), color var(--t-base), transform var(--t-fast);
}

    .ct-anchor-pill:hover,
    .ct-anchor-pill.active {
        background: color-mix(in srgb, var(--clr-accent) 22%, transparent);
        border-color: var(--clr-accent);
        color: #fff;
        transform: translateY(-2px);
    }

/* CTA row */
.ct-hero-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px;
}

/* glowing primary button */
.ct-btn-glow {
    position: relative;
    overflow: hidden;
}

    .ct-btn-glow::after {
        content: '';
        position: absolute;
        inset: 0;
        background: radial-gradient(circle at 50% 0%, rgba(255,255,255,0.18), transparent 70%);
        pointer-events: none;
    }

    .ct-btn-glow:hover {
        box-shadow: 0 6px 28px color-mix(in srgb, var(--clr-accent) 50%, transparent);
    }

/* proof card */
.ct-proof-wrap {
    position: relative;
    padding-top: 12px;
}

.ct-proof-ring {
    position: absolute;
    inset: -14px;
    border-radius: var(--radius-capsule);
    border: 1px solid rgba(255,255,255,0.06);
    pointer-events: none;
    animation: ct-ring-pulse 8s ease-in-out infinite;
}

@keyframes ct-ring-pulse {
    0%,100% {
        transform: scale(1);
        opacity: 1;
    }

    50% {
        transform: scale(1.01);
        opacity: 0.5;
    }
}

.ct-proof-card {
    position: relative;
    z-index: 1;
    padding: 28px;
    border-radius: var(--radius-xl);
    border: 1px solid rgba(255,255,255,0.13);
    background: linear-gradient(160deg, rgba(255,255,255,0.16), rgba(255,255,255,0.07));
    backdrop-filter: blur(20px);
    box-shadow: 0 30px 60px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.18);
}

.ct-proof-kicker {
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: rgba(255,255,255,0.65);
    margin-bottom: 10px;
}

.ct-proof-heading {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.15rem, 2vw, 1.5rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.35;
    margin-bottom: 18px;
}

.ct-proof-list {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
    display: grid;
    gap: 10px;
}

.ct-proof-item {
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 12px;
    align-items: start;
    padding: 12px 14px;
    border-radius: var(--radius-md);
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.10);
    transition: background-color var(--t-base);
}

    .ct-proof-item:hover {
        background: rgba(255,255,255,0.12);
    }

.ct-proof-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--clr-accent) 22%, transparent);
    color: var(--clr-accent);
    font-size: 1rem;
    flex-shrink: 0;
}

.ct-proof-item strong {
    display: block;
    font-size: var(--fs-sm);
    font-weight: 700;
    color: #fff;
    margin-bottom: 3px;
}

.ct-proof-item span {
    font-size: var(--fs-sm);
    color: rgba(255,255,255,0.72);
    line-height: 1.55;
}

.ct-proof-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #fff;
    font-weight: 600;
    font-size: var(--fs-sm);
    text-decoration: none;
    border-top: 1px solid rgba(255,255,255,0.12);
    padding-top: 18px;
    width: 100%;
    transition: gap var(--t-base), opacity var(--t-base);
}

    .ct-proof-cta:hover {
        opacity: 0.85;
        gap: 14px;
        color: #fff;
    }

/* hero bottom wave */
.ct-hero-wave {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    z-index: 1;
    line-height: 0;
}

    .ct-hero-wave::before {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: 100%;
        height: 48px;
        background: linear-gradient(180deg, rgba(7, 24, 42, 0) 0%, rgba(7, 24, 42, 0.18) 100%);
        pointer-events: none;
    }

    .ct-hero-wave svg {
        display: block;
        width: 100%;
        height: 104px;
    }


/* ════════════════════════════════════════════════════════════
   INTRO / OVERVIEW
════════════════════════════════════════════════════════════ */

.ct-intro {
    background: linear-gradient(180deg, var(--clr-white) 0%, rgba(244,249,251,0.55) 100%);
}

.ct-intro-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.72fr);
    gap: 40px;
    align-items: start;
}

.ct-intro-body {
    min-width: 0;
}

.ct-intro-rail {
    min-width: 0;
}

.ct-intro-visual {
    position: sticky;
    top: 110px;
    margin: 0;
}

.ct-intro-visual-shell {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-xl);
    min-height: 420px;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--clr-accent) 24%, transparent), transparent 42%),
        linear-gradient(160deg, var(--clr-primary-dark) 0%, var(--clr-primary) 42%, color-mix(in srgb, var(--clr-primary-dark) 82%, black) 100%);
    border: 1px solid var(--clr-card-border);
    box-shadow: 0 28px 70px rgba(15,23,42,0.16);
}

.ct-intro-image {
    width: 100%;
    height: 100%;
    min-height: 420px;
    max-height: 420px;
    display: block;
    object-fit: cover;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    image-rendering: pixelated;
    filter: contrast(1.05) brightness(0.98);
}

.ct-intro-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--clr-primary-dark) 8%, transparent) 0%, color-mix(in srgb, var(--clr-primary-dark) 18%, transparent) 34%, color-mix(in srgb, var(--clr-primary-dark) 84%, transparent) 100%),
        linear-gradient(120deg, color-mix(in srgb, var(--clr-primary) 6%, transparent) 0%, color-mix(in srgb, var(--clr-accent) 18%, transparent) 100%);
}

.ct-intro-badge {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 24px;
    z-index: 1;
    padding: 18px 20px;
    border-radius: var(--radius-lg);
    background: rgba(255,255,255,0.14);
    border: 1px solid rgba(255,255,255,0.22);
    backdrop-filter: blur(14px);
    box-shadow: 0 18px 40px rgba(7,16,29,0.18);
}

.ct-intro-badge-label {
    display: block;
    margin-bottom: 6px;
    color: rgba(255,255,255,0.78);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.ct-intro-badge strong {
    display: block;
    color: #fff;
    font-size: 1.02rem;
    line-height: 1.5;
}

.ct-intro-caption {
    margin-top: 18px;
    padding: 0 8px;
}

.ct-intro-caption-kicker {
    display: block;
    margin-bottom: 8px;
    color: var(--clr-accent);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.ct-intro-caption p {
    margin: 0;
    color: var(--clr-text-light);
    font-size: 0.96rem;
    line-height: 1.65;
}


/* ════════════════════════════════════════════════════════════
   SERVICES
════════════════════════════════════════════════════════════ */

.ct-services {
    position: relative;
    background: radial-gradient(ellipse at 80% 0%, color-mix(in srgb, var(--clr-accent) 10%, transparent), transparent 50%), var(--clr-light-bg);
    border-top: 1px solid var(--clr-border);
    border-bottom: 1px solid var(--clr-border);
}

.ct-services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
    margin-top: 48px;
}

.ct-svc-card {
    position: relative;
    padding: 28px 24px 24px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--clr-card-border);
    background: linear-gradient(180deg, var(--clr-white) 0%, rgba(246,249,252,0.95) 100%);
    box-shadow: 0 14px 34px rgba(15,23,42,0.055);
    overflow: hidden;
    transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}

    .ct-svc-card:hover {
        transform: translateY(-6px);
        border-color: color-mix(in srgb, var(--clr-accent) 40%, transparent);
        box-shadow: 0 24px 50px rgba(15,23,42,0.10);
    }

/* animated accent bar at bottom */
.ct-svc-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--clr-accent), var(--clr-primary));
    border-radius: 0 0 24px 24px;
    transition: width 400ms ease;
}

.ct-svc-card:hover .ct-svc-bar {
    width: 100%;
}

.ct-svc-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 18px;
}

.ct-svc-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    padding: 0 12px;
    border-radius: var(--radius-capsule);
    background: color-mix(in srgb, var(--clr-accent) 10%, transparent);
    color: var(--clr-accent);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.ct-svc-icon {
    width: 46px;
    height: 46px;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--clr-primary);
    color: #fff;
    font-size: 1rem;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 4px 12px color-mix(in srgb, var(--clr-primary) 28%, transparent);
    transition: background-color var(--t-base), transform var(--t-base);
}

.ct-svc-card:hover .ct-svc-icon {
    background: var(--clr-accent);
    transform: rotate(-4deg) scale(1.08);
}

.ct-svc-title {
    font-size: 1.08rem;
    font-weight: 700;
    color: var(--clr-text);
    margin-bottom: 10px;
    line-height: 1.4;
}

.ct-svc-text {
    font-size: var(--fs-sm);
    color: var(--clr-text-light);
    line-height: 1.78;
    margin: 0;
}


/* ════════════════════════════════════════════════════════════
   CAPABILITY SECTIONS  (MIS + Onsite)
════════════════════════════════════════════════════════════ */

.ct-cap--light {
    background-color: var(--clr-white);
}

.ct-cap--white {
    background: linear-gradient(180deg, rgba(248,250,252,0.7) 0%, var(--clr-white) 100%);
}

.ct-cap-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.75fr);
    gap: 48px;
    align-items: center;
}

.ct-cap-grid--balanced {
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    align-items: center;
}

.ct-cap-grid--rev {
    grid-template-columns: minmax(280px, 0.75fr) minmax(0, 1.15fr);
}

    .ct-cap-grid--rev .ct-cap-copy {
        order: 2;
    }

    .ct-cap-grid--rev .ct-cap-visual {
        order: 1;
    }

.ct-cap-grid--balanced .ct-cap-visual {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* floating capability card */
.ct-cap-card {
    position: relative;
    padding: 32px;
    border-radius: var(--radius-xl);
    border: 1px solid var(--clr-card-border);
    background: linear-gradient(180deg, var(--clr-white) 0%, var(--clr-light-bg) 100%);
    box-shadow: 0 22px 50px rgba(15,23,42,0.08);
    overflow: hidden;
    transition: transform var(--t-base), box-shadow var(--t-base);
    min-height: 280px;
    max-height: 280px;
}

    .ct-cap-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 32px 64px rgba(15,23,42,0.12);
    }

.ct-cap-card--dark {
    background: linear-gradient(160deg, var(--clr-primary-dark) 0%, rgba(10,30,46,0.97) 100%);
    border-color: rgba(255,255,255,0.08);
    box-shadow: 0 24px 56px rgba(10,30,46,0.26);
}

/* glowing background blob inside card */
.ct-cap-card-glow {
    position: absolute;
    top: -60px;
    right: -60px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--clr-accent) 14%, transparent), transparent 70%);
    pointer-events: none;
    animation: ct-orb-float 20s ease-in-out infinite alternate;
}

.ct-cap-card-glow--accent {
    background: radial-gradient(circle, color-mix(in srgb, var(--clr-accent) 22%, transparent), transparent 70%);
}

.ct-cap-icon-wrap {
    width: 58px;
    height: 58px;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--clr-accent) 12%, transparent);
    color: var(--clr-accent);
    font-size: 1.2rem;
    margin-bottom: 18px;
    position: relative;
    z-index: 1;
}

.ct-cap-card--dark .ct-cap-icon-wrap {
    background: rgba(255,255,255,0.12);
    color: #fff;
}

.ct-cap-kicker {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--clr-text-light);
    margin-bottom: 10px;
    display: block;
    position: relative;
    z-index: 1;
}

.ct-cap-card--dark .ct-cap-kicker {
    color: rgba(255,255,255,0.62);
}

.ct-cap-title {
    font-size: 1.22rem;
    font-weight: 700;
    color: var(--clr-text);
    line-height: 1.35;
    margin-bottom: 12px;
    position: relative;
    z-index: 1;
}

.ct-cap-card--dark .ct-cap-title {
    color: #fff;
}

.ct-cap-body {
    font-size: var(--fs-sm);
    color: var(--clr-text-light);
    line-height: 1.75;
    margin: 0;
    position: relative;
    z-index: 1;
}

.ct-cap-card--dark .ct-cap-body {
    color: rgba(255,255,255,0.76);
}

.ct-cap-photo-card {
    position: relative;
    overflow: hidden;
    margin: 0;
    min-height: 400px;
    border-radius: var(--radius-xl);
    border: 1px solid rgba(9,29,45,0.10);
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--clr-accent) 22%, transparent), transparent 40%),
        linear-gradient(160deg, var(--clr-primary-dark) 0%, var(--clr-primary) 42%, color-mix(in srgb, var(--clr-primary-dark) 82%, black) 100%);
    box-shadow: 0 28px 64px rgba(10,30,46,0.18);
}

.ct-cap-photo-card--mis {
    width: 100%;
    max-width: 540px;
    height: auto;
    min-height: 0;
    max-height: none;
    aspect-ratio: 5 / 4;
    margin-inline: auto;
}

.ct-cap-photo {
    width: 100%;
    height: 100%;
    min-height: 400px;
    max-height: 400px;
    display: block;
    object-fit: cover;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    image-rendering: pixelated;
    filter: contrast(1.05) brightness(0.98);
}

.ct-cap-photo--balanced {
    min-height: 0;
    max-height: none;
    height: 100%;
}

.ct-cap-photo-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--clr-primary-dark) 10%, transparent) 0%, color-mix(in srgb, var(--clr-primary-dark) 24%, transparent) 34%, color-mix(in srgb, var(--clr-primary-dark) 86%, transparent) 100%),
        linear-gradient(120deg, color-mix(in srgb, var(--clr-accent) 6%, transparent) 0%, color-mix(in srgb, var(--clr-accent) 18%, transparent) 100%);
}

.ct-cap-photo-badge {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 24px;
    z-index: 1;
    margin: 0;
    padding: 20px 22px;
    border-radius: var(--radius-lg);
    background: rgba(255,255,255,0.14);
    border: 1px solid rgba(255,255,255,0.20);
    backdrop-filter: blur(14px);
    box-shadow: 0 18px 40px rgba(7,16,29,0.20);
}

.ct-cap-photo-kicker {
    display: block;
    margin-bottom: 8px;
    color: rgba(255,255,255,0.76);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.ct-cap-photo-title {
    margin: 0 0 10px;
    color: #fff;
    font-size: 1.24rem;
    font-weight: 700;
    line-height: 1.35;
}

.ct-cap-photo-body {
    margin: 0;
    color: rgba(255,255,255,0.82);
    font-size: 0.96rem;
    line-height: 1.65;
}


/* ════════════════════════════════════════════════════════════
   CLIENTS
════════════════════════════════════════════════════════════ */

.ct-clients {
    position: relative;
    background: radial-gradient(ellipse at 20% 50%, color-mix(in srgb, var(--clr-accent) 7%, transparent), transparent 50%), var(--clr-light-bg);
}

.ct-client-wall {
    --ct-client-gap: 16px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: var(--ct-client-gap);
    margin-top: 48px;
}

.ct-client-chip {
    flex: 0 1 calc((100% - (2 * var(--ct-client-gap))) / 3);
    max-width: calc((100% - (2 * var(--ct-client-gap))) / 3);
    min-width: min(100%, 270px);
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px 20px;
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, var(--clr-white) 0%, rgba(247,249,252,0.95) 100%);
    border: 1px solid var(--clr-card-border);
    box-shadow: 0 10px 26px rgba(15,23,42,0.05);
    transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}

    .ct-client-chip:hover {
        transform: translateY(-4px);
        box-shadow: 0 18px 36px rgba(15,23,42,0.09);
        border-color: color-mix(in srgb, var(--clr-accent) 32%, transparent);
    }

.ct-client-media {
    width: 60px;
    height: 60px;
    border-radius: var(--radius-md);
    background: var(--clr-light-bg);
    border: 1px solid var(--clr-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

    .ct-client-media img {
        max-width: 38px;
        max-height: 38px;
        object-fit: contain;
    }

.ct-client-initial {
    font-family: 'Playfair Display', serif;
    font-size: var(--fs-xl);
    font-weight: 700;
    color: var(--clr-primary);
}

.ct-client-name {
    font-size: var(--fs-sm);
    font-weight: 700;
    color: var(--clr-text);
    line-height: 1.4;
}


/* ════════════════════════════════════════════════════════════
   TESTIMONIALS
════════════════════════════════════════════════════════════ */

.ct-testimonials {
    background: linear-gradient(180deg, rgba(240,245,251,0.65) 0%, var(--clr-white) 100%);
}

.ct-tgrid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
    margin-top: 48px;
    align-items: stretch;
}

.ct-tcard {
    position: relative;
    padding: 28px 26px 24px;
    border-radius: var(--radius-xl);
    border: 1px solid var(--clr-card-border);
    background: linear-gradient(180deg, var(--clr-white) 0%, rgba(247,249,252,0.95) 100%);
    box-shadow: 0 16px 36px rgba(15,23,42,0.055);
    display: flex;
    flex-direction: column;
    transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}

    .ct-tcard:hover {
        transform: translateY(-4px);
        box-shadow: 0 24px 48px rgba(15,23,42,0.09);
        border-color: color-mix(in srgb, var(--clr-accent) 28%, transparent);
    }

.ct-tcard-qmark {
    font-family: 'Playfair Display', serif;
    font-size: 4rem;
    line-height: 1;
    color: color-mix(in srgb, var(--clr-accent) 20%, transparent);
    display: block;
    margin-bottom: 8px;
}

.ct-tcard-text {
    font-size: var(--fs-sm);
    color: var(--clr-text);
    line-height: 1.85;
    font-style: italic;
    flex: 1;
    margin-bottom: 22px;
}

.ct-tcard-foot {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 18px;
    border-top: 1px solid rgba(204,221,239,0.72);
    margin-top: auto;
}

.ct-tcard-foot > div {
    min-height: 4rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.ct-tcard-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--clr-accent) 10%, transparent);
    color: var(--clr-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    flex-shrink: 0;
}

.ct-tcard-name {
    font-size: var(--fs-sm);
    font-weight: 700;
    color: var(--clr-text);
    margin-bottom: 3px;
}

.ct-tcard-role {
    font-size: var(--fs-xs);
    color: var(--clr-text-light);
    line-height: 1.55;
}


/* ════════════════════════════════════════════════════════════
   CTA
════════════════════════════════════════════════════════════ */

.ct-cta {
    position: relative;
    background: linear-gradient(135deg, var(--clr-primary-dark) 0%, var(--clr-primary) 60%, var(--clr-accent-dark) 100%);
    overflow: hidden;
}

.ct-cta-mesh {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
}

.ct-cta-orb {
    position: absolute;
    border-radius: 50%;
}

.ct-cta-orb--a {
    top: -80px;
    right: -60px;
    width: 380px;
    height: 380px;
    background: radial-gradient(circle, color-mix(in srgb, var(--clr-accent) 22%, transparent), transparent 68%);
    animation: ct-orb-float 24s ease-in-out infinite alternate;
}

.ct-cta-orb--b {
    bottom: -60px;
    left: -40px;
    width: 280px;
    height: 280px;
    background: radial-gradient(circle, rgba(255,255,255,0.06), transparent 70%);
    animation: ct-orb-float 28s ease-in-out infinite alternate-reverse;
}

.ct-cta-wave-top {
    position: relative;
    z-index: 1;
    line-height: 0;
    margin-bottom: -1px;
}

    .ct-cta-wave-top svg {
        display: block;
        width: 100%;
    }

.ct-cta-badge {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    border-radius: var(--radius-capsule);
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.18);
    color: rgba(255,255,255,0.90);
    font-size: var(--fs-xs);
    font-weight: 700;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.ct-cta-heading {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.9rem, 4vw, var(--fs-3xl));
    font-weight: 700;
    color: #fff;
    line-height: 1.18;
    margin-bottom: 16px;
}

.ct-cta-body {
    font-size: var(--fs-md);
    color: rgba(255,255,255,0.78);
    line-height: 1.72;
    max-width: 580px;
    margin-bottom: 36px;
}

.ct-cta-inner {
    padding: 80px 0;
}


/* ════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════ */

@media (max-width: 1199.98px) {
    .ct-hero-layout,
    .ct-intro-grid,
    .ct-cap-grid,
    .ct-cap-grid--rev {
        grid-template-columns: 1fr;
    }

        .ct-cap-grid--rev .ct-cap-copy,
        .ct-cap-grid--rev .ct-cap-visual {
            order: initial;
        }

    .ct-hero-layout {
        gap: 34px;
        padding: 112px 0 94px;
    }

    .ct-proof-card,
    .ct-intro-visual-shell,
    .ct-cap-card,
    .ct-cap-photo-card {
        max-width: 720px;
    }

    .ct-intro-visual {
        position: static;
    }
}

@media (max-width: 991.98px) {
    .ct-hero-layout {
        padding: 102px 0 88px;
        gap: 26px;
    }

    .ct-hero-title {
        max-width: none;
    }

    .ct-tgrid {
        grid-template-columns: 1fr 1fr;
    }

    .ct-client-chip {
        flex-basis: calc((100% - var(--ct-client-gap)) / 2);
        max-width: calc((100% - var(--ct-client-gap)) / 2);
    }

    .ct-hero-wave svg {
        height: 84px;
    }
}

@media (max-width: 767.98px) {
    .ct-hero-layout {
        padding: 94px 0 80px;
    }

    .ct-proof-card,
    .ct-cap-card,
    .ct-tcard,
    .ct-svc-card {
        padding: 22px 18px;
    }

    .ct-cap-card {
        min-height: 220px;
        max-height: 220px;
    }

    .ct-intro-visual-shell {
        min-height: 320px;
        max-height: 320px;
    }

    .ct-cap-photo-card,
    .ct-cap-photo {
        min-height: 320px;
        max-height: 320px;
    }

    .ct-intro-badge {
        left: 16px;
        right: 16px;
        bottom: 16px;
        padding: 16px;
    }

    .ct-cap-photo-badge {
        left: 16px;
        right: 16px;
        bottom: 16px;
        padding: 16px;
    }

    .ct-anchor-pill {
        height: 34px;
        font-size: var(--fs-xs);
        padding: 0 12px;
    }

    .ct-client-chip {
        flex-basis: 100%;
        max-width: 100%;
    }

    .ct-tgrid {
        grid-template-columns: 1fr;
    }

    .ct-services-grid {
        grid-template-columns: 1fr;
    }

    .ct-cta-inner {
        padding: 64px 0;
    }

    .ct-hero-wave svg {
        height: 68px;
    }
}

@media (max-width: 479.98px) {
    .ct-hero-actions {
        flex-direction: column;
        align-items: flex-start;
    }

        .ct-hero-actions .btn {
            width: 100%;
            text-align: center;
            justify-content: center;
        }

    .ct-anchor-row {
        gap: 8px;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .ct-anim-up,
    .ct-proof-ring,
    .ct-eyebrow-dot,
    .ct-orb,
    .ct-cta-orb,
    .ct-grid-lines,
    .ct-cap-card-glow {
        animation: none !important;
        transition: none !important;
    }

    .ct-anim-up {
        opacity: 1;
        transform: none;
    }
}
