﻿.container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--gutter);
}

.svc-hero__meta {
    display: flex;
    gap: 1.25rem;
      
    font-size: 0.75rem;
    letter-spacing: 0.08em;
     
    text-transform: uppercase;
    margin-bottom: 2rem;
    flex-wrap: wrap;
    align-items: center;
}
.last-text{
    display:flex;
    width:60%;
    gap:40px;
}
.svc-hero__meta span {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

        .svc-hero__meta span::before {
            content: '';
            width: 6px;
            height: 6px;
            background: var(--lime);
            border-radius: 50%;
        }


.page-hero {
    padding: 1rem 0 5rem;
    position: relative;
    overflow: hidden;
}

    .page-hero::before {
        content: '';
        position: absolute;
        top: -10%;
        right: -8%;
        width: 640px;
        height: 640px;
        background: radial-gradient(circle, rgba(208,216,32,0.12) 0%, transparent 60%);
        filter: blur(60px);
        pointer-events: none;
    }

.page-hero__inner {
    position: relative;
    z-index: 1;
}

.page-hero__meta {
    display: flex;
    gap: 1.25rem;
    flex-wrap: wrap;
    align-items: center;
      
    font-size: 0.75rem;
    letter-spacing: 0.08em;
     
    text-transform: uppercase;
    margin-bottom: 2rem;
}

    .page-hero__meta span {
        display: flex;
        align-items: center;
        gap: 0.5rem;
    }

        .page-hero__meta span::before {
            content: '';
            width: 6px;
            height: 6px;
            background: var(--lime);
            border-radius: 50%;
        }

.page-hero__title {
 
    font-weight: 300;
    font-size: clamp(2.75rem, 7.5vw, 7rem);
    line-height: 0.95;
    letter-spacing: -0.028em;
    font-variation-settings: 'opsz' 72;
    margin-bottom: 2rem;
    max-width: 18ch;
}

    .page-hero__title em {
        font-style: italic;
        font-weight: 400;
    }
.bold-text{
    font-weight:bold!important;
}
.page-hero__bottom {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 4rem;
    align-items: end;
    margin-top: 3rem;
}

.page-hero__lede {
    font-size: 1.4rem;
    line-height: 1.45;
    color: var(--ink-700);
    font-weight: 300;
    max-width: 50ch;
 
    font-variation-settings: 'opsz' 36;
}

.page-hero__actions {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
}
.svc-hero {
    position: relative;
    overflow: hidden;
}

    .svc-hero > div:first-child {
        position: absolute;
        top: 0;
        right: 0;
        width: 45%;
        height: 100%;
        display: flex;
        justify-content: flex-end;
        align-items: center;
        pointer-events: none;
        z-index: 1;
    }
.margin-top{
    margin-top:3rem
}
.svc-hero > div:first-child img {
    width: 100%;
    max-width: 700px;
    height: auto;
    object-fit: contain;
}

.svc-bar {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 24px;
    max-width: 60%;
}

.svc-bar__subvalue {
    margin-top: 2px;
    font-size: 14px;
    font-weight :500;
}
.green-background {
    background-color: #d9df55;
    margin-top:2rem;
    margin-bottom:2rem;
    padding:3rem;
    margin-right:-25rem;
    border-radius:30px;
}
.green-background-software {
    background-color: #d9df55;
    margin-top: 2rem;
    margin-bottom: 2rem;
    padding: 3rem;
    border-radius: 30px;
}
.software-sub{
    width:60%;
}
.services-grid-qa {
    display: grid;
    grid-template-columns: 2fr 1fr; 
    gap: 25px;
    align-items: stretch;
}
.green-background {
    overflow: hidden;
}

.text-bar-wrapper {
    overflow: hidden;
    width: 100%;
}
.text-bar {
    display: flex;
    gap: 30px;
    width: max-content;
    align-items: center;
    will-change: transform;
}
.work-hero {
    position: relative;
    overflow: hidden;
    min-height: 80vh;
}
.work-hero {
    position: relative;
    overflow: hidden;
}

.work-hero__bg {
    z-index:-1;
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transform: translateY(40px);
    opacity: 0;
    transition: transform 1.2s ease-out, opacity 1.2s ease-out;
}

    .work-hero__bg.is-loaded {
        transform: translateY(0);
        opacity: 1;
    }

.green-background-work {
    background-color: #d9df55;
    margin-top: 2rem;
    margin-bottom: 2rem;
    padding: 1rem;
    margin-right: -25rem;
    border-radius: 30px;
}
.text-bar__item {
    white-space: nowrap;
}

.svc-bar__label {
    font-size: 16px;
    font-weight: 500;
}

.text-bar-wrapper {
    mask-image: linear-gradient( to right, transparent, black 10%, black 90%, transparent );
}

.services-grid-qa .engage-card:first-child {
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.engage-card__footer {
    margin-top: 20px;
}


@media (max-width: 768px) {
    .services-grid-outsorcing {
        grid-template-columns: 1fr;
    }
}
.svc-hero1{
    overflow-x:hidden;
}
.svc-bar-qa {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 24px;
    max-width: 50%;
}

.services-carousel {
    position: relative;
    width: 100%;
}

.services-carousel__track {
    display: flex;
    gap: 24px;
    overflow-x: hidden;
    scroll-behavior: smooth;
}

.services-carousel {
    position: relative;
    width: 100%;
}

/* TRACK */
.services-carousel__track {
    display: flex;
    gap: 24px;
    overflow-x: auto;
    scroll-behavior: smooth;
    padding: 10px 0;
    scrollbar-width: none;
}

    .services-carousel__track::-webkit-scrollbar {
        display: none;
    }

.service-card--carousel {
    background:white;
    border:none;
    flex: 0 0 calc(33.333% - 16px);
}


.tech-hero__grid {
    margin-top:1rem;
    display: grid;
    grid-template-columns: 1fr 520px;
    align-items: center;
    gap: 80px;
}

.tech-hero__content {
    position: relative;
    z-index: 2;
}

.tech-hero__bottom {
    margin-top: 32px;
    max-width: 720px;
}

.tech-hero__image {
    position: relative;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

    .tech-hero__image img {
        width: 100%;
        max-width: 520px;
        height: auto;
        display: block;
        object-fit: contain;
    }

@media (max-width: 992px) {

    .tech-hero {
        padding: 80px 0;
    }

    .tech-hero__grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .tech-hero__image {
        justify-content: center;
    }

        .tech-hero__image img {
            max-width: 100%;
        }
}
.carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 20px;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}

    /* LEFT */
    .carousel-btn.prev {
        left: -60px;
        border-radius: 0 40px 40px 0;
    }

    /* RIGHT */
    .carousel-btn.next {
        right: -60px;
        border-radius: 40px 0 0 40px;
    }



.carousel-btn.prev .arrow {
    transform: rotate(135deg);
}

.carousel-btn.next .arrow {
    transform: rotate(-45deg);
}
.software-img{
    margin-right:100px;
}
.cap__detail {
    margin-top: 1rem;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    padding-top: 1rem;
    border-top: 1px solid var(--ink-200);
}
.services-qa-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
.last-section{
    margin-bottom:2rem;
}
.cap__detail span {
    font-size: 0.7rem;
    letter-spacing: 0.04em;
    color: var(--ink-700);
    padding: 0.3rem 0.625rem;
    background: var(--ink-100);
    border-radius: 999px;
}
.cap__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.cap__icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--ink-100);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--dur-base) var(--ease-out);
}
.svc-bar__label {
      
    font-size:14px;
    font-weight:bold;
     
}

