/* ========================================
           VARIABLES ET RESET
           ======================================== */
        :root {
            --primary-color: #2563eb;
            --primary-dark: #1e40af;
            --secondary-color: #10b981;
            --accent-color: #f59e0b;
            --bg-light: #f8fafc;
            --bg-white: #ffffff;
            --bg-gray: #f1f5f9;
            --text-dark: #1e293b;
            --text-medium: #475569;
            --text-light: #64748b;
            --border-color: #e2e8f0;
            --border-radius: 12px;
            --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1);
            --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
            --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
            --spacing-xs: 8px;
            --spacing-sm: 16px;
            --spacing-md: 24px;
            --spacing-lg: 32px;
            --spacing-xl: 48px;
            --font-size-base: 18px;
            --font-size-large: 20px;
            --font-size-xl: 24px;
            --font-size-xxl: 32px;
            --font-size-hero: 42px;
        }

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

        body {
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
            font-size: var(--font-size-base);
            line-height: 1.7;
            color: var(--text-dark);
            background-color: var(--bg-light);
        }

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

        a {
            text-decoration: none;
            color: inherit;
            transition: color 0.3s ease;
            cursor: pointer;
        }

        ul {
            list-style: none;
        }

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

        /* Pages - une seule visible à la fois */
        .page {
            display: none;
        }

        .page.active {
            display: block;
        }

        /* ========================================
           HEADER ET NAVIGATION
           ======================================== */
        header {
            background-color: var(--bg-white);
            box-shadow: var(--shadow-sm);
            position: sticky;
            top: 0;
            z-index: 1000;
        }

        .header-content {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: var(--spacing-sm) 0;
            gap: var(--spacing-md);
        }

        .logo {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }

        .logo a {
            display: flex;
            align-items: center;
        }

        .logo-image {
            width: 60px;
            height: 60px;
            object-fit: contain;
        }

        .logo-text {
            display: flex;
            flex-direction: column;
        }

        .logo-text h1 {
            font-size: var(--font-size-xxl);
            color: var(--primary-color);
            font-weight: 700;
            margin: 0;
            line-height: 1.2;
        }

        .tagline {
            font-size: 14px;
            color: var(--text-light);
            margin: 0;
        }

        .auth-module .btn-connexion {
            background-color: var(--primary-color);
            color: white;
            padding: 12px 24px;
            border-radius: var(--border-radius);
            font-size: var(--font-size-base);
            font-weight: 600;
            transition: background-color 0.3s ease;
            display: inline-block;
        }

        .auth-module .btn-connexion:hover {
            background-color: var(--primary-dark);
        }

        .main-nav {
            border-top: 1px solid var(--border-color);
            margin-top: var(--spacing-sm);
        }

        .main-nav ul {
            display: flex;
            justify-content: center;
            gap: var(--spacing-xs);
            flex-wrap: wrap;
        }

        .main-nav li {
            margin: var(--spacing-xs) 0;
        }

        .main-nav a {
            display: block;
            padding: 14px 20px;
            font-size: var(--font-size-base);
            font-weight: 500;
            color: var(--text-medium);
            border-radius: var(--border-radius);
            transition: all 0.3s ease;
        }

        .main-nav a:hover,
        .main-nav a.active {
            background-color: var(--primary-color);
            color: white;
        }

        /* ========================================
           BOUTONS
           ======================================== */
        .btn {
            display: inline-block;
            padding: 16px 32px;
            font-size: var(--font-size-base);
            font-weight: 600;
            border-radius: var(--border-radius);
            cursor: pointer;
            border: none;
            transition: all 0.3s ease;
            text-align: center;
            min-height: 52px;
        }

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

        .btn-primary:hover {
            background-color: var(--primary-dark);
            transform: translateY(-2px);
            box-shadow: var(--shadow-md);
        }

        .btn-secondary {
            background-color: var(--secondary-color);
            color: white;
        }

        .btn-secondary:hover {
            background-color: #059669;
            transform: translateY(-2px);
            box-shadow: var(--shadow-md);
        }

        .btn-full {
            width: 100%;
        }

        /* ========================================
           SECTION HÉRO
           ======================================== */
        .hero {
            background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
            color: white;
            padding: var(--spacing-xl) 0;
            text-align: center;
        }

        .hero-content h2 {
            font-size: var(--font-size-hero);
            margin-bottom: var(--spacing-md);
            font-weight: 700;
        }

        .hero-text {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-lg);
            max-width: 800px;
            margin-left: auto;
            margin-right: auto;
            line-height: 1.6;
        }

        .hero-buttons {
            display: flex;
            gap: var(--spacing-md);
            justify-content: center;
            flex-wrap: wrap;
        }

        .phone-icon {
            font-size: 24px;
            margin-right: 8px;
        }

        /* ========================================
           SECTIONS GÉNÉRALES
           ======================================== */
        section {
            padding: var(--spacing-xl) 0;
        }

        .section-title {
            font-size: var(--font-size-xxl);
            text-align: center;
            margin-bottom: var(--spacing-lg);
            color: var(--text-dark);
            font-weight: 700;
        }

        /* ========================================
           SERVICES
           ======================================== */
        .services-quick {
            background-color: var(--bg-white);
        }

        .services-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-lg);
        }

        .service-card {
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            text-align: center;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
        }

        .service-card:hover {
            transform: translateY(-5px);
            box-shadow: var(--shadow-lg);
        }

        .service-icon {
            font-size: 64px;
            margin-bottom: var(--spacing-md);
        }

        .service-card h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-sm);
            color: var(--text-dark);
        }

        .service-card p {
            font-size: var(--font-size-base);
            color: var(--text-medium);
            line-height: 1.6;
        }

        .cta-center {
            text-align: center;
            margin-top: var(--spacing-lg);
        }

        /* ========================================
           FEATURES
           ======================================== */
        .why-us {
            background-color: var(--bg-light);
        }

        .features-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: var(--spacing-lg);
        }

        .feature {
            text-align: center;
            padding: var(--spacing-md);
        }

        .feature-number {
            display: inline-block;
            width: 60px;
            height: 60px;
            background-color: var(--primary-color);
            color: white;
            border-radius: 50%;
            font-size: 28px;
            font-weight: 700;
            line-height: 60px;
            margin-bottom: var(--spacing-sm);
        }

        .feature h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-sm);
            color: var(--text-dark);
        }

        .feature p {
            font-size: var(--font-size-base);
            color: var(--text-medium);
        }

        /* ========================================
           TÉMOIGNAGES
           ======================================== */
        .testimonials-preview {
            background-color: var(--bg-white);
        }

        .testimonials-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-lg);
        }

        .testimonial-card {
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            box-shadow: var(--shadow-sm);
        }

        .stars {
            font-size: 24px;
            margin-bottom: var(--spacing-sm);
            color: #f59e0b;
        }

        .testimonial-text {
            font-size: var(--font-size-base);
            color: var(--text-medium);
            margin-bottom: var(--spacing-sm);
            line-height: 1.6;
            font-style: italic;
        }

        .testimonial-author {
            font-size: var(--font-size-base);
            color: var(--text-dark);
            font-weight: 600;
        }

        /* ========================================
           CONTACT QUICK
           ======================================== */
        .contact-quick {
            background: linear-gradient(135deg, #10b981 0%, #059669 100%);
            color: white;
            text-align: center;
        }

        .contact-quick h2 {
            font-size: var(--font-size-xxl);
            margin-bottom: var(--spacing-sm);
        }

        .contact-intro-text {
            font-size: var(--font-size-large);
            margin-bottom: var(--spacing-lg);
        }

        .contact-methods {
            display: flex;
            justify-content: center;
            gap: var(--spacing-lg);
            margin-bottom: var(--spacing-lg);
            flex-wrap: wrap;
        }

        .contact-item {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }

        .contact-icon {
            font-size: 32px;
        }

        .contact-link {
            font-size: var(--font-size-xl);
            font-weight: 600;
            color: white;
            text-decoration: underline;
        }

        /* ========================================
           FOOTER
           ======================================== */
        footer {
            background-color: var(--text-dark);
            color: white;
            padding: var(--spacing-xl) 0 var(--spacing-md);
        }

        .footer-content {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: var(--spacing-lg);
            margin-bottom: var(--spacing-lg);
        }

        .footer-section h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-sm);
            color: var(--primary-color);
        }

        .footer-section p,
        .footer-section li {
            font-size: var(--font-size-base);
            margin-bottom: var(--spacing-xs);
            color: #cbd5e1;
        }

        .footer-section a {
            color: #cbd5e1;
            transition: color 0.3s ease;
        }

        .footer-section a:hover {
            color: var(--primary-color);
        }

        .footer-bottom {
            text-align: center;
            padding-top: var(--spacing-md);
            border-top: 1px solid #475569;
        }

        .footer-bottom p {
            font-size: 16px;
            color: #94a3b8;
        }

        /* ========================================
           PAGE HEADER
           ======================================== */
        .page-header {
            background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
            color: white;
            padding: var(--spacing-lg) 0;
            text-align: center;
        }

        .page-header h1 {
            font-size: var(--font-size-hero);
            margin-bottom: var(--spacing-sm);
        }

        .breadcrumb {
            font-size: var(--font-size-base);
            opacity: 0.9;
        }

        /* ========================================
           PRESTATIONS
           ======================================== */
        .prestations-detail {
            background-color: var(--bg-white);
        }

        .intro-text {
            font-size: var(--font-size-large);
            text-align: center;
            max-width: 800px;
            margin: 0 auto var(--spacing-xl);
            color: var(--text-medium);
        }

        .prestation-category {
            margin-bottom: var(--spacing-xl);
            padding: var(--spacing-lg);
            background-color: var(--bg-gray);
            border-radius: var(--border-radius);
        }

        .prestation-category h2 {
            font-size: var(--font-size-xxl);
            margin-bottom: var(--spacing-lg);
            color: var(--text-dark);
            border-bottom: 3px solid var(--primary-color);
            padding-bottom: var(--spacing-sm);
        }

        .prestations-list {
            display: grid;
            gap: var(--spacing-md);
        }

        .prestation-item {
            background-color: var(--bg-white);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            box-shadow: var(--shadow-sm);
        }

        .prestation-item h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-sm);
            color: var(--primary-color);
        }

        .prestation-description {
            font-size: var(--font-size-base);
            color: var(--text-medium);
            margin-bottom: var(--spacing-md);
            line-height: 1.6;
        }

        .prestation-details {
            margin-bottom: var(--spacing-md);
            padding-left: var(--spacing-md);
        }

        .prestation-details li {
            font-size: var(--font-size-base);
            color: var(--text-medium);
            margin-bottom: var(--spacing-xs);
            position: relative;
            list-style: none;
        }

        .prestation-details li:before {
            content: "✓";
            color: var(--secondary-color);
            font-weight: 700;
            position: absolute;
            left: -20px;
        }

        .prestation-price {
            font-size: var(--font-size-xl);
            font-weight: 700;
            color: var(--primary-color);
        }

        .forfaits {
            background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
        }

        .forfaits-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: var(--spacing-md);
            margin-bottom: var(--spacing-lg);
        }

        .forfait-card {
            background-color: var(--bg-white);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            box-shadow: var(--shadow-md);
            text-align: center;
            position: relative;
            transition: transform 0.3s ease;
        }

        .forfait-card:hover {
            transform: scale(1.05);
        }

        .forfait-card.featured {
            border: 3px solid var(--primary-color);
        }

        .badge {
            position: absolute;
            top: -12px;
            left: 50%;
            transform: translateX(-50%);
            background-color: var(--accent-color);
            color: white;
            padding: 6px 16px;
            border-radius: 20px;
            font-size: 14px;
            font-weight: 600;
        }

        .forfait-card h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-sm);
            color: var(--text-dark);
        }

        .forfait-price {
            font-size: 40px;
            font-weight: 700;
            color: var(--primary-color);
            margin-bottom: var(--spacing-md);
        }

        .forfait-card ul {
            text-align: left;
            padding-left: var(--spacing-md);
        }

        .forfait-card li {
            font-size: var(--font-size-base);
            margin-bottom: var(--spacing-sm);
            position: relative;
            list-style: none;
        }

        .forfait-card li:before {
            content: "✓";
            color: var(--secondary-color);
            font-weight: 700;
            position: absolute;
            left: -20px;
        }

        .cta-section {
            background-color: var(--primary-color);
            color: white;
            padding: var(--spacing-xl);
            border-radius: var(--border-radius);
            text-align: center;
            margin-top: var(--spacing-xl);
        }

        .cta-section h2 {
            font-size: var(--font-size-xxl);
            margin-bottom: var(--spacing-sm);
        }

        .cta-section p {
            font-size: var(--font-size-large);
            margin-bottom: var(--spacing-lg);
        }

        /* ========================================
           NOTRE HISTOIRE
           ======================================== */
        .about-content {
            background-color: var(--bg-white);
        }

        .about-section {
            margin-bottom: var(--spacing-xl);
        }

        .about-section h2 {
            font-size: var(--font-size-xxl);
            margin-bottom: var(--spacing-md);
            color: var(--primary-color);
            border-left: 4px solid var(--primary-color);
            padding-left: var(--spacing-sm);
        }

        .about-text {
            font-size: var(--font-size-large);
            color: var(--text-medium);
            margin-bottom: var(--spacing-md);
            line-height: 1.7;
        }

        .mission {
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
        }

        .mission-values {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
            gap: var(--spacing-md);
            margin-top: var(--spacing-lg);
        }

        .value-item {
            background-color: var(--bg-white);
            padding: var(--spacing-md);
            border-radius: var(--border-radius);
            text-align: center;
            box-shadow: var(--shadow-sm);
        }

        .value-item h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-sm);
            color: var(--text-dark);
        }

        .value-item p {
            font-size: var(--font-size-base);
            color: var(--text-medium);
        }

        .team-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: var(--spacing-md);
        }

        .team-member {
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            text-align: center;
        }

        .member-icon {
            font-size: 80px;
            margin-bottom: var(--spacing-sm);
        }

        .team-member h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-xs);
            color: var(--text-dark);
        }

        .member-role {
            font-size: var(--font-size-base);
            color: var(--primary-color);
            font-weight: 600;
            margin-bottom: var(--spacing-sm);
        }

        .team-member p {
            font-size: var(--font-size-base);
            color: var(--text-medium);
        }

        .engagements-list {
            display: grid;
            gap: var(--spacing-md);
        }

        .engagement-item {
            display: flex;
            gap: var(--spacing-md);
            align-items: start;
            background-color: var(--bg-gray);
            padding: var(--spacing-md);
            border-radius: var(--border-radius);
        }

        .engagement-icon {
            font-size: 32px;
            color: var(--secondary-color);
        }

        .engagement-item h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-xs);
            color: var(--text-dark);
        }

        .engagement-item p {
            font-size: var(--font-size-base);
            color: var(--text-medium);
        }

        .stats {
            background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
            padding: var(--spacing-xl);
            border-radius: var(--border-radius);
        }

        .stats h2 {
            color: white;
            border-left-color: white;
            margin-bottom: var(--spacing-lg);
        }

        .stats-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: var(--spacing-lg);
        }

        .stat-item {
            text-align: center;
        }

        .stat-number {
            font-size: 48px;
            font-weight: 700;
            color: #fbbf24;
            margin-bottom: var(--spacing-xs);
            display: block;
        }

        .stat-label {
            font-size: var(--font-size-large);
            color: white;
            display: block;
            margin: 0;
        }

        /* ========================================
           AVIS CLIENTS
           ======================================== */
        .reviews-content {
            background-color: var(--bg-white);
        }

        .reviews-intro {
            text-align: center;
            margin-bottom: var(--spacing-xl);
        }

        .rating-summary {
            margin-top: var(--spacing-lg);
        }

        .overall-rating {
            display: inline-block;
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
        }

        .rating-number {
            font-size: 56px;
            font-weight: 700;
            color: var(--primary-color);
            display: block;
        }

        .stars-large {
            font-size: 32px;
            color: #f59e0b;
            margin: var(--spacing-sm) 0;
        }

        .reviews-list {
            display: grid;
            gap: var(--spacing-md);
        }

        .review-card {
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            box-shadow: var(--shadow-sm);
        }

        .review-header {
            display: flex;
            justify-content: space-between;
            align-items: start;
            margin-bottom: var(--spacing-md);
            flex-wrap: wrap;
            gap: var(--spacing-sm);
        }

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

        .author-avatar {
            font-size: 48px;
        }

        .review-author h3 {
            font-size: var(--font-size-xl);
            color: var(--text-dark);
            margin-bottom: 4px;
        }

        .author-info {
            font-size: 16px;
            color: var(--text-light);
        }

        .review-rating {
            text-align: right;
        }

        .review-date {
            font-size: 16px;
            color: var(--text-light);
            margin-top: 4px;
        }

        .review-text {
            font-size: var(--font-size-base);
            color: var(--text-medium);
            line-height: 1.7;
            margin-bottom: var(--spacing-sm);
        }

        .review-service {
            font-size: 16px;
            color: var(--primary-color);
            font-weight: 600;
        }

        /* ========================================
           PAGE CONTACT
           ======================================== */
        .contact-page {
            background-color: var(--bg-white);
        }

        .contact-intro {
            text-align: center;
            margin-bottom: var(--spacing-xl);
        }

        .contact-intro h2 {
            font-size: var(--font-size-xxl);
            color: var(--text-dark);
            margin-bottom: var(--spacing-sm);
        }

        .contact-intro p {
            font-size: var(--font-size-large);
            color: var(--text-medium);
        }

        .contact-layout {
            display: grid;
            grid-template-columns: 2fr 1fr;
            gap: var(--spacing-xl);
            margin-bottom: var(--spacing-xl);
        }

        .contact-form-section h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-md);
            color: var(--text-dark);
        }

        .contact-form {
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
        }

        .form-group {
            margin-bottom: var(--spacing-md);
        }

        .form-group label {
            display: block;
            font-size: var(--font-size-base);
            font-weight: 600;
            margin-bottom: var(--spacing-xs);
            color: var(--text-dark);
        }

        .form-group input,
        .form-group select,
        .form-group textarea {
            width: 100%;
            padding: 14px;
            font-size: var(--font-size-base);
            border: 2px solid var(--border-color);
            border-radius: var(--border-radius);
            font-family: inherit;
            transition: border-color 0.3s ease;
        }

        .form-group input:focus,
        .form-group select:focus,
        .form-group textarea:focus {
            outline: none;
            border-color: var(--primary-color);
        }

        .form-group small {
            display: block;
            font-size: 14px;
            color: var(--text-light);
            margin-top: 4px;
        }

        .form-info {
            margin-bottom: var(--spacing-md);
        }

        .form-info p {
            font-size: 16px;
            color: var(--text-light);
        }

        .form-message {
            margin-top: var(--spacing-md);
            padding: var(--spacing-sm);
            border-radius: var(--border-radius);
            font-size: var(--font-size-base);
        }

        .form-message.success {
            background-color: #d1fae5;
            color: #065f46;
        }

        .form-message.error {
            background-color: #fee2e2;
            color: #991b1b;
        }

        .contact-info-section h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-md);
            color: var(--text-dark);
        }

        .contact-info-card {
            background-color: var(--bg-gray);
            padding: var(--spacing-md);
            border-radius: var(--border-radius);
            margin-bottom: var(--spacing-md);
        }

        .info-icon {
            font-size: 32px;
            margin-bottom: var(--spacing-xs);
        }

        .contact-info-card h4 {
            font-size: var(--font-size-large);
            margin-bottom: var(--spacing-xs);
            color: var(--text-dark);
        }

        .info-large {
            font-size: var(--font-size-xl);
            font-weight: 600;
            color: var(--primary-color);
            margin-bottom: var(--spacing-xs);
        }

        .info-large a {
            color: var(--primary-color);
        }

        .zone-list {
            padding-left: var(--spacing-md);
        }

        .zone-list li {
            font-size: var(--font-size-base);
            margin-bottom: var(--spacing-xs);
            list-style: disc;
        }

        .urgence-info {
            background-color: #fef3c7;
            padding: var(--spacing-md);
            border-radius: var(--border-radius);
            border-left: 4px solid var(--accent-color);
        }

        .urgence-info h4 {
            font-size: var(--font-size-large);
            margin-bottom: var(--spacing-sm);
            color: var(--text-dark);
        }

        .urgence-info p {
            margin-bottom: var(--spacing-sm);
        }

        .faq-section {
            margin-top: var(--spacing-xl);
            padding-top: var(--spacing-xl);
            border-top: 2px solid var(--border-color);
        }

        .faq-section h2 {
            font-size: var(--font-size-xxl);
            text-align: center;
            margin-bottom: var(--spacing-lg);
            color: var(--text-dark);
        }

        .faq-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: var(--spacing-md);
        }

        .faq-item {
            background-color: var(--bg-gray);
            padding: var(--spacing-md);
            border-radius: var(--border-radius);
        }

        .faq-item h4 {
            font-size: var(--font-size-large);
            margin-bottom: var(--spacing-xs);
            color: var(--primary-color);
        }

        .faq-item p {
            font-size: var(--font-size-base);
            color: var(--text-medium);
            line-height: 1.6;
        }

        /* ========================================
           PAGE CONNEXION
           ======================================== */
        .login-page {
            background-color: var(--bg-light);
            min-height: 60vh;
            display: flex;
            align-items: center;
        }

        .login-container {
            max-width: 500px;
            margin: 0 auto;
        }

        .login-box,
        .register-box {
            background-color: var(--bg-white);
            padding: var(--spacing-xl);
            border-radius: var(--border-radius);
            box-shadow: var(--shadow-lg);
        }

        .login-box h1,
        .register-box h1 {
            font-size: var(--font-size-xxl);
            color: var(--text-dark);
            margin-bottom: var(--spacing-xs);
            text-align: center;
        }

        .login-subtitle {
            text-align: center;
            color: var(--text-medium);
            margin-bottom: var(--spacing-lg);
        }

        .auth-form .form-group {
            margin-bottom: var(--spacing-md);
        }

        .form-options {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: var(--spacing-md);
            flex-wrap: wrap;
        }

        .checkbox-label {
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
            cursor: pointer;
        }

        .checkbox-label input[type="checkbox"] {
            width: 20px;
            height: 20px;
            cursor: pointer;
        }

        .forgot-password {
            color: var(--primary-color);
            font-size: var(--font-size-base);
        }

        .forgot-password:hover {
            text-decoration: underline;
        }

        .auth-divider {
            text-align: center;
            margin: var(--spacing-lg) 0;
            position: relative;
        }

        .auth-divider:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            height: 1px;
            background-color: var(--border-color);
        }

        .auth-divider span {
            background-color: var(--bg-white);
            padding: 0 var(--spacing-sm);
            position: relative;
            color: var(--text-light);
        }

        .login-benefits {
            margin-top: var(--spacing-lg);
            padding-top: var(--spacing-lg);
            border-top: 1px solid var(--border-color);
        }

        .login-benefits h3 {
            font-size: var(--font-size-large);
            margin-bottom: var(--spacing-sm);
            color: var(--text-dark);
        }

        .login-benefits ul {
            padding-left: 0;
        }

        .login-benefits li {
            font-size: var(--font-size-base);
            margin-bottom: var(--spacing-xs);
            color: var(--text-medium);
        }

        /* ========================================
           RÉSEAUX SOCIAUX
           ======================================== */
        .social-intro {
            text-align: center;
            margin-bottom: var(--spacing-xl);
        }

        .social-intro h2 {
            font-size: var(--font-size-xxl);
            color: var(--text-dark);
            margin-bottom: var(--spacing-sm);
        }

        .social-intro p {
            font-size: var(--font-size-large);
            color: var(--text-medium);
        }

        .social-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: var(--spacing-lg);
            margin-bottom: var(--spacing-xl);
        }

        .social-card {
            background-color: var(--bg-gray);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            box-shadow: var(--shadow-md);
            text-align: center;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
        }

        .social-card:hover {
            transform: translateY(-5px);
            box-shadow: var(--shadow-lg);
        }

        .social-icon {
            font-size: 80px;
            margin-bottom: var(--spacing-md);
        }

        .social-card h3 {
            font-size: var(--font-size-xl);
            margin-bottom: var(--spacing-sm);
            color: var(--text-dark);
        }

        .social-description {
            font-size: var(--font-size-base);
            color: var(--text-medium);
            margin-bottom: var(--spacing-lg);
            line-height: 1.6;
        }

        .social-stats {
            display: flex;
            justify-content: space-around;
            margin-bottom: var(--spacing-lg);
            padding: var(--spacing-md) 0;
            border-top: 1px solid var(--border-color);
            border-bottom: 1px solid var(--border-color);
        }

        .stat {
            text-align: center;
        }

        .stat-number {
            font-size: var(--font-size-xl);
            font-weight: 700;
            color: var(--primary-color);
            display: block;
        }

        .stat-label {
            font-size: 14px;
            color: var(--text-light);
        }

        .social-button {
            display: inline-block;
            background-color: var(--primary-color);
            color: white;
            padding: 14px 32px;
            border-radius: var(--border-radius);
            font-size: var(--font-size-base);
            font-weight: 600;
            text-decoration: none;
            transition: all 0.3s ease;
        }

        .social-button:hover {
            background-color: var(--primary-dark);
            transform: translateY(-2px);
            box-shadow: var(--shadow-md);
        }

        .youtube-button {
            background-color: #ff0000;
        }

        .youtube-button:hover {
            background-color: #cc0000;
        }

        .instagram-button {
            background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
        }

        .instagram-button:hover {
            opacity: 0.8;
        }

        .twitter-button {
            background-color: #1DA1F2;
        }

        .twitter-button:hover {
            background-color: #1a8cd8;
        }

        .content-section {
            background-color: var(--bg-white);
            padding: var(--spacing-lg);
            border-radius: var(--border-radius);
            margin-bottom: var(--spacing-xl);
        }

        .content-section h3 {
            font-size: var(--font-size-xl);
            color: var(--text-dark);
            margin-bottom: var(--spacing-md);
        }

        .content-list {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: var(--spacing-md);
        }

        .content-item {
            background-color: var(--bg-gray);
            padding: var(--spacing-md);
            border-radius: var(--border-radius);
            border-left: 4px solid var(--primary-color);
        }

        .content-item h4 {
            font-size: var(--font-size-large);
            color: var(--text-dark);
            margin-bottom: var(--spacing-xs);
        }

        .content-item p {
            font-size: var(--font-size-base);
            color: var(--text-medium);
        }

        .follow-cta {
            background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
            color: white;
            padding: var(--spacing-xl);
            border-radius: var(--border-radius);
            text-align: center;
        }

        .follow-cta h2 {
            font-size: var(--font-size-xxl);
            margin-bottom: var(--spacing-md);
        }

        .follow-cta p {
            font-size: var(--font-size-large);
            margin-bottom: var(--spacing-lg);
        }

        .follow-buttons {
            display: flex;
            gap: var(--spacing-md);
            justify-content: center;
            flex-wrap: wrap;
        }

        @media (max-width: 768px) {
            :root {
                --font-size-hero: 32px;
                --font-size-xxl: 28px;
                --font-size-xl: 22px;
            }

            .header-content {
                flex-direction: column;
                align-items: flex-start;
            }

            .main-nav ul {
                flex-direction: column;
                width: 100%;
            }

            .main-nav a {
                width: 100%;
                text-align: center;
            }

            .hero-buttons {
                flex-direction: column;
            }

            .contact-layout {
                grid-template-columns: 1fr;
            }

            .services-grid,
            .features-grid,
            .testimonials-grid,
            .forfaits-grid,
            .team-grid,
            .stats-grid,
            .faq-grid {
                grid-template-columns: 1fr;
            }

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

            .social-stats {
                flex-direction: column;
                gap: var(--spacing-sm);
            }

            .follow-buttons {
                flex-direction: column;
            }

            .social-button {
                width: 100%;
            }
        }