/* ==========================================
   DESIGN SYSTEM - GoodCircle
   ========================================== */

/* ==========================================
   FONTS
   ========================================== */

@font-face {
    font-family: 'Monigue';
    src: url('fonts/Monigue.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Anton';
    src: url('fonts/Anton-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

:root {
    /* Colors */
    --color-green-black: #004638;
    --color-green: #00d866;
    --color-green-citrus: #DEFEA1;
    --color-dark-green: #00b855;
    --color-green-border: #C6F6D2;
    --color-green-light: #F2FDF5;
    --color-beige: #F0F7E4;
    --color-black: #101010;
    --color-black-background: #1A1A1A;
    --color-gray: #6b7280;
     --color-gray-dark:#4B5563;
    --color-gray-light: #FAFAFA;
    --color-white: #ffffff;
    --color-red: #E02424;
    
    /* Typography */
    --font-base: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-display: 'Monigue', serif;
    --font-secondary: 'Anton', serif;

    /* Typography Scale */
    --text-xs: 13px;
    --text-sm: 14px;
    --text-base: 15px;
    --text-md: 16px;
    --text-lg: 18px;
    --text-xl: 20px;
    --text-2xl: 24px;
    --text-3xl: 32px;
    --text-4xl: 40px;
    --text-5xl: 48px;

    /* Spacing */
    --spacing-1: 4px;
    --spacing-2: 8px;
    --spacing-3: 12px;
    --spacing-4: 16px;
    --spacing-5: 20px;
    --spacing-6: 24px;
    --spacing-8: 32px;
    --spacing-10: 40px;
    --spacing-12: 48px;
    --spacing-16: 64px;
    --spacing-20: 80px;
    --spacing-24: 96px;

    /* Border Radius */
    --radius-full: 9999px;
    --radius-xl: 34px;
    --radius-2xl: 24px;
    --radius-l: 16px;
    --radius-lg: 12px;
    --radius-md: 8px;
    --radius-img: 24px;

    /* Shadows */
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 8px 24px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 20px 60px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 12px 32px rgba(0, 0, 0, 0.15);
    --shadow-side: -4px 0 20px rgba(0, 0, 0, 0.1);
    --shadow-button: 0 0 0 8px;

    /* Gradients */
    --gradient-cta: linear-gradient(99.44deg, #DDEFF6 0%, #45EAE7 100%);
    --gradient-success: linear-gradient(135deg, #A8E6E1 0%, #D4F1F4 100%);

    /* Couleurs supplémentaires */
    --color-gray-lighter: #F9FAFB;
    --color-gray-border: #E0E0E0;
    --color-gray-background: #e5e5e5;
    --color-gray-background-secondary: #FAFAFA;
    --color-gray-background-tertiary: #F3F4F6;

    /* Transitions */
    --transition-base: 0.3s ease;
    --transition-fast: 0.2s ease;
}

/* ==========================================
   RESET & BASE
   ========================================== */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-base);
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-black);
    background: var(--color-beige);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

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

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
}

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

/* ==========================================
   TYPOGRAPHY UTILITIES
   ========================================== */

.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-md { font-size: var(--text-md); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }
.text-2xl { font-size: var(--text-2xl); }
.text-3xl { font-size: var(--text-3xl); }
.text-4xl { font-size: var(--text-4xl); }
.text-5xl { font-size: var(--text-5xl); }

h2 {
    font-family: 'Monigue';
}

/* ==========================================
   CONTAINER
   ========================================== */

.container {
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 var(--spacing-6);
}

/* ==========================================
   HEADER
   ========================================== */

.header {
    background: transparent;
    padding: var(--spacing-5) 0;
    position: sticky;
    top: 0;
    z-index: 100;
    transition: background-color 0.3s ease, backdrop-filter 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.header.scrolled {
    background: rgba(255, 255, 255, 0.95);
    /* backdrop-filter: blur(10px); */
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.header.hidden {
    transform: translateY(-100%);
}

.header-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Logo */
.logo {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    color: var(--color-black);
}

.logo svg {
    width: 32px;
    height: 32px;
}

.logo-text {
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.02em;
}

/* Navigation */
.nav {
    display: flex;
    align-items: center;
    gap: var(--spacing-8);
}

.nav-link {
    font-size: 15px;
    font-weight: 500;
    color: var(--color-black);
    transition: color 0.2s;
}

.nav-link:hover {
    color: var(--color-green);
}

/* Header Actions */
.header-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
}

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

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 24px;
    font-size: 15px;
    font-weight: 600;
    border-radius: var(--radius-full);
    transition: all 0.2s ease;
    white-space: nowrap;
}

.btn-lg {
    padding: 16px 32px;
    font-size: 16px;
}

.btn-primary {
    background: var(--color-green);
    color: var(--color-black);
}

.btn-primary:hover {
    box-shadow: 0 0 0 8px var(--color-green);
    border-radius: var(--radius-full);
}

.btn-ghost {
    background: transparent;
    color: var(--color-black);
    border: 1px solid transparent;
}

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

.btn-icon-dark {
    width: 48px;
    height: 48px;
    padding: 0;
    background: var(--color-black);
    color: var(--color-white);
    border-radius: var(--radius-full) !important;
}


.btn-icon {
    width: 48px;
    height: 48px;
    padding: 0;
    background: var(--color-green);
    color: var(--color-black);
    border-radius: var(--radius-full) !important;
}


.btn-icon svg {
    width: 20px;
    height: 20px;
    transition: transform 0.3s ease;
}

.btn-icon:hover svg {
    transform: rotate(-45deg);
}

.btn-icon.btn-lg {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-full) !important;
}

.btn-icon.btn-lg svg {
    width: 24px;
    height: 24px;
}

/* ==========================================
   MOBILE MENU
   ========================================== */

.mobile-menu-btn {
    display: none;
    flex-direction: column;
    gap: 6px;
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
    z-index: 101;
}

.mobile-menu-btn span {
    width: 24px;
    height: 2px;
    background: var(--color-black);
    border-radius: 2px;
    transition: all 0.3s ease;
}

.mobile-menu-btn.active span:nth-child(1) {
    transform: rotate(45deg) translateY(8px);
}

.mobile-menu-btn.active span:nth-child(2) {
    opacity: 0;
}

.mobile-menu-btn.active span:nth-child(3) {
    transform: rotate(-45deg) translateY(-8px);
}

.mobile-sidebar {
    position: fixed;
    top: 0;
    right: -100%;
    width: 100%;
    max-width: 100%;
    height: 100vh;
    background: var(--color-green);
    z-index: 1000;
    transition: right 0.3s ease;
    display: flex;
    flex-direction: column;
    padding: var(--spacing-6);
}

.mobile-sidebar.active {
    right: 0;
}

.mobile-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-8);
}

.mobile-sidebar-header .logo img {
    filter: brightness(0) invert(1);
}

.mobile-sidebar-close {
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
    color: var(--color-white);
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mobile-sidebar-nav {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-8);
    padding-top: var(--spacing-8);
}

.mobile-nav-link {
    font-family: var(--font-secondary);
    font-size: clamp(42px, 8vw, 58px);
    font-weight: 400;
    color: var(--color-white);
    text-decoration: none;
    text-transform: uppercase;
    transition: opacity 0.2s ease;
    line-height: 1.1;
}

.mobile-nav-link:hover {
    opacity: 0.8;
}

.mobile-sidebar-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-3);
    margin-top: auto;
}

.mobile-sidebar-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 999;
}

.mobile-sidebar-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* ==========================================
   HERO SECTION
   ========================================== */

.hero {
    background: var(--color-beige);
    padding: var(--spacing-20) 0 var(--spacing-24) 0;
    min-height: calc(100vh - 88px);
    display: flex;
    align-items: center;
    position: relative;
}

.hero::before {
    content: '';
    position: absolute;
    top: -100px;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: calc(100% + 100px);
    background-image: url('assets/hero-section/Brandmark.svg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 1;
    z-index: 0;
    pointer-events: none;
}

/* Hero - Fond blanc sans brandmark */
.hero-white {
    background: var(--color-white) !important;
}

.hero-white::before {
    display: none;
}

.hero-content {
    text-align: center;
    max-width: 900px;
    margin: 0 auto var(--spacing-20) auto;
    position: relative;
    z-index: 1;
}

/* Hero specific spacing */
.hero-content .section-description {
    margin-bottom: var(--spacing-10);
}

/* Hero CTA */
.hero-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-4);
    margin-bottom: var(--spacing-16);
}

/* ==========================================
   COMMON TYPOGRAPHY CLASSES
   ========================================== */

/* Common Badge */
.badge {
    display: inline-block;
    font-size: clamp(14px, 6vw, 24px);
    font-weight: 500;
    color: var(--color-black);
    margin-bottom: var(--spacing-8);
    letter-spacing: 0.01em;
}

/* Common Section Title - Large */
.section-title {
    font-size: clamp(52px, 10vw, 90px);
    font-weight: 500;
    line-height: 0.85;
    font-family: 'Monigue';
    letter-spacing: -0.001em;
    color: var(--color-black);
    text-transform: uppercase;
}

/* Common Section Title - Extra Large (for hero) */
.section-title-xl {
    font-size: clamp(80px, 10vw, 156px);
    font-weight: 500;
    line-height: 0.85;
    font-family: 'Monigue';
    letter-spacing: -0.001em;
    color: var(--color-black);
    text-transform: uppercase;
}

.section-title-l {
    font-size: clamp(70px, 10vw, 110px);
    font-weight: 500;
    line-height: 0.85;
    font-family: 'Monigue';
    letter-spacing: -0.001em;
    color: var(--color-black);
    margin-bottom: var(--spacing-2);
    text-transform: uppercase;
}

/* Common Section Title - Medium (for CTA) */
.section-title-md {
    font-size: clamp(60px, 14vw, 84px);
    font-weight: 400;
    line-height: 0.85;
    font-family: 'Monigue';
    color: var(--color-black);
    text-transform: uppercase;
}

/* Green Title Accent */
.title-green {
    color: var(--color-green);
}

/* Common Section Description */
.section-description {
    font-size: 18px;
    line-height: 1.7;
    color: var(--color-black);
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

/* Common Section Content Wrapper */
.section-content {
    text-align: center;
    max-width: 900px;
    margin: 0 auto;
}

/* Display text for special use cases */
.display-text {
    font-family: var(--font-display);
    font-size: clamp(48px, 12vw, 160px);
    font-weight: 400;
    line-height: 85%;
    color: var(--color-black);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: -0.02em;
}

/* ==========================================
   PARTNER LOGOS
   ========================================== */

.partners-logos {
    position: relative;
    z-index: 1;
    padding: var(--spacing-8) 0;
    overflow: hidden;
}

.partners-logos-track {
    display: flex;
    gap: var(--spacing-12);
    animation: scroll 30s linear infinite;
    width: fit-content;
}

.partners-logos-track:hover {
    animation-play-state: paused;
}

.partner-logo {
    opacity: 0.6;
    transition: opacity 0.3s;
    filter: grayscale(100%);
    flex-shrink: 0;
}

.partner-logo:hover {
    opacity: 1;
    filter: grayscale(0%);
}

.partner-logo img {
    height: 100px;
    width: auto;
    object-fit: contain;
}

@keyframes scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

/* ==========================================
   SOLUTION SECTION
   ========================================== */

.solution {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}


/* Solution Dashboard */
.solution-dashboard {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
}

.solution-dashboard img {
    width: 100%;
    height: auto;
    display: block;
}

/* ==========================================
   REASSURANCE SECTION
   ========================================== */

.reassurance {
    background: var(--color-white);
    padding-bottom: var(--spacing-24);
    position: relative;
}

.reassurance-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-12);
    /* max-width: 1200px; */
    margin: 0 auto;
    align-self: stretch;
}

.reassurance-card {
    text-align: left;
    background: var(--color-gray-light);
    padding: var(--spacing-8);
    border-radius: var(--radius-lg);
}

.reassurance-icon {
    width: 80px;
    height: 80px;
    margin-bottom: var(--spacing-6);
}

.reassurance-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.reassurance-title {
    font-size: 48px;
    font-weight: 500;
    font-family: var(--font-display);
    color: var(--color-black);
    margin-top: var(--spacing-8);
    /* letter-spacing: 0.02em; */
}

.reassurance-description {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-black);
}

/* ==========================================
   PARTNERS SECTION
   ========================================== */

.partners {
    background: var(--color-white);
    padding: 0;
    position: relative;
}

.partners-wrapper {
    max-width: 1280px;
    margin: 0 auto;
    padding-top: 10%;
    padding-bottom: 10%;
    padding-left: var(--spacing-6);
}

.partners-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-16);
    align-items: center;
}

.partners-text {
    max-width: 600px;
}

.partners-text .section-title {
    margin-bottom: var(--spacing-10);
    text-align: left;
}

.partners-benefits {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-10) 0;
}

.partners-benefit-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-4);
    margin-bottom: var(--spacing-5);
    font-size: 18px;
    line-height: 1.5;
    color: var(--color-black);
}

.partners-benefit-item svg {
    flex-shrink: 0;
    margin-top: 2px;
}

.partners-benefit-item span {
    flex: 1;
}

.partners-cta {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.cta-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-6);
}

/* Button Group Component */
.btn-group {
    display: flex;
    align-items: center;
    gap: 4px;
    background: transparent;
    transition: all 0.3s ease;
}

.btn-group .btn-text {
    padding: 14px 28px;
    font-size: 16px;
    font-weight: 600;
    border-radius: var(--radius-full) 0 0 var(--radius-full);
    transition: all 0.3s ease;
}