.svc-bar__value {
    font-size: 14px;
    font-weight: 500;
}

/* =========================================================
                   BUTTONS
                   ========================================================= */


.btn--primary {
    background: var(--ink-1000);
    color: var(--white);
}

    .btn--primary:hover {
        background: var(--ink-900);
        transform: translateY(-1px);
    }

    .btn--primary .btn__arrow {
        transition: transform var(--dur-base) var(--ease-out);
    }

    .btn--primary:hover .btn__arrow {
        transform: translate(3px,-3px);
    }

.btn--ghost {
    background: transparent;
    color: var(--ink-1000);
    border-color: var(--ink-300);
}

    .btn--ghost:hover {
        border-color: var(--ink-1000)!important;
        background: var(--ink-1000)!important;
        color: var(--white);
    }

.btn--lime {
    background: var(--lime);
    color: var(--ink-1000);
}

    .btn--lime:hover {
        background: var(--lime-bright);
        transform: translateY(-1px);
    }

.btn--ghost-dark {
    background: transparent;
    color: var(--white);
    border-color: var(--ink-600);
}

    .btn--ghost-dark:hover {
        border-color: var(--lime);
        color: var(--lime);
    }

/* =========================================================
                   SECTION HEADER
                   ========================================================= */
.sec-head {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 2rem;
    align-items: end;
    margin-bottom: 4rem;
}

