* {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        :root {
            --primary: #00794A;
            --primary-light: #00a05f;
            --primary-dark: #005a37;
            --primary-rgb: 0, 121, 74;
            
            --surface-0: #FFFFFF;
            --surface-1: #FAFAFA;
            --surface-2: #F5F5F7;
            --surface-3: #E8E8ED;
            --surface-dark: #1D1D1F;
            
            --text-primary: #1D1D1F;
            --text-secondary: #515154;
            --text-tertiary: #6e6e73;
            --text-inverse: #F5F5F7;
            
            --border-light: rgba(0, 0, 0, 0.04);
            --border-medium: rgba(0, 0, 0, 0.08);
            
            --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
            --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.04);
            --shadow-md: 0 4px 24px rgba(0, 0, 0, 0.08);
            --shadow-lg: 0 12px 48px rgba(0, 0, 0, 0.12);
            --shadow-xl: 0 24px 64px rgba(0, 0, 0, 0.16);
            
            --radius-sm: 6px;
            --radius-md: 12px;
            --radius-lg: 18px;
            --radius-xl: 24px;
            
            --transition-base: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            --transition-smooth: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
            
            --spacing-xs: 4px;
            --spacing-sm: 8px;
            --spacing-md: 16px;
            --spacing-lg: 24px;
            --spacing-xl: 32px;
            --spacing-2xl: 48px;
            --spacing-3xl: 64px;
        }

        /* Base Styles */