.btn-group .btn-arrow {
    width: 49.25px;
    height: 49.25px;
    padding: 0;
    border-radius: 0 var(--radius-full) var(--radius-full) 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.btn-group .btn-arrow svg {
    width: 24px;
    height: 24px;
    transition: transform 0.3s ease;
}

.btn-group:hover .btn-arrow svg {
    transform: rotate(-45deg);
}

/* Dark variant */
.btn-group.btn-group-dark .btn-text {
    background: var(--color-black);
    border-radius: var(--radius-full);
    color: var(--color-white);
}

.btn-group.btn-group-dark .btn-arrow {
    background: var(--color-black);
    border-radius: var(--radius-full);
    color: var(--color-white);
}

/* Green variant */
.btn-group.btn-group-green .btn-text {
    background: var(--color-green);
    border-radius: var(--radius-full);
    color: var(--color-black);
}

.btn-group.btn-group-green .btn-arrow {
    background: var(--color-green);
    border-radius: var(--radius-full);
    color: var(--color-black);
}

/* Black variant */
.btn-group.btn-group-black .btn-text {
    background: var(--color-black);
    border-radius: var(--radius-full);
    color: var(--color-white);
}

.btn-group.btn-group-black .btn-arrow {
    background: var(--color-black);
    border-radius: var(--radius-full);
    color: var(--color-white);
}

.btn-group-active.btn-group-white-active .btn-text {
    background: var(--color-white);
    color: var(--color-black);
    border-radius: var(--radius-full) 0 0 var(--radius-full) !important;
}

.btn-group-active.btn-group-white-active .btn-arrow {
    background: var(--color-white);
    color: var(--color-black);
    border-radius: 0 var(--radius-full) var(--radius-full) 0 
}

.btn-group-active .btn-arrow-active {
    border-radius: 0 var(--radius-full) var(--radius-full) 0 !important;
    transform: translateX(-28px) !important;
}
.btn-arrow-active .btn-group-active {
    rotate: -45deg;
}

.btn-group.btn-group-green-dark .btn-text {
    background: var(--color-green-black);
    border-radius: var(--radius-full);
    color: var(--color-white);
}

.btn-group.btn-group-green-dark .btn-arrow {
    background: var(--color-green-black);
    border-radius: var(--radius-full);
    color: var(--color-white);
}


.btn-group:hover {
    gap: 0px;
}

.btn-group:hover .btn-text {
    border-radius: var(--radius-full) 0 0 var(--radius-full) !important;
}

.btn-group:hover .btn-arrow {
    border-radius: 0 var(--radius-full) var(--radius-full) 0 !important;
    transform: translateX(-28px) !important;
}

.btn-arrow .btn-group:hover {
    rotate: -45deg;
}

/* Blue gradient variant */
.btn-group.btn-group-blue .btn-text {
    background: linear-gradient(99.44deg, #DDEFF6 0%, #45EAE7 100%);
    border-radius: var(--radius-full);
    color: var(--color-black);
}

.btn-group.btn-group-blue .btn-arrow {
    background: #45EAE7;
    border-radius: var(--radius-full);
    color: var(--color-black);
}


/* Legacy support - keep old classes for compatibility */
.btn-dark {
    background: var(--color-black);
    color: var(--color-white);
    padding: 16px 32px;
    font-size: 16px;
    font-weight: 600;
}

.btn-dark:hover {
    transform: translateY(-1px);
    box-shadow: 0 0 0 8px var(--color-black);
    border-radius: var(--radius-full);
}

.partners-image {
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 50%;
}

.partners-image img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.partners-image-gradient-top {
    position: absolute;
    top: -1px;
    left: 0;
    right: -20px;
    height: 200px;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
    z-index: 1;
    rotate: 4deg;
    pointer-events: none;
}

.partners-image-gradient-bottom {
    position: absolute;
    bottom: -1px;
    left: -15px;
    right: 0;
    height: 200px;
    background: linear-gradient(to top, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
    z-index: 1;
    rotate: 4deg;
    pointer-events: none;
}

/* Partners columns layout */
.partners-columns {
    display: flex;
    gap: 20px;
    height: 700px;
    rotate: 4deg;
    overflow: hidden;
}

.partners-column {
    flex: 1;
    overflow: hidden;
    position: relative;
}

.partners-column-track {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.partners-column-track img {
    width: 100%;
    height: auto;
    display: block;
}

/* Animation de défilement vers le haut */
@keyframes scrollUp {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(-50%);
    }
}

/* Animation de défilement vers le bas */
@keyframes scrollDown {
    0% {
        transform: translateY(-50%);
    }
    100% {
        transform: translateY(0);
    }
}

.partners-scroll-up {
    animation: scrollUp 30s linear infinite;
}

.partners-scroll-down {
    animation: scrollDown 30s linear infinite;
}

/* ==========================================
   RESPONSIVE
   ========================================== */

@media (max-width: 1024px) {
    .container {
        padding: 0 var(--spacing-5);
    }

    .display-text {
        font-size: clamp(40px, 10vw, 120px);
    }

    .partners-logos-track {
        gap: var(--spacing-10);
    }

    .partners-logos {
        padding: var(--spacing-6) 0;
    }
    /* Solution Section */
    .solution {
        padding: var(--spacing-20) 0;
    }

    .solution-content {
        margin-bottom: var(--spacing-12);
    }

    .solution-title {
        font-size: clamp(36px, 9vw, 100px);
    }

    /* Reassurance Section */
    .reassurance {
        padding: var(--spacing-20) 0;
    }

    .reassurance-grid {
        gap: var(--spacing-10);
    }

    /* Partners Section */
    .partners {
        padding: var(--spacing-16) 0;
    }

    .partners-content {
        gap: var(--spacing-12);
    }

    .partners-title {
        font-size: clamp(28px, 5vw, 48px);
    }
}

@media (max-width: 868px) {
    /* Background Brandmark */
    .hero::before {
        background-size: contain;
        opacity: 0.8;
    }

    /* Container */
    .container {
        padding: 0 var(--spacing-4);
    }

    /* Header */
    .header {
        padding: var(--spacing-6) 0;
    }

    .header-content {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }

    /* Hide desktop navigation */
    .nav,
    .header-actions {
        display: none;
    }

    /* Show mobile menu button */
    .mobile-menu-btn {
        display: flex;
    }

    /* Hero */
    .hero {
        padding: var(--spacing-10) 0 var(--spacing-12) 0;
        min-height: auto;
    }

    .hero-content {
        margin-bottom: var(--spacing-12);
    }

    .hero-badge {
        font-size: 14px;
        margin-bottom: var(--spacing-6);
    }

    .hero-title {
        font-size: clamp(36px, 9vw, 64px);
        line-height: 0.9;
        margin-bottom: var(--spacing-4);
    }

    .display-text {
        font-size: clamp(32px, 8vw, 80px);
        line-height: 90%;
    }

    .hero-description {
        font-size: 15px;
        line-height: 1.6;
        margin-bottom: var(--spacing-8);
    }

    .hero-description br {
        display: none;
    }

    .hero-cta {
        flex-direction: row;
        gap: var(--spacing-3);
        flex-wrap: wrap;
    }

    .hero-cta .btn-lg {
        padding: 14px 24px;
        font-size: 15px;
        flex: 1;
        min-width: 200px;
    }

    .hero-cta .btn-icon {
        width: 50px;
        height: 50px;
        border-radius: var(--radius-full) !important;
    }

    /* Partners */
    .partners-logos {
        padding: var(--spacing-6) 0;
        left: -3%;
        width: 106%;
        overflow: hidden;
    }

    .partners-logos-track {
        gap: var(--spacing-8);
    }

    .partner-logo img {
        height: 60px;
    }

    /* Solution Section */
    .solution {
        padding: var(--spacing-16) 0;
    }

    .solution-content {
        margin-bottom: var(--spacing-10);
    }

    .solution-badge {
        font-size: 14px;
        margin-bottom: var(--spacing-6);
    }

    .solution-title {
        font-size: clamp(40px, 10vw, 72px);
        line-height: 0.9;
        margin-bottom: var(--spacing-4);
    }

    .solution-description {
        font-size: 15px;
        line-height: 1.6;
    }

    .solution-description br {
        display: none;
    }

    .solution-dashboard {
        border-radius: var(--radius-md);
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    }

    /* Reassurance Section */
    .reassurance {
        padding: var(--spacing-16) 0;
    }

    .reassurance-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-10);
    }

    .reassurance-icon {
        width: 64px;
        height: 64px;
        margin-bottom: var(--spacing-5);
    }

    .reassurance-title {
        font-size: 36px;
        margin-top: var(--spacing-3);
    }

    .reassurance-description {
        font-size: 15px;
    }

    /* Partners Section */
    .partners {
        padding: var(--spacing-16) 0;
    }

    .partners-wrapper {
        padding-left: var(--spacing-4);
        padding-right: var(--spacing-4);
        padding-top: 0;
        padding-bottom: 0;
    }

    .partners-content {
        grid-template-columns: 1fr;
        gap: var(--spacing-10);
    }

    .partners-text .section-title {
        font-size: clamp(24px, 6vw, 36px);
        margin-bottom: var(--spacing-8);
    }

    .partners-benefit-item {
        font-size: 16px;
        gap: var(--spacing-3);
    }

    .partners-benefit-item img {
        width: 28px;
        height: 28px;
    }

    .partners-image {
        position: relative;
        width: 100%;
        top: auto;
        right: auto;
        transform: none;
        margin-top: var(--spacing-8);
    }

    .partners-image-gradient-top,
    .partners-image-gradient-bottom {
        height: 150px;
    }

    .partners-columns {
        height: 400px;
        gap: 12px;
    }

    /* CTA Section */
    .cta {
        padding: var(--spacing-16) 0;
    }

    .cta-card {
        padding: var(--spacing-16) var(--spacing-8);
    }

    .cta-content {
        font-size: clamp(32px, 7vw, 64px);
        margin-bottom: var(--spacing-5);
    }

    .cta-content .section-description {
        font-size: 16px;
        margin-bottom: var(--spacing-8);
    }

    .partners-cta,
    .cta-actions {
        flex-direction: row;
        gap: var(--spacing-4);
    }

    .cta-brandmark {
        width: 600px;
        height: 600px;
    }

    /* Features Section */
    .features {
        padding: var(--spacing-16) 0;
    }

    .features-header {
        flex-direction: column;
        gap: var(--spacing-8);
    }

    .features-header .section-content {
        text-align: center;
    }

    .features-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }

    /* Reset all cards to single column */
    .features-grid .feature-card:nth-child(1),
    .features-grid .feature-card:nth-child(2),
    .features-grid .feature-card:nth-child(3),
    .features-grid .feature-card:nth-child(4),
    .features-grid .feature-card:nth-child(5) {
        grid-column: 1 / -1 !important;
    }

    .feature-title {
        font-size: 15px;
    }

    .feature-description {
        font-size: 15px;
    }

    /* Aidons Section */
    .aidons {
        padding: var(--spacing-12) 0;
    }

    .aidons-header {
        margin-bottom: var(--spacing-12);
    }

    .subtitle {
        font-size: 14px;
    }

    .aidons-title {
        font-size: clamp(40px, 7vw, 72px);
    }

    .aidons-description {
        font-size: 16px;
    }

    .aidons-tabs {
        margin-bottom: var(--spacing-12);
    }

    .aidons-tab {
        padding: 12px 28px;
        font-size: 15px;
    }

    .aidons-content {
        grid-template-columns: none !important;
        gap: var(--spacing-12);
    }

    .aidons-accordion-header span {
        font-size: clamp(24px, 4vw, 32px);
    }

    .aidons-accordion-header svg {
        width: 28px;
        height: 28px;
    }

    .aidons-accordion-content p {
        font-size: 15px;
    }

    .aidons-image-content {
        left: 0;
        max-width: 40%;
    }

    .aidons-image-title {
        font-size: clamp(20px, 5vw, 28px);
        margin-bottom: var(--spacing-3);
    }

    .aidons-image-description {
        font-size: 14px;
        margin-bottom: var(--spacing-4);
    }

    /* Testimonials Section */
    .testimonials {
        padding: var(--spacing-16) 0;
    }

    .testimonials-header {
        flex-direction: column;
        gap: var(--spacing-8);
        margin-bottom: var(--spacing-12);
    }

    .testimonials-header .section-title {
        text-align: center;
    }

    .testimonials-header .section-description {
        text-align: center;
    }

    .testimonials-grid {
        grid-template-columns: none !important;
        gap: var(--spacing-6);
    }

    .testimonial-card {
        padding: var(--spacing-8);
    }

    .testimonial-text {
        font-size: 15px;
    }

    /* Success Stories Section */
    .success-stories {
        padding: var(--spacing-16) 0;
    }

    .success-stories-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: var(--spacing-6);
    }

    .success-card-title {
        font-size: 18px;
    }

    .success-info-item {
        font-size: 13px;
    }

    .success-score-badge {
        font-size: 20px;
        padding: 6px 14px;
    }
}

@media (max-width: 480px) {
    /* Container */
    .container {
        padding: 0 var(--spacing-3);
    }

    /* Header */
    .header {
        padding: var(--spacing-6) 0;
    }

    .nav {
        gap: var(--spacing-3);
    }

    .nav-link {
        font-size: 13px;
    }

    .btn-primary {
        flex: 1;
    }

    /* Hero */
    .hero {
        padding: var(--spacing-8) 0;
    }

    .hero-badge {
        font-size: 13px;
    }

    .hero-title {
        font-size: clamp(64px, 16vw, 110px);
        line-height: 0.8;
    }

    .hero-description {
        font-size: 14px;
        margin-bottom: var(--spacing-6);
    }

    .hero-cta {
        flex-direction: row;
        gap: var(--spacing-3);
    }

    .hero-cta .btn-lg {
        flex: 1;
        min-width: auto;
        padding: 12px 16px;
    }

    .hero-cta .btn-icon {
        width: 48px;
        height: 48px;
        flex-shrink: 0;
        border-radius: var(--radius-full) !important;
    }

    .display-text {
        font-size: clamp(28px, 7vw, 56px);
        line-height: 95%;
    }

    /* Partners */
    .partners-logos {
        padding: var(--spacing-4) 0;
    }

    .partners-logos-track {
        gap: var(--spacing-6);
        animation: scroll 20s linear infinite;
    }

    .partner-logo img {
        height: 50px;
    }

    /* Solution Section */
    .solution {
        padding: var(--spacing-12) 0;
    }

    .solution-content {
        margin-bottom: var(--spacing-8);
    }

    .solution-badge {
        font-size: 13px;
        margin-bottom: var(--spacing-5);
    }

    .solution-title {
        font-size: clamp(48px, 12vw, 88px);
        line-height: 0.85;
    }

    .solution-description {
        font-size: 14px;
        margin-bottom: var(--spacing-6);
    }

    .solution-dashboard {
        border-radius: var(--radius-md);
    }

    /* Reassurance Section */
    .reassurance {
        padding: var(--spacing-12) 0;
    }

    .reassurance-grid {
        gap: var(--spacing-8);
    }

    .reassurance-icon {
        width: 56px;
        height: 56px;
        margin-bottom: var(--spacing-4);
    }

    .reassurance-title {
        font-size: 28px;
    }

    .reassurance-description {
        font-size: 14px;
    }

    /* Partners Section */
    .partners {
        padding: var(--spacing-12) 0;
    }

    .partners-wrapper {
        padding-left: var(--spacing-3);
        padding-right: var(--spacing-3);
        padding-top: 0;
        padding-bottom: 0;
    }

    .partners-text .section-title {
        font-size: clamp(20px, 5vw, 32px);
        margin-bottom: var(--spacing-6);
    }

    .partners-benefit-item {
        font-size: 14px;
        margin-bottom: var(--spacing-4);
    }

    .partners-benefit-item img {
        width: 24px;
        height: 24px;
    }

    .partners-cta,
    .cta-actions {
        flex-direction: column;
        gap: var(--spacing-3);
    }

    .partners-cta .btn,
    .cta-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .btn-dark {
        padding: 12px 24px;
        font-size: 14px;
    }

    /* Button Group Responsive */
    .btn-group {
        flex-direction: row;
        gap: 2px;
    }

    .btn-group .btn-text {
        flex: 1;
        padding: 12px 20px;
        font-size: 14px;
    }

    .btn-group .btn-arrow {
        width: 42.5px;
        height: 42.5px;
        flex-shrink: 0;
    }

    .btn-group:hover .btn-arrow {
        transform: translateX(-20px) !important;
    }
    .partners-image {
        position: relative;
        width: 100%;
        top: auto;
        right: auto;
        transform: none;
        margin-top: var(--spacing-6);
    }

    .partners-image-gradient-top,
    .partners-image-gradient-bottom {
        height: 100px;
    }

    /* CTA Section */
    .cta {
        padding: var(--spacing-12) 0;
    }

    .cta-card {
        padding: var(--spacing-12) var(--spacing-6);
        border-radius: var(--radius-md);
    }

    .cta-content .section-title-md {
        font-size: clamp(48px, 6vw, 68px);
        margin-bottom: var(--spacing-4);
    }

    .cta-content .section-description {
        font-size: 15px;
        margin-bottom: var(--spacing-6);
    }


    .cta-brandmark {
        width: 400px;
        height: 400px;
    }

    /* Features Section */
    .features {
        padding: var(--spacing-12) 0;
    }

    .features-header {
        margin-bottom: var(--spacing-10);
    }

    .features-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-5);
    }

    /* Reset all cards to single column */
    .features-grid .feature-card:nth-child(1),
    .features-grid .feature-card:nth-child(2),
    .features-grid .feature-card:nth-child(3),
    .features-grid .feature-card:nth-child(4),
    .features-grid .feature-card:nth-child(5) {
        grid-column: 1 / -1 !important;
    }

    .feature-card {
        padding: var(--spacing-6);
    }

    .feature-title {
        font-size: 14px;
        margin-bottom: var(--spacing-3);
    }

    .feature-description {
        font-size: 14px;
        margin-bottom: var(--spacing-4);
    }

    .feature-link {
        font-size: 14px;
    }

    /* Aidons Section */
    .aidons {
        padding: var(--spacing-12) 0;
    }

    .aidons-header {
        margin-bottom: var(--spacing-10);
    }

    .subtitle {
        font-size: 13px;
    }

    .aidons-title {
        font-size: clamp(32px, 8vw, 52px);
        margin-bottom: var(--spacing-4);
    }

    .aidons-description {
        font-size: 15px;
    }

    .aidons-tabs {
        flex-wrap: wrap;
        gap: var(--spacing-2);
        margin-bottom: var(--spacing-10);
    }

    .aidons-tab {
        padding: 10px 20px;
        font-size: 14px;
    }

    .aidons-content {
        grid-template-columns: none !important;
        gap: var(--spacing-10);
    }

    .aidons-image {
        margin-bottom: var(--spacing-6);
    }

    .aidons-accordion-header span {
        font-size: clamp(20px, 5vw, 28px);
    }

    .aidons-accordion-header svg {
        width: 24px;
        height: 24px;
    }

    .aidons-accordion-content p {
        font-size: 14px;
    }

    .aidons-image-content {
        left: 0;
        max-width: 45%;
    }

    .aidons-image-title {
        font-size: clamp(24px, 4vw, 32px);
    }

    .aidons-image-description {
        font-size: 14px;
    }

    /* Testimonials Section */
    .testimonials {
        padding: var(--spacing-12) 0;
    }

    .testimonials-header {
        flex-direction: column;
        gap: var(--spacing-6);
        margin-bottom: var(--spacing-10);
    }

    .testimonials-header .section-title {
        text-align: center;
        font-size: clamp(32px, 8vw, 52px);
    }

    .testimonials-header .section-description {
        text-align: center;
        font-size: 15px;
    }

    .testimonials-grid {
        grid-template-columns: none !important;
        gap: var(--spacing-5);
    }

    .testimonial-card {
        padding: var(--spacing-6);
        gap: var(--spacing-6);
    }

    .testimonial-logo {
        height: 50px;
    }

    .testimonial-text {
        font-size: 14px;
    }

    .testimonial-avatar {
        width: 48px;
        height: 48px;
    }

    .testimonial-author-name {
        font-size: 15px;
    }

    .testimonial-author-title {
        font-size: 13px;
    }

    /* Success Stories Section */
    .success-stories {
        padding: var(--spacing-12) 0;
    }

    .success-stories-header .section-title {
        font-size: clamp(32px, 8vw, 52px);
    }

    .success-stories-header .section-description {
        font-size: 15px;
    }

    .success-stories-grid {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-5);
    }

    .success-card-content {
        padding: var(--spacing-5);
        gap: var(--spacing-4);
    }

    .success-card-title {
        font-size: 16px;
    }

    .success-info-item {
        font-size: 12px;
    }

    .success-score-badge {
        font-size: 18px;
        padding: 6px 12px;
    }

    .success-score-max {
        font-size: 16px;
    }

    .success-logo-box {
        width: 70px;
        height: 70px;
    }
}