.sec-head__eyebrow {
      
    font-size: 0.75rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
     
    margin-bottom: 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.625rem;
}

    .sec-head__eyebrow::before {
        content: '';
        width: 24px;
        height: 1px;
        background: var(--ink-500);
    }

.sec-head__title {
 
    font-weight: 300;
    font-size: clamp(2.5rem, 5.5vw, 4.5rem);
    line-height: 0.95;
    letter-spacing: -0.025em;
    font-variation-settings: 'opsz' 72;
    max-width: 18ch;
}

    .sec-head__title em {
        font-style: italic;
        font-weight: 400;
    }

        .sec-head__title em::after {
            content: '.';
            color: var(--lime);
        }

/* =========================================================
                   SERVICES GRID — "What we offer"
                   ========================================================= */
.services-overview {
    padding: 3rem 0;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}
.services-grid-software {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.card-software {
    background-color: #d9df55;
    margin-top: 2rem;
    margin-bottom: 2rem;
    padding: 3rem;
    border-radius: 30px;
}
.svc-card {
    background: var(--white);
    border: 1px solid var(--ink-200);
    border-radius: 16px;
    padding: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    position: relative;
    transition: all var(--dur-base) var(--ease-out);
    min-height: 280px;
}

    .svc-card:hover {
        border-color: var(--ink-1000);
        transform: translateY(-2px);
    }

.svc-card--featured {
    grid-column: span 2;
    flex-direction: row;
    align-items: flex-start;
    gap: 3rem;
    min-height: 220px;
    background: var(--ink-1000);
    color: var(--white);
    border-color: var(--ink-1000);
}

    .svc-card--featured:hover {
        background: var(--ink-900);
        transform: translateY(-2px);
    }

.svc-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.svc-card__num {
      
    font-size: 0.7rem;
    letter-spacing: 0.12em;
     
}

.svc-card--featured .svc-card__num {
    color: var(--ink-400);
}

.svc-card__icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--ink-100);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--dur-base) var(--ease-out);
    flex-shrink: 0;
}

.svc-card:hover .svc-card__icon {
    background: var(--lime);
}

.svc-card--featured .svc-card__icon {
    background: var(--ink-700);
}

.svc-card--featured:hover .svc-card__icon {
    background: var(--lime);
}

.svc-card__body {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    flex: 1;
}

.svc-card__title {
 
    font-weight: 300;
    font-size: 1.875rem;
    line-height: 1.05;
    letter-spacing: -0.022em;
    font-variation-settings: 'opsz' 72;
    color: var(--ink-1000);
}

.svc-card--featured .svc-card__title {
    color: var(--white);
    font-size: 2.25rem;
}

.svc-card__title em {
    font-style: italic;
    font-weight: 400;
}

.svc-card__desc {
    font-size: 0.95rem;
    color: var(--ink-700);
    line-height: 1.6;
    flex-grow: 1;
}

.svc-card--featured .svc-card__desc {
    color: var(--ink-300);
    font-size: 1rem;
    max-width: 48ch;
}

.svc-card__tags {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    padding-top: 1rem;
    border-top: 1px solid var(--ink-200);
}

.svc-card--featured .svc-card__tags {
    border-top-color: var(--ink-700);
}

.svc-card__tags span {
      
    font-size: 0.7rem;
    letter-spacing: 0.04em;
    color: var(--ink-700);
    padding: 0.3rem 0.625rem;
    background: var(--ink-100);
    border-radius: 999px;
}