body {
            font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
            background: var(--surface-0);
            color: var(--text-primary);
            line-height: 1.4;
            font-size: 16px;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            overflow-x: hidden;
            position: relative;
        }

        /* Typography System - REDUCED SIZES */
        .display-1 {
            font-size: clamp(2rem, 6vw, 3.5rem);
            font-weight: 700;
            letter-spacing: -0.04em;
            line-height: 1;
        }

        .display-2 {
            font-size: clamp(1.5rem, 4vw + 0.5rem, 2.5rem);
            font-weight: 700;
            letter-spacing: -0.03em;
            line-height: 1.1;
        }

        .heading-1 {
            font-size: clamp(1.5rem, 4vw, 2rem);
            font-weight: 600;
            letter-spacing: -0.02em;
            line-height: 1.2;
        }

        .heading-2 {
            font-size: clamp(1rem, 2vw, 1.25rem);
            font-weight: 600;
            letter-spacing: -0.01em;
            line-height: 1.3;
        }

        .heading-3 {
            font-size: clamp(0.875rem, 2vw, 1.125rem);
            font-weight: 500;
            line-height: 1.4;
        }

        .body-large {
            font-size: 1rem;
            line-height: 1.5;
            color: var(--text-secondary);
        }

        .body-medium {
            font-size: 0.875rem;
            line-height: 1.5;
            color: var(--text-secondary);
        }

        /* ── Desktop ≥ 1200 px: wider hero content ─────────────── */
        @media (min-width: 1200px){
        .hero-content{
            max-width: 1400px;
        }
        .hero-copy h1{
            font-size: clamp(3.5rem, 6vw + .5rem, 5.5rem);
            line-height: 1.05;
        }
        }

        /* ── Desktop-first hero enlargement ─────────────────────────── */
        @media (min-width: 992px){

        /* stretch the hero to full viewport minus navbar height */
        .hero{
            min-height: calc(100vh - var(--nav-height, 72px));
            padding-top: 8rem;                     /* more breathing room   */
            padding-bottom: 6rem;
        }

        /* widen the inner container */
        .hero .section-container,
        .hero-inner{
            max-width: 1200px;                     /* was ~840px            */
        }

        /* beef up headline */
        .hero h1,
        .hero .display-1{
            font-size: clamp(3rem, 5vw + 1rem, 5rem);  /* scales 48-80 px    */
            line-height: 1.08;
        }

        /* sub-headline */
        .hero-sub{
            font-size: 1.25rem;                    /* 20 px                 */
            max-width: 720px;
            margin-bottom: 3rem;
        }

        /* CTA buttons – fixed width looks tiny on 4K, so let them grow */
        .hero-ctas .btn{
            padding: 1rem 2.25rem;
            font-size: 1rem;
        }

        /* Hero image animation */
        .hero-image{
            transform: scale(1.05);
        }
        }

        @media (max-width: 768px) {
            .body-large {
                font-size: 0.875rem;
            }
            .body-medium {
                font-size: 0.8125rem;
            }
        }

        /* Navigation - REDUCED PADDING */
        .nav {
            position: fixed;
            top: 0;
            width: 100%;
            z-index: 1000;
            transition: var(--transition-smooth);
        }

        .nav-backdrop {
            position: absolute;
            inset: 0;
            background: rgba(255, 255, 255, 0.72);
            backdrop-filter: saturate(180%) blur(20px);
            -webkit-backdrop-filter: saturate(180%) blur(20px);
            border-bottom: 1px solid var(--border-light);
            transition: var(--transition-base);
        }

        .nav.scrolled .nav-backdrop {
            background: rgba(255, 255, 255, 0.9);
            border-bottom-color: var(--border-medium);
        }

        .nav-container {
            position: relative;
            max-width: 1200px;
            margin: 0 auto;
            padding: 0.5rem 1rem;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .nav-brand {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            text-decoration: none;
            color: var(--text-primary);
            cursor: pointer;
        }

        .nav-logo {
            width: 36px;
            height: 36px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .nav-wordmark {
            font-size: 1rem;
            font-weight: 600;
            letter-spacing: -0.01em;
        }

        .nav-menu {
            display: flex;
            gap: 1.5rem;
            list-style: none;
            align-items: center;
        }

       /* ─── Navigation Link Base ─────────────────────────────────────────────── */
.nav-link{
    color:var(--text-primary);
    text-decoration:none;
    font-size:0.875rem;
    font-weight:400;
    position:relative;
    cursor:pointer;
    padding:.25rem 0;
    transition:var(--transition-base);
}

/* underline ONLY for non-CTA links */
.nav-link:not(.nav-cta)::after{
    content:'';
    position:absolute;
    inset:auto 0 0 0;
    height:2px;
    background:var(--primary);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .35s var(--transition-base);
}
.nav-link:not(.nav-cta):hover,
.nav-link:not(.nav-cta).active{
    color:var(--primary);
}
.nav-link:not(.nav-cta):hover::after,
.nav-link:not(.nav-cta).active::after{
    transform:scaleX(1);
}

/* ─── CTA "Apple-Style" Glossy Pill ────────────────────────────────────── */
.nav-cta{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:.4rem 1.25rem;
    border-radius:9999px;
    font-weight:600;
    line-height:1;
    color:var(--text-inverse);
    background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);
    box-shadow:
        inset 0 1px 1px rgba(255,255,255,.35),
        0 4px 12px rgba(var(--primary-rgb),.35);
    transition:
        transform .35s cubic-bezier(.4,0,.2,1),
        box-shadow .35s cubic-bezier(.4,0,.2,1);
    overflow:hidden;          /* clip shine */
    text-decoration:none!important;
}

    .nav-cta{
        position:relative;
        display:inline-flex;
        align-items:center;
        justify-content:center;
        padding:.4rem 1.25rem;
        border-radius:9999px;
        font-weight:600;
        line-height:1;
        color:var(--text-inverse);
        background:linear-gradient(180deg,
                    hsl(156 90% 25%) 0%,
                    hsl(156 90% 18%) 100%);
        box-shadow:
            0 3px 12px rgba(var(--primary-rgb),.35);
        text-decoration:none!important;
        transition:
            transform .3s cubic-bezier(.4,0,.2,1),
            box-shadow .3s cubic-bezier(.4,0,.2,1);
        overflow:hidden;
    }

    /* top-edge sheen (dialed-back) */
    .nav-cta::before{
        content:'';
        position:absolute;
        inset:0;
        border-radius:inherit;
        background:linear-gradient(180deg,
                    rgba(255,255,255,.15) 0%,
                    rgba(255,255,255,0) 42%);
        pointer-events:none;
    }

    /* traveling sparkle */
    .nav-cta::after{
        content:'';
        position:absolute;
        top:-110%; left:-45%;
        width:70%; height:250%;
        background:linear-gradient(70deg,
                    rgba(255,255,255,.40) 0%,
                    rgba(255,255,255,0) 70%);
        border-radius:inherit;
        transform:translateX(-140%) rotate(20deg);
        transition:transform .9s cubic-bezier(.4,0,.2,1);
        pointer-events:none;
    }

    .nav-cta:hover{
        transform:translateY(-2px);
        box-shadow:
            0 6px 20px rgba(var(--primary-rgb),.45);
    }
    .nav-cta:hover::after{
        transform:translateX(260%) rotate(20deg);
    }

    .nav-cta:active{
        transform:translateY(-1px);
        box-shadow:
            0 3px 12px rgba(var(--primary-rgb),.30);
    }

/* respectful motion fallback */
@media (prefers-reduced-motion:reduce){
    .nav-cta,
    .nav-cta::after{
        transition:none;
    }
    .nav-cta:hover{transform:none;}
    .nav-cta:hover::after{display:none;}
}


        /* Mobile Menu */
        .mobile-menu-toggle {
            display: none;
            background: none;
            border: none;
            width: 1.5rem;
            height: 1.5rem;
            position: relative;
            cursor: pointer;
            padding: 0;
        }

        .hamburger {
            width: 1.25rem;
            height: 2px;
            background: var(--text-primary);
            position: relative;
            transition: var(--transition-base);
        }

        .hamburger::before,
        .hamburger::after {
            content: '';
            position: absolute;
            width: 100%;
            height: 100%;
            background: var(--text-primary);
            transition: var(--transition-base);
        }

        .hamburger::before {
            transform: translateY(-5px);
        }

        .hamburger::after {
            transform: translateY(5px);
        }

        .mobile-menu-toggle.active .hamburger {
            background: transparent;
        }

        .mobile-menu-toggle.active .hamburger::before {
            transform: rotate(45deg);
        }

        .mobile-menu-toggle.active .hamburger::after {
            transform: rotate(-45deg);
        }

        @media (max-width: 768px) {
            .mobile-menu-toggle {
                display: block;
            }

            .nav-menu {
                display: none;
                position: absolute;
                top: 100%;
                left: 0;
                width: 100%;
                background: var(--surface-0);
                box-shadow: var(--shadow-lg);
                flex-direction: column;
                padding: 1rem;
                gap: 0.25rem;
            }

            .nav-menu.active {
                display: flex;
            }

            .nav-link {
                width: 100%;
                padding: 0.5rem;
                border-radius: var(--radius-sm);
            }

            .nav-link:hover {
                background: var(--surface-2);
            }
        }

        /* Page Wrapper */
        @keyframes pageIn {
            from {
                opacity: 0;
                transform: translateY(20px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        /* Hero Section - REDUCED HEIGHT */
        .hero {
            min-height: 80vh;
            display: flex;
            align-items: center;
            padding: 4rem 0 3rem;
            position: relative;
            background: linear-gradient(180deg, var(--surface-0) 0%, var(--surface-1) 100%);
            overflow: hidden;
        }

        .hero-pattern {
            position: absolute;
            top: 0;
            left: 50%;
            transform: translateX(-50%);
            width: 120%;
            height: 100%;
            opacity: 0.03;
            background-image: radial-gradient(circle at 2px 2px, var(--primary) 1px, transparent 1px);
            background-size: 40px 40px;
            animation: drift 20s linear infinite;
        }

        .hero-glow {
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at 30% 30%, rgba(var(--primary-rgb), 0.15), transparent 70%);
            filter: blur(60px);
            z-index: 0;
            pointer-events: none;
        }

        @keyframes drift {
            from { transform: translateX(-50%) translateY(0); }
            to { transform: translateX(-50%) translateY(40px); }
        }

        .hero-content {
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 1rem;
            display: grid;
            grid-template-columns: 1fr;
            gap: 3rem;
            align-items: center;
            position: relative;
            z-index: 1;
        }

        @media (max-width: 768px) {
            .hero-content {
                grid-template-columns: 1fr;
                gap: 2rem;
                text-align: center;
            }
        }

        .hero-text {
            animation: heroSlideIn 1s cubic-bezier(0.4, 0, 0.2, 1);
        }

        @keyframes heroSlideIn {
            from {
                opacity: 0;
                transform: translateX(-30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

        .hero-badge {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            background: rgba(0, 121, 74, 0.08);
            color: var(--primary);
            padding: 0.2rem 0.75rem;
            border-radius: 1rem;
            font-size: 0.75rem;
            font-weight: 500;
            margin-bottom: 1rem;
        }

        .hero-badge::before {
            content: '';
            width: 0.4rem;
            height: 0.4rem;
            background: var(--primary);
            border-radius: 50%;
            animation: pulse 2s ease-in-out infinite;
        }

        @keyframes pulse {
            0%, 100% { opacity: 1; transform: scale(1); }
            50% { opacity: 0.6; transform: scale(1.2); }
        }

        .hero-title {
            margin-bottom: 1rem;
        }

        .hero-title-gradient {
            background: linear-gradient(135deg, var(--text-primary) 0%, var(--primary) 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        .hero-actions {
            display: flex;
            gap: 0.75rem;
            flex-wrap: wrap;
            margin-top: 1.5rem;
        }

        @media (max-width: 768px) {
            .hero-actions {
                justify-content: center;
            }
        }

        /* Buttons - REDUCED PADDING */
        .btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 0.625rem 1.5rem;
            border-radius: var(--radius-xl);
            font-size: 0.875rem;
            font-weight: 500;
            text-decoration: none;
            transition: var(--transition-base);
            cursor: pointer;
            border: none;
            position: relative;
            overflow: hidden;
            white-space: nowrap;
        }

        .btn-primary {
            background: var(--primary);
            color: var(--text-inverse);
            box-shadow: 0 4px 16px rgba(var(--primary-rgb), 0.3);
        }

        .btn-primary::before {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            width: 0;
            height: 0;
            background: rgba(255, 255, 255, 0.2);
            border-radius: 50%;
            transform: translate(-50%, -50%);
            transition: width 0.6s, height 0.6s;
        }

        .btn-primary:hover {
            background: var(--primary-dark);
            transform: translateY(-2px);
            box-shadow: 0 8px 24px rgba(var(--primary-rgb), 0.4);
        }

        .btn-primary:hover::before {
            width: 300px;
            height: 300px;
        }

        .btn-secondary {
            background: var(--surface-2);
            color: var(--text-primary);
            border: 1px solid var(--border-medium);
        }

        .btn-secondary:hover {
            background: var(--surface-3);
            transform: translateY(-1px);
            box-shadow: var(--shadow-sm);
        }


        .btn-outline-primary {
            background: var(--surface-0);
            color: var(--primary);
            border: 2px solid var(--primary);
        }

        .btn-outline-primary:hover {
            background: #000;
            color: #fff;
            border-color: #000;
        }


        /* Section Base - REDUCED PADDING */
        .section {
            padding: 4rem 0;
            position: relative;
        }

        @media (max-width: 768px) {
            .section {
                padding: 2.5rem 0;
            }
        }

        .section-container {
            max-width: 1280px;
            margin-inline:auto;
            padding-inline:1rem; 
        }

        .section-header {
            text-align: center;
            margin-bottom: 3rem;
        }

        @media (max-width: 768px) {
            .section-header {
                margin-bottom: 2rem;
            }
        }

        .section-overline {
            font-size: 0.75rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.1em;
            color: var(--primary);
            margin-bottom: 0.5rem;
        }

        .section-description {
            max-width: 640px;
            margin: 1rem auto 0;
        }

        /* Problem Cards - REDUCED PADDING */
        .problem-section {
            background: var(--surface-1);
            position: relative;
            padding: 1.5rem 0;
        }

        .threat-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: 0.75rem;
        }

        @media (max-width: 768px) {
            .threat-grid {
                grid-template-columns: 1fr;
            }
        }

        .threat-card {
            background: var(--surface-0);
            border-radius: var(--radius-lg);
            padding: 0.75rem;
            position: relative;
            overflow: hidden;
            transition: var(--transition-smooth);
            border: 1px solid var(--border-light);
            cursor: pointer;
        }

        .threat-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0;
            width: 100%;
            height: 3px;
            background: linear-gradient(90deg, var(--primary) 0%, var(--primary-light) 100%);
            transform: scaleX(0);
            transform-origin: left;
            transition: var(--transition-smooth);
        }

        .threat-card:hover {
            transform: translateY(-3px);
            box-shadow: var(--shadow-lg);
            border-color: transparent;
        }

        .threat-card:hover::before {
            transform: scaleX(1);
        }

        .threat-icon {
            width: 2rem;
            height: 2rem;
            background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.08) 0%, rgba(var(--primary-rgb), 0.12) 100%);
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 0.75rem;
        }

        .threat-icon svg {
            width: 1rem;
            height: 1rem;
            stroke: var(--primary);
            stroke-width: 2;
            fill: none;
        }

        /* adjust title + text inside */
        .threat-card .threat-title {
            font-size: clamp(0.875rem, 1.5vw, 1rem);
            margin-bottom: 0.375rem;
        }

        .threat-card .threat-description {
            font-size: 0.75rem;
            line-height: 1.3;
        }

        /* About Us section - REDUCED PADDING */
        .story-section,
        .values-section,
        .impact-section{
            padding:3rem 0;
        }

        /* ― Our Story ― */
        .story-grid{
            display:grid;
            grid-template-columns:1fr 1fr;
            gap:3rem;
            align-items:center;
        }
        .story-text{max-width:600px;}
        .story-image{display:flex;align-items:center;justify-content:center;}
        .story-image img{
            width:100%;
            height:auto;
            border-radius:var(--radius-lg);
            box-shadow:var(--shadow-lg);
            object-fit:cover;
        }

        /* ― Core Values ― */
        .values-section{background:var(--surface-1);}
        .heritage-values{
            display:grid;
            grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
            gap:1.25rem;
            margin-top:1.5rem;
        }
        .value-card{
            background:var(--surface-0);
            border-radius:var(--radius-md);
            padding:1rem;
            box-shadow:var(--shadow-sm);
            border:1px solid var(--border-light);
            transition:var(--transition-base);
        }
        .value-card:hover{
            transform:translateX(4px);
            box-shadow:var(--shadow-md);
            border-color:var(--primary);
        }
        .value-icon{
            width:2.25rem;
            height:2.25rem;
            background:rgba(var(--primary-rgb),.1);
            border-radius:var(--radius-sm);
            display:flex;
            align-items:center;
            justify-content:center;
            padding:.1rem;
        }
        .value-icon svg{width:1.25rem;height:1.25rem;stroke:var(--primary);stroke-width:2;fill:none}

        /* ― Impact ― */
        .impact-section{text-align:center;}
        .impact-title{font-size:clamp(1.5rem,3vw+0.5rem,2.5rem);margin-bottom:2.5rem;}

        .impact-grid{
            max-width:900px;
            margin-inline:auto;
            display:grid;
            grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
            column-gap:1rem;
            row-gap:1.5rem;
        }

        .impact-item{
            background:var(--surface-0);
            border-radius:var(--radius-lg);
            padding:2rem 1.5rem 1.75rem;
            box-shadow:var(--shadow-sm);
            position:relative;
            transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1);
            overflow:hidden;
        }
        .impact-item::before{
            content:"";
            position:absolute;
            inset:0;
            background:radial-gradient(circle at 50% 120%,rgba(var(--primary-rgb),.15) 0%,transparent 70%);
            transform:translateY(40%);
            transition:transform .6s cubic-bezier(.4,0,.2,1);
        }
        .impact-item:hover{
            transform:translateY(-6px);
            box-shadow:var(--shadow-lg);
        }
        .impact-item:hover::before{transform:translateY(0);}

        .impact-icon{
            width:2.75rem;
            height:2.75rem;
            border-radius:50%;
            background:rgba(var(--primary-rgb),.08);
            display:flex;
            align-items:center;
            justify-content:center;
            margin:0 auto 1rem;
        }
        .impact-icon svg{width:1.4rem;height:1.4rem;stroke:var(--primary);stroke-width:2;fill:none}

        .impact-number{
            font-size:clamp(1.75rem,2.5vw+0.5rem,2.75rem);
            font-weight:700;
            color:var(--primary);
        }
        .suffix{
            font-size:1.25rem;
            font-weight:700;
            color:var(--primary);
            margin-left:.1em;
        }
        .impact-label{
            font-size:0.875rem;
            color:var(--text-secondary);
            margin-top:.375rem;
        }

        /* Quote & animations */
        .heritage-quote{
            font-size:1rem;
            font-style:italic;
            color:var(--primary);
            margin-bottom:1.5rem;
            padding-left:0.75rem;
            border-left:3px solid var(--primary);
        }
        .fade-in-left,
        .fade-in-right{
            opacity:0;
            transform:translateY(20px);
            transition:all .8s cubic-bezier(.4,0,.2,1);
        }
        .fade-in-left.visible,
        .fade-in-right.visible{
            opacity:1;
            transform:translateY(0);
        }

        /* Responsive */
        @media(max-width:768px){
            .story-grid{grid-template-columns:1fr;gap:2rem;text-align:center;}
            .story-image img{max-height:280px;}
        }

        /* Services Page - REDUCED HEIGHTS */
        .services-hero {
            background: linear-gradient(135deg, var(--surface-dark) 0%, var(--primary-dark) 100%);
            color: var(--text-inverse);
            padding: 6rem 0 3rem;
            text-align: center;
        }

        .services-hero h1,
        .services-hero p {
            color: var(--text-inverse);
        }


        .program-card {
            background: var(--surface-0);
            border-radius: var(--radius-lg);
            overflow: hidden;
            transition: var(--transition-smooth);
            cursor: pointer;
            position: relative;
            border: 1px solid var(--border-light);
            height: 100%;
            display: flex;
            flex-direction: column;
        }

        .program-card:hover {
            transform: translateY(-8px) scale(1.02);
            box-shadow: var(--shadow-xl);
            border-color: transparent;
        }

        .program-header {
            padding: 1.25rem;
            background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.04) 0%, rgba(var(--primary-rgb), 0.08) 100%);
            border-bottom: 1px solid var(--border-light);
        }


        .program-content {
            padding: 1.25rem;
            flex: 1;
            display: flex;
            flex-direction: column;
        }


        /* -- NEW: Services Section Enhancements -- */

        /* High-contrast tier headers */
        .tier-basic .service-header {
            background: linear-gradient(135deg,
                        rgba(var(--primary-rgb), 0.06) 0%,
                        rgba(var(--primary-rgb), 0.12) 100%);
        }
        .tier-mid .service-header {
            background: linear-gradient(135deg,
                        rgba(var(--primary-rgb), 0.14) 0%,
                        rgba(var(--primary-rgb), 0.24) 100%);
        }
        .tier-premium .service-header {
            background: linear-gradient(135deg,
                        rgba(var(--primary-rgb), 0.26) 0%,
                        rgba(var(--primary-rgb), 0.38) 100%);
        }

        /* Card interaction – hover + keyboard focus */
        .service-card {
            transition: transform .35s var(--transition-base),
                        box-shadow .35s var(--transition-base);
            display: flex;
            flex-direction: column;
            position: relative;
        }
        .service-card:hover,
        .service-card:focus-within {
            transform: translateY(-6px) scale(1.02);
            box-shadow: var(--shadow-xl);
            border-color: transparent;
            outline: none;
        }

        /* Ensure content pushes CTA to bottom */
        .service-content {
            flex: 1;
            display: flex;
            flex-direction: column;
        }

        /* CTA row inside cards */
        .service-cta {
            margin-top: auto;
            text-align: center;
        }

        /* Corner ribbon for Most Popular */
        .ribbon {
            position: absolute;
            top: 0;
            right: 0;
            width: 120px;
            height: 26px;
            background: var(--primary-dark);
            color: var(--text-inverse);
            font-size: 0.625rem;
            font-weight: 700;
            text-transform: uppercase;
            display: flex;
            align-items: center;
            justify-content: center;
            transform: translate(50%, -50%) rotate(45deg);
            transform-origin: top right;
            box-shadow: 0 2px 6px rgba(0, 0, 0, 0.16);
            pointer-events: none;
        }

        .service-card {
        overflow: visible !important;    
        z-index: 1;            
        }

        .service-card .ribbon {
        z-index: 10;
        }

        .service-card .ribbon {
        top: -8px;
        right: -8px;
        }

        .service-card {
        overflow: visible !important;
        }

        .tier-mid .ribbon {
        position: absolute;
        right: -1px;            
        width: 100px;
        height: 24px;
        background: var(--primary-dark);
        color: var(--text-inverse);
        font-size: 0.625rem;
        font-weight: 700;
        text-transform: uppercase;
        display: flex;
        align-items: center;
        justify-content: center;
        transform: rotate(0deg);
        transform-origin: center center;
        box-shadow: 0 2px 6px rgba(0,0,0,0.16);
        z-index: 10;
        pointer-events: none;
        }

        /* ─────  À-la-Carte grid & card styling  ───── */
        .alacarte-section{background:var(--surface-0);}

        .alacarte-grid{
        display:grid;
        grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
        gap:2rem;                                   /* wider breathing room */
        }
        @media(max-width:768px){
        .alacarte-grid{grid-template-columns:1fr;}
        }

        /* Card foundation */
        .program-card{
        display:flex;flex-direction:column;
        background:var(--surface-0);
        border:1px solid var(--border-light);
        border-radius:var(--radius-lg);
        box-shadow:0 2px 8px rgba(0,0,0,.05);
        overflow:hidden;
        transition:transform .22s ease,box-shadow .22s ease;
        }
        .program-card:hover{
        transform:translateY(-4px);
        box-shadow:0 6px 20px rgba(0,0,0,.08);
        }

        /* Card header with subtle brand tint */
        .program-header{
        background:linear-gradient(135deg,
                    rgba(var(--primary-rgb),.06) 0%,
                    rgba(var(--primary-rgb),.02) 100%);
        padding:1.25rem 1.5rem;
        }
        .program-header h3{margin:0;font-size:1.125rem;line-height:1.4;}

        /* Card body & CTA */
        .program-content{
        flex:1;
        display:flex;flex-direction:column;
        gap:1.25rem;
        padding:1.5rem;
        }
        .program-content p{
        margin:0;
        font-size:.9rem;
        line-height:1.55;
        color:var(--text-secondary);
        }
        .btn.btn-secondary{
        align-self:center;
        width:100%;max-width:240px;
        padding:.65rem 1rem;
        font-size:.875rem;font-weight:600;
        border-radius:9999px;
        border:2px solid rgba(var(--primary-rgb),.25);
        background:linear-gradient(180deg,#f9f9f9 0%,#ededed 100%);
        color:var(--text-primary);
        transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;
        }
        .btn.btn-secondary:hover{
        background:linear-gradient(180deg,#ffffff 0%,#f3f3f3 100%);
        border-color:rgba(var(--primary-rgb),.45);
        box-shadow:0 3px 10px rgba(var(--primary-rgb),.15);
        }
        .btn.btn-secondary:active{
        box-shadow:0 2px 6px rgba(var(--primary-rgb),.15) inset;
        }

        /* ─────────── Engagement Process Timeline (v2) ────────────
        • Desktop (≥ 992 px)  →  horizontal, numbered, baseline
        • Mobile / tablet      →  vertical stack, brand-green spine
        -------------------------------------------------------- */

        /* reset / shared tokens */
        .timeline-modern{
        counter-reset:step;          /* auto-numbering                */
        list-style:none;
        margin-block:4rem 0;
        padding-block:2rem;          /* space top & bottom            */
        position:relative;
        }

        /* ── 1) Desktop & large laptop  ─────────────────────────── */
        @media (min-width:992px){

        .timeline-modern{
            display:flex;
            justify-content:space-between;
            gap:1.5rem;                /* even flex spacing             */
        }
        /* full-width baseline */
        .timeline-modern::before{
            content:'';position:absolute;
            top:3rem;left:0;right:0;height:2px;
            background:rgba(var(--primary-rgb),.18);
        }

        /* individual step column */
        .tl-step{
            flex:1 1 0;
            max-width:200px;           /* readable measure              */
            text-align:center;
            position:relative;
            padding-top:3.5rem;        /* room for dot+number above     */
        }

        /* automatic numbers */
        .tl-step::before{
            counter-increment:step;
            content:counter(step)'.';
            position:absolute;
            top:-2.25rem;left:50%;
            transform:translateX(-50%);
            font-weight:600;
            color:var(--text-secondary);
        }

        /* dot on the baseline */
        .tl-dot{
            position:absolute;
            left:50%;top:-0.5rem;transform:translateX(-50%);
            width:14px;height:14px;border-radius:50%;
            background:var(--primary);
            box-shadow:0 0 0 4px rgba(var(--primary-rgb),.08);
        }
        /* stub line from dot → card */
        .tl-dot::after{
            content:'';position:absolute;
            top:14px;left:50%;transform:translateX(-50%);
            width:2px;height:24px;
            background:rgba(var(--primary-rgb),.18);
        }

        /* typography */
        .tl-title{
            margin:.75rem 0 .1rem;
            font-size:1rem;font-weight:600;color:var(--text-primary);
        }
        .tl-meta{
            display:block;
            font-size:.75rem;font-weight:600;
            color:var(--primary);margin-bottom:.25rem;
        }
        .tl-copy{
            font-size:.9rem;line-height:1.55;
            color:var(--text-secondary);
        }
        }

        /* ── 2) Mobile / tablet (≤ 991.98 px)  ─────────────────── */
        @media (max-width:991.98px){

        .timeline-modern{
            display:flex;flex-direction:column;
            gap:2rem;
            padding-left:1rem;
        }
        /* vertical spine */
        .timeline-modern::before{
            content:'';position:absolute;
            left:.5rem;top:0;bottom:0;width:2px;
            background:rgba(var(--primary-rgb),.18);
        }

        .tl-step{
            position:relative;
            padding-left:2.25rem;
        }
        .tl-dot{
            position:absolute;
            left:0;top:.35rem;
            width:14px;height:14px;border-radius:50%;
            background:var(--primary);
            box-shadow:0 0 0 4px rgba(var(--primary-rgb),.08);
        }

        .tl-title{font-weight:600;color:var(--text-primary);}
        .tl-meta{display:block;font-size:.75rem;color:var(--primary);margin-bottom:.25rem;}
        .tl-copy{font-size:.9rem;line-height:1.55;color:var(--text-secondary);}
        }



        /* Contact Page - REDUCED SIZES */
        /* hero banner */
        .contact-hero{
            background:linear-gradient(180deg,var(--surface-1) 0%,var(--surface-0) 100%);
            padding:5rem 0 1.5rem;
            text-align:center;
        }

        /* two-column layout */
        .contact-grid{
            display:grid;
            grid-template-columns:minmax(0,1.4fr) minmax(0,.6fr);
            column-gap:2rem;
            align-items:start;
            margin-top:1.5rem;
        }

        @media(max-width:768px){
            .contact-grid{
                grid-template-columns:1fr;
                row-gap:1.5rem;
            }
        }

        /* form card */
        .contact-form-card{
        }
        .form-group{margin-bottom:0.75rem;}
        .form-label{
            display:block;
            font-weight:500;
            margin-bottom:.3rem;
            color:var(--text-primary);
            font-size: 0.875rem;
        }
        .form-input{
            width:100%;
            padding:.6rem .875rem;
            border:1px solid var(--border-medium);
            border-radius:var(--radius-md);
            font-size:.875rem;
            background:var(--surface-1);
            transition:var(--transition-base);
        }
        .form-input:focus{
            outline:none;
            border-color:var(--primary);
            box-shadow:0 0 0 2px rgba(var(--primary-rgb),.12);
            background:var(--surface-0);
        }
        @media(min-width:1024px){
            /* keep the whole form visible with its own scroll */
            .contact-form-card{
                max-height:calc(100vh - 7rem);
                overflow-y:auto;
            }
        }

        /* info column */
        .contact-info{
            position:static;
            top:auto;
            max-height:none;
            overflow:visible;
            padding-right:0;
        }

        /* individual info cards */
        .info-card{
            background:var(--surface-1);
            border-radius:var(--radius-lg);
            padding:0.75rem 1rem;
            display:flex;
            gap:.625rem;
            margin-bottom:.625rem;
            transition:var(--transition-base);
        }
        .info-card:hover{
            background:var(--surface-2);
            transform:translateX(3px);
        }
        .info-icon{
            width:2rem;
            height:2rem;
            background:rgba(var(--primary-rgb),.1);
            border-radius:var(--radius-md);
            display:flex;
            align-items:center;
            justify-content:center;
            flex-shrink:0;
        }
        .info-icon svg{
            width:1rem;
            height:1rem;
            stroke:var(--primary);
            stroke-width:2;
            fill:none;
        }

        /* emergency CTA box */
        .emergency-card{
            background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
            color:var(--text-inverse);
            border-radius:var(--radius-lg);
            padding:0.75rem .5rem;
            text-align:center;
            margin-top:0.75rem;
        }
        .emergency-number{
            font-size:1.25rem;
            font-weight:700;
            margin:.5rem 0;
        }

        /* ── Chip-style multi-select ──────────────────────────────── */

        .chip {
        /* fallbacks if your CSS vars aren’t defined */
        --chip-bg:      var(--surface-1, #f7f7f7);
        --chip-border:  var(--border-medium, rgba(0,0,0,.14));
        --chip-active:  var(--primary, #00794A);
        --chip-active2: var(--primary-dark, #005a37);

        padding: .5rem .9rem;
        font-size: .875rem;
        border: 1px solid var(--chip-border);
        border-radius: 9999px;            /* pill */
        background: var(--chip-bg);
        color: var(--text-primary, #1d1d1f);
        cursor: pointer;
        transition: background .18s, border-color .18s, color .18s;
        }

        .chip:hover {
        background: var(--surface-2, #ececec);
        }

        /* checked state */
        input[type="checkbox"]:checked + .chip {
        background: var(--chip-active);
        border-color: var(--chip-active2);
        color: #fff;
        }

        /* ✓ icon */
        .chip::after {
        content: "✓";
        margin-left: .4rem;
        font-weight: 600;
        opacity: 0;
        transform: scale(.6);
        transition: opacity .18s, transform .18s;
        }
        input[type="checkbox"]:checked + .chip::after {
        opacity: 1;
        transform: scale(1);
        }

        /* accessibility focus ring */
        input[type="checkbox"]:focus-visible + .chip {
        outline: 2px solid var(--primary, #00794A);
        outline-offset: 2px;
        }

        /* hide actual checkboxes */


        /* CTA Section - REDUCED PADDING */
        .cta-wrapper {
            max-width: 1000px;
            margin: 0 auto;
            padding: 0 1rem;
        }

        .cta-card {
            background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
            border-radius: var(--radius-xl);
            padding: 3rem 2rem;
            text-align: center;
            color: var(--text-inverse);
            position: relative;
            overflow: hidden;
            box-shadow: var(--shadow-xl);
        }

        @media (max-width: 768px) {
            .cta-card {
                padding: 2rem 1.5rem;
            }
        }

        .cta-card::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: radial-gradient(circle at 30% 50%, rgba(255, 255, 255, 0.1) 0%, transparent 50%);
            animation: cta-glow 10s ease-in-out infinite;
        }

        @keyframes cta-glow {
            0%, 100% { transform: translate(0, 0); }
            50% { transform: translate(10%, 10%); }
        }

        .cta-title {
            color: var(--text-inverse);
            margin-bottom: 0.75rem;
            position: relative;
            z-index: 1;
        }

        .cta-description {
            font-size: 1rem;
            opacity: 0.9;
            margin-bottom: 1.5rem;
            position: relative;
            z-index: 1;
        }

        .cta-card .btn {
            background: var(--surface-0);
            color: var(--primary);
            position: relative;
            z-index: 1;
        }

        .cta-card .btn:hover {
            background: var(--surface-1);
            transform: translateY(-2px);
            box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
        }

        /* Footer - REDUCED PADDING */
        .footer {
            background: var(--text-primary);
            color: var(--text-inverse);
            padding: 3rem 0 1.5rem;
        }

        .footer-logo {
        display: block;
        height: 3rem;
        width: auto;
        margin-right: 0.5rem;
        }

        .footer-grid {
            display: grid;
            grid-template-columns: 2fr 1fr 1fr 1fr;
            gap: 2rem;
            margin-bottom: 2rem;
        }

        @media (max-width: 768px) {
            .footer-grid {
                grid-template-columns: 1fr;
                gap: 1.5rem;
            }
        }

        .footer-brand {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            margin-bottom: 0.75rem;
        }

        .footer-brand svg {
            width: 2.5rem;
            height: 2.5rem;
        }

        .footer-description {
            color: var(--text-tertiary);
            margin-top: 0.75rem;
            line-height: 1.5;
            font-size: 0.875rem;
        }

        .footer-links {
            list-style: none;
        }

        .footer-links h4 {
            font-size: 0.875rem;
            font-weight: 600;
            margin-bottom: 0.75rem;
            color: var(--text-inverse);
        }

        .footer-links a {
            color: var(--text-tertiary);
            text-decoration: none;
            display: block;
            padding: 0.2rem 0;
            transition: var(--transition-base);
            font-size: 0.8125rem;
        }

        .footer-links a:hover {
            color: var(--text-inverse);
            transform: translateX(3px);
        }

        .footer-divider {
            border-top: 1px solid rgba(255, 255, 255, 0.1);
            margin: 2rem 0 1.25rem;
        }

        .footer-bottom {
            text-align: center;
            color: var(--text-tertiary);
            font-size: 0.75rem;
        }

        /* Animations */
        .fade-in {
            opacity: 0;
            transform: translateY(15px);
            transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .fade-in.visible {
            opacity: 1;
            transform: translateY(0);
        }

        .fade-in-left {
            opacity: 0;
            transform: translateX(-15px);
            transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .fade-in-left.visible {
            opacity: 1;
            transform: translateX(0);
        }

        .fade-in-right {
            opacity: 0;
            transform: translateX(15px);
            transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .fade-in-right.visible {
            opacity: 1;
            transform: translateX(0);
        }


        .stagger-1 { transition-delay: 0.1s; }
        .stagger-2 { transition-delay: 0.2s; }
        .stagger-3 { transition-delay: 0.3s; }
        .stagger-4 { transition-delay: 0.4s; }


        /* Loading State */
        .loading {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: var(--surface-0);
            display: flex;
            align-items: center;
            justify-content: center;
            z-index: 9999;
            transition: opacity 0.5s ease;
        }

        .loading.hidden {
            opacity: 0;
            pointer-events: none;
        }

        .loading-spinner {
            width: 2.5rem;
            height: 2.5rem;
            border: 3px solid var(--surface-3);
            border-top-color: var(--primary);
            border-radius: 50%;
            animation: spin 0.8s linear infinite;
        }

        @keyframes spin {
            to { transform: rotate(360deg); }
        }



/*New shit*/

        /* Problem Section - REDUCED SIZES */
        .problem-section {
            background: var(--surface-1);
            position: relative;
            overflow: hidden;
        }

        .problem-section::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 1px;
            background: linear-gradient(90deg, transparent 0%, var(--border-medium) 50%, transparent 100%);
        }

        .threat-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
            gap: 20px;
        }

        .threat-card {
            background: var(--surface-0);
            border-radius: var(--radius-lg);
            padding: 24px;
            position: relative;
            overflow: hidden;
            transition: var(--transition-smooth);
            border: 1px solid var(--border-light);
        }

        .threat-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 3px;
            background: linear-gradient(90deg, var(--primary) 0%, var(--primary-light) 100%);
            transform: scaleX(0);
            transform-origin: left;
            transition: var(--transition-smooth);
        }

        .threat-card:hover {
            transform: translateY(-6px);
            box-shadow: var(--shadow-lg);
            border-color: transparent;
        }

        .threat-card:hover::before {
            transform: scaleX(1);
        }

        .threat-icon {
            width: 40px;
            height: 40px;
            background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.08) 0%, rgba(var(--primary-rgb), 0.12) 100%);
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 16px;
            position: relative;
        }

        .threat-icon svg {
            width: 20px;
            height: 20px;
            stroke: var(--primary);
            stroke-width: 2;
            fill: none;
        }

        .threat-title {
            margin-bottom: 8px;
            font-size: 1.125rem;
        }

        .threat-description {
            color: var(--text-secondary);
            line-height: 1.5;
            font-size: 0.875rem;
        }

        /* Solution Section - REDUCED SIZES */
        .solution-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 60px;
            align-items: center;
        }

        .solution-content {
            position: relative;
        }

        .solution-features {
            margin-top: 24px;
            display: grid;
            gap: 16px;
        }

        .solution-feature {
            display: flex;
            gap: 12px;
            padding: 16px;
            background: var(--surface-1);
            border-radius: var(--radius-md);
            transition: var(--transition-base);
        }

        .solution-feature:hover {
            background: var(--surface-2);
            transform: translateX(6px);
        }

        .solution-feature-icon {
            width: 32px;
            height: 32px;
            background: var(--primary);
            border-radius: var(--radius-sm);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }

        .solution-feature-icon svg {
            width: 16px;
            height: 16px;
            stroke: white;
            stroke-width: 2;
            fill: none;
        }

        .solution-visual {
            position: relative;
        }

        .training-showcase {
            background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
            border-radius: var(--radius-lg);
            padding: 40px;
            color: var(--text-inverse);
            position: relative;
            overflow: hidden;
            box-shadow: var(--shadow-xl);
        }

        .training-showcase::before {
            content: '';
            position: absolute;
            top: -50%;
            right: -50%;
            width: 200%;
            height: 200%;
            background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
            animation: rotate 20s linear infinite;
        }

        @keyframes rotate {
            from { transform: rotate(0deg); }
            to { transform: rotate(360deg); }
        }

        /* Services Section - REDUCED SIZES */
        .services-section {
            background: var(--surface-1);
        }

        .services-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
            gap: 20px;
        }

        .service-card {
            background: var(--surface-0);
            border-radius: var(--radius-lg);
            overflow: hidden;
            transition: var(--transition-smooth);
            cursor: pointer;
            position: relative;
            border: 1px solid var(--border-light);
        }

        .service-card:hover {
            transform: translateY(-8px);
            box-shadow: var(--shadow-xl);
            border-color: transparent;
        }

        .service-header {
            padding: 20px;
            background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.04) 0%, rgba(var(--primary-rgb), 0.08) 100%);
            border-bottom: 1px solid var(--border-light);
        }

        .service-duration {
            font-size: 12px;
            color: var(--primary);
            font-weight: 500;
            margin-top: 3px;
        }

        .service-content {
            padding: 20px;
        }

        .service-description {
            color: var(--text-secondary);
            margin-bottom: 16px;
            font-size: 0.875rem;
        }

        .service-features {
            list-style: none;
        }

        .service-features li {
            padding: 6px 0;
            display: flex;
            align-items: center;
            gap: 10px;
            color: var(--text-secondary);
            font-size: 0.8125rem;
        }

        .service-features li::before {
            content: '';
            width: 16px;
            height: 16px;
            background: rgba(var(--primary-rgb), 0.1);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            position: relative;
        }

        .service-features li::after {
            content: '✓';
            position: absolute;
            left: 4px;
            color: var(--primary);
            font-weight: bold;
            font-size: 10px;
        }

        /* Trust Section - REDUCED SIZES */
        .trust-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
            gap: 32px;
        }

        .trust-item {
            text-align: center;
            position: relative;
        }

        .trust-icon-wrapper {
            width: 60px;
            height: 60px;
            margin: 0 auto 16px;
            position: relative;
        }

        .trust-icon {
            width: 100%;
            height: 100%;
            background: linear-gradient(135deg, var(--surface-2) 0%, var(--surface-3) 100%);
            border-radius: var(--radius-lg);
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            overflow: hidden;
        }

        .trust-icon::before {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            width: 120%;
            height: 120%;
            background: radial-gradient(circle, rgba(var(--primary-rgb), 0.1) 0%, transparent 70%);
            transform: translate(-50%, -50%);
            opacity: 0;
            transition: var(--transition-base);
        }

        .trust-item:hover .trust-icon::before {
            opacity: 1;
        }

        .trust-icon svg {
            width: 28px;
            height: 28px;
            stroke: var(--primary);
            stroke-width: 2;
            fill: none;
        }

        /* CTA Section - REDUCED SIZES */
        .cta-wrapper {
            max-width: 1000px;
            margin: 0 auto;
        }

        .cta-card {
            background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
            border-radius: var(--radius-xl);
            padding: 48px;
            text-align: center;
            color: var(--text-inverse);
            position: relative;
            overflow: hidden;
            box-shadow: var(--shadow-xl);
        }

        .cta-card::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: radial-gradient(circle at 30% 50%, rgba(255, 255, 255, 0.1) 0%, transparent 50%);
            animation: cta-glow 10s ease-in-out infinite;
        }

        @keyframes cta-glow {
            0%, 100% { transform: translate(0, 0); }
            50% { transform: translate(10%, 10%); }
        }

        .cta-title {
            color: var(--text-inverse);
            margin-bottom: 12px;
        }

        .cta-description {
            font-size: 16px;
            opacity: 0.9;
            margin-bottom: 24px;
        }

        .cta-card .btn {
            background: var(--surface-0);
            color: var(--primary);
        }

        .cta-card .btn:hover {
            background: var(--surface-1);
            transform: translateY(-2px);
            box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
        }

        /* FAQ Section - REDUCED SIZES */
        /* ── FAQ accordion ─────────────────────────────────────────── */
        .faq-section{background:var(--surface-1);}          /* same tint as tier cards */

        .faq-wrap details{
        border:1px solid var(--border-light);
        border-radius:var(--radius-md);
        padding:.9rem 1.25rem;
        margin-bottom:.75rem;
        background:var(--surface-0);
        overflow:hidden;
        transition:max-height .45s ease;                 /* smooth open/close   */
        }
        .faq-wrap summary{
        cursor:pointer;
        list-style:none;
        font-weight:600;
        position:relative;
        padding-right:1.5rem;                            /* space for arrow     */
        }
        .faq-wrap summary::-webkit-details-marker{display:none;} /* Safari/Chrome */
        .faq-wrap summary::after{
        content:'›';
        position:absolute;right:0;top:0;
        font-size:1rem;font-weight:700;
        transform:rotate(90deg);                         /* closed arrow        */
        transition:transform .35s ease;
        color:var(--primary);
        }
        .faq-wrap details[open] summary::after{
        transform:rotate(270deg);                        /* open arrow          */
        }
        .faq-wrap p{
        margin-top:.75rem;
        font-size:.875rem;
        line-height:1.55;
        color:var(--text-secondary);
        }

        /* Contact Section - REDUCED SIZES */
        .contact-grid {
            display: grid;
            grid-template-columns: minmax(0, 1.4fr) minmax(0, .6fr);
            gap: 32px;
            align-items: start;
        }

        .contact-form-card {
            background: var(--surface-0);
            border-radius: var(--radius-xl);
            padding: 32px;
            box-shadow: var(--shadow-lg);
            border: 1px solid var(--border-light);
        }

        .form-group {
            margin-bottom: 16px;
        }

        .form-label {
            display: block;
            font-weight: 500;
            margin-bottom: 6px;
            color: var(--text-primary);
        }

        .form-input {
            width: 100%;
            padding: 12px 16px;
            border: 1px solid var(--border-medium);
            border-radius: var(--radius-md);
            font-size: 14px;
            transition: var(--transition-base);
            background: var(--surface-1);
        }

        .form-input:focus {
            outline: none;
            border-color: var(--primary);
            box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.1);
            background: var(--surface-0);
        }


        .contact-info {
            position: static;
            top: auto;
            max-height: none;
            overflow: visible;
            padding-right: 0;
        }

        .info-card {
            background: var(--surface-1);
            border-radius: var(--radius-lg);
            padding: 20px;
            margin-bottom: 16px;
            display: flex;
            gap: 16px;
            align-items: start;
            transition: var(--transition-base);
        }

        .info-card:hover {
            background: var(--surface-2);
            transform: translateX(6px);
        }

        .info-icon {
            width: 36px;
            height: 36px;
            background: rgba(var(--primary-rgb), 0.1);
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }

        .info-icon svg {
            width: 18px;
            height: 18px;
            stroke: var(--primary);
            stroke-width: 2;
            fill: none;
        }

        .testimonial-card {
            background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.04) 0%, rgba(var(--primary-rgb), 0.08) 100%);
            border-radius: var(--radius-lg);
            padding: 24px;
            margin-top: 24px;
            border: 1px solid rgba(var(--primary-rgb), 0.1);
            text-align: center;
        }

        .testimonial-card p {
            margin: 0;
            word-break: break-word;
        }

        /* lock card once it hits 2-6 vh from top */