/* ==========================================
   HOW IT WORKS SECTION
   ========================================== */

.how-it-works {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.how-it-works-header {
    text-align: center;
    max-width: 1000px;
    margin: 0 auto var(--spacing-16) auto;
}

.how-it-works-header .subtitle {
    margin-bottom: var(--spacing-4);
}

.how-it-works-header .section-title {
    margin-bottom: var(--spacing-6);
}

.how-it-works-header .section-description {
    margin-bottom: 0;
}

.how-it-works-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-8);
    position: relative;
}

.how-it-works-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    text-align: center;
}

.how-it-works-sub-card {
    text-align: left !important;
    background-color: var(--color-gray-light);
    padding: var(--spacing-8);
    border-radius: var(--radius-img);
    width: 100%;
}

.how-it-works-visual {
    width: 100%;
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.how-it-works-visual img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.how-it-works-step-title {
    font-size: clamp(38px, 6vw, 62px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-black);
    text-transform: uppercase;
}

.how-it-works-description {
    font-size: 18px;
    line-height: 1.6;
    color: var(--color-black);
    max-width: 100%;
    margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
    .how-it-works {
        padding: var(--spacing-20) 0;
    }

    .how-it-works-grid {
        gap: var(--spacing-12);
    }

    .how-it-works-visual {
        height: 350px;
    }

    .how-it-works-step-title {
        font-size: clamp(40px, 5vw, 60px);
    }

    .how-it-works-description {
        font-size: 15px;
    }

    .how-it-works-card {
        align-items: stretch;
    }
}

@media (max-width: 868px) {
    .how-it-works {
        padding: var(--spacing-16) 0;
    }

    .how-it-works-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-16);
    }

    .how-it-works-visual {
        height: 300px;
        margin-bottom: var(--spacing-6);
    }

    .how-it-works-step-title {
        font-size: clamp(36px, 7vw, 52px);
        margin-bottom: var(--spacing-4);
    }

    .how-it-works-description {
        font-size: 15px;
    }

    .how-it-works-card {
        align-items: stretch;
    }
}

@media (max-width: 480px) {
    .how-it-works {
        padding: var(--spacing-12) 0;
    }

    .how-it-works-header {
        margin-bottom: var(--spacing-12);
    }

    .how-it-works-grid {
        gap: var(--spacing-12);
    }

    .how-it-works-visual {
        height: 250px;
        margin-bottom: var(--spacing-5);
    }

    .how-it-works-step-title {
        font-size: clamp(32px, 8vw, 48px);
        margin-bottom: var(--spacing-3);
    }

    .how-it-works-description {
        font-size: 14px;
    }

    .how-it-works-card {
        align-items: stretch;
    }
}

/* ==========================================
   BENEFITS SECTION
   ========================================== */

.benefits {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.benefits-wrapper {
    max-width: 1280px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-16);
    align-items: center;
}

.benefits-content {
    max-width: 600px;
}

.benefits-subtitle {
    font-size: 16px;
    font-weight: 400;
    color: var(--color-black);
    margin-bottom: var(--spacing-6);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.benefits-title {
    font-size: clamp(48px, 8vw, 90px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-black);
    margin-bottom: var(--spacing-2);
    text-transform: uppercase;
}

.benefits-description {
    font-size: 17px;
    line-height: 1.6;
    color: var(--color-black);
    margin-bottom: var(--spacing-12);
}

.benefits-accordions {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.benefits-accordion {
    border-bottom: 1px solid #E0E0E0;
}

.benefits-accordion:last-child {
    border-bottom: none;
}

.benefits-accordion-header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-8) 0;
    background: transparent;
    border: none;
    font-family: var(--font-display);
    cursor: pointer;
    text-align: left;
    transition: all 0.3s ease;
}

.benefits-accordion-header span {
    font-size: clamp(30px, 12vw, 36px);
    font-weight: 500;
    font-family: 'Monigue';
    color: var(--color-black);
    text-transform: uppercase;
    line-height: 1;
}

.benefits-accordion-header svg {
    width: 32px;
    height: 32px;
    transition: transform 0.3s ease;
    flex-shrink: 0;
}

.benefits-accordion-header.active svg {
    transform: rotate(180deg);
}

.benefits-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
}

.benefits-accordion-content.active {
    max-height: 300px;
    padding-bottom: var(--spacing-8);
}

.benefits-accordion-content p {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-black);
    margin: 0;
}

.benefits-image-wrapper {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.benefits-image {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--radius-lg);
}

.benefits-cta {
    position: absolute;
    bottom: var(--spacing-8);
    right: var(--spacing-8);
    z-index: 10;
}

/* Responsive */
@media (max-width: 1024px) {
    .benefits {
        padding: var(--spacing-20) 0;
    }

    .benefits-wrapper {
        gap: var(--spacing-12);
    }

    .benefits-title {
        font-size: clamp(40px, 7vw, 72px);
    }

    .benefits-description {
        font-size: 16px;
    }

    .benefits-accordion-header span {
        font-size: clamp(20px, 3vw, 33px);
    }
}

@media (max-width: 868px) {
    .benefits {
        padding: var(--spacing-16) 0;
    }

    .benefits-wrapper {
        grid-template-columns: 1fr;
        gap: var(--spacing-12);
    }

    .benefits-content {
        max-width: 100%;
    }

    .benefits-title {
        font-size: clamp(32px, 8vw, 52px);
    }

    .benefits-description {
        font-size: 15px;
        margin-bottom: var(--spacing-10);
    }

    .benefits-accordion-header {
        padding: var(--spacing-6) 0;
    }

    .benefits-accordion-header span {
        font-size: clamp(18px, 4vw, 34px);
    }

    .benefits-accordion-header svg {
        width: 28px;
        height: 28px;
    }

    .benefits-image-wrapper {
        order: 2;
    }

    .benefits-content {
        order: 1;
    }
}

@media (max-width: 480px) {
    .benefits {
        padding: var(--spacing-12) 0;
    }

    .benefits-wrapper {
        gap: var(--spacing-10);
    }

    .benefits-subtitle {
        font-size: 13px;
    }

    .benefits-title {
        font-size: clamp(28px, 8vw, 48px);
        margin-bottom: var(--spacing-4);
    }

    .benefits-description {
        font-size: 14px;
        margin-bottom: var(--spacing-8);
    }

    .benefits-accordion-header {
        padding: var(--spacing-5) 0;
    }

    .benefits-accordion-header span {
        font-size: clamp(26px, 4vw, 30px);
    }

    .benefits-accordion-header svg {
        width: 24px;
        height: 24px;
    }

    .benefits-accordion-content p {
        font-size: 14px;
    }

    .benefits-cta {
        bottom: var(--spacing-6);
        right: var(--spacing-6);
    }
}

/* ==========================================
   FEATURES SECTION
   ========================================== */

.features {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.features-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-10);
    gap: var(--spacing-10);
}

.features-header .section-content {
    /* flex: 1; */
    text-align: left;
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--spacing-8);
}

/* First two cards take 3 columns each (2 cards per row) */
.features-grid .feature-card:nth-child(1),
.features-grid .feature-card:nth-child(2) {
    grid-column: span 3;
}

/* Last three cards take 2 columns each (3 cards per row) */
.features-grid .feature-card:nth-child(3),
.features-grid .feature-card:nth-child(4),
.features-grid .feature-card:nth-child(5) {
    grid-column: span 2;
}

.feature-card {
    border-radius: var(--radius-lg);
    margin: var(--spacing-4);
    display: flex;
    flex-direction: column;
}

.feature-image {
    width: 100%;
    margin-bottom: var(--spacing-4);
    background: #e5e5e5;
    border-radius: var(--radius-img);
}

.feature-image img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--radius-md);
}

.feature-title {
    font-size: 20px;
    font-weight: 600;
    font-family: 'DM Sans', sans-serif;
    color: var(--color-black);
    margin-bottom: var(--spacing-1);
    text-transform: none;
}

.feature-description {
    font-size: 14px;
    line-height: 1.6;
    color: var(--color-black);
    margin-bottom: var(--spacing-2);
    flex: 1;
}

.feature-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 16px;
    font-weight: 500;
    color: var(--color-black);
    transition: gap 0.3s ease;
    text-decoration: none;
}

.feature-link:hover {
    gap: var(--spacing-3);
}

.feature-link svg {
    width: 20px;
    height: 20px;
}

/* ==========================================
   AIDONS SECTION
   ========================================== */

.aidons {
    background: var(--color-white);
    padding: var(--spacing-12) 0;
    position: relative;
}

.aidons-header {
    text-align: center;
    max-width: 1000px;
    margin: 0 auto var(--spacing-16) auto;
}

.subtitle {
    font-size: 16px;
    font-weight: 400;
    color: var(--color-black);
    margin-bottom: var(--spacing-4);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.aidons-title {
    font-size: clamp(48px, 8vw, 90px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-black);
    margin-bottom: var(--spacing-6);
    text-transform: uppercase;
}

.aidons-description {
    font-size: 17px;
    line-height: 1.6;
    color: var(--color-black);
    max-width: 900px;
    margin: 0 auto;
}

/* Tabs */
.aidons-tabs {
    display: flex;
    justify-content: center;
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-16);
}

.aidons-tab {
    padding: 6px 12px;
    font-size: 16px;
    font-weight: 500;
    background: transparent;
    border: none;
    border-radius: var(--radius-md);
    color: var(--color-black);
    cursor: pointer;
    transition: all 0.3s ease;
}

.aidons-tab.active {
    background: var(--color-black);
    color: var(--color-white);
}

.aidons-tab:hover:not(.active) {
    background: var(--color-gray-light);
}

/* Content */
.aidons-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-16);
    align-items: flex-start;
}

/* Left - Image */
.aidons-image-wrapper {
    position: relative;
}

.aidons-image {
    position: relative;
    width: 100%;
    border-radius: var(--radius-lg);
    overflow: hidden;
    max-height: 500px;
    margin-bottom: var(--spacing-8);
}

.filter-image {
    background: rgba(0, 0, 0, 0.4);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    border-radius: var(--radius-lg);
    pointer-events: none;
}

.aidons-image .tab-image {
    width: 100%;
    display: none;
    border-radius: var(--radius-lg);
}

.aidons-image .tab-image.active {
    display: block;
}

.aidons-image-content {
    position: absolute;
    bottom: 0;
    left: var(--spacing-8);
    transform: translateY(-50%);
    max-width: 480px;
    z-index: 10;
    color: var(--color-white);
    display: none;
}

.aidons-image-content.active {
    display: block;
}

.aidons-image-title {
    font-family: var(--font-display);
    font-size: clamp(28px, 3.5vw, 42px);
    font-weight: 500;
    line-height: 1.1;
    color: var(--color-white);
    text-transform: uppercase;
    margin-bottom: var(--spacing-4);
}

.aidons-image-description {
    font-size: 15px;
    line-height: 1.6;
    color: var(--color-white);
    margin-bottom: var(--spacing-6);
    opacity: 0.95;
}

.aidons-cta {
    z-index: 10;
    position: absolute;
    top: 20px;
    right: 20px;
}

/* Right - Accordions */
.aidons-accordions {
    display: none;
    flex-direction: column;
    gap: 0;
}

.aidons-accordions.active {
    display: flex;
}

.aidons-accordion {
    border-bottom: 1px solid #E0E0E0;
}

.aidons-accordion:last-child {
    border-bottom: none;
}

.aidons-accordion-header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-8) 0;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: all 0.3s ease;
}