.svc-card--featured .svc-card__tags span {
    background: var(--ink-700);
    color: var(--ink-300);
}

.svc-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--lime);
    margin-top: auto;
    white-space: nowrap;
    flex-shrink: 0;
    transition: gap var(--dur-base) var(--ease-out);
}

    .svc-card__link:hover {
        gap: 0.75rem;
    }

    .svc-card__link svg {
        flex-shrink: 0;
    }

/* Featured layout: left meta, right content */
.svc-card--featured .svc-card__left {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-width: 200px;
    padding-top: 0;
}

.svc-card--featured .svc-card__right {
    flex: 1;
}

/* =========================================================
                   PROCESS
                   ========================================================= */
.process {
    position: relative;
    overflow: hidden;
}



.process-services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 320px;
    gap: 24px;

}

    .process-services-grid .process-card:nth-child(1) {
        grid-column: span 2;
        grid-row: span 1;
    }

    .process-services-grid .process-card:nth-child(2) {
        grid-column: span 1;
    }

    .process-services-grid .process-card:nth-child(3) {
      min-height:360px;
        grid-column: span 1;
    }

    .process-services-grid .process-card:nth-child(4) {
        grid-column: span 2;
        min-height: 360px;
        grid-row: span 1;
    }
.service-card-body{
    margin-bottom:1rem;
}
.cta__inner1{
    display:flex;
    align-items:center;
    justify-content:flex-start;
}
.process-card {
    min-height: 320px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.process-card--wide {
    grid-column: span 1;
}

.process-card--narrow {
    grid-column: span 1;
}

.process-step__time {
    font-size: 14px;
    opacity: 0.7;
}

@media (max-width: 992px) {
    .process-services-grid {
        grid-template-columns: 1fr;
    }
}
.service-card-title{
    font-size:22px;
    font-weight:bold;
}
.service-card-text{
    font-size:14px;
}
.number-grid {
    display: grid;
    grid-template-columns: 92px 1fr;
    align-items: stretch;
    gap: 0px;
    position: relative;
}

.big-number {
    font-size: 300px;
    margin-top:-40px;
    font-weight: 500;
    line-height: 1;
    color: #6b7280;
    user-select: none;
    pointer-events: none;
}

.proof__wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 60px;
}

/* LEFT SIDE */
.proof__content {
    flex: 1;
    max-width: 550px;
}

.proof__description {
    margin-top: 15px;
    margin-bottom: 25px;
    color: #555;
    line-height: 1.6;
}
.capabilities__wrapper {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 60px;
}

/* LEFT SIDE */
.capabilities__content {
    flex: 1;
    max-width: 450px;
}

/* RIGHT SIDE */
.capabilities__cards {
    flex: 1.5;
}

.outsorcing-card {
    display: flex;
    width: 100%;
    align-items: stretch;
}

    .outsorcing-card .engage-card {
        flex: 1;
        padding: 20px;
        position: relative;
        transition: all 0.3s ease;
    }

        .outsorcing-card .engage-card:not(:first-child) {
            margin-left: -20px;
        }

        .outsorcing-card .engage-card:nth-child(1) {
            z-index: 4;
        }

        .outsorcing-card .engage-card:nth-child(2) {
            z-index: 3;
        }

        .outsorcing-card .engage-card:nth-child(3) {
            z-index: 2;
            transform: scale(1.08);
            margin-top: -10px;
            box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
        }

        .outsorcing-card .engage-card:nth-child(4) {
            z-index: 1;
        }

        /* HOVER EFFECT */
        .outsorcing-card .engage-card:hover {
            transform: translateY(-10px);
            z-index: 10;
        }
.services-grid-outsorcing {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
}
@media (max-width: 992px) {
    .capabilities__wrapper {
        flex-direction: column;
    }

    .services-grid-software {
        grid-template-columns: 1fr;
    }
}
.proof__image {
    flex: 1;
    display: flex;
    justify-content: flex-end;
}

    .proof__image img {
        width: 100%;
        max-width: 800px;
        height: auto;
        border-radius: 12px;
        object-fit: cover;
    }