.sticky-form{
        position:sticky;
        top:clamp(2rem,6vh,120px);
        }

@media(max-width:768px){
        .sticky-form{
                position:static;
                top:auto;
        }
}

        /* pill-style submit button without radial blast */
        .btn-form-submit{
        display:inline-block;
        width:100%;                 /* ≤640 px full-width; otherwise intrinsic */
        max-width:320px;
        margin-inline:auto;
        padding:.75rem 1.5rem;
        font-size:.875rem;
        font-weight:600;
        color:var(--text-inverse);
        background:var(--primary);
        border:none;
        border-radius:9999px;
        cursor:pointer;
        transition:var(--transition-base);
        box-shadow:0 4px 16px rgba(var(--primary-rgb),.28);
        }
        .btn-form-submit:hover{
        box-shadow:0 6px 24px rgba(var(--primary-rgb),.38);
        transform:translateY(-2px);
        }
        .btn-form-submit:active{
        transform:translateY(0);
        box-shadow:0 3px 12px rgba(var(--primary-rgb),.22);
        }

        /* ── floating-label helper (updated) ───────────────────────────── */
        .form-floating{position:relative;margin-bottom:.9rem;}

        .form-floating .form-input{
        width:100%;
        padding:1.15rem .9rem .45rem;          /* leave room on top */
        background:var(--surface-1);
        border:1px solid var(--border-medium);
        border-radius:var(--radius-md);
        font-size:.875rem;
        transition:var(--transition-base);
        }

        .form-floating label{
        position:absolute;
        top:1rem; left:.9rem;
        font-size:.75rem;
        color:var(--text-tertiary);
        pointer-events:none;
        transition:var(--transition-base);
        }

        /* lift background once field is in use */
        .form-floating .form-input:focus,
        .form-floating .form-input:not(:placeholder-shown){
        background:var(--surface-0);
        }

        /* ── FLOAT LABELS ─────────────────────────────────────────────── */

        /* a) text inputs & textareas – placeholder trick still works */
        .form-floating input.form-input:focus + label,
        .form-floating input.form-input:not(:placeholder-shown) + label,
        .form-floating textarea.form-input:focus + label,
        .form-floating textarea.form-input:not(:placeholder-shown) + label{
        top:.35rem;
        font-size:.65rem;
        color:var(--primary);
        }

        /* b) selects – float only when focused *or* valid (after choice) */
        .form-floating select.form-input:focus + label,
        .form-floating select.form-input:valid + label{
        top:.35rem;
        font-size:.65rem;
        color:var(--primary);
        }

        /* accessible focus ring */
        .form-input:focus{
        outline:none;
        border-color:var(--primary);
        box-shadow:0 0 0 3px rgba(0,121,74,.25);
        }

        /* ── minimal searchable multi-select enhancement ──────────────── */