.aidons-accordion-header span {
    font-size: clamp(24px, 4vw, 36px);
    font-weight: 500;
    font-family: 'Monigue';
    color: var(--color-black);
    text-transform: uppercase;
    line-height: 1;
}

.aidons-accordion-header svg {
    width: 32px;
    height: 32px;
    transition: transform 0.3s ease;
    flex-shrink: 0;
}

.aidons-accordion-header.active svg {
    transform: rotate(180deg);
}

.aidons-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
}

.aidons-accordion-content.active {
    max-height: 300px;
    padding-bottom: var(--spacing-8);
}

.aidons-accordion-content p {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-black);
    margin: 0;
}

/* ==========================================
   CTA SECTION
   ========================================== */

.cta {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.cta-card {
    background: linear-gradient(99.44deg, rgba(221, 239, 246, 1) 0%, rgba(69, 234, 231, 1) 100%);
    border-radius: var(--radius-lg);
    padding: 120px var(--spacing-10);
    position: relative;
    overflow: hidden;
}

.cta-content {
    text-align: center;
    max-width: 700px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.cta-content .section-description {
    margin-bottom: var(--spacing-10);
}

.cta-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 16px;
    font-weight: 500;
    color: var(--color-black);
    transition: gap 0.3s ease;
}

.cta-link:hover {
    gap: var(--spacing-3);
}

.cta-link svg {
    width: 20px;
    height: 20px;
}

.cta-brandmark {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    opacity: 1;
    width: 900px;
    height: 900px;
    z-index: 0;
    pointer-events: none;
}

.cta-brandmark img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* ==========================================
   TESTIMONIALS SECTION
   ========================================== */

.testimonials {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.testimonials-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-16);
    gap: var(--spacing-10);
}

.testimonials-header-content {
    flex: 1;
}

.testimonials-header .section-title {
    text-align: left;
}

.testimonials-header {
    text-align: left;
    max-width: 100%;
}

.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-8);
}

.testimonial-card {
    background: var(--color-gray-light);
    border-radius: var(--radius-lg);
    padding: var(--spacing-10);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-8);
    
}

.shadow-card:hover {
    transform: translateY(-4px);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

.testimonial-logo {
    height: 60px;
    display: flex;
    align-items: center;
}

.testimonial-logo img {
    max-height: 100%;
    width: auto;
    object-fit: contain;
}

.testimonial-text {
    font-size: 16px;
    line-height: 1.7;
    font-weight: 600;
    font-style: normal;
    color: var(--color-black);
    flex: 1;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
}

.testimonial-avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
}

.testimonial-author-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.testimonial-author-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-black);
}

.testimonial-author-title {
    font-size: 14px;
    color: var(--color-black);
    opacity: 0.7;
}

/* ==========================================
   SUCCESS STORIES SECTION
   ========================================== */

/* White Title Accent */
.title-white {
    color: white;
}

.success-stories {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
    overflow: hidden;
}

.success-stories-header {
    text-align: center;
    max-width: 900px;
    margin: 0 auto var(--spacing-16) auto;
}

.success-stories-header .section-title {
    color: var(--color-black);
}

.success-stories-header .section-description {
    color: var(--color-black);
}

.success-stories-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-8);
}

.success-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.10);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.success-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}

.success-card-header {
    position: relative;
    height: 100px;
}

.success-card-header-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.success-card-badge {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 2;
}

.success-card-content {
    margin-top: -60px;
    padding: var(--spacing-6);
    display: flex;
    z-index: 99;
    flex-direction: column;
    gap: var(--spacing-5);
    flex: 1;
}

/* .success-card-logo {
    margin-top: calc(var(--spacing-6) * -1);
    margin-bottom: var(--spacing-2);
} */

.success-logo-box {
    width: 80px;
    height: 80px;
    margin-top: -5px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-white);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.success-card-title {
    font-size: 20px;
    font-weight: 600;
    font-family: 'DM Sans', sans-serif;
    color: var(--color-black);
    margin: 0;
    text-transform: uppercase;
}

.success-card-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.success-info-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 14px;
    color: var(--color-black);
}

.success-info-item svg {
    flex-shrink: 0;
    opacity: 0.7;
}

.success-card-score {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-2);
    margin-top: var(--spacing-4);
}

.success-score-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0px 4px;
    border-radius: var(--radius-md);
    font-size: 24px;
    font-weight: 600;
    color: var(--color-black);
}

.success-score-max {
    font-size: 16px;
    font-weight: 500;
    color: var(--color-black);
}

.success-score-bar {
    position: relative;
    margin-top: var(--spacing-2);
}

.success-score-track {
    display: flex;
    gap: 4px;
    height: 8px;
    border-radius: var(--radius-full);
    overflow: hidden;
}

.success-score-segment {
    flex: 1;
    border-radius: 2px;
}

.success-score-indicator {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--color-white);
    border: 3px solid var(--color-black);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.success-stories-brandmark {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    opacity: 0.15;
    width: 1000px;
    height: 1000px;
    z-index: 0;
    pointer-events: none;
}

.success-stories-brandmark img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* ==========================================
   ADVANTAGES SECTION
   ========================================== */

.advantages {
    background: var(--color-black);
    padding: 200px 0;
    position: relative;
    overflow: visible;
}

.advantages::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 1100px;
    height: 1000px;
    background-image: url('./assets/commun/Brandmark-logo-white.svg');
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.05;
    z-index: 0;
    pointer-events: none;
}

.advantages-header {
    text-align: center;
    max-width: 1000px;
    margin: 0 auto var(--spacing-12) auto;
    position: relative;
    z-index: 1;
}

.advantages-subtitle {
    font-size: 18px;
    font-weight: 400;
    color: var(--color-white);
    margin-bottom: var(--spacing-4);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.advantages-title {
    font-size: clamp(48px, 8vw, 90px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-white);
    margin-bottom: var(--spacing-6);
    text-transform: uppercase;
}

.advantages-description {
    font-size: 17px;
    line-height: 1.6;
    color: var(--color-white);
    max-width: 900px;
    margin: 0 auto;
}

.advantages-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-8);
    position: relative;
    z-index: 1;
}

.advantage-card {
    background: var(--color-white);
    border-radius: var(--radius-l);
    padding: var(--spacing-8);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

.advantage-icon {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.advantage-icon svg {
    width: 100%;
    height: 100%;
}

.advantage-title {
    font-size: clamp(34px, 3vw, 52px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-black);
    text-transform: uppercase;
}

.advantage-description {
    font-size: 18px;
    line-height: 1.6;
    color: var(--color-black);
    margin: 0;
}

/* Responsive */
@media (max-width: 1024px) {
    .advantages {
        padding: var(--spacing-20) 0;
    }

    .advantages::before {
        width: 600px;
        height: 600px;
    }

    .advantages-title {
        font-size: clamp(40px, 7vw, 72px);
    }

    .advantages-description {
        font-size: 16px;
    }

    .advantages-grid {
        gap: var(--spacing-6);
    }

    .advantage-card {
        padding: var(--spacing-8);
    }
}

@media (max-width: 868px) {
    .advantages {
        padding: var(--spacing-16) 0;
    }

    .advantages::before {
        width: 400px;
        height: 400px;
    }

    .advantages-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }

    .advantages-title {
        font-size: clamp(42px, 8vw, 52px);
    }

    .advantages-description {
        font-size: 15px;
    }

    .advantage-card {
        padding: var(--spacing-8);
        gap: var(--spacing-5);
    }

    .advantage-icon {
        width: 56px;
        height: 56px;
    }

    .advantage-title {
        font-size: clamp(34px, 8vw, 44px);
    }

    .advantage-description {
        font-size: 15px;
    }
}

@media (max-width: 480px) {
    .advantages {
        padding: var(--spacing-12) 0;
    }

    .advantages::before {
        width: 300px;
        height: 300px;
    }

    .advantages-header {
        margin-bottom: var(--spacing-12);
    }

    .advantages-subtitle {
        font-size: 13px;
        margin-bottom: var(--spacing-4);
    }

    .advantages-title {
        font-size: clamp(48px, 14vw, 58px);
        margin-bottom: var(--spacing-4);
    }

    .advantages-description {
        font-size: 14px;
    }

    .advantages-grid {
        gap: var(--spacing-5);
    }

    .advantage-card {
        padding: var(--spacing-6);
        gap: var(--spacing-4);
    }

    .advantage-icon {
        width: 48px;
        height: 48px;
    }

    .advantage-title {
        font-size: clamp(38px, 8vw, 44px);
    }

    .advantage-description {
        font-size: 14px;
    }
}

/* ==========================================
   FAQ SECTION
   ========================================== */

.faq {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.faq-wrapper {
    background: #F9FAFB;
    padding: var(--spacing-24);
    border-radius: var(--radius-xl);
    position: relative;
}

.faq-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-16);
    gap: var(--spacing-10);
}

.faq-title-wrapper {
    flex: 1;
}

.faq-title {
    font-size: clamp(48px, 8vw, 90px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-black);
    text-transform: uppercase;
    margin: 0;
}

.faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

.faq-item {
    background: var(--color-gray-light);
    border-bottom: 1px solid #E5E7EB;
    overflow: hidden;
}

.faq-question {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-8) var(--spacing-10);
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: all 0.3s ease;
}

.faq-question span {
    font-size: clamp(18px, 3vw, 24px);
    font-weight: 600;
    font-family: 'DM Sans', sans-serif;
    color: var(--color-black);
    line-height: 1.4;
    flex: 1;
}

.faq-icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    transition: all 0.3s ease;
    color: var(--color-black);
}

.faq-icon path {
    transition: d 0.3s ease;
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    padding: 0 var(--spacing-10);
}

.faq-answer.active {
    max-height: 500px;
    padding: 0 var(--spacing-10) var(--spacing-8) var(--spacing-10);
}

.faq-answer p {
    font-size: 16px;
    line-height: 1.7;
    color: var(--color-black);
    margin: 0;
}

/* FAQ Content Wrapper with Sidebar */
.faq-content-wrapper {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: var(--spacing-10);
    margin-top: var(--spacing-10);
}

/* FAQ Sidebar */
.faq-sidebar {
    background: var(--color-white);
    border-radius: var(--radius-2xl);
    padding: var(--spacing-6);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
    height: fit-content;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.faq-tab {
    padding: var(--spacing-4) var(--spacing-5);
    background: transparent;
    border: none;
    border-radius: var(--radius-lg);
    font-size: 16px;
    font-weight: 500;
    font-family: 'DM Sans', sans-serif;
    color: var(--color-black);
    text-align: left;
    cursor: pointer;
    transition: all 0.3s ease;
}

.faq-tab:hover {
    background: rgba(0, 216, 102, 0.08);
}

.faq-tab.active {
    background: rgba(0, 216, 102, 0.15);
    color: var(--color-green-black);
    font-weight: 600;
}

/* FAQ Content Area */
.faq-content {
    background: var(--color-white);
    border-radius: var(--radius-2xl);
    padding: var(--spacing-10);
    min-height: 400px;
}

.faq-category {
    display: none;
}

.faq-category.active {
    display: block;
}

.faq-category-title {
    font-size: 32px;
    font-weight: 700;
    font-family: 'Anton', sans-serif;
    color: var(--color-black);
    text-transform: uppercase;
    margin: 0 0 var(--spacing-8) 0;
    letter-spacing: 0.5px;
}

/* FAQ Responsive */
@media (max-width: 1024px) {
    .faq {
        padding: var(--spacing-16) 0;
    }

    .faq-header {
        flex-direction: column;
        gap: var(--spacing-8);
        margin-bottom: var(--spacing-12);
    }

    .faq-title {
        font-size: clamp(40px, 7vw, 72px);
    }

    .faq-question {
        padding: var(--spacing-6) var(--spacing-8);
    }

    .faq-question span {
        font-size: clamp(16px, 3vw, 20px);
    }

    .faq-answer {
        padding: 0 var(--spacing-8);
    }

    .faq-answer.active {
        padding: 0 var(--spacing-8) var(--spacing-6) var(--spacing-8);
    }

    .faq-answer p {
        font-size: 15px;
    }

    .faq-content-wrapper {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }

    .faq-sidebar {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-2);
        padding: var(--spacing-4);
    }

    .faq-tab {
        font-size: 14px;
        padding: var(--spacing-3) var(--spacing-4);
        text-align: center;
    }

    .faq-content {
        padding: var(--spacing-6);
    }

    .faq-category-title {
        font-size: 24px;
        margin-bottom: var(--spacing-6);
    }
}

@media (max-width: 480px) {
    .faq {
        padding: var(--spacing-12) 0;
    }

    .faq-header {
        gap: var(--spacing-6);
        margin-bottom: var(--spacing-10);
    }

    .faq-title {
        font-size: clamp(32px, 8vw, 52px);
    }

    .faq-question {
        padding: var(--spacing-5) var(--spacing-6);
    }

    .faq-question span {
        font-size: clamp(15px, 3vw, 18px);
    }

    .faq-icon {
        width: 20px;
        height: 20px;
    }

    .faq-wrapper {
        padding: var(--spacing-10) var(--spacing-4);
    }

    .faq-answer {
        padding: 0 var(--spacing-6);
    }

    .faq-answer.active {
        padding: 0 var(--spacing-6) var(--spacing-5) var(--spacing-6);
    }

    .faq-answer p {
        font-size: 14px;
    }
}

/* ==========================================
   FINAL CTA SECTION
   ========================================== */

.final-cta {
    background: var(--color-white);
    padding: var(--spacing-20) 0;
    position: relative;
}

.final-cta-card {
    background: var(--color-green-black);
    border-radius: var(--radius-xl);
    padding: 100px var(--spacing-10);
    position: relative;
    overflow: hidden;
    min-height: 500px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.final-cta-content {
    text-align: center;
    max-width: 900px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.final-cta-title {
    font-size: clamp(80px, 10vw, 220px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-white);
    text-transform: uppercase;
}

.final-cta-description {
    font-size: 20px;
    line-height: 1.6;
    color: var(--color-white);
    margin-bottom: var(--spacing-10);
}

.final-cta-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-6);
}

.final-cta-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 16px;
    font-weight: 500;
    color: var(--color-white);
    transition: gap 0.3s ease;
    text-decoration: none;
}

.final-cta-link:hover {
    gap: var(--spacing-3);
}

.final-cta-link svg {
    width: 20px;
    height: 20px;
}

.final-cta-brandmark {
    position: absolute;
    width: 600px;
    height: 600px;
    z-index: 0;
    pointer-events: none;
}

.final-cta-brandmark-left {
    left: -300px;
    bottom: -300px;
    transform: rotate(-90deg);
}

.final-cta-brandmark-right {
    right: -300px;
    top: -300px;
    transform: rotate(90deg);
}

.final-cta-brandmark img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    /* filter: brightness(0) invert(1); */
}

/* Final CTA Responsive */
@media (max-width: 1024px) {
    .final-cta {
        padding: var(--spacing-16) 0;
    }

    .final-cta-card {
        padding: var(--spacing-16) var(--spacing-8);
        min-height: 400px;
    }

    .final-cta-title {
        font-size: clamp(68px, 9vw, 90px);
        margin-bottom: var(--spacing-6);
    }

    .final-cta-description {
        font-size: 18px;
        margin-bottom: var(--spacing-8);
    }

    .final-cta-actions {
        flex-direction: row;
        gap: var(--spacing-4);
    }

    .final-cta-brandmark {
        width: 400px;
        height: 400px;
    }

    .final-cta-brandmark-left {
        left: -200px;
        bottom: -200px;
    }

    .final-cta-brandmark-right {
        right: -200px;
        top: -200px;
    }
}