/* RESPONSIVE */
@media (max-width: 992px) {
    .proof__wrapper {
        flex-direction: column;
        text-align: left;
    }

    .proof__image {
        justify-content: center;
    }
}
/* =========================================================
                   ENGAGEMENT MODELS
                   ========================================================= */
.engage {
    padding: 3rem 0;
}
.nr3,
.nr2{
    margin-left:-75px
}
.engage-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10.25rem;
    margin-top: 3rem;
}
.margin-bottom{
    margin-bottom:4rem;
}
.engage-card {
    background: #f2f3f5;
    border: 2px solid #606163;
    border-radius: 40px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    transition: all var(--dur-base) var(--ease-out);
    cursor: pointer;
    min-height: 320px;
}

    .engage-card:hover {
        border-color: var(--ink-1000);
        transform: translateY(-2px);
    }

.engage-card--featured {
    background: var(--lime);
    border-color: var(--lime);
}

    .engage-card--featured:hover {
        background: var(--lime-bright);
        border-color: var(--lime-bright);
    }

.engage-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.engage-card__label {
      
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
     
}

.engage-card--featured .engage-card__label {
    color: var(--ink-900);
    opacity: 0.7;
}

.engage-card__tag {
      
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.3rem 0.625rem;
    border-radius: 999px;
    background: var(--ink-100);
    color: var(--ink-700);
}

.engage-card--featured .engage-card__tag {
    background: var(--ink-1000);
    color: var(--lime);
}


    .engage-card__title em {
        font-style: italic;
        font-weight: 400;
    }

.engage-card__desc {
    font-size: 0.9rem;
    color: var(--ink-700);
    line-height: 1.55;
    flex-grow: 1;
}

.engage-card--featured .engage-card__desc {
    color: var(--ink-900);
}

.engage-card__terms {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--ink-200);
      
    font-size: 0.7rem;
}

.engage-card--featured .engage-card__terms {
    border-top-color: rgba(0,0,0,0.2);
}

.engage-card__term-label {
     
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.25rem;
}

.engage-card--featured .engage-card__term-label {
    color: var(--ink-700);
    opacity: 0.7;
}

.engage-card__term-value {
    color: var(--ink-1000);
    font-weight: 500;
}

/* =========================================================
                   STACK / TOOLS
                   ========================================================= */
.stack {
    padding: 3rem 0;
    background: var(--paper);
}
.cta-service{
    margin-top:3rem;
    margin-bottom:3rem;
}
.stack__head {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    margin-bottom: 4rem;
    align-items: end;
}

.stack__title {
 
    font-weight: 300;
    font-size: clamp(2rem, 4vw, 3.25rem);
    line-height: 1;
    letter-spacing: -0.025em;
    font-variation-settings: 'opsz' 72;
}

    .stack__title em {
        font-style: italic;
        font-weight: 400;
    }

.stack__desc {
    font-size: 1rem;
    color: var(--ink-700);
    line-height: 1.6;
    max-width: 40ch;
    padding-bottom: 0.5rem;
}

.stack-grid {
    display: grid;
    grid-template-columns: 200px 1fr;
    border-top: 1px solid var(--ink-1000);
    position: relative;
}

    .stack-grid::before {
        content: '';
        position: absolute;
        top: -3px;
        left: 0;
        width: 7px;
        height: 7px;
        background: var(--lime);
        border-radius: 50%;
    }

.stack-row {
    display: contents;
}

.stack-row__label, .stack-row__items {
    padding: 1.5rem 0;
    border-bottom: 1px solid var(--ink-200);
}

.stack-row__label {
      
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
     
    padding-right: 2rem;
}

.stack-row__items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.tag {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.75rem;
      
    font-size: 0.75rem;
    letter-spacing: 0.04em;
    border-radius: 999px;
    background: var(--white);
    color: var(--ink-1000);
    border: 1px solid var(--ink-200);
    transition: all var(--dur-fast) var(--ease-out);
}

    .tag:hover {
        border-color: var(--ink-1000);
    }

.tag--feature {
    background: var(--lime);
    border-color: var(--lime);
}

/* =========================================================
                   PROOF / CASE STUDIES
                   ========================================================= */
.proof {
    padding: 3rem 0;
}

.proof-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
}