.multiselect-wrapper{
        position:relative;
        cursor:pointer;
        }
.multiselect-search{
        width:100%;
        margin-bottom:.25rem;
        padding:.45rem .75rem;
        border:1px solid var(--border-medium);
        border-radius:var(--radius-md);
        font-size:.875rem;
        padding-right:2rem;
        cursor:pointer;
        caret-color:transparent;
        }
.multiselect-wrapper::after{
        content:'\25BC';
        position:absolute;
        right:.5rem;top:.85rem;
        font-size:.625rem;
        color:var(--text-secondary);
        pointer-events:none;
        transition:transform .2s;
        }
.multiselect-wrapper.open::after{transform:rotate(180deg);}
.multiselect-chips{
        display:flex;
        flex-wrap:wrap;
        gap:.25rem;
        margin-bottom:.25rem;
        }
.multiselect-chips .chip{
        padding:.3rem .6rem;
        font-size:.75rem;
        border:1px solid var(--border-medium);
        border-radius:var(--radius-md);
        background:var(--surface-2);
        cursor:pointer;
        user-select:none;
        }
.multiselect-options{
        position:absolute;
        z-index:30;
        top:calc(100% + .25rem);
        left:0;width:100%;
        max-height:240px;
        overflow-y:auto;
        background:var(--surface-0);
        border:1px solid var(--border-medium);
        border-radius:var(--radius-md);
        display:none;
        }