@media (max-width: 480px) {
    .final-cta {
        padding: var(--spacing-12) 0;
    }

    .final-cta-card {
        padding: var(--spacing-12) var(--spacing-6);
        border-radius: var(--radius-md);
        min-height: 350px;
    }

    .final-cta-title {
        font-size: clamp(60px, 10vw, 72px);
        margin-bottom: var(--spacing-5);
    }

    .final-cta-description {
        font-size: 16px;
        margin-bottom: var(--spacing-6);
    }

    .final-cta-actions {
        flex-direction: column;
        gap: var(--spacing-3);
        width: 100%;
    }

    .final-cta-actions .btn-group {
        width: 100%;
    }

    .final-cta-brandmark {
        width: 200px;
        height: 200px;
    }

    .final-cta-brandmark-left {
        left: -100px;
        bottom: -100px;
    }

    .final-cta-brandmark-right {
        right: -100px;
        top: -100px;
    }
}

/* ==========================================
   ACTUS SECTION
   ========================================== */

.actus {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.actus-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-16);
    gap: var(--spacing-10);
}

.actus-header-content {
    flex: 1;
}

.actus-header .section-title {
    text-align: left;
}

.actus-header .section-description {
    text-align: left;
    margin-left: 0;
}

/* Articles Grid */
.actus-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-8);
    align-items: start;
}

.actus-card-column {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-8);
}

/* Article Card */
.actus-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.actus-card-image {
    position: relative;
    width: 100%;
    height: 300px;
    overflow: hidden;
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.actus-card-large {
    height: 100%;
}

.actus-card-large .actus-card-image {
    height: 100%;
    flex: 2;
}

.actus-card-large .actus-card-content {
    flex: 0 0 auto;
}

.actus-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.actus-card-tags {
    position: absolute;
    top: var(--spacing-4);
    right: var(--spacing-4);
    display: flex;
    gap: var(--spacing-2);
    z-index: 2;
}

.actus-tag {
    display: inline-block;
    padding: 8px 16px;
    background: var(--color-white);
    border-radius: var(--radius-full);
    font-size: 14px;
    font-weight: 500;
    border: 1px solid var(--color-black);
    color: var(--color-black);
}

.actus-card-content {
    padding: var(--spacing-6) 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
    margin-right: 50px;
    flex: 1;
}

.actus-card-meta {
    font-size: 16px;
    color: var(--color-gray);
    font-weight: 400;
}

.actus-card-title {
    font-size: 32px;
    font-weight: 600;
    font-family: var(--font-base), sans-serif;
    color: var(--color-black);
    line-height: 1;
    
    margin: 0;
}

.actus-card-description {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-black);
    margin: 0;
    flex: 1;
}

.actus-card-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 16px;
    font-weight: 600;
    color: var(--color-black);
    transition: gap 0.3s ease;
    text-decoration: none;
    margin-top: auto;
}

.actus-card-link svg {
    width: 20px;
    height: 20px;
    transition: transform 0.3s ease;
}

/* Actus Responsive */
@media (max-width: 1024px) {
    .actus {
        padding: var(--spacing-16) 0;
    }

    .actus-header {
        flex-direction: column;
        gap: var(--spacing-8);
        margin-bottom: var(--spacing-12);
    }

    .actus-header .section-title {
        text-align: left;
    }

    .actus-header .section-description {
        text-align: left;
        margin-left: auto;
        margin-right: auto;
    }

    .actus-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }

    .actus-card-image {
        height: 250px;
    }

    .actus-card-large .actus-card-image {
        height: 300px;
    }

    .actus-card-title {
        font-size: 20px;
    }

    .actus-card-description {
        font-size: 15px;
    }
}

@media (max-width: 480px) {
    .actus {
        padding: var(--spacing-12) 0;
    }

    .actus-header {
        gap: var(--spacing-6);
        margin-bottom: var(--spacing-10);
    }

    .actus-header .section-title {
        font-size: clamp(32px, 8vw, 52px);
    }

    .actus-header .section-description {
        font-size: 15px;
    }

    .actus-grid {
        gap: var(--spacing-5);
    }

    .actus-card-column {
        gap: var(--spacing-5);
    }

    .actus-card-image {
        height: 200px;
    }

    .actus-card-large .actus-card-image {
        height: 250px;
    }

    .actus-card-content {
        padding: var(--spacing-5);
        gap: var(--spacing-3);
    }

    .actus-card-meta {
        font-size: 13px;
    }

    .actus-card-title {
        font-size: 18px;
    }

    .actus-card-description {
        font-size: 14px;
    }

    .actus-tag {
        padding: 6px 12px;
        font-size: 12px;
    }

    .actus-card-link {
        font-size: 14px;
    }
}

/* ============================================
   Newsletter Section
   ============================================ */

.newsletter-section {
    background: var(--color-green);
    padding: var(--spacing-20) 0;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}

.newsletter-section .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-12);
}

.newsletter-content {
    flex: 1;
    margin-bottom: 20px;
}

.newsletter-title {
    font-size: 54px;
    font-weight: 500;
    font-family: 'Monigue', sans-serif;
    color: var(--color-white);
    line-height: 1;
    margin: 0 0 var(--spacing-4) 0;
    text-transform: uppercase;
}

.newsletter-description {
    font-size: 18px;
    color: var(--color-white);
    margin: 0;
    line-height: 1.5;
}

.newsletter-form {
    display: flex;
    gap: 0;
    background: var(--color-white);
    border-radius: var(--radius-full);
    max-width: 500px;
}

.newsletter-input {
    flex: 1;
    padding: var(--spacing-4) var(--spacing-6);
    border: none;
    border-radius: var(--radius-full) 0 0 var(--radius-full);
    font-size: 16px;
    font-family: 'DM Sans', sans-serif;
    outline: none;
}

.newsletter-input::placeholder {
    color: var(--color-gray);
}

.newsletter-button {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-4) var(--spacing-6);
    background: var(--color-black);
    color: var(--color-white);
    border: none;
    margin: var(--spacing-2);
    border-radius: var(--radius-full);
    font-size: 16px;
    font-weight: 600;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    transition: gap 0.3s ease;
}

.newsletter-button svg {
    width: 20px;
    height: 20px;
    rotate: -45deg;
}


/* Responsive */
@media (max-width: 1024px) {
    .newsletter-section .container {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: var(--spacing-8);
    }

    .newsletter-title {
        font-size: 50px;
    }

    .newsletter-description {
        font-size: 17px;
    }

    .newsletter-form {
        max-width: 600px;
        width: 100%;
    }
}

@media (max-width: 768px) {
    .newsletter-section {
        padding: var(--spacing-16) 0;
    }

    .newsletter-title {
        text-align: left;
        font-size: 42px;
        margin-left: var(--spacing-2);
        line-height: 1.1;
    }

    .newsletter-description {
        text-align: left;
        margin-left: var(--spacing-2);
        font-size: 16px;
    }

    .newsletter-form {
        max-width: 100%;
    }

    .newsletter-input {
        font-size: 15px;
        padding: var(--spacing-3) var(--spacing-5);
    }

    .newsletter-button {
        font-size: 15px;
        padding: var(--spacing-3) var(--spacing-5);
    }
}

@media (max-width: 480px) {
    .newsletter-section {
        padding: var(--spacing-16) var(--spacing-4) var(--spacing-20) var(--spacing-4);
    }

    .newsletter-title {
        font-size: 38px;
        margin-right: var(--spacing-16);
    }

    .newsletter-description {
        font-size: 14px;
    }

    .newsletter-form {
        max-width: 100%;
    }

    .newsletter-input {
        font-size: 14px;
        padding: var(--spacing-3) var(--spacing-4);
    }

    .newsletter-button {
        font-size: 13px;
        padding: var(--spacing-3) var(--spacing-4);
        white-space: nowrap;
    }

    .newsletter-button svg {
        width: 16px;
        height: 16px;
    }
}

/* ============================================
   Footer
   ============================================ */

.footer {
    background: #1a1a1a;
    color: var(--color-white);
    padding: var(--spacing-16) 0 var(--spacing-8) 0;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    z-index: 2;
    margin-top: -30px;
}

.footer-top {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-12);
    padding-bottom: var(--spacing-12);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    margin-bottom: var(--spacing-8);
}

.footer-brand {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.footer-logo {
    height: 40px;
    width: auto;
}

.footer-columns {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-16);
}

.footer-column-title {
    font-size: 16px;
    font-weight: 600;
    font-family: 'DM Sans', sans-serif;
    color: var(--color-white);
    margin: 0 0 var(--spacing-4) 0;
}

.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.footer-links a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 14px;
    transition: color 0.3s ease;
}

.footer-links a:hover {
    color: var(--color-white);
}

.footer-bottom {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding-top: var(--spacing-6);
    gap: var(--spacing-8);
}

.footer-copyright {
    color: rgba(255, 255, 255, 0.5);
    font-size: 14px;
    justify-self: flex-start;
}

.footer-legal {
    display: flex;
    gap: var(--spacing-6);
    justify-self: center;
}

.footer-legal a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 14px;
    transition: color 0.3s ease;
}

.footer-legal a:hover {
    color: var(--color-white);
}

.footer-bottom-right {
    display: flex;
    gap: var(--spacing-4);
    justify-self: flex-end;
}

.footer-social {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    border-radius: var(--radius-md);
    color: var(--color-white);
    text-decoration: none;
    transition: background 0.3s ease;
}

.footer-social:hover {
    background: rgba(255, 255, 255, 0.2);
}

/* Responsive */
@media (max-width: 1024px) {
    .footer-columns {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .footer {
        padding: var(--spacing-12) 0 var(--spacing-6) 0;
    }

    .footer-columns {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }

    .footer-bottom {
        grid-template-columns: 1fr;
        gap: var(--spacing-6);
    }

    .footer-copyright,
    .footer-legal,
    .footer-bottom-right {
        justify-self: flex-start;
    }

    .footer-legal {
        flex-direction: column;
        gap: var(--spacing-3);
    }
}

@media (max-width: 480px) {
    .footer-logo {
        height: 32px;
    }

    .footer-column-title {
        font-size: 14px;
    }

    .footer-links a,
    .footer-legal a {
        font-size: 13px;
    }
}

/* ==========================================
   FEATURE DETAIL PAGE
   ========================================== */
.hero-feature-detail {
    background: var(--color-white);
    padding: 200px 0;
    position: relative;
    overflow: visible;
    width: 100%;
}

.hero-feature-detail::before {
    content: '';
    position: absolute;
    top: 50%;
    right: 0;
    transform: translate(0%, -50%);
    width: 1100px;
    height: 1100px;
    background-image: url('./assets/commun/Brandmark-logo-black.svg');
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.03;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}
/* Hero Section */
.feature-detail-hero {
    background: var(--color-white);
    padding: var(--spacing-24) 0 var(--spacing-16) 0;
    position: relative;
}

.feature-detail-hero-title {
    font-size: clamp(48px, 8vw, 90px);
    font-weight: 500;
    line-height: 0.9;
    font-family: 'Monigue';
    color: var(--color-black);
    text-transform: uppercase;
    margin: 0 0 var(--spacing-6) 0;
}

.feature-detail-hero-description {
    font-size: 18px;
    line-height: 1.6;
    color: var(--color-black);
    margin: 0 0 var(--spacing-8) 0;
}

/* Feature Detail Sections */
.feature-detail-section {
    /* background: var(--color-white); */
    padding: var(--spacing-16) 0;
    position: relative;
}

.feature-detail-section-reverse {
    background: #F9FAFB;
}

.feature-detail-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-16);
    align-items: center;
    justify-content: center;
    display: flex;
}

.feature-detail-section-reverse .feature-detail-row {
    direction: rtl;
}

.feature-detail-section-reverse .feature-detail-content {
    direction: ltr;
}

.feature-detail-image {
    width: 100%;
    max-width: 450px;
    border-radius: var(--radius-img);
    overflow: hidden;
}

.feature-detail-image img {
    width: 100%;
    height: auto;
    display: block;
}

.feature-detail-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-4);
}

.feature-detail-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.feature-detail-icon img {
    width: 100%;
    height: 100%;
}

.feature-detail-title {
    font-size: clamp(28px, 8vw, 42px);
    font-weight: 500;
    line-height: 1.2;
    color: var(--color-black);
    margin: 0;
    text-transform: uppercase;
}

.feature-detail-description {
    font-size: 18px;
    line-height: 1.6;
    color: var(--color-black);
    margin: 0;
}

/* Other Features Section */
.other-features {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
    position: relative;
}

.other-features-header {
    text-align: center;
    max-width: 1000px;
    margin: 0 auto var(--spacing-16) auto;
}

.other-features-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-8);
    margin-bottom: var(--spacing-10);
}

.other-feature-card {
    /* background: #F9FAFB; */
    border-radius: var(--radius-xl);
    /* padding: var(--spacing-6); */
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

.other-feature-image {
    width: 100%;
    border-radius: var(--radius-img);
    overflow: hidden;
    margin-bottom: var(--spacing-2);
}

.other-feature-image img {
    width: 100%;
    height: auto;
    display: block;
}

.other-feature-title {
    font-size: 24px;
    font-weight: 600;
    line-height: 1.2;
    color: var(--color-black);
    margin: 0;
    margin-bottom: -7px;
}

.other-feature-description {
    font-size: 18px;
    line-height: 1.5;
    color: var(--color-black);
    margin: 0;
    flex: 1;
}

.other-feature-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 16px;
    font-weight: 600;
    color: var(--color-black);
    text-decoration: none;
    transition: color 0.3s ease;
}

.other-feature-link:hover {
    color: var(--color-primary);
}

.other-feature-link svg {
    width: 20px;
    height: 20px;
    transition: transform 0.3s ease;
}

.other-feature-link:hover svg {
    transform: translateX(4px);
}

.other-features-cta {
    display: flex;
    justify-content: center;
    margin-top: var(--spacing-10);
}

/* Responsive - Feature Detail Page */
@media (max-width: 1024px) {
    .feature-detail-row {
        flex-direction: column;
        grid-template-columns: 1fr !important;
        gap: var(--spacing-8);
    }
    .reverse {
        flex-direction: column-reverse;
    }
    .hero-feature-detail::before {
        width: 800px;
        height: 800px;
    }

    .feature-detail-section-reverse .feature-detail-row {
        direction: ltr;
    }

    .other-features-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .feature-detail-description {
        max-width: 400px;
    }
}

