/* Masquer la section soumission en bas (remplacee par popup) */
        .ent-soumission {
            display: none !important;
        }

        /* ============================================
           POPUP / MODALE (identique a index.php)
           ============================================ */
        .modal-overlay {
            position: fixed;
            inset: 0;
            background: rgba(0, 0, 0, 0.6);
            z-index: 9998;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 30px;
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.4s ease, visibility 0.4s ease;
        }
        .modal-overlay.is-open {
            opacity: 1;
            visibility: visible;
        }
        .modal-box {
            position: relative;
            background: #fff;
            border-radius: 20px;
            width: 100%;
            max-width: 560px;
            padding: 50px 45px;
            box-shadow: 0 30px 80px rgba(0, 0, 0, 0.25);
            text-align: center;
            max-height: 90vh;
            overflow-y: auto;
            transform: translateY(30px) scale(0.97);
            transition: transform 0.4s ease;
        }
        .modal-overlay.is-open .modal-box {
            transform: translateY(0) scale(1);
        }
        .modal-close {
            position: absolute;
            top: 18px;
            right: 18px;
            width: 40px;
            height: 40px;
            border-radius: 50%;
            background: #f5f3eb;
            border: none;
            cursor: pointer;
            color: #4a4c70;
            font-size: 16px;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: background 0.2s;
        }
        .modal-close:hover { background: #efc940; }
        .modal-pretitle {
            display: block;
            font-family: 'Quicksand', sans-serif;
            font-size: 16px;
            font-weight: 700;
            color: #9e9e9e;
            margin-bottom: 10px;
        }
        .modal-title {
            font-family: 'Quicksand', sans-serif;
            font-size: 32px;
            font-weight: 700;
            color: #4a4c70;
            line-height: 1.1;
            letter-spacing: -2px;
            margin: 0 0 12px;
        }
        .modal-title em { font-style: normal; color: #efc940; }
        .modal-text {
            font-family: 'Quicksand', sans-serif;
            font-size: 16px;
            font-weight: 400;
            color: #666;
            line-height: 1.5;
            margin: 0 0 30px;
        }
        .modal-form-row {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 15px;
            margin-bottom: 15px;
        }
        .modal-field {
            display: flex;
            flex-direction: column;
            text-align: left;
        }
        .modal-field span {
            font-family: 'Quicksand', sans-serif;
            font-size: 13px;
            font-weight: 600;
            color: #4a4c70;
            margin-bottom: 6px;
        }
        .modal-field input,
        .modal-field select {
            font-family: 'Quicksand', sans-serif;
            font-size: 15px;
            padding: 12px 16px;
            border: 1.5px solid #e0e0e0;
            border-radius: 10px;
            color: #333;
            background: #fff;
            transition: border-color 0.3s;
            outline: none;
        }
        .modal-field input:focus,
        .modal-field select:focus { border-color: #efc940; }
        .modal-field input::placeholder { color: #bbb; }
        .modal-submit {
            font-family: 'Quicksand', sans-serif;
            font-size: 16px;
            font-weight: 700;
            color: #4a4c70;
            background: #efc940;
            border: none;
            padding: 14px 40px;
            border-radius: 50px;
            cursor: pointer;
            transition: background 0.3s, transform 0.2s;
            margin-top: 10px;
        }
        .modal-submit:hover { background: #d4ae2e; transform: translateY(-2px); }
        .modal-micro {
            font-family: 'Quicksand', sans-serif;
            font-size: 12px;
            color: #999;
            margin-top: 15px;
            line-height: 1.4;
        }
        .modal-micro a { color: #efc940; text-decoration: underline; }
        @media (max-width: 600px) {
            .modal-box { padding: 35px 25px; }
            .modal-form-row { grid-template-columns: 1fr; }
            .modal-title { font-size: 26px; }
        }

        /* Bandeau risque reglementaire (identique a index.php) */
        .bandeau-risque {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 14px;
            width: 100%;
            padding: 15px 40px;
            background: #FFF0E0;
            font-family: 'Quicksand', sans-serif;
            font-size: 14px;
            color: #1a1a1a;
            line-height: 1.5;
            text-align: center;
        }
        .bandeau-risque i {
            color: #F59E0B;
            font-size: 18px;
            flex-shrink: 0;
        }
        .bandeau-risque p {
            margin: 0;
        }
        @media (max-width: 768px) {
            .bandeau-risque {
                padding: 12px 20px;
                font-size: 12px;
            }
        }

        /* Override : titre hero plus large, spans inline */
        .inv-hero-title {
            max-width: 70%;
        }
        .inv-hero-title span {
            display: inline;
        }

        /* On a 4 cards : on annule le grid-column: 2 force sur le last-child d'investir */
        .inv-pourquoi-cards .inv-pourquoi-card:last-child {
            grid-column: auto;
        }

        /* 4eme card "accent" : fond vert clair, pas de picto, titre centre */
        .inv-pourquoi-card--accent {
            background: #dfe8a0;
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
        }

        .inv-pourquoi-card--accent .inv-pourquoi-card-title {
            margin-bottom: 0;
        }

        /* Petit texte sous le paragraphe principal de la section modules */
        .inv-modules-subtext {
            font-family: 'Quicksand', sans-serif;
            font-size: 14px;
            font-weight: 500;
            color: #999;
            line-height: 1.3;
            margin-top: 15px;
        }

        /* 3 compteurs au lieu de 2 dans la section modules */
        .inv-modules-counters {
            grid-template-columns: 1fr 1fr 1fr;
            gap: 60px;
        }

        /* Reduction du padding bas de la section modules (specifique entreprises) */
        .inv-modules {
            padding-bottom: 90px;
        }

        /* ============================================
           SECTION : SERVICES (style Helpo "What We Do")
           4 cards en grille avec icone + titre + texte
           ============================================ */
        .ent-services {
            padding: 140px 0 160px;
            background: #fff;
            position: relative;
            overflow: hidden;
        }

        .ent-services-container {
            max-width: 1440px;
            margin: 0 auto;
            padding: 0 40px;
            position: relative;
            z-index: 1;
        }

        /* Header : pre-title + H2 + texte centres */
        .ent-services-header {
            text-align: center;
            max-width: 700px;
            margin: 0 auto 40px;
        }

        .ent-services-title {
            font-family: 'Quicksand', sans-serif;
            font-size: 50px;
            color: #4a4c70;
            line-height: 1.1;
            letter-spacing: -3.5px;
            margin-bottom: 15px;
        }

        .ent-services-title .inv-bold { font-weight: 700; }
        .ent-services-title .inv-light { font-weight: 400; }

        .ent-services-text {
            font-family: 'Quicksand', sans-serif;
            font-size: 18px;
            font-weight: 400;
            color: #666;
            line-height: 1.5;
        }

        /* Grille des 4 cards */
        .ent-services-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 30px;
        }

        /* Card individuelle */
        .ent-service-card {
            text-align: center;
            padding: 40px 25px;
            transition: transform 0.3s;
            position: relative;
        }

        .ent-service-card:hover {
            transform: translateY(-8px);
        }

        /* Pointilles entre les pictos (sauf apres la derniere card) */
        .ent-service-card:not(:last-child)::after {
            content: '';
            position: absolute;
            top: 130px; /* centre vertical du picto (40px padding + 90px = moitie de 180px) */
            left: calc(50% + 100px); /* 10px apres le bord droit du picto centre */
            width: calc(100% - 170px); /* s'etend jusqu'a 10px avant le picto suivant */
            height: 0;
            border-top: 4px dotted #d0d0d0;
            z-index: 0;
            pointer-events: none;
        }

        /* Masquer les pointilles quand les cards sont empilees (tablette/mobile) */
        @media (max-width: 1024px) {
            .ent-service-card::after {
                display: none;
            }
        }

        /* Phrase d'accroche du CTA en 20px */
        .inv-cta-text strong {
            font-size: 20px;
        }

        /* ============================================
           CTA - Layout 2 colonnes (objection / bouton)
           ============================================ */
        .cta-action-grid {
            display: grid;
            grid-template-columns: 6fr 4fr;
            align-items: center;
            gap: 90px;
            max-width: 1100px;
            margin: 50px auto 0;
            position: relative;
        }

        /* Fleche en absolute, positionnee a la volee, empietant sur la pilule de gauche */
        .cta-action-arrow {
            position: absolute;
            top: 50%;
            left: 55%;
            transform: translate(-50%, -50%);
            z-index: 2;
            pointer-events: none;
        }

        .cta-action-arrow img {
            width: 90px;
            height: auto;
            display: block;
        }

        /* Colonne gauche : card objection en pilule horizontale */
        .cta-objection-pill {
            background: rgba(255, 255, 255, 0.30);
            border-radius: 100px;
            padding: 10px 35px 10px 15px;
            display: flex;
            align-items: center;
            gap: 22px;
            text-align: left;
        }

        /* Avatar rond a gauche */
        .cta-objection-avatar {
            width: 100px;
            height: 100px;
            border-radius: 50%;
            object-fit: cover;
            flex-shrink: 0;
        }

        /* Bloc texte de l'objection */
        .cta-objection-content {
            flex: 1;
            min-width: 0;
        }

        .cta-objection-content h4 {
            font-family: 'Quicksand', sans-serif;
            font-size: 17px;
            font-weight: 700;
            color: #4a4c70;
            line-height: 1.3;
            margin: 0 0 6px 0;
        }

        .cta-objection-content p {
            font-family: 'Quicksand', sans-serif;
            font-size: 13px;
            font-weight: 500;
            color: #5a5c80;
            line-height: 1.4;
            margin: 0;
        }

        /* Colonne droite : bouton + reassurances empilees */
        .cta-action-right {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: stretch;
        }

        /* Bouton principal (override des regles inv-cta-btn) */
        .cta-action-grid .inv-cta-btn {
            margin: 0 0 18px 0;
            text-align: center;
            padding: 22px 30px;
            font-size: 18px;
            border-radius: 100px;
        }

        /* Reassurances empilees verticalement */
        .cta-action-reassurance {
            display: flex;
            flex-direction: column;
            gap: 0;
            padding-left: 10px;
        }

        .cta-action-reassurance span {
            font-family: 'Quicksand', sans-serif;
            font-size: 14px;
            font-weight: 500;
            color: #4a4c70;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .cta-action-reassurance i {
            color: #4a4c70;
            font-size: 14px;
            width: 16px;
            text-align: center;
        }

        /* Responsive */
        @media (max-width: 900px) {
            .cta-action-grid {
                grid-template-columns: 1fr;
                gap: 60px;
            }

            .cta-action-arrow {
                position: absolute;
                top: 50%;
                left: 50%;
                transform: translate(-50%, -50%) rotate(90deg);
            }

            .cta-action-arrow img {
                width: 60px;
            }

            .cta-objection-pill {
                border-radius: 24px;
                padding: 25px;
            }
        }

        /* Icone : PNG decoratif en background + FA inside */
        .ent-service-icon {
            width: 180px;
            height: 180px;
            background-repeat: no-repeat;
            background-position: center;
            background-size: contain;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 10px;
        }

        .ent-service-icon i {
            font-size: 100px;
        }

        /* Card 1 : rouge/rose */
        .ent-service-card--1 .ent-service-icon {
            background-image: url('../images/fond-icone-rouge.png');
        }
        .ent-service-card--1 .ent-service-icon i {
            color: #f36f8f;
        }

        /* Card 2 : jaune/orange */
        .ent-service-card--2 .ent-service-icon {
            background-image: url('../images/fond-icone-jaune.png');
        }
        .ent-service-card--2 .ent-service-icon i {
            color: #feb248;
        }

        /* Card 3 : vert */
        .ent-service-card--3 .ent-service-icon {
            background-image: url('../images/fond-icone-vert.png');
        }
        .ent-service-card--3 .ent-service-icon i {
            color: #76d785;
        }

        /* Card 4 : bleu */
        .ent-service-card--4 .ent-service-icon {
            background-image: url('../images/fond-icone-bleu.png');
        }
        .ent-service-card--4 .ent-service-icon i {
            color: #8bbde8;
        }

        /* Titre H3 */
        .ent-service-title {
            font-family: 'Quicksand', sans-serif;
            font-size: 24px;
            font-weight: 700;
            color: #4a4c70;
            line-height: 1.2;
            letter-spacing: -1px;
            margin-bottom: 15px;
        }

        /* Description */
        .ent-service-card p {
            font-family: 'Quicksand', sans-serif;
            font-size: 18px;
            font-weight: 400;
            color: #666;
            line-height: 1.5;
        }

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

        @media (max-width: 768px) {
            .ent-services {
                padding: 80px 0;
            }
            .ent-services-grid {
                grid-template-columns: 1fr;
            }
            .ent-services-title {
                font-size: 30px;
            }
        }

        /* ============================================
           HERO : double CTA (primaire + outline)
           meme gabarit que index.php
           ============================================ */
        .inv-hero-ctas {
            display: flex;
            flex-wrap: wrap;
            gap: 15px;
            margin-top: 25px;
        }
        .inv-hero-ctas .inv-hero-btn {
            margin-top: 0;
        }
        .inv-hero-btn--outline {
            background: transparent !important;
            border: 2px solid #fff !important;
            color: #fff !important;
        }
        .inv-hero-btn--outline:hover {
            background: rgba(255, 255, 255, 0.12) !important;
        }
        @media (max-width: 768px) {
            .inv-hero-ctas { flex-direction: column; align-items: stretch; }
            .inv-hero-ctas .inv-hero-btn { text-align: center; }
        }

        /* ============================================
           BLOC B : CRITERES D'ELIGIBILITE PORTEUR
           ============================================ */
        .ent-eligibilite {
            background: #f9f7f6;
            padding: 140px 0;
        }
        .ent-eligibilite-container {
            max-width: 1440px;
            margin: 0 auto;
            padding: 0 40px;
        }
        .ent-eligibilite-grid {
            display: grid;
            grid-template-columns: 4fr 6fr;
            gap: 120px;
            align-items: start;
        }
        .ent-eligibilite-title {
            font-family: 'Quicksand', sans-serif;
            font-size: 50px;
            color: #4a4c70;
            line-height: 1.1;
            letter-spacing: -3.5px;
            margin: 10px 0 40px;
        }
        .ent-eligibilite-title .inv-bold { font-weight: 700; }
        .ent-eligibilite-title .inv-light { font-weight: 400; }
        .ent-eligibilite-intro {
            font-family: 'Quicksand', sans-serif;
            font-size: 18px;
            font-weight: 400;
            color: #666;
            line-height: 1.5;
            margin-bottom: 30px;
        }
        .ent-eligibilite-intro strong {
            color: #4a4c70;
        }
        .ent-eligibilite-list {
            list-style: none;
            padding: 0;
            margin: 0 0 40px;
            display: flex;
            flex-direction: column;
            gap: 0;
        }
        .ent-eligibilite-list li {
            font-family: 'Quicksand', sans-serif;
            font-size: 18px;
            font-weight: 500;
            color: #4a4c70;
            line-height: 1.5;
            display: flex;
            align-items: flex-start;
            gap: 12px;
            padding: 14px 0;
            border-bottom: 1px solid rgba(74, 76, 112, 0.1);
        }
        .ent-eligibilite-list li:last-child {
            border-bottom: none;
        }
        .ent-eligibilite-list li i {
            color: #efc940;
            font-size: 14px;
            flex-shrink: 0;
            margin-top: 5px;
        }
        .ent-eligibilite-aside {
            background: #4a4c70;
            border-radius: 16px;
            padding: 35px 30px;
            color: #fff;
            margin-top: 10px;
        }
        .ent-eligibilite-aside h3 {
            font-family: 'Quicksand', sans-serif;
            font-size: 22px;
            font-weight: 700;
            color: #fff;
            line-height: 1.2;
            letter-spacing: -0.5px;
            margin: 0 0 12px;
        }
        .ent-eligibilite-aside p {
            font-family: 'Quicksand', sans-serif;
            font-size: 16px;
            font-weight: 400;
            color: rgba(255, 255, 255, 0.85);
            line-height: 1.5;
            margin: 0 0 20px;
        }
        .ent-eligibilite-aside p strong { color: #efc940; }
        .ent-eligibilite-btn {
            display: inline-flex;
            align-items: center;
            background: #efc940;
            color: #4a4c70;
            padding: 14px 28px;
            border-radius: 50px;
            border: none;
            font-family: 'Quicksand', sans-serif;
            font-size: 15px;
            font-weight: 700;
            text-decoration: none;
            transition: all 0.3s;
        }
        .ent-eligibilite-btn:hover {
            background: #d4ae2e;
            transform: translateY(-2px);
        }
        @media (max-width: 900px) {
            .ent-eligibilite { padding: 70px 0; }
            .ent-eligibilite-container { padding: 0 20px; }
            .ent-eligibilite-grid {
                grid-template-columns: 1fr;
                gap: 40px;
            }
            .ent-eligibilite-title { font-size: 32px; }
            .ent-eligibilite-aside { position: static; padding: 30px 25px; }
        }

        /* ============================================
           BLOC C : FORMULAIRE SOUMISSION PORTEUR
           ============================================ */
        .ent-soumission {
            background: #F5F5F5;
            padding: 100px 0;
        }
        .ent-soumission-container {
            max-width: 720px;
            margin: 0 auto;
            padding: 0 40px;
        }
        .ent-soumission-head {
            text-align: center;
            margin-bottom: 40px;
        }
        .ent-soumission-title {
            font-family: 'Quicksand', sans-serif;
            font-size: 42px;
            color: #4a4c70;
            line-height: 1.1;
            letter-spacing: -2px;
            margin: 10px 0 15px;
        }
        .ent-soumission-title .inv-bold { font-weight: 700; }
        .ent-soumission-title .inv-light { font-weight: 400; }
        .ent-soumission-text {
            font-family: 'Quicksand', sans-serif;
            font-size: 17px;
            color: #666;
            line-height: 1.5;
            margin: 0;
        }
        .ent-soumission-form {
            background: #fff;
            border-radius: 20px;
            padding: 40px;
            box-shadow: 0 8px 30px rgba(27, 42, 74, 0.08);
            display: flex;
            flex-direction: column;
            gap: 20px;
        }
        .ent-form-row {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 20px;
        }
        .ent-field {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        .ent-field label {
            font-family: 'Quicksand', sans-serif;
            font-size: 13px;
            font-weight: 600;
            color: #4a4c70;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .ent-field input,
        .ent-field select {
            font-family: 'Quicksand', sans-serif;
            font-size: 15px;
            color: #333;
            background: #F5F7FA;
            border: 2px solid #E0E4EC;
            border-radius: 12px;
            padding: 14px 18px;
            outline: none;
            transition: border-color 0.2s, background 0.2s;
            width: 100%;
            box-sizing: border-box;
        }
        .ent-field input:focus,
        .ent-field select:focus {
            border-color: #00B4D8;
            background: #fff;
        }
        .ent-field select {
            appearance: none;
            -webkit-appearance: none;
            background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234a4c70' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
            background-repeat: no-repeat;
            background-position: right 18px center;
            background-size: 18px;
            padding-right: 45px;
        }
        .ent-soumission-btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            background: #00B4D8;
            color: #fff;
            padding: 18px 30px;
            border: none;
            border-radius: 100px;
            font-family: 'Quicksand', sans-serif;
            font-size: 16px;
            font-weight: 700;
            cursor: pointer;
            transition: background 0.3s;
            margin-top: 10px;
        }
        .ent-soumission-btn:hover {
            background: #0096B7;
        }
        .ent-soumission-micro {
            font-family: 'Quicksand', sans-serif;
            font-size: 12px;
            font-weight: 400;
            color: #888;
            line-height: 1.5;
            text-align: center;
            margin: 5px 0 0;
        }
        .ent-soumission-micro a {
            color: #00B4D8;
            text-decoration: underline;
        }
        @media (max-width: 700px) {
            .ent-soumission { padding: 70px 0; }
            .ent-soumission-container { padding: 0 20px; }
            .ent-soumission-title { font-size: 30px; }
            .ent-soumission-form { padding: 28px 22px; }
            .ent-form-row { grid-template-columns: 1fr; }
        }