.multiselect-options.open{display:block;}
.multiselect-options li{
        padding:.45rem .75rem;
        cursor:pointer;
        }
.multiselect-options li:hover{background:var(--surface-2);}
.multiselect-options li.selected{
        background:rgba(var(--primary-rgb),.10);
        font-weight:600;
        }

        /* Mobile Menu - REDUCED SIZES */
        .mobile-menu-toggle {
            display: none;
            background: none;
            border: none;
            width: 24px;
            height: 24px;
            position: relative;
            cursor: pointer;
        }

        .mobile-menu-toggle span {
            display: block;
            width: 18px;
            height: 2px;
            background: var(--text-primary);
            margin: 4px 0;
            transition: var(--transition-base);
        }

        /* Responsive */
        @media (max-width: 768px) {
            .mobile-menu-toggle {
                display: block;
            }

            .nav-menu {
                display: none;
                position: absolute;
                top: 100%;
                left: 0;
                width: 100%;
                background: var(--surface-0);
                box-shadow: var(--shadow-lg);
                flex-direction: column;
                padding: 16px;
                gap: 12px;
            }

            .nav-menu.active {
                display: flex;
            }

            .hero-grid,
            .solution-grid,
            .contact-grid {
                grid-template-columns: 1fr;
                gap: 32px;
            }

            .display-1 {
                font-size: 32px;
            }


            .footer-grid {
                grid-template-columns: 1fr;
                gap: 24px;
            }

            .cta-card {
                padding: 32px 24px;
            }
        }

        /* Loading Animation */
        .fade-in {
            opacity: 0;
            transform: translateY(16px);
            transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
        }

        .fade-in.visible {
            opacity: 1;
            transform: translateY(0);
        }

        .fade-in-delay-1 {
            transition-delay: 0.1s;
        }

        .fade-in-delay-2 {
            transition-delay: 0.2s;
        }

        .fade-in-delay-3 {
            transition-delay: 0.3s;
        }
/* Skip link + focus styles */
.skip-link{position:absolute;left:-999px;top:auto;background:#fff;color:#000;padding:0.5rem 1rem;z-index:100;}
.skip-link:focus{left:0;top:0;}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;}

/* Mobile legibility fixes */
body { font-size: 16px; }
.btn,
.btn-form-submit,
.nav-link,
.footer-links a,
.form-input {
  min-height: 48px;
  padding: 0.75rem 1.25rem;
}
.mobile-menu-toggle {
  width: 48px;
  height: 48px;
}
.nav-link {
  padding: 0.75rem 0;
}