@media (max-width: 868px) {
    .feature-detail-hero-title {
        font-size: clamp(46px, 6vw, 58px);
    }
    .hero-feature-detail::before {
        width: 500px;
        height: 500px;
    }
    .feature-detail-hero-description {
        font-size: 16px;
    }

    .feature-detail-title {
        font-size: 34px;
    }

    .feature-detail-description {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .feature-detail-hero {
        padding: var(--spacing-16) 0 var(--spacing-12) 0;
    }

    .hero-feature-detail::before {
        top: 40%;
        width: 300px;
        height: 300px;
    }
    .feature-detail-section {
        padding: var(--spacing-12) 0;
    }

    .other-features {
        padding: var(--spacing-16) 0;
    }

    .other-features-grid {
        grid-template-columns: 1fr;
    }

    .feature-detail-title {
        font-size: 28px;
    }
}
/* ==========================================
   PRICING SECTION
   ========================================== */

/* Pricing Hero Section */
.pricing-hero {
    padding: 120px 0 var(--spacing-20);
    background: var(--color-white);
}

.pricing-hero-content {
    text-align: center;
    margin-bottom: var(--spacing-16);
}

.pricing-badge {
    display: inline-block;
    padding: var(--spacing-2) var(--spacing-6);
    background: rgba(0, 0, 0, 0.05);
    border-radius: var(--radius-full);
    font-size: 14px;
    font-weight: 500;
    margin-bottom: var(--spacing-6);
    color: var(--color-black);
}

.pricing-title {
    font-family: var(--font-display);
    font-size: 80px;
    font-weight: 700;
    line-height: 1.1;
    margin-bottom: var(--spacing-6);
    letter-spacing: -2px;
    text-transform: uppercase;
}

.pricing-title .title-green {
    color: #00D084;
}

.pricing-description {
    font-size: 18px;
    line-height: 1.6;
    color: var(--color-gray);
    max-width: 800px;
    margin: 0 auto;
}

/* Recommended Button */
.recommended-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2);
    padding: 10px var(--spacing-4);
    background: var(--color-green-black);
    color: var(--color-white);
    border-radius: var(--radius-md);
    width: 100%;
    font-size: 15px;
    font-weight: 500;
    margin-bottom: 14px;
}

.recommended-btn svg {
    width: 16px;
    height: 16px;
}

/* Pricing Grid */
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-6);
    align-items: flex-end;
}

.pricing-card {
    background: var(--color-white);
    border-radius: var(--radius-2xl);
    padding: 14px;
    position: relative;
    display: flex;
    flex-direction: column;
    /* border: 3px solid transparent; */
    transition: var(--transition-base);
    box-shadow: 0 25px 31.25px -6.25px rgba(0, 0, 0, 0.10), 0 12.5px 12.5px 0 rgba(0, 0, 0, 0.04);
}

.pricing-card.featured {
    background: var(--color-green);
    /* transform: scale(1.02); */
    box-shadow: 0 8px 32px rgba(0, 209, 132, 0.25);
}

.pricing-card-header {
    display: flex;
    align-items: flex-start;
    padding: var(--spacing-8) var(--spacing-16) var(--spacing-8) var(--spacing-8);
    background-color: var(--color-gray-light);
    border-radius: var(--radius-lg);
    justify-content: center;
    flex-direction: column;
}

.pricing-plan-name {
    font-family: var(--font-secondary);
    font-size: clamp(46px, 6vw, 78px);
    font-weight: 500;
    line-height: normal;
    line-height: 1;
    text-transform: uppercase;
}

.pricing-plan-subtitle {
    font-size: clamp(16px, 6vw, 18px);
}

.pricing-card.featured .pricing-plan-subtitle {
    color: var(--color-green-black);
}

.pricing-price-wrapper {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
}

.pricing-price {
    margin-bottom: var(--spacing-3);
}



.pricing-amount {
    color: var(--color-black);
    font-size: 75px;
    font-style: normal;
    font-weight: 1000;
    line-height: 150%;
    letter-spacing: -4px;
    font-family: var(--font-base);
    display: flex;
    align-items: baseline;
    gap: var(--spacing-1);
}

.pricing-period {
    margin-top: var(--spacing-6);
    padding: var(--spacing-1) var(--spacing-3);
    background: var(--color-black);
    color: var(--color-white);
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
}

.pricing-billing {
    margin-top: -16px;
    font-size: 16px;
    color: var(--color-black);
}

.pricing-features {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-8) 0;
}

.pricing-feature {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-3);
    margin-bottom: var(--spacing-2);
    font-size: 16px;
    line-height: 1.5;
}

.pricing-feature-icon {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--color-green);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
}

.pricing-card.featured .pricing-feature-icon {
    background: var(--color-white);
}

.pricing-feature-icon svg {
    width: 12px;
    height: 12px;
    color: var(--color-white);
}

.pricing-card.featured .pricing-feature-icon svg {
    color: var(--color-green);
}

.pricing-feature-icon.disabled {
    background: var(--color-red);
}

.pricing-feature-icon.disabled svg {
    color: var(--color-white);
}

.pricing-feature-badge {
    display: inline-block;
    padding: 5px 5px 1px 5px;
    background: var(--color-black);
    color: var(--color-white);
    border-radius: 4px;
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 500;
    line-height: 0.8;
    margin: var(--spacing-1);
    text-transform: uppercase;
}

.pricing-feature-badge.annual {
    background: var(--color-beige);
    color: var(--color-green-black);
}

.pricing-feature-badge.semestrial {
    background: var(--color-green);
    color: var(--color-white);
}

.pricing-cta {
    width: 100%;
}

.pricing-cta-btn {
    width: 100%;
    padding: var(--spacing-4) var(--spacing-6);
    background: var(--color-white);
    border: 1px solid var(--color-green-black);
    border-radius: var(--radius-lg);
    font-size: 16px;
    font-weight: 600;
    color: var(--color-black);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: var(--transition-base);
}

.pricing-cta-btn:hover {
    background: var(--color-black);
    color: var(--color-white);
}

.pricing-card.featured .pricing-cta-btn {
    border-color: var(--color-green);
}

.pricing-card.featured .pricing-cta-btn:hover {
    background: #003d2f;
}

.pricing-cta-btn svg {
    width: 20px;
    height: 20px;
}

.pricing-compare {
    text-align: center;
    margin-top: var(--spacing-10);
}

.pricing-compare-text {
    font-size: 16px;
    color: var(--color-gray);
    margin-bottom: var(--spacing-5);
}

.pricing-compare-btn {
    display: inline-flex;
    align-items: center;
    /* gap: var(--spacing-3); */
    padding: var(--spacing-4) var(--spacing-8);
    background: var(--color-white);
    border: 1px solid var(--color-black);
    border-radius: var(--radius-lg);
    font-size: 16px;
    font-weight: 600;
    color: var(--color-black);
    cursor: pointer;
    transition: var(--transition-base);
}

.pricing-compare-btn:hover {
    background: var(--color-black);
    color: var(--color-white);
}

/* Responsive */
@media (max-width: 1024px) {
    .pricing-grid {
        grid-template-columns: 1fr;
        max-width: 500px;
        gap: 20px;
        margin: 0 auto var(--spacing-10);
    }

    .pricing-card.featured {
        transform: scale(1);
    }

    .pricing-title {
        font-size: 78px;
    }

}

@media (max-width: 768px) {

    .pricing-title {
        font-size: 46px;
    }


    .pricing-plan-name {
        font-size: 80px;
        
    }

    .pricing-card.featured {
        border-width: 6px;
    }
}
/* ==========================================
   PRICING COMPARISON TABLE
   ========================================== */

.pricing-comparison {
    padding: 0 var(--spacing-24) var(--spacing-24) var(--spacing-24);
    background: var(--color-white);
    display: block; /* Caché par défaut */
}

.pricing-comparison-header {
    text-align: left;
    border-right: 1px solid var(--color-gray-border);
    /* margin-bottom: var(--spacing-16); */
}

.pricing-comparison-title {
    font-family: var(--font-display);
    font-size: 56px;
    font-weight: 500;
    line-height: 0.8;
    margin-bottom: var(--spacing-4);
    text-transform: uppercase;
}

.pricing-comparison-description {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-gray);
}

.pricing-comparison-table {
    background: var(--color-white);
    overflow: hidden;
}

/* Header Row */
.comparison-header-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 0;
    background: var(--color-white);
    padding: var(--spacing-8) 0 0 0;
    border-bottom: 1px solid var(--color-gray-border);
}

.comparison-header-cell {
    padding: var(--spacing-6);
    text-align: left;
}

.comparison-header-cell:first-child {
    text-align: left;
}

.comparison-plan-name {
    font-family: var(--font-secondary);
    font-size: 52px;
    line-height: 1.5;
    font-weight: 500;
    text-transform: uppercase;
}

.comparison-price {
    font-family: var(--font-base);
    font-size: 28px;
    display: flex;
    align-items: center;
    font-weight: 1000;
}

.comparison-period {
    font-size: 12px;
    margin-bottom: 5px;
    font-weight: 400;
    font-family: var(--font-base);
}

.comparison-cta-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-6);
    background: var(--color-green);
    color: var(--color-white);
    border-radius: var(--radius-lg);
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: var(--transition-base);
}

.comparison-cta-btn:hover {
    background: var(--color-dark-green);
}

.comparison-cta-btn svg {
    width: 16px;
    height: 16px;
}

/* Category Row */
.comparison-category {
    /* display: block; */
    padding: var(--spacing-4) var(--spacing-6);
    background: var(--color-gray-background-tertiary);
    font-size: 14px;
    font-weight: 600;
    color: var(--color-black);
    /* border-top: 1px solid red; */
}

/* Feature Rows */
.comparison-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 0;
    border-top: 1px solid var(--color-gray-border);
}

.comparison-feature-cell {
    padding: var(--spacing-5) var(--spacing-6);
    font-size: 15px;
    line-height: 1.5;
    border-right: 1px solid var(--color-gray-border);
    color: var(--color-black);
}

.comparison-check-cell {
    padding: var(--spacing-5) var(--spacing-4);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2);
}

.check-icon,
.cross-icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

.comparison-info {
    font-size: 14px;
    color: var(--color-black);
    text-align: center;
}

/* Responsive */
@media (max-width: 1024px) {
    .comparison-header-row,
    .comparison-row {
        grid-template-columns: 1.5fr 1fr 1fr 1fr;
    }

    .comparison-plan-name {
        font-size: 24px;
    }

    .comparison-price {
        font-size: 20px;
    }

    .comparison-feature-cell {
        font-size: 14px;
        padding: var(--spacing-4);
    }
}

@media (max-width: 768px) {
    .pricing-comparison {
        padding: var(--spacing-16) 0;
    }

    .pricing-comparison-title {
        font-size: 36px;
    }

    .pricing-comparison-table {
        overflow-x: auto;
    }

    .comparison-header-row,
    .comparison-row {
        min-width: 600px;
    }

    .comparison-plan-name {
        font-size: 20px;
    }

    .comparison-price {
        font-size: 18px;
    }

    .comparison-cta-btn {
        padding: var(--spacing-2) var(--spacing-4);
        font-size: 12px;
    }
}

/* ==========================================
   FAQ TABS PAGE (faq.html)
   ========================================== */
.hero-faq::before {
    content: '';
    position: absolute;
    top: -100px;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: calc(100% + 100px);
    background-image: url('./assets/hero-section/Brandmark.svg');
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.93;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}
/* Hero Section */
.hero-faq {
    background: var(--color-white);
    padding: var(--spacing-24) 0 var(--spacing-16) 0;
    position: relative;
}

.faq-tabs-section {
    background: var(--color-white);
    padding: 0;
}

.faq-tabs-wrapper {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: var(--spacing-10);
}

/* FAQ Tabs Navigation */
.faq-tabs-nav {
    background: var(--color-gray-background-secondary);
    border: 1px solid var(--color-gray-background);
    border-radius: var(--radius-2xl);
    padding: var(--spacing-5);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
    height: fit-content;
    position: sticky;
    top: 100px;
}

.faq-tab-btn {
    padding: var(--spacing-3) var(--spacing-4);
    background: transparent;
    border: none;
    border-radius: var(--radius-lg);
    font-size: 16px;
    font-weight: 500;
    font-family: 'DM Sans', sans-serif;
    color: var(--color-black);
    text-align: left;
    cursor: pointer;
    transition: all 0.3s ease;
}

.faq-tab-btn:hover {
    background: var(--color-green-border);
}

.faq-tab-btn.active {
    border: 1px solid var(--color-green-border);
    background: var(--color-green-light);
    color: var(--color-green-black);
    font-weight: 600;
}

/* FAQ Tabs Content */
.faq-tabs-content {
    min-height: 600px;
}

.faq-tab-content {
    display: none;
}

.faq-tab-content.active {
    display: block;
}

.faq-tab-title {
    font-size: 32px;
    font-weight: 600;
    font-family: var(--font-base);
    color: var(--color-black);
    text-transform: uppercase;
    margin: 0 0 var(--spacing-8) 0;
}

/* FAQ Accordion List */
.faq-accordion-list {
    display: flex;
    flex-direction: column;
}

.faq-accordion-item {
    border-bottom: 1px solid #E5E7EB;
}

.faq-accordion-item:first-child {
    border-top: 1px solid #E5E7EB;
}

.faq-accordion-question {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-6) 0;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: all 0.3s ease;
}

.faq-accordion-question:hover {
    opacity: 0.8;
}

.faq-accordion-question span {
    font-size: 20px;
    font-weight: 500;
    font-family: 'DM Sans', sans-serif;
    color: var(--color-black);
    line-height: 1.4;
    flex: 1;
    padding-right: var(--spacing-4);
}

.faq-accordion-icon {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    transition: all 0.3s ease;
    color: var(--color-black);
}

.faq-accordion-icon path {
    transition: d 0.3s ease;
}

.faq-accordion-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, padding 0.4s ease;
    padding: 0;
}

.faq-accordion-answer.active {
    max-height: 600px;
    padding: 0 0 var(--spacing-6) 0;
}

.faq-accordion-answer p {
    font-size: 17px;
    line-height: 1.7;
    color: #4B5563;
    margin: 0;
    padding-right: 48px;
}

/* Responsive */
@media (max-width: 1024px) {
    .faq-tabs-wrapper {
        grid-template-columns: 1fr;
        gap: var(--spacing-8);
    }

    .faq-tabs-nav {
        position: static;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-2);
        padding: var(--spacing-4);
    }

    .faq-tab-btn {
        font-size: 14px;
        padding: var(--spacing-3);
        text-align: center;
    }

    .faq-tab-title {
        font-size: 28px;
        margin-bottom: var(--spacing-6);
    }

    .faq-accordion-question span {
        font-size: 18px;
    }

    .faq-accordion-answer p {
        font-size: 16px;
        padding-right: 0;
    }
}

@media (max-width: 480px) {
    .faq-tabs-section {
        padding: var(--spacing-12) 0 var(--spacing-16) 0;
    }

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

    .faq-tab-title {
        font-size: 24px;
    }

    .faq-accordion-question {
        padding: var(--spacing-5) 0;
    }

    .faq-accordion-question span {
        font-size: 16px;
    }

    .faq-accordion-icon {
        width: 24px;
        height: 24px;
    }

    .faq-accordion-answer p {
        font-size: 15px;
    }
}

/* ==========================================
   HERO PARALLAX (partenaire.html)
   ========================================== */

.hero-parallax-wrapper {
    position: relative;
    width: 100%;
    margin-top: var(--spacing-16);
    min-height: 600px;
}

.hero-main-image {
    width: 100%;
    max-width: 800px;
    height: auto;
    display: block;
    position: relative;
    z-index: 1;
}

.parallax-element {
    position: absolute;
    z-index: 2;
    transition: transform 0.3s ease-out;
    will-change: transform;
}

.parallax-element img {
    width: 100%;
    height: auto;
    display: block;
    filter: drop-shadow(0 10px 30px rgba(0, 0, 0, 0.15));
}

/* Left Card Positioning (BackMarket) */
.parallax-card-left {
    top: 10%;
    left: -12%;
    width: 300px;
    z-index: 3;
}