.case {
    background: var(--ink-1000);
    border-radius: 20px;
    padding: 2.5rem;
    color: var(--white);
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: transform var(--dur-base) var(--ease-out);
    display: flex;
    flex-direction: column;
    min-height: 360px;
}

    .case:hover {
        transform: translateY(-4px);
    }

    .case::before {
        content: '';
        position: absolute;
        inset: 0;
        background: radial-gradient(ellipse at top right, rgba(208,216,32,0.1) 0%, transparent 55%);
        pointer-events: none;
        opacity: 0.7;
        transition: opacity var(--dur-base) var(--ease-out);
    }

    .case:hover::before {
        opacity: 1;
    }

.case__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
}

.case__country {
      
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--lime);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

    .case__country::before {
        content: '';
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--lime);
    }

.case__year {
      
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    color: var(--ink-400);
}

.case__title {
 
    font-weight: 300;
    font-size: 2rem;
    line-height: 1.05;
    letter-spacing: -0.025em;
    font-variation-settings: 'opsz' 72;
    margin: 1.5rem 0 1rem;
    position: relative;
    max-width: 16ch;
}

    .case__title em {
        font-style: italic;
        font-weight: 400;
    }

.case__desc {
    color: var(--ink-300);
    font-size: 0.9rem;
    line-height: 1.55;
    max-width: 42ch;
    margin-bottom: auto;
    position: relative;
}

.case__bottom {
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--ink-700);
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    position: relative;
}

.case__metrics {
    display: flex;
    gap: 2rem;
}

.case__metric strong {
    display: block;
 
    font-weight: 300;
    font-size: 1.5rem;
    letter-spacing: -0.025em;
    color: var(--lime);
    font-variation-settings: 'opsz' 72;
    line-height: 1;
}

    .case__metric strong sup {
        font-size: 0.5em;
        vertical-align: super;
    }

.case__metric span {
    font-size: 0.7rem;
    color: var(--ink-400);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-top: 0.4rem;
    display: block;
}

.case__arrow {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--ink-600);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--dur-base) var(--ease-out);
}

.case:hover .case__arrow {
    background: var(--lime);
    border-color: var(--lime);
    transform: rotate(-45deg);
}

    .case:hover .case__arrow svg path {
        stroke: var(--ink-1000);
    }

/* =========================================================
                   FAQ
                   ========================================================= */
.faq {
    padding: 3rem 0;
    background: var(--paper);
    border-top: 1px solid var(--ink-200);
}

.faq-list {
    display: grid;
    grid-template-columns: 200px 1fr;
    border-top: 1px solid var(--ink-1000);
    position: relative;
}

    .faq-list::before {
        content: '';
        position: absolute;
        top: -3px;
        left: 0;
        width: 7px;
        height: 7px;
        background: var(--lime);
        border-radius: 50%;
    }

.faq-row {
    display: contents;
}

.faq-row__q, .faq-row__a {
    padding: 2rem 0;
    border-bottom: 1px solid var(--ink-200);
}

.faq-row__q {
      
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
     
    padding-right: 2rem;
}

.faq-row__a {
    font-size: 1rem;
    color: var(--ink-800);
    line-height: 1.6;
    max-width: 60ch;
}

    .faq-row__a strong {
        font-weight: 500;
        color: var(--ink-1000);
    }

/* =========================================================
                   RELATED SERVICES
                   ========================================================= */
.related {
    padding: 3rem 0;
    background: var(--ink-1000);
    color: var(--white);
}

    .related .sec-head__eyebrow {
        color: var(--lime);
    }

        .related .sec-head__eyebrow::before {
            background: var(--lime);
        }

    .related .sec-head__title {
        color: var(--white);
    }

        .related .sec-head__title em::after {
            color: var(--lime);
        }

.related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-top: 3rem;
}

.related-card {
    background: transparent;
    border: 1px solid var(--ink-700);
    border-radius: 14px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    transition: all var(--dur-base) var(--ease-out);
    min-height: 200px;
}

    .related-card:hover {
        border-color: var(--lime);
        transform: translateY(-2px);
    }

.related-card__num {
      
    font-size: 0.7rem;
    letter-spacing: 0.12em;
     
}