/* Right Card Positioning (Alan) */
.parallax-card-right {
    bottom: 5%;
    right: -2%;
    width: 280px;
    z-index: 3;
}

/* Plus Button Positioning */
.parallax-plus-btn {
    top: -3%;
    right: 5%;
    width: 80px;
    z-index: 4;
}

/* Hand Clicking Positioning */
.parallax-hand {
    top: 12%;
    right: 2%;
    width: 80px;
    z-index: 5;
    pointer-events: none;
}

/* Responsive */
@media (max-width: 1024px) {
    .hero-parallax-wrapper {
        min-height: 500px;
    }

    .parallax-card-left {
        width: 240px;
        top: 8%;
        left: -4%;
    }

    .parallax-card-right {
        width: 220px;
        bottom: 4%;
        right: -1%;
    }

    .parallax-plus-btn {
        width: 65px;
        top: -2%;
        right: 4%;
    }

    .parallax-hand {
        width: 70px;
        top: 13.5%;
        right: -2.5%;
    }
}

@media (max-width: 768px) {
    .hero-parallax-wrapper {
        min-height: 400px;
    }

    .parallax-card-left {
        width: 200px;
        top: 6%;
        left: -3%;
    }

    .parallax-card-right {
        width: 180px;
        bottom: 3%;
        right: -2%;
    }

    .parallax-plus-btn {
        width: 50px;
        top: -1%;
        right: 3%;
    }

    .parallax-hand {
        width: 60px;
        top: 11%;
        right: -3.5%;
    }
}

@media (max-width: 480px) {
    .hero-parallax-wrapper {
        min-height: 300px;
    }

    .parallax-card-left {
        width: 150px;
        top: 4%;
        left: -3%;
    }

    .parallax-card-right {
        width: 140px;
        bottom: 2%;
        right: -1%;
    }

    .parallax-plus-btn {
        width: 40px;
        top: 0%;
        right: 2%;
    }

    .parallax-hand {
        width: 45px;
        top: 15%;
        right: -3%;
    }
}


/* ==========================================
   HERO PARALLAX POUR QUI (pour-qui.html)
   ========================================== */

/* Top Left Card Positioning (Social) */
.parallax-top-left {
    top: 8%;
    left: -2%;
    width: 240px;
    z-index: 3;
}

/* Bottom Left Card Positioning (Environnement) */
.parallax-bottom-left {
    bottom: 10%;
    left: -5%;
    width: 250px;
    z-index: 3;
}

/* Bottom Right ard Positioning (Gouvernance) */
.parallax-bottom-right {
    bottom: 8%;
    right: 3%;
    width: 250px;
    z-index: 3;
}

/* Responsive for Pour Qui page */
@media (max-width: 1024px) {
    .parallax-top-left {
        width: 190px;
        top: 6%;
        left: -1%;
    }

    .parallax-bottom-left {
        width: 200px;
        bottom: 8%;
        left: -3%;
    }

    .parallax-bottom-right {
        width: 200px;
        bottom: 6%;
        right: -2%;
    }
}

@media (max-width: 768px) {
    .parallax-top-left {
        width: 150px;
        top: 5%;
        left: -2%;
    }

    .parallax-bottom-left {
        width: 160px;
        bottom: 6%;
        left: -2%;
    }

    .parallax-bottom-right {
        width: 160px;
        bottom: 5%;
        right: -1%;
    }
}

@media (max-width: 480px) {
    .parallax-top-left {
        width: 110px;
        top: 3%;
        left: 0%;
    }

    .parallax-bottom-left {
        width: 120px;
        bottom: 4%;
        left: -1%;
    }

    .parallax-bottom-right {
        width: 120px;
        bottom: 3%;
        right: -2%;
    }
}

/* ==========================================
   CONTACT PAGE
   ========================================== */

.contact-page {
    margin: 0;
    padding: 0;
    overflow-x: clip;
}

.contact-section {
    min-height: 100vh;
    background-color: var(--color-black-background);
    overflow: visible;
}

.contact-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    height: 100vh;
    overflow: hidden;
}

/* Left Side - Form */
.contact-form-wrapper {
    background-color: white;
    padding: var(--spacing-6) var(--spacing-8);
    margin: var(--spacing-4);
    display: flex;
    flex-direction: column;
    border-radius: 24px;
    height: calc(100vh - var(--spacing-8));
    overflow-y: auto;
    overflow-x: hidden;
}

/* Hide scrollbar for form wrapper */
.contact-form-wrapper::-webkit-scrollbar {
    display: none;
}

.contact-form-wrapper {
    -ms-overflow-style: none;  /* IE and Edge */
    scrollbar-width: none;  /* Firefox */
}

.contact-back-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-black);
    text-decoration: none;
    margin-bottom: var(--spacing-6);
    transition: opacity 0.3s ease;
}

.contact-back-link:hover {
    opacity: 0.7;
}

.contact-back-link svg {
    width: 20px;
    height: 20px;
}

.contact-form-content {
    max-width: 100%;
}

.contact-title {
    font-family: var(--font-secondary);
    font-size: 66px;
    font-weight: 600;
    line-height: 1;
    margin: var(--spacing-6) 0 var(--spacing-6) 0;
    text-transform: uppercase;
    /* letter-spacing: -0.02em; */
}

.contact-description {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-black);
    margin: 0 0 var(--spacing-10) 0;
}

/* HubSpot Form Styles */
#hubspot-form-container {
    margin-top: var(--spacing-4);
    width: 100%;
}

#hubspot-form-container .hs-form {
    font-family: var(--font-primary);
}

#hubspot-form-container .hs-form-field {
    margin-bottom: var(--spacing-4);
}

#hubspot-form-container label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-black);
    margin-bottom: 0;
}

#hubspot-form-container label .hs-form-required {
    color: var(--color-primary);
}

#hubspot-form-container input[type="text"],
#hubspot-form-container input[type="email"],
#hubspot-form-container input[type="tel"],
#hubspot-form-container textarea,
#hubspot-form-container select {
    width: 100%;
    padding: var(--spacing-3) var(--spacing-4);
    border: 1px solid #E0E0E0;
    border-radius: 0px;
    font-size: 16px;
    font-family: var(--font-base);
    background-color: white;
    transition: border-color 0.3s ease;
}

#hubspot-form-container input:focus,
#hubspot-form-container textarea:focus,
#hubspot-form-container select:focus {
    outline: none;
    border-color: var(--color-primary);
}

#hubspot-form-container textarea {
    min-height: 120px;
    resize: vertical;
}

#hubspot-form-container .hs-input[type="checkbox"] {
    width: auto;
    margin-right: var(--spacing-2);
}

#hubspot-form-container .hs-form-booleancheckbox {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-2);
}

#hubspot-form-container .hs-form-booleancheckbox label {
    margin: 0;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.5;
}

#hubspot-form-container .hs-form-booleancheckbox a {
    color: var(--color-primary);
    text-decoration: none;
}

#hubspot-form-container .hs-form-booleancheckbox a:hover {
    text-decoration: underline;
}

#hubspot-form-container .hs-button {
    width: 200%;
    padding: var(--spacing-4) var(--spacing-6);
    background-color: var(--color-black);
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    font-family: var(--font-primary);
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: var(--spacing-4);
}

#hubspot-form-container .hs-button:hover {
    background-color: red;
    transform: translateY(-1px);
}

#hubspot-form-container .hs-error-msgs {
    list-style: none;
    padding: 0;
    margin: var(--spacing-2) 0 0 0;
}

#hubspot-form-container .hs-error-msg {
    color: #E53E3E;
    font-size: 13px;
}

/* Two Column Layout for Form Fields */
#hubspot-form-container .hs-form-field {
    margin-bottom: var(--spacing-4);
}

/* First row: Prénom + Nom */
#hubspot-form-container .hs-form-field:has([name="firstname"]),
#hubspot-form-container .hs-form-field:has([name="lastname"]) {
    display: inline-block;
    width: calc(50% - 8px);
    vertical-align: top;
}

#hubspot-form-container .hs-form-field:has([name="firstname"]) {
    margin-right: 16px;
}

/* Second row: Entreprise + Téléphone */
#hubspot-form-container .hs-form-field:has([name="company"]),
#hubspot-form-container .hs-form-field:has([name="phone"]) {
    display: inline-block;
    width: calc(50% - 8px);
    vertical-align: top;
}

#hubspot-form-container .hs-form-field:has([name="company"]) {
    margin-right: 16px;
}

/* Third row: Email + Source */
#hubspot-form-container .hs-form-field:has([name="email"]),
#hubspot-form-container .hs-form-field:has([name="how_did_you_hear_about_us_"]) {
    display: inline-block;
    width: calc(50% - 8px);
    vertical-align: top;
}

#hubspot-form-container .hs-form-field:has([name="email"]) {
    margin-right: 16px;
}

/* Alternative pour les navigateurs sans support :has() */
@supports not (selector(:has(*))) {
    #hubspot-form-container .hs-form-field:nth-child(1),
    #hubspot-form-container .hs-form-field:nth-child(2) {
        display: inline-block;
        width: calc(50% - 8px);
        vertical-align: top;
    }

    #hubspot-form-container .hs-form-field:nth-child(1) {
        margin-right: 16px;
    }

    #hubspot-form-container .hs-form-field:nth-child(3),
    #hubspot-form-container .hs-form-field:nth-child(4) {
        display: inline-block;
        width: calc(50% - 8px);
        vertical-align: top;
    }

    #hubspot-form-container .hs-form-field:nth-child(3) {
        margin-right: 16px;
    }

    #hubspot-form-container .hs-form-field:nth-child(5),
    #hubspot-form-container .hs-form-field:nth-child(6) {
        display: inline-block;
        width: calc(50% - 8px);
        vertical-align: top;
    }

    #hubspot-form-container .hs-form-field:nth-child(5) {
        margin-right: 16px;
    }
}

/* Right Side - Hero */
.contact-hero {
    background-color: var(--color-black-background);
    padding: var(--spacing-8) var(--spacing-10);
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    height: 100vh;
    overflow: hidden;
    position: relative;
}

.contact-hero-content {
    max-width: 900px;
    width: 100%;
}

.contact-hero-title {
    font-family: var(--font-secondary);
    font-size: 84px;
    font-weight: 600;
    line-height: 1.1;
    color: white;
    margin: 0 0 var(--spacing-4) 0;
    text-transform: uppercase;
}

.contact-hero-description {
    font-size: 16px;
    line-height: 1.6;
    color: white;
    margin: 0 0 var(--spacing-8) 0;
    max-width: 600px;
}

/* Partner Cards Carousel - Stacked Effect */
.contact-partner-cards-wrapper {
    position: relative;
    width: 100%;
    max-width: 600px;
}

.contact-carousel {
    position: relative;
    width: 100%;
    overflow: visible;
}

.contact-carousel-track {
    position: relative;
    width: 100%;
    height: 450px;
    overflow: visible;
}

.contact-carousel-slide {
    position: absolute;
    width: 350px;
    height: auto;
    border-radius: 16px;
    transition: all 0.5s ease;
    left: calc(50% - 160px);
    top: 20px;
    /* opacity: 0.6; */
    /* box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3); */
}

/* Carousel Dots */
.contact-carousel-dots {
    position: absolute;
    bottom: 24px;
    left: 24px;
    display: flex;
    gap: 8px;
    z-index: 10;
}

.contact-carousel-dot {
    width: 32px;
    height: 8px;
    border-radius: 3px;
    border: none;
    background-color: rgba(255, 255, 255, 0.777);
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 0;
}

.contact-carousel-dot:hover {
    background-color: rgba(0, 216, 102, 0.7);
}

.contact-carousel-dot.active {
    background-color: var(--color-green);
    width: 32px;
}

.contact-partner-brandmark {
    position: absolute;
    bottom: 0px;
    right: 0px;
    width: 300px;
    height: auto;
    z-index: 4;
    pointer-events: none;
}

/* Responsive Design */
@media (max-width: 1024px) {
    .contact-container {
        grid-template-columns: 1fr;
        height: auto;
        overflow: visible;
        display: flex;
        flex-direction: column;
    }

    /* Reverse order: hero first, form second */
    .contact-hero {
        order: 1;
        padding: var(--spacing-10) var(--spacing-6);
        height: auto;
        overflow: visible;
    }

    .contact-form-wrapper {
        order: 2;
        padding: var(--spacing-8) var(--spacing-6);
        height: auto;
        overflow: visible;
    }

    .contact-title {
        font-size: 40px;
    }

    .contact-hero-title {
        font-size: 48px;
    }
}

@media (max-width: 768px) {
    .contact-title {
        font-size: 36px;
    }

    .contact-hero-title {
        font-size: 40px;
    }

    .contact-carousel-dots {
        bottom: 16px;
        left: 16px;
        gap: 6px;
    }

    .contact-carousel-dot {
        width: 7px;
        height: 7px;
    }

    .contact-carousel-dot.active {
        width: 20px;
    }

    .contact-partner-brandmark {
        width: 40px;
        bottom: 12px;
        right: 12px;
    }

    #hubspot-form-container .hs-form-field:has([name="firstname"]),
    #hubspot-form-container .hs-form-field:has([name="lastname"]),
    #hubspot-form-container .hs-form-field:has([name="company"]),
    #hubspot-form-container .hs-form-field:has([name="phone"]),
    #hubspot-form-container .hs-form-field:has([name="email"]),
    #hubspot-form-container .hs-form-field:has([name="how_did_you_hear_about_us_"]) {
        display: block;
        width: 100%;
        margin-right: 0;
    }
}

@media (max-width: 480px) {
    .contact-title {
        font-size: 32px;
    }

    .contact-hero-title {
        font-size: 32px;
    }

    .contact-description,
    .contact-hero-description {
        font-size: 15px;
    }

    .contact-form-wrapper {
        padding: var(--spacing-6) var(--spacing-4);
    }

    .contact-hero {
        padding: var(--spacing-8) var(--spacing-4);
    }

    .contact-carousel-dots {
        bottom: 12px;
        left: 12px;
        gap: 5px;
    }

    .contact-carousel-dot {
        width: 6px;
        height: 6px;
    }

    .contact-carousel-dot.active {
        width: 18px;
    }

    .contact-partner-brandmark {
        width: 30px;
        bottom: 8px;
        right: 8px;
    }
}

/* ========================================
   Legal Pages (CGU, Privacy Policy, Legal Notice)
   ======================================== */

.legal-page {
    background-color: white;
    min-height: 100vh;
}

.legal-content {
    max-width: 900px;
    margin: 0 auto;
    padding: var(--spacing-12) var(--spacing-6);
}

.legal-header {
    margin-bottom: var(--spacing-10);
    padding-bottom: var(--spacing-6);
    border-bottom: 1px solid var(--color-gray-200);
}

.legal-title {
    font-family: var(--font-secondary);
    font-size: 48px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-3);
    text-transform: uppercase;
}

.legal-subtitle {
    font-size: 16px;
    font-weight: 500;
    color: var(--color-gray-500);
    margin-top: var(--spacing-2);
}

.legal-section {
    margin-bottom: var(--spacing-8);
}

.legal-section-title {
    font-family: var(--font-base);
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-4);
    margin-top: var(--spacing-6);
}

.legal-text {
    font-size: 16px;
    line-height: 1.8;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-4);
}

.legal-text strong {
    color: var(--color-text-primary);
    font-weight: 600;
}

.legal-link {
    color: var(--color-green);
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.legal-link:hover {
    opacity: 0.8;
    text-decoration: underline;
}

.legal-list {
    margin: var(--spacing-4) 0;
    padding-left: var(--spacing-6);
}

.legal-list li {
    font-size: 16px;
    line-height: 1.8;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-2);
}

.legal-divider {
    height: 1px;
    background-color: var(--color-gray-200);
    margin: var(--spacing-8) 0;
}

/* Responsive Legal Pages */
@media (max-width: 768px) {
    .legal-content {
        padding: var(--spacing-8) var(--spacing-4);
    }

    .legal-title {
        font-size: 36px;
    }

    .legal-section-title {
        font-size: 20px;
    }

    .legal-text,
    .legal-list li {
        font-size: 15px;
    }
}

@media (max-width: 480px) {
    .legal-content {
        padding: var(--spacing-6) var(--spacing-3);
    }

    .legal-title {
        font-size: 28px;
    }

    .legal-section-title {
        font-size: 18px;
    }

    .legal-text,
    .legal-list li {
        font-size: 14px;
    }
}
/* ==========================================
   BLOG STYLES
   ========================================== */

/* Blog Container */
.blog-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 80px 24px 120px;
}

/* Featured Article */
.featured-article {
    margin-bottom: 80px;
}

.featured-article-card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.featured-article-image {
    position: relative;
    width: 100%;
    height: 520px;
    border-radius: var(--radius-img);
    overflow: hidden;
    background: var(--color-green-black);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.featured-article-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.featured-article-tags {
    position: absolute;
    top: 24px;
    right: 24px;
    display: flex;
    gap: 12px;
    z-index: 2;
}

.featured-article-content {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.article-date-author {
    font-size: var(--text-sm);
    color: var(--color-gray);
    margin: 0;
}

.featured-article-content h2 {
    font-family: var(--font-base);
    font-size: var(--text-4xl);
    line-height: 1.2;
    color: var(--color-black);
    margin: 0;
}

.featured-article-content p {
    font-size: var(--text-base);
    line-height: 1.6;
    color: var(--color-gray);
    margin: 0;
}

.read-more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--text-base);
    font-weight: 500;
    color: var(--color-black);
    text-decoration: none;
    transition: var(--transition-fast);
    width: fit-content;
}

.read-more:hover {
    color: var(--color-green-black);
    gap: 12px;
}

.read-more svg {
    transition: var(--transition-fast);
}

/* Categories Filter */
.categories-filter {
    gap: 12px;
    background-color: var(--color-gray-light);
    padding: 3px;
    border: 1px solid var(--color-gray-background-tertiary);
    border-radius: var(--radius-md);
    margin-bottom: 60px;
    flex-wrap: wrap;
}

.filter-btn {
    padding: 12px 14px;
    border: none;
    background: var(--color-gray-lighter);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    font-weight: 400;
    color: var(--color-black);
    cursor: pointer;
    transition: var(--transition-fast);
}

.filter-btn:hover {
    background: var(--color-gray-light);
}

.filter-btn.active {
    background: var(--color-green);
    color: var(--color-black);
    font-weight: 600;
}

/* Mobile Filter Container */
.mobile-filter-container {
    display: none;
    gap: 12px;
    align-items: center;
    margin-bottom: 40px;
}

.mobile-category-select {
    flex: 1;
    padding: 12px 16px;
    border: 1px solid var(--color-gray-border);
    border-radius: var(--radius-md);
    background: white;
    font-size: var(--text-base);
    font-family: var(--font-base);
    color: var(--color-black);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23101010' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 40px;
}

.mobile-category-select:focus {
    outline: none;
    border-color: var(--color-green);
}

.results-count {
    font-size: var(--text-base);
    color: var(--color-gray);
    white-space: nowrap;
}

/* Articles Grid */
.articles-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-bottom: 60px;
}

.article-card {
    display: flex;
    flex-direction: column;
    background: white;
    transition: var(--transition-base);
}

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

.article-card a {
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.article-card-image {
    position: relative;
    width: 100%;
    height: 240px;
    border-radius: var(--radius-img);
    overflow: hidden;
    background: var(--color-green-black);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.article-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.article-card-tags {
    position: absolute;
    top: 20px;
    right: 12px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    z-index: 2;
}

.article-card-content {
    padding: 24px 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}

.article-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.tag {
    display: inline-block;
    padding: 5px 12px;
    background: white;
    border: 1px solid var(--color-black);
    border-radius: var(--radius-full);
    font-size: var(--text-xl);
    font-weight: 400;
    color: var(--color-black);
}

.article-card h3 {
    font-family: var(--font-base);
    font-size: var(--text-2xl);
    line-height: 1.3;
    color: var(--color-black);
    margin: 0;
}

.article-description {
    font-size: var(--text-sm);
    line-height: 1.6;
    color: var(--color-black);
    margin: 0;
}

.article-date-reading {
    font-size: var(--text-md);
    color: var(--color-gray);
    display: block;
}

.article-read-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-black);
    transition: var(--transition-fast);
}

.article-card:hover .article-read-link {
    gap: 12px;
    color: var(--color-green-black);
}

.article-read-link svg {
    transition: var(--transition-fast);
}

.article-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: var(--text-md);
    color: var(--color-gray);
    margin-top: auto;
    padding-bottom: var(--spacing-1);
}

.article-meta .author {
    font-weight: 500;
}

.article-meta .date::before {
    content: "•";
    margin-right: 12px;
}

/* Pagination */
.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 60px;
    margin-bottom: 60px;
}

.pagination button {
    padding: 12px 12px;
    background: white;
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-gray);
    cursor: pointer;
    transition: var(--transition-fast);
    min-width: 44px;
}

.pagination button:hover:not(:disabled) {
    border-color: var(--color-green);
    color: var(--color-green-black);
}

.pagination button.active {
    background: var(--color-green);
    color: var(--color-white);
}

.pagination button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Article Detail Page */
.article-container {
    max-width: 900px;
    margin: 0 auto;
    padding: 80px 24px 120px;
}

.back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-black);
    text-decoration: none;
    margin-bottom: 40px;
    transition: var(--transition-fast);
}

.back-link:hover {
    color: var(--color-green-black);
}

.article-detail {
    margin-bottom: 100px;
}

/* Article Hero Section */
.article-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    margin-bottom: 80px;
    padding: 40px 0;
}

.article-hero-content {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.article-categories {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.article-meta-top {
    display: flex;
    gap: 8px;
    align-items: center;
    font-size: var(--text-sm);
    color: var(--color-gray-dark);
}

.article-meta-top .date::after {
    content: "•";
    margin-left: 8px;
}

.article-hero h1 {
    font-family: var(--font-base);
    font-size: var(--text-4xl);
    line-height: 1;
    color: var(--color-black);
    margin: 0;
}

.article-description {
    font-size: var(--text-base);
    line-height: 1.6;
    color: var(--color-black);
    margin: 0;
}

.read-article-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--text-base);
    font-weight: 500;
    color: var(--color-black);
    text-decoration: none;
    transition: var(--transition-fast);
    width: fit-content;
}

.read-article-btn:hover {
    color: var(--color-green-black);
    gap: 12px;
}

.read-article-btn svg {
    transition: var(--transition-fast);
}

.article-hero-image {
    width: 100%;
    height: 600px;
    border-radius: var(--radius-img);
    overflow: hidden;
    background: var(--color-green-black);
}

.article-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.article-header {
    margin-bottom: 40px;
}

.article-header .article-categories {
    margin-bottom: 20px;
}

.article-header h1 {
    font-family: var(--font-base);
    font-size: var(--text-5xl);
    line-height: 1.2;
    color: var(--color-black);
    margin: 0 0 20px 0;
}

.article-header .article-meta {
    border-top: none;
    padding-top: 0;
}

.article-image {
    width: 100%;
    height: 500px;
    border-radius: var(--radius-img);
    overflow: hidden;
    margin-bottom: 40px;
}

.article-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.article-content {
    max-width: 800px;
    margin: 0 auto;
    font-size: var(--text-base);
    line-height: 1.8;
    color: var(--color-black);
    padding: 20px 0;
}

.article-content p {
    margin: 0 0 24px 0;
    font-size: 16px;
    line-height: 1.7;
}

.article-content h1 {
    font-family: var(--font-base);
    font-size: var(--text-3xl);
    font-weight: 600;
    line-height: 1.2;
    margin: 48px 0 24px 0;
    color: var(--color-black);
}

.article-content h2 {
    font-family: var(--font-base);
    font-size: var(--text-2xl);
    font-weight: 600;
    line-height: 1.3;
    margin: 44px 0 22px 0;
    color: var(--color-black);
}

.article-content h3 {
    font-family: var(--font-base);
    font-size: var(--text-xl);
    font-weight: 600;
    line-height: 1.3;
    margin: 34px 0 20px 0;
    color: var(--color-black);
}

.article-content h4 {
    font-family: var(--font-base);
    font-size: var(--text-lg);
    font-weight: 600;
    line-height: 1.3;
    margin: 30px 0 18px 0;
    color: var(--color-black);
}

.article-content ul,
.article-content ol {
    margin: 0 0 32px 0;
    padding-left: 24px;
}

.article-content li {
    margin-bottom: 12px;
    line-height: 1.7;
    font-size: 16px;
}

.article-content ul li {
    list-style-type: disc;
}

.article-content ol li {
    list-style-type: decimal;
}

.article-content blockquote {
    margin: 32px 0;
    padding: 24px 32px;
    background: var(--color-gray-lighter);
    border-left: 4px solid var(--color-green);
    border-radius: var(--radius-md);
}

.article-content img {
    width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    margin: 32px 0;
}

.article-content strong {
    font-weight: 600;
    color: var(--color-black);
}

.article-content a {
    color: var(--color-green);
    text-decoration: underline;
    transition: opacity 0.2s ease;
}

.article-content a:hover {
    opacity: 0.8;
}

.article-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
    max-width: 800px;
    margin: 40px auto 0;
    padding-top: 40px;
}

/* Related Articles Section */
.related-articles {
    margin: 0 auto;
    padding: 80px 24px;
}

.related-articles-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 40px;
    margin-bottom: 60px;
}

.related-articles-title-block {
    text-align: left;
    flex: 1;
}

.related-articles-label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-black);
    margin: 0 0 12px 0;
    letter-spacing: 0.5px;
}

.related-articles .faq-title {
    margin-bottom: 16px;
    text-align: left;
}

.related-articles .subtitle {
    font-size: var(--text-base);
    color: var(--color-gray-dark);
    margin: 0;
    text-align: left;
    max-width: 600px;
}

.related-articles .articles-grid {
    margin-bottom: 0;
}

.view-all {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--text-base);
    font-weight: 500;
    color: var(--color-black);
    text-decoration: none;
    transition: var(--transition-fast);
}

.view-all:hover {
    color: var(--color-green-black);
    gap: 12px;
}

/* Loading State */
.loading {
    text-align: center;
    padding: 60px 24px;
    font-size: var(--text-lg);
    color: var(--color-gray);
}

/* Error State */
.error {
    text-align: center;
    padding: 60px 24px;
    font-size: var(--text-lg);
    color: var(--color-red);
}

.no-articles {
    text-align: center;
    padding: 60px 24px;
    font-size: var(--text-lg);
    color: var(--color-gray);
}

/* Responsive Design */
@media (max-width: 1024px) {
    .articles-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .blog-container,
    .article-container {
        padding: 60px 20px 80px;
    }

    /* Masquer les filtres desktop, afficher le filtre mobile */
    .categories-filter {
        display: none !important;
    }

    .mobile-filter-container {
        display: flex;
    }

    .featured-article-card {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .featured-article-image {
        height: 300px;
    }

    .featured-article-content h2 {
        font-size: var(--text-3xl);
    }

    .categories-filter {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .categories-filter::-webkit-scrollbar {
        display: none;
    }

    .articles-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .article-hero {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 20px 0;
    }

    .article-hero-image {
        height: 300px;
        order: 2;
    }

    .article-hero-content {
        order: 1;
    }

    .article-hero h1 {
        font-size: var(--text-3xl);
    }

    .article-content {
        padding: 20px 0;
    }

    .article-content h2 {
        font-size: var(--text-xl);
        margin: 32px 0 16px 0;
    }

    .article-content h3 {
        font-size: var(--text-lg);
        margin: 24px 0 12px 0;
    }

    .article-content p,
    .article-content li {
        font-size: 15px;
    }

    .article-header h1 {
        font-size: var(--text-3xl);
    }

    .article-image {
        height: 300px;
    }

    .related-articles {
        padding: 60px 20px;
    }

    .related-articles-header {
        flex-direction: column;
        align-items: stretch;
        gap: 32px;
        margin-bottom: 40px;
    }

    .related-articles .faq-title,
    .related-articles .subtitle {
        text-align: left;
    }

    .related-articles .subtitle {
        max-width: 100%;
    }

    .related-articles-title-block {
        text-align: left;
    }

    .tag {
    padding: 6px 10px;
    font-size: var(--text-md);
}
    .related-articles-header .btn-group {
        /* width: 100%; */
        flex:0;
        justify-content: left;
    }

    .pagination {
        flex-wrap: wrap;
    }
}

/* ============================================
   Partner Offers Section
   ============================================ */

.partner-offers {
    background: var(--color-white);
    padding: var(--spacing-24) 0;
}

.partner-offers-header {
    text-align: center;
    margin-bottom: var(--spacing-16);
}

.partner-offers-header .subtitle {
    margin-bottom: var(--spacing-4);
}

.partner-offers-header .section-title-md {
    margin-bottom: var(--spacing-6);
}

.partner-offers-header .section-description {
    max-width: 800px;
    margin: 0 auto;
}

/* Category Tabs */
.partner-offers-tabs {
    display: flex;
    justify-content: center;
    gap: var(--spacing-1);
    flex-wrap: wrap;
    background: var(--color-gray-background-secondary);
    padding: 3px;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-gray-background-tertiary);
    margin-bottom: var(--spacing-16);
}

.partner-offer-tab {
    padding: var(--spacing-3) var(--spacing-6);
    background: var(--color-gray-background-secondary);
    border-radius: var(--radius-md);
    font-size: var(--text-md);
    font-weight: 500;
    color: var(--color-dark);
    cursor: pointer;
    transition: all 0.3s ease;
}

.partner-offer-tab:hover {
    border-color: var(--color-green-citrus);
    background-color: var(--color-green-citrus);
    font-weight: 700;
    color: var(--color-black);
}

.partner-offer-tab.active {
    border-color: var(--color-green-citrus);
    font-weight: 700;
    background-color: var(--color-green-citrus);
    color: var(--color-black);
}

/* Offers Image */
.partner-offers-image {
    display: flex;
    justify-content: center;
    margin-bottom: var(--spacing-12);
    text-align: center;
    align-items: center;
}

.partner-offers-image img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
}

/* CTA */
.partner-offers-cta {
    display: flex;
    justify-content: center;
    margin-top: var(--spacing-12);
}

/* Responsive */
@media (max-width: 768px) {
    .partner-offers {
        padding: var(--spacing-16) 0;
    }

    .partner-offers-header {
        margin-bottom: var(--spacing-12);
    }

    .partner-offers-tabs {
        gap: var(--spacing-2);
        margin-bottom: var(--spacing-12);
    }

    .partner-offer-tab {
        padding: var(--spacing-2) var(--spacing-4);
        font-size: var(--text-sm);
    }
}