.related-card__title {
 
    font-weight: 300;
    font-size: 1.5rem;
    line-height: 1.05;
    letter-spacing: -0.022em;
    font-variation-settings: 'opsz' 72;
    color: var(--white);
    flex-grow: 1;
}

    .related-card__title em {
        font-style: italic;
        font-weight: 400;
    }

.related-card__link {
     
    font-size: 0.85rem;
    color: var(--lime);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    margin-top: auto;
}

/* =========================================================
                   CTA
                   ========================================================= */
.cta {
    padding: 8rem 0;
    background: var(--paper);
    border-top: 1px solid var(--ink-200);
}
.whitebtn{
    background:white!important;
    border:none!important
}
.cta__inner {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 4rem;
    align-items: center;
}

.cta__title {
 
    font-weight: 300;
    font-size: clamp(3rem, 7vw, 6rem);
    line-height: 0.92;
    letter-spacing: -0.028em;
    font-variation-settings: 'opsz' 72;
}

    .cta__title em {
        font-style: italic;
        font-weight: 400;
    }

        .cta__title em::after {
            content: '.';
            color: var(--lime);
        }

.cta__side {
    padding-bottom: 0.75rem;
}

.cta__lede {
    font-size: 1.05rem;
    color: var(--ink-700);
    line-height: 1.55;
    margin-bottom: 1.75rem;
    max-width: 38ch;
}

.cta__actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

/* =========================================================
                   FOOTER
                   ========================================================= */
.footer {
    background: var(--ink-1000);
    color: var(--ink-300);
    padding: 5rem 0 2rem;
}

.footer__top {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 3rem;
    margin-bottom: 4rem;
}

.footer__brand {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.footer__brand-logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.footer__brand-text {
    color: var(--white);
    font-weight: 500;
    font-size: 1rem;
}

.footer__tagline {
    color: var(--ink-400);
    font-size: 0.875rem;
    max-width: 36ch;
    line-height: 1.55;
}

.footer__col-title {
      
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
     
    margin-bottom: 1.25rem;
}

.footer__col ul li {
    padding: 0.375rem 0;
}

.footer__col ul a {
    font-size: 0.9rem;
    color: var(--ink-300);
    transition: color var(--dur-fast) var(--ease-out);
}

    .footer__col ul a:hover {
        color: var(--lime);
    }

.footer__bottom {
    padding-top: 2rem;
    border-top: 1px solid var(--ink-700);
    display: flex;
    justify-content: space-between;
    align-items: center;
      
    font-size: 0.7rem;
    letter-spacing: 0.08em;
     
}

/* =========================================================
                   ENTRY ANIMATIONS
                   ========================================================= */
.fade-in {
    opacity: 0;
    transform: translateY(20px);
    animation: fadeIn 1s var(--ease-out) forwards;
}

    .fade-in.d1 {
        animation-delay: 0.1s;
    }

    .fade-in.d2 {
        animation-delay: 0.25s;
    }

    .fade-in.d3 {
        animation-delay: 0.4s;
    }

    .fade-in.d4 {
        animation-delay: 0.55s;
    }

/* =========================================================
                   RESPONSIVE
                   ========================================================= */
@media (max-width: 1024px) {

    .page-hero__bottom {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .svc-bar {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }

    .svc-bar__cell {
        border-right: none;
        padding-right: 0;
        padding-bottom: 1rem;
        border-bottom: 1px solid var(--ink-200);
    }

    .services-grid, .proof-grid, .related-grid {
        grid-template-columns: 1fr;
    }

    .svc-card--featured {
        grid-column: span 1;
        flex-direction: column;
    }

    .engage-grid {
        grid-template-columns: 1fr;
    }

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

    .stack__head {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .stack-grid {
        grid-template-columns: 1fr;
    }

    .stack-row__label {
        padding-bottom: 0.5rem;
        border-bottom: none;
    }

    .faq-list {
        grid-template-columns: 1fr;
    }

    .faq-row__q {
        padding-bottom: 0.5rem;
        border-bottom: none;
    }

    .cta__inner {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .sec-head {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .process-grid {
        grid-template-columns: 1fr;
    }
}
