/*
Theme Name:  Blocksy Child
Description:  Thème enfant personnalisé pour Cesc Riviera
Author:       Web Up
Template:     blocksy
Version:      1.0.0
*/

/* Ajoute ton CSS personnalisé en dessous de cette ligne */

/* ==========================================================================
   FORCER LA TAILLE DE TOUS LES TITRES H2 SUR MOBILE
   ========================================================================== */
@media (max-width: 767px) {
    .cr-title-h2,
    .cr-bento-section .cr-title-h2,
    .cr-secteur-header .cr-title-h2,
    .cr-faq-header .cr-title-h2,
    .cr-calc-seo-content .cr-title-h2,
    .cr-trust-content .cr-title-h2 {
        font-size: 2.5rem !important; /* Force la taille exacte du huge-h2 sur mobile */
        line-height: 1.1 !important; /* Resserre les lignes pour un aspect plus massif */
        letter-spacing: -0.5px !important; /* Donne cet aspect premium et compact */
    }
}

/* ==========================================================================
   VARIABLES GLOBALES CESC RIVIERA
   ========================================================================== */
:root {
    --cr-dore: #C6A75E;
    --cr-beige: #F5F1E8;
    --cr-blanc: #FFFFFF;
    --cr-noir: #1A1A1A;
    --cr-gris: #6D6D6D;
    --cr-anthracite: #2C2C2C;
    --cr-marine: #1C2A39;
    --cr-font-playfair: 'Playfair Display', serif;
    --cr-font-poppins: 'Poppins', sans-serif;
}

/* ==========================================================================
   TYPOGRAPHIE GLOBALE & RÉINITIALISATION
   ========================================================================== */
.cr-header, .cr-hero, .cr-insights-section, .cr-3d-section, .cr-bento-section, .e85-calculator-section {
    box-sizing: border-box;
}

.cr-header *, .cr-hero *, .cr-insights-section *, .cr-3d-section *, .cr-bento-section *, .e85-calculator-section * {
    box-sizing: inherit;
}

/* Application systématique des polices */
.cr-title-h2 {
    font-family: var(--cr-font-playfair);
    font-size: clamp(2.25rem, 4vw, 3rem);
    font-weight: 600;
    line-height: 1.2;
    margin: 0;
}

.cr-card-title-dark,
.cr-feature-title,
.cr-bento-title {
    font-family: var(--cr-font-playfair);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 0.5rem 0;
}

.cr-calc-text,
.cr-card-text-dark,
.cr-feature-text,
.cr-bento-text,
.cr-feature-desc {
    font-family: var(--cr-font-poppins);
    font-size: 1rem;
    line-height: 1.6;
    font-weight: 300;
}

.cr-btn {
    font-family: var(--cr-font-poppins);
    font-weight: 600;
    font-size: 1rem;
    padding: 1rem 2.5rem;
    border-radius: 9999px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
}

.cr-btn-gold {
    background-color: var(--cr-dore);
    color: var(--cr-blanc);
    border: none;
    box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1);
}

.cr-btn-gold:hover {
    background-color: #b59853;
    transform: translateY(-4px);
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.15);
}

/* ==========================================================================
   1. HEADER & NAVIGATION
   ========================================================================== */
.cr-header {
    position: absolute;
    top: 2rem;
    left: 0;
    width: 100%;
    z-index: 50;
    display: flex;
    justify-content: center;
    padding: 0 1.5rem;
    font-family: var(--cr-font-poppins);
}

.cr-nav-container {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.cr-glass {
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: 0 8px 32px 0 rgba(28, 42, 57, 0.2);
}

.cr-nav-group {
    display: flex;
    align-items: center;
    gap: 2rem;
    padding: 0.75rem 2.5rem;
    border-radius: 9999px;
}

.cr-nav-link {
    color: var(--cr-blanc);
    font-weight: 500;
    font-size: 0.875rem;
    text-decoration: none;
    transition: color 0.3s ease;
    white-space: nowrap;
    font-family: var(--cr-font-poppins);
}

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

.cr-nav-dot {
    width: 4px;
    height: 4px;
    background-color: var(--cr-dore);
    border-radius: 50%;
}

.cr-nav-logo-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

.cr-logo-img {
    height: 90px;
    width: auto;
    object-fit: contain;
    filter: drop-shadow(0 4px 6px rgba(0,0,0,0.2));
}

/* ==========================================================================
   MENU DÉROULANT (DROPDOWN)
   ========================================================================== */
.cr-dropdown {
    position: relative;
    display: inline-block;
}

/* Flèche pour indiquer le menu */
.cr-nav-link-dropdown {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    cursor: default; /* Évite que l'utilisateur pense que c'est un lien cliquable s'il n'y a pas de page mère */
}

/* Conteneur invisible pour maintenir le survol */
.cr-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    padding-top: 1.2rem; 
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 100;
    min-width: 220px;
}

/* Apparition au survol */
.cr-dropdown:hover .cr-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

/* Style de la bulle déroulante (glassmorphism sombre) */
.cr-dropdown-content {
    background: rgba(28, 42, 57, 0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 16px;
    padding: 0.5rem 0;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

/* Liens du sous-menu */
.cr-dropdown-link {
    color: var(--cr-blanc);
    padding: 0.75rem 1.5rem;
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 400;
    font-family: var(--cr-font-poppins);
    transition: all 0.2s ease;
    text-align: center;
}

.cr-dropdown-link:hover {
    background: rgba(198, 167, 94, 0.15);
    color: var(--cr-dore);
}

/* ==========================================================================
   2. SECTION HERO (RECENTRÉE)
   ========================================================================== */
.cr-hero {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 750px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center; /* On remet au centre parfait */
    overflow: hidden;
    font-family: var(--cr-font-poppins);
    color: var(--cr-noir);
    background-color: var(--cr-beige);
}

/* ==========================================================================
   TITRE H1 : OMBRE STYLE APPLE 2026
   ========================================================================== */
.cr-title {
    font-family: var(--cr-font-playfair);
    font-size: clamp(2rem, 4vw, 3.75rem);
    font-weight: 700;
    color: var(--cr-blanc);
    line-height: 1.2;
    max-width: 60rem;
    margin: 0;
    margin-top: -5px;
    /* On remplace l'ancien filter par un text-shadow multi-couches profond et diffus */
    text-shadow: 0 4px 15px rgba(0, 0, 0, 0.4), 
                 0 15px 40px rgba(0, 0, 0, 0.6), 
                 0 30px 80px rgba(0, 0, 0, 0.8);
}

.cr-hero-bg {
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    z-index: 0;
}

.cr-picture {
    display: block;
    width: 100%;
    height: 100%;
}

.cr-bg-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cr-overlay-top {
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    background: linear-gradient(to bottom, rgba(26, 26, 26, 0.7) 0%, transparent 50%, var(--cr-beige) 100%);
}

.cr-overlay-bottom {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 16rem;
    background: linear-gradient(to top, var(--cr-beige) 0%, rgba(245, 241, 232, 0.9) 55%, transparent 100%);
}

.cr-main-content {
    position: relative;
    z-index: 10;
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    
    /* Ajout d'une marge haute de sécurité pour éviter le menu */
    margin-top: 80px; 
    
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    
    /* FIX : On annule le décalage vers le haut (-85px) qui cassait le responsive */
    transform: translateY(0); 
}

.cr-italic {
    font-style: italic;
    font-weight: 300;
}

.cr-subtitle {
    font-family: var(--cr-font-poppins);
    font-size: 1.125rem;
    color: var(--cr-blanc);
    margin: 1.5rem auto 2rem;
    max-width: 44rem;
    font-weight: 300;
    background-color: rgba(26, 26, 26, 0.2);
    padding: 0.75rem 1.5rem;
    border-radius: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.cr-cta-group {
    margin-top: 5rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.5rem;
}

.cr-btn-outline {
    background-color: rgba(26, 26, 26, 0.65);
    color: var(--cr-blanc);
    border: 1px solid rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.cr-btn-outline:hover {
    background-color: rgba(26, 26, 26, 0.85);
    border-color: rgba(255, 255, 255, 0.4);
    transform: translateY(-4px);
}

.cr-widget { display: none; }

.cr-widget.cr-glass {
    background: rgba(26, 26, 26, 0.65);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.5);
}

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

.cr-border-bottom {
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    padding-bottom: 0.75rem;
}

.cr-mb-6 { margin-bottom: 1.5rem; }

.cr-widget-title {
    color: var(--cr-blanc);
    font-weight: 500;
    font-size: 0.875rem;
    font-family: var(--cr-font-poppins);
}

.cr-widget-subtitle {
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.75rem;
    font-family: var(--cr-font-poppins);
}

.cr-widget-body {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

/* ==========================================================================
   MISE À JOUR : JAUGE CIRCULAIRE (92%)
   ========================================================================== */

.cr-circle-chart {
    position: relative;
    width: 5rem;
    height: 5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    /* On supprime l'ancien 'border' ici, tout est géré par la classe fill */
}

.cr-circle-fill {
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    border-radius: 50%;
    /* 1. Le conic-gradient crée le remplissage exact (92% or, le reste en or transparent) */
    background: conic-gradient(var(--cr-dore) 92%, rgba(198, 167, 94, 0.3) 0deg);
    
    /* 2. Le masque évide le centre pour créer l'anneau de 4px d'épaisseur (effet donut) */
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 4px), #fff calc(100% - 3px));
    mask: radial-gradient(farthest-side, transparent calc(100% - 4px), #fff calc(100% - 3px));
}

.cr-circle-text {
    font-family: var(--cr-font-playfair);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--cr-blanc);
}

.cr-circle-text span { font-size: 0.875rem; }

.cr-stats-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.cr-stat-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.cr-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.cr-dot-primary { background-color: var(--cr-dore); }
.cr-dot-secondary { background-color: rgba(255, 255, 255, 0.3); }

.cr-stat-label {
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.75rem;
    font-family: var(--cr-font-poppins);
}

.cr-user-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.cr-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background-color: var(--cr-marine);
    border: 1px solid var(--cr-dore);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cr-dore);
    font-size: 0.75rem;
    font-weight: 700;
    font-family: var(--cr-font-poppins);
}

.cr-user-name {
    color: var(--cr-blanc);
    font-weight: 500;
    font-size: 0.875rem;
    font-family: var(--cr-font-poppins);
}

.cr-amount {
    font-family: var(--cr-font-playfair);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--cr-dore);
}

.cr-bar-chart {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    height: 4rem;
    gap: 0.25rem;
    margin-bottom: 1rem;
}

.cr-bar {
    width: 100%;
    border-radius: 0.125rem 0.125rem 0 0;
}

.cr-bar-primary { background-color: rgba(198, 167, 94, 0.8); }
.cr-bar-active { background-color: var(--cr-dore); }
.cr-bar-secondary { background-color: rgba(255, 255, 255, 0.2); }

.cr-chart-labels {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.6);
    font-family: var(--cr-font-poppins);
}

@media (max-width: 991px) {
    .cr-main-content {
        margin-top: 0px !important; /* Réduit ou remplace le centrage automatique */
    }
}

/* ==========================================================================
   3. SECTION 2 : INSIGHTS & DASHBOARD (MARINE MODE)
   ========================================================================== */
.cr-insights-section {
    background-color: var(--cr-beige);
    padding: 2rem 1.5rem;
    font-family: var(--cr-font-poppins);
}

.cr-container {
    max-width: 1280px;
    margin: 0 auto;
}

.cr-insights-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 4rem;
    gap: 4rem;
}

.cr-title-h2 {
    color: var(--cr-noir);
    flex: 1;
}

.cr-insights-intro {
    flex: 1;
    font-size: 1.125rem;
    color: var(--cr-anthracite);
    line-height: 1.6;
    font-weight: 300;
    margin: 0;
    max-width: 600px;
    font-family: var(--cr-font-poppins);
}

.cr-insights-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

.cr-insights-features {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.cr-feature-item {
    display: flex;
    gap: 1.5rem;
    padding: 1rem 0;
}

.cr-feature-number {
    font-family: var(--cr-font-poppins);
    font-size: 1.5rem;
    font-weight: 300;
    color: rgba(26, 26, 26, 0.3);
    line-height: 1.2;
}

.cr-feature-icon {
    width: 3rem;
    height: 3rem;
    background: rgba(255,255,255,0.1);
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cr-blanc);
}

.cr-feature-icon svg {
    width: 1.5rem;
    height: 1.5rem;
}

.cr-feature-text { flex: 1; }

.cr-feature-title { color: var(--cr-noir); }

.cr-feature-highlight {
    background-color: var(--cr-marine);
    border-radius: 1.5rem;
    padding: 2rem;
    box-shadow: 0 20px 40px rgba(28, 42, 57, 0.25);
    transform: translateX(-1rem);
    width: calc(100% + 2rem);
}

.cr-feature-highlight .cr-feature-title { color: var(--cr-blanc); }
.cr-feature-highlight .cr-feature-desc { color: rgba(255, 255, 255, 0.7); }
.cr-feature-highlight .cr-feature-number { color: var(--cr-blanc); }

.cr-insights-visual {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 500px;
    border-radius: 2rem;
    background: linear-gradient(135deg, rgba(245,241,232,0) 0%, rgba(198,167,94,0.15) 40%, rgba(28,42,57,0.4) 100%); 
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    overflow: hidden;
}

.cr-dashboard-card {
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 1.5rem;
    padding: 2.5rem;
    width: 100%;
    max-width: 450px;
    box-shadow: 0 25px 50px rgba(0,0,0,0.05);
}

.cr-dash-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}

.cr-dash-title {
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--cr-noir);
    font-family: var(--cr-font-poppins);
}

.cr-dash-options {
    display: flex;
    gap: 4px;
    background: var(--cr-beige);
    padding: 8px;
    border-radius: 50%;
}

.cr-dash-options .cr-dot {
    width: 4px;
    height: 4px;
    background: var(--cr-gris);
    border-radius: 50%;
}

.cr-dash-value {
    font-family: var(--cr-font-playfair);
    font-size: 3.5rem;
    font-weight: 700;
    color: var(--cr-noir);
    line-height: 1;
    margin-bottom: 1rem;
}

.cr-dash-badge-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 3rem;
}

.cr-dash-badge {
    background-color: rgba(46, 204, 113, 0.15);
    color: #27ae60;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    font-weight: 500;
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-family: var(--cr-font-poppins);
}

.cr-dash-compare {
    color: var(--cr-gris);
    font-size: 0.875rem;
    font-family: var(--cr-font-poppins);
}

.cr-dash-chart {
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    height: 150px;
    gap: 0.5rem;
    margin-top: 2rem;
}

.cr-bar-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    height: 100%;
    justify-content: flex-end;
    position: relative;
    z-index: 2;
}

.cr-chart-bar {
    width: 100%;
    background-color: rgba(28, 42, 57, 0.15);
    border-radius: 0.5rem;
    transition: height 0.5s ease;
}

.cr-bar-gold {
    background-color: var(--cr-dore);
    position: relative;
    box-shadow: 0 10px 20px rgba(198, 167, 94, 0.3);
}

.cr-bar-label {
    font-size: 0.75rem;
    color: var(--cr-gris);
    text-transform: uppercase;
    font-family: var(--cr-font-poppins);
}

.cr-bar-col-active .cr-bar-label {
    font-weight: 600;
    color: var(--cr-noir);
    background: var(--cr-beige);
    padding: 2px 8px;
    border-radius: 12px;
}

.cr-bar-tooltip {
    position: absolute;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--cr-marine);
    color: var(--cr-blanc);
    font-size: 0.75rem;
    padding: 4px 8px;
    border-radius: 4px;
    font-weight: 600;
    font-family: var(--cr-font-poppins);
}

.cr-trend-line {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 80%;
    z-index: 1;
    pointer-events: none;
}

/* ==========================================================================
   4. SECTION PILIERS 3D DYNAMIQUES
   ========================================================================== */
.cr-3d-section {
    position: relative;
    width: 100%;
    min-height: 85vh; 
    background-color: var(--cr-marine); 
    border-radius: 2rem;
    margin: 4rem auto;
    max-width: 1360px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end; 
    overflow: visible; 
    padding-bottom: 2rem;
    margin-top: 100px; 
}

.cr-3d-text-layer {
    position: absolute;
    top: 5rem;
    left: 0;
    width: 100%;
    text-align: center;
    z-index: 2;
    padding: 0 1.5rem;
}

.cr-huge-h2 {
    font-family: var(--cr-font-playfair);
    font-size: clamp(2.5rem, 6vw, 4.5rem); 
    font-weight: 600;
    color: var(--cr-blanc);
    line-height: 1.1;
    margin: 0;
    letter-spacing: -1px;
    text-shadow: 0 10px 30px rgba(0,0,0,0.8); 
}

.cr-huge-h2 .cr-italic {
    font-family: var(--cr-font-playfair);
    font-style: italic;
    font-weight: 500;
    letter-spacing: 0;
}

.cr-3d-image-layer {
    position: absolute;
    top: -150px; 
    left: 50%;
    transform: translateX(-50%) scale(1.1); 
    width: 120%; 
    max-width: none;
    z-index: 1;
    pointer-events: none;
    transform-origin: center center;
}

.cr-cutout-villa {
    width: 100%;
    height: auto;
    display: block;
    filter: drop-shadow(0 20px 30px rgba(0,0,0,0.5));
}

.cr-3d-cards-layer {
    position: relative;
    z-index: 3;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    margin-top: 45vh; 
}

.cr-glass-card-dark {
    background: rgba(000, 000, 000, 0.5); 
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 1.5rem;
    padding: 2.5rem 2rem;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, background 0.3s ease;
}

.cr-glass-card-dark:hover {
    transform: translateY(-5px);
    background: rgba(0, 0, 0, 0.7);
}

.cr-card-title-dark {
    color: var(--cr-blanc);
}

.cr-card-text-dark {
    color: rgba(255, 255, 255, 0.7);
    margin: 0 0 2.5rem 0;
    flex-grow: 1;
}

.cr-card-link-dark {
    font-family: var(--cr-font-poppins);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--cr-blanc);
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.1);
    transition: color 0.3s ease;
}

.cr-card-link-dark:hover {
    color: var(--cr-dore);
}

.cr-arrow-circle-dark {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    transition: all 0.3s ease;
}

.cr-card-link-dark:hover .cr-arrow-circle-dark {
    background-color: var(--cr-dore);
    border-color: var(--cr-dore);
    color: var(--cr-blanc);
}

/* ==========================================================================
   5. SECTION CALCULATEUR DE RENTABILITÉ (DARK MODE INTÉGRAL)
   ========================================================================== */

/* Structure principale */
.e85-calculator-section.e85-dark { /* Remarque : on utilise e85-dark ici */
    padding-top: 15rem;
    padding-bottom: 8rem;
    background-color: #1C2A39; /* Fond sombre principal */
    position: relative;
    overflow: hidden; 
    font-family: var(--cr-font-poppins);
}

.cr-bg-halo-gold {
    position: absolute;
    top: 50%;
    left: -10%;
    width: 800px;
    height: 800px;
    background: radial-gradient(circle, rgba(198, 167, 94, 0.12) 0%, rgba(255, 255, 255, 0) 70%);
    transform: translateY(-50%);
    z-index: 0;
    pointer-events: none;
}

.cr-relative-z {
    position: relative;
    z-index: 1; 
}

.cr-calc-split-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    max-width: 1200px;
    margin: 0 auto;
    align-items: center;
}

/* Typographie de la colonne de gauche */
.cr-badge-solution {
    font-family: var(--cr-font-poppins);
    display: inline-block;
    background-color: rgba(198, 167, 94, 0.1);
    color: var(--cr-dore);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 0.4rem 1rem;
    border-radius: 4px;
    margin-bottom: 1.5rem;
}

.cr-calc-seo-content .cr-title-h2 {
    color: var(--cr-blanc);
    margin-bottom: 1.5rem;
    font-family: var(--cr-font-poppins);
}

.cr-calc-text {
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 2.5rem;
    line-height: 1.6;
    font-family: var(--cr-font-poppins);
}

/* Grille des 4 caractéristiques (Isolée pour éviter les conflits) */
.cr-calc-features-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.cr-calc-feature-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    background: rgba(255, 255, 255, 0.03); /* Fond type carte */
    padding: 1.5rem; 
    border-radius: 1rem; 
    border: 1px solid rgba(255, 255, 255, 0.05); 
    transition: transform 0.3s ease, background 0.3s ease; 
}

.cr-calc-feature-item:hover {
    background: rgba(255, 255, 255, 0.06);
    transform: translateY(-5px);
}

.cr-calc-feature-title {
    color: var(--cr-blanc);
    margin-bottom: 0.5rem;
    font-size: 1.05rem;
    font-weight: 600;
    font-family: var(--cr-font-poppins);
}

.cr-calc-feature-text {
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.85rem;
    line-height: 1.5;
    margin: 0;
    font-family: var(--cr-font-poppins);
}

.cr-calc-feature-icon {
    background-color: rgba(255, 255, 255, 0.05); 
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--cr-dore); 
    width: 48px;
    height: 48px;
    padding: 12px;
    border-radius: 12px;
    margin-bottom: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cr-calc-feature-icon svg {
    width: 100%;
    height: 100%;
}

/* Colonne de droite : Le formulaire (Glassmorphism Dark) */
.cr-calc-wrapper-dark {
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 3rem;
    border-radius: 1.5rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

/* Champs Inputs et Selects */
.cr-input-group label {
    display: block;
    color: var(--cr-blanc);
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
    font-weight: 500;
    font-family: var(--cr-font-poppins);
}

.cr-input-group input, 
.cr-input-group select {
    width: 100%;
    min-height: 54px; 
    padding: 0.75rem 1rem;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 0.5rem;
    color: var(--cr-blanc);
    font-size: 1rem;
    font-family: var(--cr-font-poppins);
    line-height: 1.5; 
    transition: border-color 0.3s ease, background 0.3s ease;
}

.cr-input-group input:focus, 
.cr-input-group select:focus {
    outline: none;
    border-color: var(--cr-dore);
    background: rgba(0, 0, 0, 0.5);
}

.cr-input-group select {
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    /* Flèche SVG en blanc pour être visible sur fond sombre */
    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='%23ffffff' 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 1rem center;
    background-size: 1.2em;
    padding-right: 2.5rem; 
}

.cr-input-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

/* Grille et design des Checkboxes Dark */
.cr-amenities-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin: 1.5rem 0 2rem;
}

.cr-checkbox-dark {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
}

.cr-checkbox-dark input {
    display: none; 
}

.cr-custom-check {
    width: 22px;
    height: 22px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.cr-checkbox-dark input:checked + .cr-custom-check {
    background-color: var(--cr-dore);
    border-color: var(--cr-dore);
}

.cr-checkbox-dark input:checked + .cr-custom-check::after {
    content: '';
    width: 6px;
    height: 12px;
    border: solid #1C2A39; /* Couleur de la coche = fond de la section pour contraster avec l'or */
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    margin-bottom: 2px;
}

.cr-check-label {
    color: var(--cr-blanc);
    font-size: 0.9rem;
    font-family: var(--cr-font-poppins);
}

.cr-full-width {
    display: block !important;
    width: 100%;
    text-align: center;
    box-sizing: border-box;
    margin-top: 2rem;
}

/* Zone des résultats finaux */
.cr-calc-results-dark {
    background: rgba(198, 167, 94, 0.1);
    border-radius: 1rem;
    padding: 2rem;
    text-align: center;
    border: 1px solid rgba(198, 167, 94, 0.2);
}

.cr-result-item {
    margin-bottom: 1.5rem;
}

.cr-result-label-dark {
    display: block;
    color: var(--cr-dore);
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 1px;
    margin-bottom: 0.5rem;
    font-weight: 600;
    font-family: var(--cr-font-poppins);
}

.cr-result-value-dark {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--cr-blanc);
    font-family: var(--cr-font-poppins);
}

.cr-calc-disclaimer-dark {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.5);
    margin-top: 1rem;
    font-family: var(--cr-font-poppins);
}

/* RESPONSIVE */
@media (max-width: 1023px) {
    .cr-calc-split-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    .cr-input-row, .cr-amenities-grid, .cr-calc-features-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   6. SECTION OFFRES & BENTO (LIGHT MODE)
   ========================================================================== */

.cr-bento-section {
    background-color: #F5F1E8; 
    padding: 6rem 1.5rem;
    font-family: 'Poppins', sans-serif; /* Typographie globale du texte */
}

.cr-bento-header {
    text-align: center;
    max-width: 900px;
    margin: 0 auto 5rem auto;
}

/* Typographie des titres principaux */
.cr-bento-section .cr-title-h2 {
    font-family: 'Playfair Display', serif;
    color: #1a1a1a;
    margin-bottom: 1.5rem;
}

.cr-bento-intro {
    color: #4a4a4a;
    font-size: 1.1rem;
    line-height: 1.6;
}

/* --- GRILLE PRINCIPALE (12 COLONNES) --- */
.cr-bento-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: minmax(320px, auto);
    gap: 1.5rem;
    max-width: 1200px;
    margin: 0 auto;
}

/* Placement exact des 7 cartes */
.cr-card-annonce { grid-column: span 7; }
.cr-card-accueil { grid-column: span 5; }
.cr-card-maintenance { grid-column: span 4; }
.cr-card-menage { grid-column: span 8; }
.cr-card-pricing-main { grid-column: span 12; }
.cr-card-pack { grid-column: span 6; }
.cr-card-options { grid-column: span 6; }

/* --- STYLE DE BASE DES CARTES --- */
.cr-bento-card {
    position: relative;
    background-color: #ffffff; 
    border-radius: 1.5rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04);
    border: 1px solid rgba(0, 0, 0, 0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    z-index: 1;
}

.cr-bento-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08);
}

/* Typographie interne des cartes */
.cr-bento-title {
    font-family: 'Playfair Display', serif;
    color: #1a1a1a;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
}

.cr-bento-text {
    color: #4a4a4a;
    font-size: 0.95rem;
    line-height: 1.5;
}

/* Halos décoratifs subtils */
.cr-halo-gold {
    position: absolute;
    top: -50%; right: -50%; width: 100%; height: 100%;
    background: radial-gradient(circle, rgba(198, 167, 94, 0.15) 0%, transparent 70%);
    filter: blur(40px);
    z-index: 0;
    pointer-events: none;
}

.cr-halo-marine {
    position: absolute;
    bottom: -50%; left: -50%; width: 100%; height: 100%;
    background: radial-gradient(circle, rgba(28, 42, 57, 0.08) 0%, transparent 70%);
    filter: blur(40px);
    z-index: 0;
    pointer-events: none;
}

/* --- CARTES SÉPARÉES (SPLIT) --- */
.cr-card-split {
    padding: 0; 
    justify-content: space-between; 
}

.cr-split-text {
    position: relative;
    padding: 2.5rem;
    z-index: 2;
    flex-grow: 1; 
}

.cr-split-image-wrapper {
    position: relative;
    width: 100%;
    height: 240px; 
    flex-shrink: 0; 
    overflow: hidden;
    z-index: 2;
    border-radius: 0 0 1.5rem 1.5rem; 
}

.cr-split-img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.cr-bento-card:hover .cr-split-img {
    transform: scale(1.05);
}

/* --- CARTE IMAGE DE FOND (COVER) --- */
.cr-card-cover {
    padding: 0;
    justify-content: flex-end;
}

.cr-bento-bg-img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    z-index: 0;
    transition: transform 0.5s ease;
}

.cr-bento-card:hover .cr-bento-bg-img {
    transform: scale(1.05);
}

/* Dégradé blanc en bas pour lire le texte sombre */
.cr-card-overlay-gradient {
    position: absolute;
    bottom: 0; left: 0;
    width: 100%; height: 80%;
    background: linear-gradient(to top, rgba(255,255,255, 1) 0%, rgba(255,255,255, 0.8) 40%, transparent 100%);
    z-index: 1;
    pointer-events: none;
}

.cr-content-bottom {
    position: relative;
    z-index: 2;
    padding: 2.5rem;
}

.cr-bento-tag {
    display: inline-block;
    background: #ffffff;
    border: 1px solid rgba(198, 167, 94, 0.5);
    color: var(--cr-dore);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 0.4rem 1rem;
    border-radius: 99px;
    margin-bottom: 1rem;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

/* --- CARTE MÉNAGE --- */
.cr-card-menage {
    padding: 2.5rem;
    justify-content: space-between;
}

.cr-menage-top {
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2rem;
}

.cr-bento-text-side {
    flex: 1;
    max-width: 350px;
}

.cr-menage-img-wrapper {
    flex: 1;
    height: 160px;
    border-radius: 1rem;
    overflow: hidden;
    position: relative; 
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.cr-menage-img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}

.cr-tasks-inline {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    padding-top: 1.5rem;
    margin-top: 1.5rem;
}

.cr-mockup-task {
    background: #f8f9fa;
    border: 1px solid rgba(0, 0, 0, 0.05);
    padding: 0.875rem 1rem;
    border-radius: 1rem;
    color: #1a1a1a;
    font-size: 0.85rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    flex: 1;
    text-align: center;
    white-space: nowrap;
}

.cr-task-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #27ae60;
}

.cr-task-dot.cr-dot-gold { 
    background: var(--cr-dore); 
}

/* ==========================================================================
   6. SECTION SERVICES (BENTO) & TARIFS (APPLE 2026)
   ========================================================================== */

.cr-bento-section {
    background-color: #F5F1E8; 
    padding: 6rem 1.5rem;
    font-family: 'Poppins', sans-serif;
    position: relative;
    overflow: hidden;
}

.cr-container {
    position: relative;
    z-index: 1;
    max-width: 1200px;
    margin: 0 auto;
}

/* --- TYPOGRAPHIE GLOBALE DE LA SECTION --- */
.cr-title-h2 {
    font-family: 'Playfair Display', serif;
    color: #1a1a1a;
    font-size: 2.8rem;
    line-height: 1.2;
    margin-bottom: 1.5rem;
}

.cr-bento-intro {
    color: #2c2c2c;
    font-size: 1.1rem;
    line-height: 1.6;
    margin-bottom: 4rem;
}

/* --- PARTIE 1 : GRILLE BENTO SERVICES --- */
.cr-bento-header {
    text-align: center;
    max-width: 900px;
    margin: 0 auto;
}

.cr-bento-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: minmax(320px, auto);
    gap: 1.5rem;
    margin-bottom: 6rem; /* Espace avant les tarifs */
}

.cr-card-annonce { grid-column: 1 / 2; grid-row: 1 / 2; }
.cr-card-accueil { grid-column: 2 / 3; grid-row: 1 / 2; }
.cr-card-maintenance { grid-column: 3 / 4; grid-row: 1 / 3; }
.cr-card-menage { grid-column: 1 / 3; grid-row: 2 / 3; }

.cr-bento-card {
    position: relative;
    background-color: #ffffff; 
    border-radius: 1.5rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 30px rgba(0,0,0,0.04);
    border: 1px solid rgba(0,0,0,0.05);
    transition: transform 0.3s ease;
    z-index: 1;
}

.cr-bento-card:hover {
    transform: translateY(-5px);
}

.cr-bento-title {
    font-family: 'Playfair Display', serif;
    color: #1a1a1a;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
}

.cr-bento-text {
    color: #2c2c2c;
    font-size: 0.95rem;
    line-height: 1.5;
}

/* Halos */
.cr-halo-gold, .cr-halo-marine, .cr-halo-wide {
    position: absolute;
    pointer-events: none;
    filter: blur(40px);
    z-index: 0;
}
.cr-halo-gold {
    top: -50%; right: -50%; width: 100%; height: 100%;
    background: radial-gradient(circle, rgba(198, 167, 94, 0.15) 0%, transparent 70%);
}
.cr-halo-marine {
    bottom: -50%; left: -50%; width: 100%; height: 100%;
    background: radial-gradient(circle, rgba(28, 42, 57, 0.08) 0%, transparent 70%);
}
.cr-halo-wide {
    top: 0; left: 20%; width: 80%; height: 100%;
    background: radial-gradient(ellipse at center, rgba(198, 167, 94, 0.2) 0%, transparent 100%);
}

/* Cards Bento Spécifiques */
.cr-card-split { padding: 0; justify-content: space-between; }
.cr-split-text { position: relative; padding: 2.5rem; z-index: 2; flex-grow: 1; }
.cr-split-image-wrapper { position: relative; width: 100%; height: 240px; overflow: hidden; z-index: 2; border-radius: 0 0 1.5rem 1.5rem; }
.cr-split-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.cr-bento-card:hover .cr-split-img { transform: scale(1.05); }

.cr-card-cover { padding: 0; justify-content: flex-end; }
.cr-bento-bg-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; transition: transform 0.5s ease; }
.cr-bento-card:hover .cr-bento-bg-img { transform: scale(1.05); }
.cr-card-overlay-gradient { position: absolute; bottom: 0; left: 0; width: 100%; height: 80%; background: linear-gradient(to top, rgba(255,255,255,1) 0%, rgba(255,255,255,0.7) 50%, transparent 100%); z-index: 1; pointer-events: none; }
.cr-content-bottom { position: relative; z-index: 2; padding: 2.5rem; }

.cr-card-menage { padding: 2.5rem; justify-content: space-between; }
.cr-menage-top { position: relative; z-index: 2; display: flex; justify-content: space-between; align-items: center; gap: 2rem; }
.cr-bento-text-side { flex: 1; max-width: 350px; }
.cr-menage-img-wrapper { flex: 1; height: 160px; border-radius: 1rem; overflow: hidden; position: relative; box-shadow: 0 10px 20px rgba(0,0,0,0.1); }
.cr-menage-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cr-tasks-inline { position: relative; z-index: 2; display: flex; justify-content: space-between; align-items: center; gap: 1rem; border-top: 1px solid rgba(0,0,0,0.05); padding-top: 1.5rem; margin-top: 1.5rem; }
.cr-mockup-task { background: #f8f9fa; border: 1px solid rgba(0,0,0,0.05); padding: 0.875rem 1rem; border-radius: 1rem; color: #1a1a1a; font-size: 0.85rem; font-weight: 500; display: flex; align-items: center; justify-content: center; gap: 0.6rem; flex: 1; text-align: center; white-space: nowrap; }
.cr-task-dot { width: 8px; height: 8px; border-radius: 50%; background: #27ae60; }
.cr-task-dot.cr-dot-gold { background: var(--cr-dore); }

/* ==========================================================================
   PARTIE 2 : TARIFS APPLE 2026
   ========================================================================== */

.cr-pricing-header-spacing {
    margin-bottom: 3rem;
}

.cr-pricing-grid-apple {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin-bottom: 2rem;
}

/* La carte Excellence prend 2 colonnes */
.cr-card-excellence {
    grid-column: span 2;
}

.cr-pricing-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 3.5rem;
    border-radius: 2.5rem;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.04);
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.05);
    transition: transform 0.3s ease;
}

.cr-pricing-card:hover {
    transform: translateY(-5px);
}

.cr-pricing-tag {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--cr-gris);
    margin-bottom: 0.5rem;
    font-weight: 500;
}

.cr-pricing-h3 {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    line-height: 1.1;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 1.5rem;
}

.cr-pricing-text {
    font-size: 0.95rem;
    line-height: 1.6;
    color: #4a4a4a;
    margin-bottom: 2.5rem;
}

.cr-price-display {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--cr-dore);
    margin-bottom: 1.5rem;
    font-family: 'Playfair Display', serif;
}

.cr-price-sub {
    font-size: 0.9rem;
    color: var(--cr-gris);
    font-weight: 400;
    font-family: 'Poppins', sans-serif;
}

/* --- LISTES À PUCES CORRIGÉES --- */
.cr-pricing-checklist {
    list-style: none;
    padding: 0;
    margin: 0 0 3rem 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    flex-grow: 1; /* Pousse le bouton vers le bas */
}

/* Grille interne pour l'offre Excellence */
.cr-checklist-two-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem 2.5rem;
    width: 100%;
}

.cr-pricing-checklist li {
    display: block; /* Remplace le 'flex' qui cassait le texte en gras */
    color: #4a4a4a;
    font-size: 0.95rem;
    line-height: 1.5;
    position: relative;
    padding-left: 1.5rem;
}

.cr-pricing-checklist li::before {
    content: '✦'; /* Étoile élégante comme sur la maquette */
    position: absolute;
    left: 0;
    color: var(--cr-dore);
    font-weight: bold;
    font-size: 1.1rem;
}

/* --- BOX COMMISSIONS --- */
.cr-commissions-box {
    background: rgba(198, 167, 94, 0.05); /* Fond très léger doré */
    border-radius: 1.5rem;
    padding: 2rem;
    width: 100%;
    margin-top: auto;
    margin-bottom: 2.5rem;
    border: 1px solid rgba(198, 167, 94, 0.2);
}

.cr-commission-rates {
    display: flex;
    gap: 3rem;
    flex-wrap: wrap;
}

.cr-rate-item {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
}

.cr-rate-label {
    font-family: var(--cr-font-poppins);
    font-size: 1rem;
    font-weight: 500;
    color: var(--cr-noir);
}

.cr-rate-value {
    font-family: var(--cr-font-playfair);
    font-size: 2rem;
    font-weight: 700;
    color: var(--cr-dore);
}

.cr-tva-text {
    font-family: var(--cr-font-poppins);
    font-size: 0.75rem;
    color: var(--cr-gris);
    margin: 1rem 0 0 0;
    font-style: italic;
}

/* Boutons */
.cr-btn-gold {
    background: linear-gradient(145deg, var(--cr-dore) 0%, #d4b56a 100%);
    color: #ffffff !important;
    border: none;
    border-radius: 99px;
    padding: 1rem 2rem;
    font-size: 1rem;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    transition: transform 0.3s ease;
}
.cr-btn-gold:hover { transform: scale(1.02); }
.cr-full-width { width: 100%; box-sizing: border-box; }

/* Responsive de la grille des prix */
@media (max-width: 1024px) {
    .cr-pricing-grid-apple {
        grid-template-columns: 1fr;
    }
    .cr-card-excellence {
        grid-column: span 1;
    }
    .cr-checklist-two-cols {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    .cr-rate-item {
        flex-direction: column;
        gap: 0;
    }
    .cr-rate-value {
        font-size: 2.2rem;
    }
    .cr-commissions-box {
        padding: 1.5rem;
    }
}

/* ==========================================================================
   RESPONSIVE DESIGN (GRILLE DES PRIX)
   ========================================================================== */

/* Tablettes (1024px et moins) */
@media (max-width: 1024px) {
    .cr-pricing-grid-apple {
        grid-template-columns: 1fr; /* On empile les deux cartes */
    }
    .cr-checklist-two-cols {
        grid-template-columns: 1fr; /* La liste passe sur 1 seule colonne */
    }
    .cr-commission-rates {
        gap: 2rem;
    }
}

/* Mobiles (767px et moins) */
@media (max-width: 767px) {
    .cr-pricing-card {
        padding: 2.5rem 1.5rem;
    }
    .cr-pricing-h3 {
        font-size: 1.8rem;
    }
    .cr-rate-value {
        font-size: 2.2rem;
    }
    .cr-price-display {
        font-size: 2.2rem;
    }
    .cr-commissions-box {
        padding: 1.5rem;
    }
}

/* ==========================================================================
   BLOC LARGE DARK : SERVICES À LA CARTE (OVERHAUL DESIGN)
   ========================================================================== */

.cr-card-dark-apple {
    grid-column: span 12;
    background: linear-gradient(145deg, #1C2A39 0%, #111a24 100%);
    border: 1px solid rgba(198, 167, 94, 0.3);
    color: #ffffff;
    position: relative; /* Indispensable pour la pastille flottante */
    margin-top: 2rem; /* Espace pour la pastille */
    padding: 5rem 3rem 4rem 3rem; /* On augmente le padding haut */
}

/* Pastille parfaitement centrée sur la bordure supérieure */
.cr-tag-floating {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #ffffff;
    border: 1px solid rgba(198, 167, 94, 0.5);
    color: var(--cr-dore);
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 0.6rem 1.5rem;
    border-radius: 99px;
    box-shadow: 0 10px 20px rgba(0,0,0,0.15);
    white-space: nowrap;
    z-index: 10;
}

/* En-tête centré */
.cr-centered-banner {
    text-align: center;
}

.cr-banner-header {
    max-width: 750px;
    margin: 0 auto 4rem auto;
}

.cr-pricing-h4 {
    font-family: 'Playfair Display', serif;
    font-size: 2.5rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 1rem;
}

.cr-pricing-text-dark {
    font-size: 1.1rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.8);
    font-family: 'Poppins', sans-serif;
}

/* La mini-grille des 3 services (remplace la liste à puces) */
.cr-services-mini-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin-bottom: 4rem;
}

.cr-service-box {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.5rem;
    padding: 2rem;
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    transition: transform 0.3s ease, background 0.3s ease;
}

.cr-service-box:hover {
    transform: translateY(-5px);
    background: rgba(255, 255, 255, 0.06);
}

.cr-service-price {
    font-family: 'Poppins', sans-serif;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 0.5rem;
}

.cr-service-title {
    font-family: 'Playfair Display', serif;
    color: var(--cr-dore);
    font-size: 1.3rem;
    margin-bottom: 1rem;
    line-height: 1.2;
}

.cr-service-desc {
    color: rgba(255, 255, 255, 0.7);
    font-family: 'Poppins', sans-serif;
    font-size: 0.95rem;
    line-height: 1.5;
    margin: 0;
}

/* ==========================================================================
   DOUBLE CTA & BOUTON GLASSMORPHISM
   ========================================================================== */

/* Centrage et espacement des deux boutons */
.cr-banner-action {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

/* Le bouton or (rappel pour qu'il soit identique en taille) */
.cr-btn-gold.cr-btn-large {
    padding: 1.25rem 3rem;
    border-radius: 99px;
    font-size: 1.1rem;
    font-family: 'Poppins', sans-serif;
}

/* Le nouveau bouton Glassmorphism */
.cr-btn-glass {
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #ffffff !important;
    border-radius: 99px;
    padding: 0.9rem 1.5rem;
    font-size: 1.1rem;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    transition: all 0.3s ease;
}

.cr-btn-glass:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.4);
    transform: translateY(-3px);
}

/* --- RESPONSIVE DE CE BLOC --- */
@media (max-width: 1023px) {
    .cr-services-mini-grid {
        grid-template-columns: 1fr; /* On empile sur tablette/mobile */
        gap: 1.5rem;
    }
    .cr-card-dark-apple {
        padding: 4rem 2rem;
    }
}

@media (max-width: 767px) {
    .cr-tag-floating {
        font-size: 0.7rem;
        padding: 0.5rem 1rem;
        width: 90%; /* Évite que la pastille déborde sur très petit écran */
        text-align: center;
        white-space: normal;
    }
    .cr-pricing-h4 {
        font-size: 2rem;
    }
}

.cr-bento-tag {
    display: inline-block;
    background: #ffffff;
    border: 1px solid rgba(198, 167, 94, 0.5);
    color: var(--cr-dore);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 0.4rem 1rem;
    border-radius: 99px;
    margin-bottom: 1.5rem;
}

.cr-dark-content-split {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 4rem;
}

.cr-pricing-h4 {
    font-family: 'Playfair Display', serif;
    font-size: 2.2rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 1rem;
}

.cr-pricing-text-dark {
    font-size: 1rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 2rem;
}

.cr-dark-pricing-checklist {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.cr-dark-pricing-checklist li {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.95rem;
    line-height: 1.5;
    position: relative;
    padding-left: 1.5rem;
}

.cr-dark-pricing-checklist li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--cr-dore);
    font-weight: bold;
}

.cr-dark-pricing-checklist strong {
    color: #ffffff;
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
    letter-spacing: 0.5px;
}

.cr-dark-pricing-side {
    min-width: 300px;
}

/* --- RESPONSIVE DESIGN --- */
@media (max-width: 1023px) {
    .cr-bento-grid {
        grid-template-columns: 1fr;
    }
    .cr-card-annonce, .cr-card-accueil, .cr-card-maintenance, .cr-card-menage {
        grid-column: span 1;
        grid-row: auto;
    }
    .cr-pricing-grid-apple {
        grid-template-columns: 1fr;
    }
    .cr-dark-content-split {
        flex-direction: column;
        align-items: flex-start;
    }
    .cr-dark-pricing-side {
        width: 100%;
    }
}

@media (max-width: 767px) {
    .cr-bento-section { padding: 4rem 1rem; }
    .cr-pricing-card, .cr-card-split .cr-split-text, .cr-card-menage { padding: 2rem; }
    .cr-pricing-h3 { font-size: 1.8rem; }
    .cr-pricing-h4 { font-size: 1.8rem; }
    .cr-menage-top, .cr-tasks-inline { flex-direction: column; }
}

/* ==========================================================================
   7. MEDIA QUERIES GLOBALES & RESPONSIVE
   ========================================================================== */

/* Masquer le Header codé sur mobile (géré par WordPress) */
@media (max-width: 767px) {
    .cr-header {
        display: none !important;
    }
}

/* --- Tablettes / Petits écrans PC --- */
@media (max-width: 1024px) {
    .cr-insights-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 1.5rem;
    }
    .cr-insights-grid {
        grid-template-columns: 1fr;
    }
    .cr-feature-highlight {
        transform: translateX(0);
        width: 100%;
    }
    .cr-3d-cards-layer {
        grid-template-columns: 1fr;
        gap: 1rem;
        margin-top: 35vh;
    }
    .cr-3d-image-layer {
        width: 140%;
        top: -100px;
    }
    .cr-calc-split-layout {
        grid-template-columns: 1fr;
        gap: 4rem;
    }
    .cr-bento-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .cr-card-maintenance {
        grid-column: 1 / 3;
        grid-row: 3 / 4;
        min-height: 400px;
    }
}

/* --- Mobiles / Petites tablettes --- */
@media (max-width: 768px) {
    .cr-menage-top {
        flex-direction: column;
        align-items: flex-start;
    }
    .cr-bento-text-side {
        max-width: 100%;
    }
    .cr-menage-img-wrapper {
        width: 100%;
        height: 200px;
    }
    .cr-tasks-inline {
        flex-direction: column;
        align-items: stretch;
    }
    .cr-mockup-task {
        width: 100%;
        white-space: normal;
    }
}

/* --- Mobile pur --- */
@media (max-width: 640px) {
    .cr-main-content {
        transform: translateY(0px);
    }
    .cr-cta-group {
        flex-direction: column;
        width: 100%;
        max-width: 300px;
    }
    .cr-btn {
        width: 100%;
    }
    .cr-insights-section { 
        padding: 2rem 1.5rem; 
    }
    .cr-dashboard-card { 
        padding: 1.5rem; 
    }
    .cr-3d-section {
        margin: 0; 
        border-radius: 0; 
        min-height: auto;
    }
    .cr-3d-image-layer {
        position: relative;
        width: 100%;
        top: 0;
        margin-top: 4rem;
        transform: none; 
        left: 0;
    }
    .cr-3d-cards-layer {
        margin-top: 0;
    }
    .cr-features-grid {
        grid-template-columns: 1fr;
    }
    .cr-calc-wrapper-light {
        padding: 1.5rem;
    }
    .cr-input-row, .cr-amenities-grid {
        grid-template-columns: 1fr;
    }
    .cr-bento-section {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }
    .cr-bento-grid {
        grid-template-columns: 1fr;
    }
    .cr-card-annonce, .cr-card-accueil, .cr-card-maintenance, .cr-card-menage {
        grid-column: 1 / -1;
        grid-row: auto;
    }
    .cr-bento-card {
        min-height: 350px;
    }
    .cr-card-menage {
        padding: 1.5rem;
    }
}

/* --- Hero Layout fixes for large screens --- */
@media (min-width: 768px) {
    .cr-subtitle { font-size: 1.25rem; }
}

@media (min-width: 1024px) {
    .cr-widget {
        display: block;
        position: absolute;
        z-index: 20;
        border-radius: 1rem;
        padding: 1.5rem;
    }
    .cr-widget-left {
        top: 50%;
        left: 2.5rem;
        width: 18rem;
    }
    .cr-widget-right {
        bottom: 8rem;
        right: 2.5rem;
        width: 20rem;
    }
}

@media (min-width: 1280px) {
    .cr-widget-left { left: 6rem; }
    .cr-widget-right { right: 6rem; }
}

/* ==========================================================================
   SECTION RÉASSURANCE & AVIS GOOGLE
   ========================================================================== */

.cr-trust-section {
    background-color: #1C2A39; /* Remplace par ton fond sombre exact si besoin, ex: #111 */
    padding: 6rem 0;
    overflow: hidden;
}

.cr-trust-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

/* --- Typographie et Contenu --- */
.cr-trust-text {
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.1rem;
    line-height: 1.6;
    margin-bottom: 2.5rem;
}

.cr-legal-box {
    display: flex;
    gap: 1.5rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(198, 167, 94, 0.3); /* Bordure dorée subtile */
    padding: 1.5rem;
    border-radius: 1rem;
    margin-bottom: 2.5rem;
}

.cr-legal-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    color: var(--cr-dore);
}

.cr-legal-title {
    color: var(--cr-blanc);
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
    font-family: var(--cr-font-poppins);
}

.cr-legal-desc {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.9rem;
    line-height: 1.5;
}

/* --- Ajustement du bloc des métriques --- */
.cr-trust-metrics {
    display: flex;
    justify-content: flex-start; /* Aligne le groupe à gauche par rapport au texte au-dessus */
    gap: 2rem; /* Espacement entre les 3 blocs */
    margin-bottom: 2.5rem;
    flex-wrap: wrap; /* Évite que ça ne déborde sur mobile */
}

.cr-metric {
    display: flex;
    flex-direction: column;
    align-items: center; /* CENTRE LE TEXTE À L'INTÉRIEUR DU BLOC */
    text-align: center;
    background: rgba(255, 255, 255, 0.03); /* Petit fond subtil pour les isoler */
    padding: 1rem 1.5rem;
    border-radius: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.cr-metric-value {
    color: var(--cr-dore);
    font-size: 2rem; /* Légèrement réduit pour faire rentrer les 3 blocs proprement */
    font-weight: 700;
    line-height: 1;
}

.cr-stars {
    color: #FABB05; 
    font-size: 1rem;
    letter-spacing: 2px;
    margin: 0.25rem 0;
}

.cr-metric-label {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 0.25rem;
}

.cr-trust-cta {
    display: inline-block;
}

/* --- Mur d'avis en CSS Pur (Marquee) --- */
.cr-reviews-wall {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    height: 600px;
    position: relative;
    /* Effet de fondu en haut et en bas pour masquer la coupe des cartes */
    -webkit-mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
    mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
}

.cr-review-card-gold {
    background: rgba(198, 167, 94, 0.1);
    border: 1px solid var(--cr-dore);
    box-shadow: 0 0 15px rgba(198, 167, 94, 0.2);
}
.cr-review-card-gold .cr-review-name {
    color: var(--cr-dore);
}

.cr-marquee-col {
    display: flex;
    overflow: hidden;
}

.cr-marquee-track {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    width: 100%;
}

.cr-scroll-up .cr-marquee-track {
    animation: scrollVerticalUp 30s linear infinite;
}

.cr-scroll-down .cr-marquee-track {
    animation: scrollVerticalDown 30s linear infinite;
    /* On démarre plus haut pour que le défilement vers le bas ait du sens */
    transform: translateY(-50%);
}

.cr-review-card {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1rem;
    padding: 1.25rem;
    backdrop-filter: blur(8px);
}

.cr-review-head {
    display: flex;
    flex-direction: column;
    margin-bottom: 0.75rem;
}

.cr-review-name {
    color: var(--cr-blanc);
    font-weight: 600;
    font-size: 0.9rem;
}

.cr-review-comment {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.875rem;
    line-height: 1.5;
}

/* Animations CSS */
@keyframes scrollVerticalUp {
    0% { transform: translateY(0); }
    100% { transform: translateY(-50%); } /* S'arrête à la moitié (fin des originaux, début des duplicatas) */
}

@keyframes scrollVerticalDown {
    0% { transform: translateY(-50%); }
    100% { transform: translateY(0); }
}

/* Mode Responsive */
@media (max-width: 1023px) {
    .cr-trust-split {
        grid-template-columns: 1fr;
    }
    .cr-reviews-wall {
        height: 400px;
        grid-template-columns: repeat(2, 1fr); /* 2 colonnes sur tablette */
    }
    .cr-marquee-col:nth-child(3) {
        display: none; /* On cache la 3e colonne sur les petits écrans */
    }
}

@media (max-width: 767px) {
    .cr-reviews-wall {
        grid-template-columns: 1fr; /* 1 seule colonne sur mobile */
    }
    .cr-marquee-col:nth-child(2) {
        display: none;
    }
}

/* C'EST CETTE LIGNE QUI GÈRE LA COULEUR DU H2 */
.cr-text-white {
    color: #ffffff !important;
}

/* ==========================================================================
   SECTION CTA FINAL : DISPOSITION OVERLAP (MODE CLAIR)
   ========================================================================== */

.cr-apple-cta-section {
    background-color: #FAFAFA; /* Un gris extrêmement clair pour faire ressortir la carte blanche */
    padding: 8rem 0;
    position: relative;
    overflow: hidden;
    font-family: 'Poppins', sans-serif;
}

/* Le halo lumineux décentré sur la droite pour accompagner l'image */
.cr-bg-halo-gold-right {
    position: absolute;
    top: 20%;
    right: -10%;
    width: 800px;
    height: 800px;
    background: radial-gradient(circle, rgba(198, 167, 94, 0.15) 0%, transparent 65%);
    z-index: 0;
    pointer-events: none;
}

.cr-container {
    position: relative;
    z-index: 1;
}

/* --- La Magie de la Grille Asymétrique --- */
.cr-apple-overlap-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    align-items: center;
}

/* La carte texte prend les colonnes 1 à 7 et flotte au premier plan */
.cr-apple-text-card {
    grid-column: 1 / 8;
    grid-row: 1;
    z-index: 2; /* Passe au-dessus de l'image */
    background: #ffffff;
    padding: 4rem;
    border-radius: 2rem;
    box-shadow: 0 40px 80px rgba(0, 0, 0, 0.08), 0 10px 20px rgba(198, 167, 94, 0.05);
    border: 1px solid rgba(198, 167, 94, 0.15);
}

/* L'image prend les colonnes 6 à 13 (chevauchement volontaire) en arrière-plan */
.cr-apple-image-card {
    grid-column: 6 / 13;
    grid-row: 1;
    z-index: 1;
    height: 650px; /* Force une belle hauteur d'image */
    border-radius: 2rem;
    overflow: hidden;
    box-shadow: 0 20px 40px rgba(0,0,0,0.1);
}

.cr-apple-img-overlap {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Animation luxueuse de l'image au survol de toute la section */
.cr-apple-overlap-grid:hover .cr-apple-img-overlap {
    transform: scale(1.04);
}

/* --- Contenu & Typographies --- */
.cr-apple-title {
    font-family: 'Playfair Display', serif;
    font-size: 3.2rem;
    line-height: 1.1;
    font-weight: 700;
    color: var(--cr-noir);
    margin-bottom: 1.5rem;
    letter-spacing: -0.02em;
}

.cr-text-gradient {
    background: linear-gradient(90deg, var(--cr-dore) 0%, #d4b56a 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.cr-apple-subtitle {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--cr-anthracite);
    margin-bottom: 2.5rem;
}

/* --- Liste à puces --- */
.cr-apple-list {
    list-style: none;
    padding: 0;
    margin: 0 0 3rem 0;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.cr-apple-list li {
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
}

.cr-list-icon {
    width: 32px;
    height: 32px;
    background: rgba(198, 167, 94, 0.1);
    color: var(--cr-dore);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 7px;
    margin-top: 2px;
}

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

.cr-list-text {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.cr-list-text strong {
    font-family: 'Playfair Display', serif;
    color: var(--cr-noir);
    font-size: 1.3rem;
    font-weight: 600;
    letter-spacing: 0.5px;
}

.cr-list-text span {
    color: var(--cr-gris);
    font-size: 0.95rem;
    line-height: 1.5;
}

.cr-btn-large {
    padding: 1.25rem 2.5rem;
    font-size: 1.1rem;
    border-radius: 99px;
}

/* --- Responsive Design --- */
@media (max-width: 1199px) {
    .cr-apple-title { font-size: 2.8rem; }
    .cr-apple-text-card { padding: 3rem; }
}

@media (max-width: 991px) {
    /* Sur tablette et mobile, on annule le chevauchement et on empile classiquement */
    .cr-apple-overlap-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
    .cr-apple-text-card {
        grid-column: 1 / -1;
        grid-row: auto;
    }
    .cr-apple-image-card {
        grid-column: 1 / -1;
        grid-row: auto;
        height: 450px;
    }
}

@media (max-width: 767px) {
    .cr-apple-cta-section { padding: 5rem 0; }
    .cr-apple-title { font-size: 2.2rem; }
    .cr-apple-text-card { padding: 2rem; }
    .cr-apple-image-card { order: -1; height: 350px; } /* L'image passe au-dessus sur mobile */
}

/* ==========================================================================
   SECTION ZONE D'INTERVENTION (DARK MODE)
   ========================================================================== */

.cr-secteur-wrapper { 
    position: relative; 
    background-color: #1C2A39; 
    padding: 6rem 1.5rem; 
    overflow: hidden; 
    font-family: 'Poppins', sans-serif;
}

/* Halos de fond */
.cr-secteur-halo { 
    position: absolute; 
    width: 600px; 
    height: 600px; 
    border-radius: 50%; 
    filter: blur(120px); 
    z-index: 0; 
    pointer-events: none; 
}
.cr-secteur-halo-gold { background: rgba(198, 167, 94, 0.15); top: 5%; left: -10%; }
.cr-secteur-halo-marine { background: rgba(255, 255, 255, 0.03); bottom: -10%; right: -10%; }

/* En-tête */
.cr-secteur-header { 
    text-align: center; 
    max-width: 800px; 
    margin: 0 auto 4rem auto; 
    position: relative; 
    z-index: 2; 
}

.cr-secteur-description {
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.1rem;
    line-height: 1.6;
}

/* Grille et Cartes Glassmorphism Dark */
.cr-secteur-grid { 
    max-width: 1200px; 
    margin: 0 auto; 
    display: grid; 
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); 
    gap: 2.5rem; 
    position: relative; 
    z-index: 2; 
}

.cr-secteur-glass-card { 
    background: rgba(255, 255, 255, 0.03); 
    border: 1px solid rgba(255, 255, 255, 0.08); 
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-radius: 2rem; 
    padding: 2.5rem; 
    display: flex; 
    flex-direction: column; 
    gap: 2rem; 
    transition: all 0.4s ease; 
}

.cr-secteur-glass-card:hover { 
    transform: translateY(-5px); 
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(198, 167, 94, 0.3); 
}

@media (min-width: 900px) { 
    .cr-secteur-glass-card { flex-direction: row; align-items: stretch; } 
    .cr-secteur-card-col { width: 50%; display: flex; flex-direction: column; } 
}

/* Badges et statuts */
.cr-secteur-badge-container { margin-bottom: 1rem; }
.cr-secteur-badge { 
    padding: 6px 14px; 
    background: rgba(198, 167, 94, 0.1); 
    color: var(--cr-dore);
    border: 1px solid rgba(198, 167, 94, 0.3); 
    border-radius: 50px; 
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.cr-secteur-status { display: flex; align-items: center; margin-bottom: 1rem; }
.cr-secteur-status-text { color: rgba(255, 255, 255, 0.8); font-size: 0.9rem; }

.cr-secteur-glow-dot { 
    width: 8px; 
    height: 8px; 
    background-color: var(--cr-dore); 
    border-radius: 50%; 
    margin-right: 10px; 
    box-shadow: 0 0 10px rgba(198, 167, 94, 0.6); 
    animation: crPulse 2s infinite; 
}
.cr-secteur-glow-green { background-color: #34c759; box-shadow: 0 0 10px rgba(52, 199, 89, 0.6); }
.cr-secteur-text-green { color: #34c759; }

@keyframes crPulse { 
    0%, 100% { transform: scale(1); opacity: 1; } 
    50% { transform: scale(1.4); opacity: 0.6; } 
}

/* Textes de la carte */
.cr-secteur-city-title { 
    font-family: 'Playfair Display', serif;
    color: var(--cr-blanc);
    font-size: 1.8rem;
    margin: 0 0 1.5rem 0; 
}

.cr-secteur-info-col { justify-content: space-between; }
.cr-secteur-city-text {
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.6;
    font-size: 0.95rem;
}
.cr-secteur-city-text strong {
    color: var(--cr-blanc);
    font-weight: 600;
}

/* Map Iframe en couleur d'origine */
.cr-secteur-map-box { 
    margin-top: auto; 
    height: 220px; 
    width: 100%; 
    border-radius: 1rem; 
    overflow: hidden; 
    border: 1px solid rgba(255, 255, 255, 0.1); 
    position: relative; 
    transform: translateZ(0); 
}

.cr-secteur-map-iframe { 
    width: 100%; 
    height: 100%; 
    border: 0; 
}

/* Boutons d'action */
.cr-btn-maps {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 2rem;
}

/* Responsive */
@media (max-width: 768px) { 
    .cr-secteur-wrapper { padding: 4rem 1rem; } 
    .cr-secteur-grid { grid-template-columns: 1fr; gap: 2rem; } 
    .cr-secteur-glass-card { padding: 2rem; border-radius: 1.5rem; } 
    .cr-secteur-map-box { height: 200px; margin-bottom: 2rem;} 
}

/* ==========================================================================
   SECTION FAQ (DESIGN DEUX COLONNES PC)
   ========================================================================== */

.cr-faq-section {
    background-color: #F5F1E8; 
    padding: 6rem 1.5rem;
    font-family: 'Poppins', sans-serif;
}

.cr-faq-header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 4rem auto;
}

.cr-faq-header .cr-title-h2 {
    font-family: 'Playfair Display', serif;
    font-size: 2.8rem;
    color: #1a1a1a;
    margin-bottom: 1rem;
}

.cr-faq-intro {
    color: #4a4a4a;
    font-size: 1.1rem;
    line-height: 1.6;
}

/* --- GRILLE DE LA FAQ --- */
.cr-faq-grid {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr; /* Une seule colonne par défaut (Mobile/Tablette) */
    gap: 1.5rem;
    align-items: start; /* Empêche les items de s'étirer en hauteur */
}

/* Passage sur deux colonnes pour les écrans PC (1024px et plus) */
@media (min-width: 1024px) {
    .cr-faq-grid {
        grid-template-columns: 1fr 1fr;
        gap: 2rem;
    }
}

/* Style de chaque bloc question */
.cr-faq-item {
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 1.5rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
    overflow: hidden;
    transition: all 0.3s ease;
}

.cr-faq-item[open] {
    box-shadow: 0 10px 30px rgba(198, 167, 94, 0.08);
    border-color: rgba(198, 167, 94, 0.3);
}

/* L'en-tête cliquable (Question) */
.cr-faq-question {
    font-family: 'Playfair Display', serif;
    font-size: 1.2rem;
    font-weight: 600;
    color: #1a1a1a;
    padding: 1.5rem 2rem;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    list-style: none;
}

.cr-faq-question::-webkit-details-marker {
    display: none;
}

.cr-faq-icon {
    font-family: 'Poppins', sans-serif;
    font-size: 1.6rem;
    font-weight: 300;
    color: var(--cr-dore);
    transition: transform 0.3s ease;
    flex-shrink: 0;
    margin-left: 1rem;
}

.cr-faq-item[open] .cr-faq-icon {
    transform: rotate(45deg);
}

/* La réponse */
.cr-faq-answer {
    padding: 0 2rem 1.5rem 2rem;
    color: #4a4a4a;
    font-size: 0.95rem;
    line-height: 1.6;
}

.cr-faq-answer p {
    margin: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    padding-top: 1.5rem;
}

/* Responsive ajustements */
@media (max-width: 767px) {
    .cr-faq-header .cr-title-h2 { font-size: 2.2rem; }
    .cr-faq-question { font-size: 1.1rem; padding: 1.25rem 1.5rem; }
}

/* ==========================================================================
   8. FOOTER CESC RIVIERA (DARK MODE)
   ========================================================================== */

.cr-footer {
    background-color: var(--cr-marine); /* #1C2A39 */
    padding: 5rem 1.5rem 2rem 1.5rem;
    color: var(--cr-blanc);
    font-family: var(--cr-font-poppins);
    border-top: 1px solid rgba(198, 167, 94, 0.2); /* Légère ligne dorée */
}

/* Grille principale */
.cr-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
    gap: 4rem;
    margin-bottom: 4rem;
}

/* Colonne 1 : Brand */
.cr-footer-brand {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.cr-footer-logo {
    max-width: 100px;
    height: auto;
    margin-bottom: 1.5rem;
    display: block;
}

.cr-footer-desc {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 2rem;
    max-width: 320px;
}

/* Réseaux sociaux */
.cr-footer-socials {
    display: flex;
    gap: 1rem;
}

.cr-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
    color: var(--cr-blanc);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.3s ease;
}

.cr-social-link svg {
    width: 18px;
    height: 18px;
}

.cr-social-link:hover {
    background: var(--cr-dore);
    border-color: var(--cr-dore);
    color: #ffffff;
    transform: translateY(-3px);
}

/* Colonnes Liens & Contact */
.cr-footer-title {
    font-family: var(--cr-font-playfair);
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--cr-dore);
    margin-bottom: 1.5rem;
    letter-spacing: 0.5px;
}

.cr-footer-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.cr-footer-list a {
    color: rgba(255, 255, 255, 0.8);
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.3s ease, padding-left 0.3s ease;
}

.cr-footer-list a:hover {
    color: var(--cr-dore);
    padding-left: 5px; /* Petit effet au survol */
}

/* Liste de contact avec icônes */
.cr-footer-contact-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.cr-footer-contact-list li {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.cr-contact-icon {
    color: var(--cr-dore);
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    margin-top: 2px;
}

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

.cr-footer-contact-list a, 
.cr-footer-contact-list span {
    color: rgba(255, 255, 255, 0.8);
    text-decoration: none;
    font-size: 0.95rem;
    line-height: 1.5;
    transition: color 0.3s ease;
}

.cr-footer-contact-list a:hover {
    color: var(--cr-dore);
}

/* Barre inférieure (Copyright) */
.cr-footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.5);
}

.cr-legal-links {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}

.cr-legal-links a {
    color: rgba(255, 255, 255, 0.5);
    text-decoration: none;
    transition: color 0.3s ease;
}

.cr-legal-links a:hover {
    color: var(--cr-blanc);
}

.cr-separator {
    color: rgba(255, 255, 255, 0.2);
}

/* RESPONSIVE FOOTER */
@media (max-width: 1023px) {
    .cr-footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 3rem;
    }
}

@media (max-width: 767px) {
    .cr-footer {
        padding: 4rem 1rem 2rem 1rem;
    }
    .cr-footer-grid {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }
    .cr-footer-bottom {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
    }
    .cr-legal-links {
        flex-wrap: wrap;
        justify-content: center;
    }
}

/* Mobile pur (767px et moins) */
@media (max-width: 767px) {
    .cr-input-row, .cr-amenities-grid, .cr-calc-features-grid { grid-template-columns: 1fr; }
    
    /* FIX : Suppression de la marge monstrueuse de la section 3D */
    .cr-3d-section {
        min-height: auto;
        padding-bottom: 2rem; /* On réduit l'espace en bas de la section 3D */
    }

    /* FIX : Réduction du padding géant du calculateur */
    .e85-calculator-section.e85-dark {
        padding-top: 4rem !important; /* Force la réduction du padding haut */
        padding-bottom: 4rem;
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
    
    /* FIX : Padding de la section de réassurance */
    .cr-trust-section {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    /* FIX : Alignement des métriques (100%, 5/5) sur mobile */
    .cr-trust-metrics {
        display: grid;
        grid-template-columns: 1fr; /* On les met les unes sous les autres pour que ce soit propre */
        gap: 1rem;
        width: 100%;
        justify-content: stretch; /* Prend toute la largeur */
    }
    
    /* FIX : Uniformisation de TOUS les titres H2 pour avoir la taille imposante */
    .cr-title-h2,
    .cr-apple-title,
    .cr-bento-section .cr-title-h2,
    .cr-secteur-header .cr-title-h2,
    .cr-faq-header .cr-title-h2,
    .cr-calc-seo-content .cr-title-h2,
    .cr-trust-content .cr-title-h2 {
        font-size: clamp(2.5rem, 6vw, 4.5rem) !important;
        line-height: 1.1 !important;
        letter-spacing: -1px !important;
    }

    .cr-bento-section { padding: 4rem 1rem; }
    .cr-pricing-card, .cr-card-split .cr-split-text, .cr-card-menage { padding: 2rem; }
    
    .cr-reviews-wall { grid-template-columns: 1fr; }
    .cr-marquee-col:nth-child(2) { display: none; }
    .cr-apple-cta-section { padding: 5rem 0; }
    .cr-apple-text-card { padding: 2rem; }
    .cr-apple-image-card { order: -1; height: 350px; }
    
    .cr-footer { padding: 4rem 1.5rem 2rem 1.5rem; }
    .cr-footer-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .cr-footer-bottom { flex-direction: column; text-align: center; gap: 1rem; }
    .cr-legal-links { flex-wrap: wrap; justify-content: center; }
}

/* ==========================================================================
   MARGES ISOLÉES (TOP & BOTTOM) : BANDEAU 3D PAGE LUXE
   ========================================================================== */

/* --- Version PC --- */
@media (min-width: 1024px) {
    .cr-3d-section.cr-3d-section-luxe {
        margin-top: 190px !important; /* Compense le débordement de l'image */
        margin-bottom: 0px !important; /* Respiration avant le calculateur */
    }
}

/* --- Version Mobile --- */
@media (max-width: 767px) {
    .cr-3d-section.cr-3d-section-luxe {
        margin-top: 0px !important; /* Annule l'espacement inutile */
        margin-bottom: 0px !important; /* Annule l'espacement inutile */
    }
}

/* ==========================================================================
   FIX IMAGE COLLÉE EN TOP SUR MOBILE (PAGE LUXE)
   ========================================================================== */
@media (max-width: 767px) {
    /* On annule la marge qui poussait l'image vers le bas */
    .cr-3d-section.cr-3d-section-luxe .cr-3d-image-layer {
        margin-top: 0 !important;
    }
    
    /* On remonte légèrement le texte pour qu'il soit bien centré sur le haut de l'image */
    .cr-3d-section.cr-3d-section-luxe .cr-3d-text-layer {
        top: 2rem !important; 
    }
}

/* Bouton Outline pour fonds clairs (ex: cartes blanches) */
.cr-btn-outline-marine {
    background-color: transparent;
    color: var(--cr-marine);
    border: 2px solid var(--cr-marine);
}

.cr-btn-outline-marine:hover {
    background-color: var(--cr-marine);
    color: var(--cr-blanc);
    transform: translateY(-4px);
    box-shadow: 0 10px 15px -3px rgba(28, 42, 57, 0.15);
}

/* ==========================================================================
   HALOS DE PROFONDEUR - SECTION TARIFS
   ========================================================================== */

.cr-pricing-wrapper {
    position: relative;
    /* On ajoute une petite marge pour laisser respirer les halos */
    margin-top: 4rem; 
}

/* On s'assure que tout le contenu reste cliquable au-dessus des halos */
.cr-pricing-content {
    position: relative;
    z-index: 1;
}

.cr-pricing-wrapper .cr-halo-gold {
    position: absolute;
    top: 10%;
    left: -15%;
    width: 50vw;
    height: 50vw;
    max-width: 600px;
    max-height: 600px;
    background: radial-gradient(circle, rgba(198, 167, 94, 0.90) 0%, transparent 90%);
    filter: blur(80px);
    z-index: 0;
    border-radius: 50%;
    pointer-events: none; /* Empêche le halo de bloquer les clics sur les boutons */
}

/* ==========================================================================
   VARIABLES CESC RIVIERA
   ========================================================================== */
:root {
    --cr-dore: #C6A75E;
    --cr-beige: #F5F1E8;
    --cr-blanc: #FFFFFF;
    --cr-noir: #1A1A1A;
    --cr-gris: #6D6D6D;
    --cr-marine: #1C2A39;
    --cr-font-poppins: 'Poppins', sans-serif;
    --cr-bg-light: #F8F9FA;
}

/* 1. CONTENEUR PRINCIPAL */
.cr-article-box {
    max-width: 900px;
    margin: 60px auto;
    padding: 60px 50px;
    font-family: var(--cr-font-poppins);
    background: var(--cr-blanc); 
    box-shadow: 0 10px 40px rgba(0,0,0,0.06);
    border-radius: 24px;
    border: 1px solid #e2e8f0;
    color: var(--cr-noir);
    line-height: 1.6;
}

/* Ligne de force sur les H2 */
.cr-h2 {
    font-size: 1.7rem; 
    color: var(--cr-marine); 
    font-weight: 800;
    margin: 60px 0 25px 0; 
    border-left: 5px solid var(--cr-dore);
    padding-left: 20px; 
    line-height: 1.3;
}

.cr-h1 {
    font-size: 2.2rem;
    color: var(--cr-marine);
    font-weight: 800;
    text-align: center;
    margin-bottom: 20px;
}

.text-gold {
    color: var(--cr-dore);
}

.text-red {
    color: #e53e3e;
    font-weight: bold;
}

.cr-intro, .cr-p {
    font-size: 1.1rem;
    color: var(--cr-gris);
    margin-bottom: 20px;
}

.cr-intro {
    text-align: center;
    margin-bottom: 40px;
}

.cr-main-img {
    border-radius: 16px;
    margin-bottom: 40px;
    width: 100%;
    height: auto;
}

/* 2. BOUTONS */
.cr-glb-btn {
    display: inline-flex; 
    align-items: center; 
    justify-content: center; 
    gap: 10px; 
    background: var(--cr-dore);
    color: var(--cr-blanc); 
    padding: 15px 35px; 
    border-radius: 50px; 
    font-weight: 700; 
    font-size: 1.05rem; 
    text-decoration: none; 
    transition: transform 0.3s ease, box-shadow 0.3s ease; 
    box-shadow: 0 10px 20px rgba(198, 167, 94, 0.3);
}
.cr-glb-btn:hover { 
    transform: translateY(-3px); 
    box-shadow: 0 15px 30px rgba(198, 167, 94, 0.4);
    color: var(--cr-blanc);
}

/* 3. TABLEAUX */
.table-scroll-wrapper {
    border-radius: 16px;
    overflow-x: auto;
    border: 1px solid #e2e8f0;
    margin: 30px 0;
    background-color: var(--cr-blanc);
}
.cr-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
    min-width: 600px; 
    background-color: var(--cr-blanc);
}
.cr-table thead { 
    background: var(--cr-bg-light); 
    color: var(--cr-marine); 
}
.cr-table th { 
    padding: 18px; 
    text-align: left; 
    font-weight: 700; 
    font-size: 0.9rem; 
    text-transform: uppercase; 
    letter-spacing: 0.05em; 
    border-bottom: 1px solid #e2e8f0; 
}
.cr-table td { 
    padding: 16px 18px; 
    border-bottom: 1px solid #e2e8f0; 
    color: var(--cr-noir); 
}
.cr-table tr:last-child td { border-bottom: none; }

.cr-match-table th {
    background-color: var(--cr-marine) !important;
    color: var(--cr-blanc) !important;
}

/* 4. GRILLES ET CARTES */
.cr-summary-box {
    background: var(--cr-bg-light);
    padding: 30px;
    border-radius: 16px;
    margin-bottom: 40px;
    border: 1px solid #e2e8f0;
}

.cr-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    list-style: none;
    padding-left: 0;
}

.cr-grid-2 a {
    color: var(--cr-marine);
    text-decoration: none;
    font-weight: 600;
}

.cr-grid-2 a:hover {
    color: var(--cr-dore);
}

.cr-cta-card {
    background: rgba(28, 42, 57, 0.03);
    border: 1px solid rgba(28, 42, 57, 0.1);
    border-radius: 16px;
    padding: 30px;
    text-align: center;
    margin: 40px 0;
}

.cta-title {
    display: block;
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--cr-marine);
    margin-bottom: 10px;
}

.cta-desc {
    display: block;
    color: var(--cr-gris);
    margin-bottom: 20px;
}

/* COLONNES COMPARATIVES (Tarifs) */
.cr-compare-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 30px 0;
}

.cr-compare-card {
    background: var(--cr-blanc);
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    padding: 30px;
    position: relative;
    overflow: hidden;
    text-align: center;
}

.cr-compare-card.highlight {
    background: rgba(198, 167, 94, 0.05);
    border-color: var(--cr-dore);
}

.cr-compare-header {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--cr-marine);
    margin-bottom: 15px;
}

.cr-price-huge {
    font-size: 3rem;
    font-weight: 800;
    color: var(--cr-noir);
    margin-bottom: 15px;
}

/* STACK VERTICAL (Pack lancement) */
.cr-vertical-stack {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-bottom: 40px;
}

.cr-stack-card {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    background: var(--cr-bg-light);
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    padding: 25px;
    transition: all 0.3s ease;
}

.cr-stack-card:hover {
    border-color: var(--cr-dore);
    transform: translateX(5px);
}

.cr-stack-icon {
    flex-shrink: 0;
    width: 36px; height: 36px;
    background: var(--cr-blanc);
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800; color: var(--cr-dore);
}

.cr-stack-title {
    font-size: 1.15rem; font-weight: 800; color: var(--cr-marine);
    margin-bottom: 10px; margin-top: 0;
}

/* ==========================================================================
   GRILLE BENTO ISOLÉE POUR LES ARTICLES (INCONVÉNIENTS VS AVANTAGES)
   ========================================================================== */
.cr-article-bento-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin: 2.5rem 0;
}

/* Base de la carte Bento (Design Apple) */
.cr-article-bento-card {
    border-radius: 28px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s ease;
    overflow: hidden;
}

.cr-article-bento-card:hover {
    transform: scale(1.02);
}

.cr-article-bento-icon {
    font-size: 2.5rem;
    margin-bottom: 1rem;
    line-height: 1;
}

.cr-article-bento-title {
    font-family: var(--cr-font-poppins);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 0.75rem 0;
    line-height: 1.3;
}

.cr-article-bento-text {
    font-size: 0.95rem;
    line-height: 1.6;
    margin: 0;
}

/* Cartes alertes (La charge mentale) */
.cr-article-bento-alert {
    background: linear-gradient(145deg, #fff0f0, #ffe1e1);
    border: 1px solid rgba(255, 200, 200, 0.5);
    box-shadow: 0 10px 30px rgba(211, 47, 47, 0.08);
}

.cr-article-bento-alert .cr-article-bento-title {
    color: #b71c1c;
}

.cr-article-bento-alert .cr-article-bento-text {
    color: #5c2b2b;
}

/* Carte solution (L'agence) */
.cr-article-bento-solution {
    grid-column: span 2;
    background: linear-gradient(135deg, rgba(28, 42, 57, 0.95), rgba(18, 28, 38, 0.98));
    border: 1px solid rgba(198, 167, 94, 0.3);
    box-shadow: 0 15px 40px rgba(28, 42, 57, 0.2);
    justify-content: center;
}

.cr-article-bento-solution .cr-article-bento-title {
    color: #c6a75e;
    font-size: 1.4rem;
}

.cr-article-bento-solution .cr-article-bento-text {
    color: #e2e8f0;
    font-size: 1.05rem;
    max-width: 90%;
}

/* Adaptation pour les écrans mobiles */
@media (max-width: 767px) {
    .cr-article-bento-container {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    .cr-article-bento-solution {
        grid-column: span 1;
    }
    .cr-article-bento-card {
        padding: 1.5rem;
        border-radius: 20px;
    }
}

/* RATING BADGE (inchangé s'il ne posait pas de souci, ou à garder tel quel) */
.cr-rating-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--cr-bg-light);
    padding: 8px 16px;
    border-radius: 50px;
    font-weight: 600;
    font-size: 0.9rem;
    margin-bottom: 20px;
    border: 1px solid #e2e8f0;
}

.cr-rating-badge .stars {
    color: #FBBC04;
}

/* FAQ */
.cr-faq-item {
    border-bottom: 1px solid #e2e8f0;
    padding: 15px 0;
}
.cr-faq-item summary {
    font-weight: 700;
    color: var(--cr-marine);
    cursor: pointer;
    font-size: 1.1rem;
    outline: none;
}
.cr-faq-item p {
    margin-top: 10px;
    color: var(--cr-gris);
}

/* CTA BOTTOM */
.cr-cta-bottom {
    background: var(--cr-marine);
    border-radius: 20px;
    padding: 40px;
    text-align: center;
    margin-top: 60px;
}
.cta-bottom-title {
    color: var(--cr-blanc);
    font-size: 1.8rem;
    font-weight: 800;
    margin-bottom: 15px;
}
.cta-bottom-desc {
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 30px;
    font-size: 1.1rem;
}

/* RESPONSIVE */
@media (max-width: 768px) {
    .cr-article-box {
        padding: 30px 20px;
        margin: 20px;
    }
    .cr-compare-grid, .cr-grid-2 {
        grid-template-columns: 1fr;
    }
    .cr-h1 {
        font-size: 1.8rem;
    }
}

/* ==========================================================================
   VARIABLES CESC RIVIERA
   ========================================================================== */
:root {
    --cr-dore: #C6A75E;
    --cr-beige: #F5F1E8;
    --cr-blanc: #FFFFFF;
    --cr-noir: #1A1A1A;
    --cr-gris: #6D6D6D;
    --cr-marine: #1C2A39;
    --cr-font-poppins: 'Poppins', sans-serif;
    --cr-bg-light: #F8F9FA;
}

/* ==========================================================================
   1. CONTENEUR PRINCIPAL AVEC OVERLAP BLOCKSY
   ========================================================================== */
.cr-article-box {
    position: relative;
    z-index: 10;
    max-width: 900px;
    margin: -120px auto 60px auto; 
    padding: 60px 50px;
    font-family: var(--cr-font-poppins);
    background: var(--cr-blanc); 
    box-shadow: 0 10px 40px rgba(0,0,0,0.06);
    border-radius: 24px;
    border: 1px solid #e2e8f0;
    color: var(--cr-noir);
    line-height: 1.6;
    display: block; 
}

/* ==========================================================================
   2. CORRECTION STRICTE DU CONFLIT DE SUPERPOSITION (IMAGE & HEADER)
   ========================================================================== */
.cr-main-img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 16px;
    margin-bottom: 30px !important;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
}

.cr-header {
    /* Le !important neutralise les styles de contrainte de Blocksy */
    position: relative !important; 
    top: auto !important;
    left: auto !important;
    transform: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 40px !important;
}

.cr-cta-card {
    background: rgba(28, 42, 57, 0.03);
    border: 1px solid rgba(28, 42, 57, 0.1);
    border-radius: 16px;
    padding: 30px;
    text-align: center;
    margin: 40px auto !important; 
    width: 100%;
    max-width: 650px; 
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative !important;
}

.cta-title {
    display: block;
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--cr-marine);
    margin-bottom: 10px;
}

.cta-desc {
    display: block;
    color: var(--cr-gris);
    margin-bottom: 20px;
}

/* ==========================================================================
   3. TYPOGRAPHIE ET TEXTES
   ========================================================================== */
.cr-h1 {
    font-size: 2.2rem;
    color: var(--cr-marine);
    font-weight: 800;
    text-align: center;
    margin-bottom: 20px;
    margin-top: 0;
}

/* Ligne de force sur les H2 */
.cr-h2 {
    font-size: 1.7rem; 
    color: var(--cr-marine); 
    font-weight: 800;
    margin: 60px 0 25px 0; 
    border-left: 5px solid var(--cr-dore);
    padding-left: 20px; 
    line-height: 1.3;
}

.text-gold { color: var(--cr-dore); }
.text-red { color: #e53e3e; font-weight: bold; }

.cr-intro, .cr-p {
    font-size: 1.1rem;
    color: var(--cr-gris);
    margin-bottom: 20px;
}

.cr-intro {
    text-align: center;
    margin-bottom: 40px;
}

/* ==========================================================================
   4. BOUTONS D'ACTION
   ========================================================================== */
.cr-glb-btn {
    display: inline-flex; 
    align-items: center; 
    justify-content: center; 
    gap: 10px; 
    background: var(--cr-dore);
    color: var(--cr-blanc); 
    padding: 15px 35px; 
    border-radius: 50px; 
    font-weight: 700; 
    font-size: 1.05rem; 
    text-decoration: none; 
    transition: transform 0.3s ease, box-shadow 0.3s ease; 
    box-shadow: 0 10px 20px rgba(198, 167, 94, 0.3);
}
.cr-glb-btn:hover { 
    transform: translateY(-3px); 
    box-shadow: 0 15px 30px rgba(198, 167, 94, 0.4);
    color: var(--cr-blanc);
}

/* ==========================================================================
   5. TABLEAUX DE DONNÉES
   ========================================================================== */
.table-scroll-wrapper {
    border-radius: 16px;
    overflow-x: auto;
    border: 1px solid #e2e8f0;
    margin: 30px 0;
    background-color: var(--cr-blanc);
}
.cr-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
    min-width: 600px; 
    background-color: var(--cr-blanc);
}
.cr-table thead { 
    background: var(--cr-bg-light); 
    color: var(--cr-marine); 
}
.cr-table th { 
    padding: 18px; 
    text-align: left; 
    font-weight: 700; 
    font-size: 0.9rem; 
    text-transform: uppercase; 
    letter-spacing: 0.05em; 
    border-bottom: 1px solid #e2e8f0; 
}
.cr-table td { 
    padding: 16px 18px; 
    border-bottom: 1px solid #e2e8f0; 
    color: var(--cr-noir); 
}
.cr-table tr:last-child td { border-bottom: none; }

.cr-match-table th {
    background-color: var(--cr-marine) !important;
    color: var(--cr-blanc) !important;
}

/* ==========================================================================
   6. GRILLES ET CARTES TARIFAIRES
   ========================================================================== */
.cr-summary-box {
    background: var(--cr-bg-light);
    padding: 30px;
    border-radius: 16px;
    margin-bottom: 40px;
    border: 1px solid #e2e8f0;
}

.cr-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    list-style: none;
    padding-left: 0;
}

.cr-grid-2 a {
    color: var(--cr-marine);
    text-decoration: none;
    font-weight: 600;
}

.cr-grid-2 a:hover {
    color: var(--cr-dore);
}

.cr-compare-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 30px 0;
}

.cr-compare-card {
    background: var(--cr-blanc);
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    padding: 30px;
    position: relative;
    overflow: hidden;
    text-align: center;
}

.cr-compare-card.highlight {
    background: rgba(198, 167, 94, 0.05);
    border-color: var(--cr-dore);
}

.cr-compare-header {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--cr-marine);
    margin-bottom: 15px;
}

.cr-price-huge {
    font-size: 3rem;
    font-weight: 800;
    color: var(--cr-noir);
    margin-bottom: 15px;
}

/* ==========================================================================
   7. STACK VERTICAL (ÉTAPES)
   ========================================================================== */
.cr-vertical-stack {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-bottom: 40px;
}

.cr-stack-card {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    background: var(--cr-bg-light);
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    padding: 25px;
    transition: all 0.3s ease;
}

.cr-stack-card:hover {
    border-color: var(--cr-dore);
    transform: translateX(5px);
}

.cr-stack-icon {
    flex-shrink: 0;
    width: 36px; height: 36px;
    background: var(--cr-blanc);
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800; color: var(--cr-dore);
}

.cr-stack-title {
    font-size: 1.15rem; font-weight: 800; color: var(--cr-marine);
    margin-bottom: 10px; margin-top: 0;
}

/* ==========================================================================
   8. ÉLÉMENTS ANNEXES (RATING, FAQ, BOTTOM CTA)
   ========================================================================== */
.cr-rating-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--cr-bg-light);
    padding: 8px 16px;
    border-radius: 50px;
    font-weight: 600;
    font-size: 0.9rem;
    margin-bottom: 20px;
    border: 1px solid #e2e8f0;
}

.cr-rating-badge .stars {
    color: #FBBC04;
}

.cr-faq-item {
    border-bottom: 1px solid #e2e8f0;
    padding: 15px 0;
}
.cr-faq-item summary {
    font-weight: 700;
    color: var(--cr-marine);
    cursor: pointer;
    font-size: 1.1rem;
    outline: none;
}
.cr-faq-item p {
    margin-top: 10px;
    color: var(--cr-gris);
}

.cr-cta-bottom {
    background: var(--cr-marine);
    border-radius: 20px;
    padding: 40px;
    text-align: center;
    margin-top: 60px;
}
.cta-bottom-title {
    color: var(--cr-blanc);
    font-size: 1.8rem;
    font-weight: 800;
    margin-bottom: 15px;
}
.cta-bottom-desc {
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 30px;
    font-size: 1.1rem;
}

/* ==========================================================================
   9. RESPONSIVE (Plein écran sur mobile)
   ========================================================================== */
@media (max-width: 768px) {
    /* L'article prend toute la largeur */
    .cr-article-box {
        padding: 40px 10px;
        margin-top: -60px !important; /* Garde l'overlap du Hero */
        margin-left: 0 !important;    /* Colle au bord gauche */
        margin-right: 0 !important;   /* Colle au bord droit */
        margin-bottom: 0 !important;
        border-radius: 0 !important;  /* Retire les coins arrondis */
        border-left: none !important; /* Enlève la bordure gauche */
        border-right: none !important;/* Enlève la bordure droite */
        width: 100% !important;
        max-width: 100vw !important;
    }
    
    /* L'image de couverture perd aussi ses coins arrondis pour coller aux bords */
    .cr-main-img {
        border-radius: 0 !important;
    }

    /* Les grilles passent sur une seule colonne */
    .cr-compare-grid, .cr-grid-2 {
        grid-template-columns: 1fr;
    }
    
    /* Titre légèrement réduit pour les petits écrans */
    .cr-h1 {
        font-size: 1.8rem;
    }
}

/* ==========================================================================
   EN-TÊTE & NAVIGATION : CENTRAGE VERTICAL
   ========================================================================== */
.cr-nav-container {
    display: flex;
    align-items: center; 
    justify-content: center; 
    gap: 30px; 
}

.cr-nav-group {
    display: flex;
    align-items: center; 
    gap: 15px; 
}

.cr-nav-logo-wrapper {
    display: flex;
    align-items: center; 
}

.cr-nav-dot {
    display: inline-block;
}

/* ==========================================================================
   EFFET GLASSMORPHISM MARINE POUR LE MENU DE NAVIGATION
   ========================================================================== */

.cr-nav-group.cr-glass {
    /* Utilisation du bleu marine officiel avec une opacité à 75% */
    background: rgba(28, 42, 57, 0.75) !important; 
    
    /* Effet de flou arrière-plan à 24px */
    backdrop-filter: blur(24px) !important;
    -webkit-backdrop-filter: blur(24px) !important; /* Sécurité pour la compatibilité Safari */
    
    /* Bordure fine pour accentuer le relief effet verre */
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    transition: background 0.3s ease, border-color 0.3s ease;
}

/* Optionnel : léger effet de survol pour dynamiser la navigation */
.cr-nav-group.cr-glass:hover {
    background: rgba(28, 42, 57, 0.85) !important;
    border-color: rgba(198, 167, 94, 0.3) !important; /* Lueur dorée discrète au survol */
}

/* ==========================================================================
   SECTION "POURQUOI NOUS CHOISIR" - DARK MODE SAAS 2026
   ========================================================================== */

.cr-why-saas-dark {
    position: relative;
    padding: 120px 0 140px 0;
    background-color: var(--cr-marine); /* Dark mode */
    overflow: hidden;
    font-family: var(--cr-font-poppins);
}

.cr-relative-z {
    position: relative;
    z-index: 2;
}

/* --- Effets d'arrière-plan (Glow + Formes carrées) --- */
.cr-glow-behind {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60vw;
    height: 60vw;
    background: radial-gradient(circle, rgba(198, 167, 94, 0.15) 0%, transparent 60%);
    filter: blur(80px);
    z-index: 0;
    pointer-events: none;
}

.cr-geom-square {
    position: absolute;
    /* Bordure dorée très discrète (opacité à 4% au lieu de 15%) */
    border: 1px solid rgba(198, 167, 94, 0.04); 
    border-radius: 40px;
    transform: rotate(45deg);
    background: radial-gradient(circle at center, transparent 30%, var(--cr-marine) 80%);
    z-index: 1;
    pointer-events: none;
}

.cr-geom-1 {
    width: 80vw;
    max-width: 500px;
    aspect-ratio: 1 / 1;
    top: -20%;
    left: -20%;
}

.cr-geom-2 {
    width: 60vw;
    max-width: 400px;
    aspect-ratio: 1 / 1;
    bottom: -15%;
    right: -15%;
}

/* --- En-tête --- */
.cr-why-header-saas {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 70px auto;
}

.cr-text-white { color: var(--cr-blanc) !important; }
.cr-text-gray { color: rgba(255, 255, 255, 0.6) !important; }
.cr-text-gold { color: var(--cr-dore) !important; }

.cr-why-intro-saas {
    font-size: 1.15rem;
    line-height: 1.6;
    margin: 20px auto 30px auto;
    max-width: 650px;
    font-weight: 300;
}

/* Lien Google My Business */
.cr-glass-rating {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    padding: 12px 24px;
    border-radius: 50px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    text-decoration: none;
    transition: background 0.3s ease, transform 0.3s ease, border-color 0.3s ease;
}

.cr-glass-rating:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: var(--cr-dore);
    transform: translateY(-2px);
}

.cr-stars {
    color: #FBBF24;
    font-size: 1.3rem;
    letter-spacing: 2px;
}

.cr-rating-note {
    font-weight: 700;
    font-size: 1.1rem;
}

.cr-rating-txt {
    font-size: 0.9rem;
    font-weight: 300;
}

/* --- Grille Asymétrique (Alignée en bas) --- */
.cr-bento-saas-grid {
    display: flex;
    align-items: flex-end; /* Alignement strict par le bas de toutes les colonnes */
    justify-content: center;
    gap: 24px;
    max-width: 1200px;
    margin: 0 auto;
    height: 450px; 
}

.cr-saas-card {
    border-radius: 24px;
    padding: 35px 30px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    box-sizing: border-box;
}

.cr-saas-card:hover {
    transform: translateY(-8px);
}

.cr-huge-number {
    font-family: var(--cr-font-poppins);
    font-size: clamp(2.5rem, 3vw, 3.5rem);
    font-weight: 700;
    line-height: 1;
    margin-bottom: 20px;
    letter-spacing: -1px;
}

.cr-text-white-70 { color: rgba(255, 255, 255, 0.7); margin: 0; }

/* Carte 1 : Image (La plus haute) */
.cr-card-tall-img {
    width: 28%;
    height: 450px; 
    padding: 0;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.cr-card-tall-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.cr-card-tall-img:hover img {
    transform: scale(1.05);
}

.cr-card-overlay-bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 40px 25px 30px 25px;
    background: linear-gradient(to top, var(--cr-marine) 0%, rgba(28, 42, 57, 0) 100%);
}

/* Carte 2 : Verre fumé */
.cr-card-glass {
    width: 24%;
    height: 340px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

/* Carte 3 : Widget (Alignée en bas, suppression du margin-bottom) */
.cr-card-widget {
    width: 24%;
    height: 280px;
    background: linear-gradient(145deg, rgba(198, 167, 94, 0.08), rgba(0,0,0,0));
    border: 1px solid rgba(198, 167, 94, 0.2);
}

.cr-widget-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: auto;
}

.cr-widget-icon {
    width: 36px;
    height: 36px;
    background: rgba(16, 185, 129, 0.15);
    color: #10B981;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cr-widget-icon svg { width: 18px; height: 18px; }

.cr-widget-dots span {
    display: inline-block;
    width: 4px;
    height: 4px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    margin-left: 3px;
}

.cr-widget-subtitle {
    font-size: 0.9rem;
    margin: 15px 0 8px 0;
}

.cr-widget-footer {
    font-size: 0.85rem;
    color: #10B981;
    margin: 10px 0 0 0;
    font-weight: 500;
}

/* Carte 4 : Opaque (Transparence totale) */
.cr-card-opaque {
    width: 24%;
    height: 380px;
    background-color: #131E2A; /* Fond opaque très sombre, légèrement distinct du marine */
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.cr-card-opaque:hover {
    border-color: var(--cr-dore);
}

/* --- Responsive --- */
@media (max-width: 991px) {
    .cr-why-saas-dark {
        padding: 80px 20px;
    }

    .cr-geom-1, .cr-geom-2 {
        width: 100vw;
        border-radius: 20px;
    }

    .cr-bento-saas-grid {
        flex-direction: column;
        align-items: center;
        height: auto;
    }

    .cr-saas-card {
        width: 100% !important;
        height: auto !important;
        min-height: 250px;
    }
    
    .cr-card-tall-img {
        min-height: 350px;
    }
}

.cr-header {
    padding-top: 20px; 
}

/* ==========================================================================
   WIDGETS FLOTTANTS GENERAUX (PC)
   ========================================================================== */
.cr-floating-widget {
    position: fixed;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9999;
}

.cr-floating-menu {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.cr-floating-toggle, .cr-mobile-text, .cr-contact-item-mobile {
    display: none !important; /* Eléments masqués sur ordinateur */
}

.cr-social-item {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(28, 42, 57, 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: #ffffff;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 8px 32px 0 rgba(28, 42, 57, 0.2);
}

.cr-social-item:hover {
    color: #c6a75e;
    border-color: #c6a75e;
    transform: scale(1.1);
    background: rgba(28, 42, 57, 0.95);
}

/* Style de l'icône téléphone à droite (PC) */
.cr-call-item {
    background: rgba(198, 167, 94, 0.15);
    border-color: rgba(198, 167, 94, 0.4);
    color: #c6a75e;
}

/* BOUTON CONTACT BAS DROITE (PC) */
.cr-desktop-btn-bottom {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 9998;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.85rem 1.75rem;
    border-radius: 99px;
    background: rgba(28, 42, 57, 0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: #ffffff;
    font-family: var(--cr-font-poppins);
    font-size: 0.9rem;
    font-weight: 500;
    text-decoration: none;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
    transition: all 0.3s ease;
}

.cr-desktop-btn-bottom:hover {
    background: #c6a75e;
    border-color: #c6a75e;
    color: #ffffff;
    transform: translateY(-3px);
    box-shadow: 0 12px 35px rgba(198, 167, 94, 0.3);
}

/* ==========================================================================
   WIDGETS FLOTTANTS GENERAUX (PC) - GLASSMORPHISM APPLE 2026
   ========================================================================== */
.cr-floating-widget {
    position: fixed;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9999;
}

.cr-floating-menu {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.cr-floating-toggle, .cr-mobile-text, .cr-contact-item-mobile {
    display: none !important; /* Eléments masqués sur ordinateur */
}

/* Pastilles réseaux sociaux (Glassmorphism) */
.cr-social-item {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    
    /* Effet Glassmorphism Apple */
    background: rgba(255, 255, 255, 0.65); /* Fond blanc très translucide */
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.8);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.08);
    
    color: var(--cr-noir); /* Icône sombre pour contraster sur le blanc */
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.cr-social-item:hover {
    color: var(--cr-dore);
    border-color: var(--cr-dore);
    transform: scale(1.1);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 12px 40px 0 rgba(0, 0, 0, 0.12);
}

/* Style de l'icône téléphone à droite (PC) */
.cr-call-item {
    /* Le téléphone garde une teinte légèrement dorée pour se démarquer */
    background: rgba(198, 167, 94, 0.15); 
    border-color: rgba(198, 167, 94, 0.3);
    color: var(--cr-dore);
}

.cr-call-item:hover {
    background: rgba(198, 167, 94, 0.25);
}

/* BOUTON CONTACT BAS DROITE (PC) - GLASSMORPHISM APPLE 2026 */
.cr-desktop-btn-bottom {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 9998;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.85rem 1.75rem;
    border-radius: 99px;
    
    /* Effet Glassmorphism Apple */
    background: rgba(255, 255, 255, 0.75); /* Fond blanc translucide */
    backdrop-filter: blur(24px) saturate(180%);
    -webkit-backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.9);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    
    color: var(--cr-noir); /* Texte sombre */
    font-family: var(--cr-font-poppins);
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
}

.cr-desktop-btn-bottom:hover {
    background: var(--cr-dore); /* Le bouton devient or au survol */
    border-color: var(--cr-dore);
    color: var(--cr-blanc); /* Le texte passe en blanc */
    transform: translateY(-3px);
    box-shadow: 0 15px 40px rgba(198, 167, 94, 0.3);
}

/* ==========================================================================
   FIX : MASQUER LE BOUTON TÉLÉPHONE SUR ORDINATEUR
   ========================================================================== */
@media (min-width: 768px) {
    .cr-call-item {
        display: none !important;
    }
}

/* ==========================================================================
   OPTIMISATION ERGONOMIQUE MOBILE
   ========================================================================== */
@media (max-width: 767px) {
    .cr-desktop-btn-bottom {
        display: none !important; /* On coupe le bouton du bas sur mobile */
    }

    .cr-floating-widget {
        top: auto;
        right: auto;
        bottom: 1.5rem;
        left: 1rem;
        transform: none;
    }

    /* Le bouton de déclenchement 3 points apparait en bas à gauche */
    .cr-floating-toggle {
        display: flex !important;
        align-items: center;
        justify-content: center;
        width: 48px;
        height: 48px;
        border-radius: 50%;
        background: rgba(28, 42, 57, 0.95);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        border: 1px solid rgba(255, 255, 255, 0.2);
        color: #ffffff;
        cursor: pointer;
        box-shadow: 0 8px 32px 0 rgba(28, 42, 57, 0.3);
        z-index: 2;
        position: relative;
        transition: all 0.3s ease;
    }

    /* Le tiroir de contenu se cache au-dessus du bouton */
    .cr-floating-menu {
        position: absolute;
        bottom: calc(100% + 12px);
        left: 0;
        flex-direction: column-reverse; /* Empilement vers le haut */
        align-items: flex-start;
        opacity: 0;
        visibility: hidden;
        transform: translateY(20px) scale(0.95);
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: 1;
        pointer-events: none;
        gap: 0.6rem;
    }

    /* Déploiement mécanique au clic */
    .cr-floating-widget.cr-is-open .cr-floating-menu {
        opacity: 1;
        visibility: visible;
        transform: translateY(0) scale(1);
        pointer-events: auto;
    }

    .cr-floating-widget.cr-is-open .cr-floating-toggle {
        transform: rotate(90deg);
        background: #c6a75e;
        border-color: #c6a75e;
    }

    /* Ajustement des boutons ronds de réseaux */
    .cr-social-item {
        width: 42px;
        height: 42px;
    }

    .cr-mobile-text {
        display: inline !important;
        font-family: var(--cr-font-poppins);
        font-size: 0.9rem;
        font-weight: 500;
        white-space: nowrap;
        color: #ffffff;
    }

    /* Transformation des boutons de contact et d'appel en ligne de boutons (Pilules) */
    .cr-contact-item-mobile, .cr-call-item {
        display: flex !important; /* On réaffiche le téléphone ici */
        width: auto !important;
        padding: 0 1.25rem;
        gap: 0.6rem;
        border-radius: 99px !important;
    }

    .cr-contact-item-mobile {
        background: linear-gradient(135deg, rgba(198, 167, 94, 0.95), rgba(168, 137, 64, 0.95));
        border-color: transparent;
        margin-bottom: 0.25rem;
    }

    .cr-call-item {
        background: rgba(28, 42, 57, 0.95);
        border-color: rgba(255, 255, 255, 0.15);
        color: #c6a75e;
    }
}

/* --- DESIGN SYSTEM CONTACT CESC RIVIERA --- */
.contact-hero {
    padding: 200px 5% 60px;
    background-color: var(--cr-blanc);
    display: flex;
    justify-content: center;
    font-family: var(--cr-font-poppins);
}

.contact-hero__container {
    max-width: 1200px;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1.1fr; 
    gap: 80px;
    align-items: start;
}

/* Colonne Gauche : Contenu */
.contact-hero__content {
    display: flex;
    flex-direction: column;
    gap: 32px;
    position: sticky;
    top: 120px;
}

.contact-hero__accent-title {
    color: var(--cr-dore);
    font-family: var(--cr-font-playfair);
    font-size: 32px;
    font-style: italic; /* Rendu élégant typique du Playfair */
    font-weight: 600;
    margin-bottom: -15px; 
}

.contact-hero__title {
    font-family: var(--cr-font-playfair);
    font-size: clamp(32px, 4vw, 56px);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--cr-noir);
    margin: 0;
}

.contact-hero__checklist {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.contact-hero__checklist li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 17px;
    color: var(--cr-anthracite);
    font-weight: 300;
}

.contact-hero__checklist svg {
    width: 20px;
    height: 20px;
    color: var(--cr-noir);
    flex-shrink: 0;
}

/* Carte Manager */
.contact-manager-card {
    background: var(--cr-beige); /* Utilisation de ton beige */
    border: 1px solid rgba(198, 167, 94, 0.2); /* Touche dorée discrète */
    border-radius: 24px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 20px;
    max-width: 400px;
    margin-top: 20px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.contact-manager-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.contact-manager-card__img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    background-color: var(--cr-blanc);
}

.contact-manager-card__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex-grow: 1;
}

.contact-manager-card__name {
    font-family: var(--cr-font-playfair);
    font-size: 18px;
    font-weight: 600;
    color: var(--cr-noir);
    margin: 0;
}

.contact-manager-card__role {
    font-size: 14px;
    color: var(--cr-gris);
    margin-bottom: 8px;
}

/* Couleur du bouton avec le dégradé Instagram */
.contact-manager-card__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    color: var(--cr-blanc) !important;
    text-decoration: none;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    width: fit-content;
    transition: transform 0.2s, box-shadow 0.2s;
}

/* Effet au survol du bouton Instagram */
.contact-manager-card__btn:hover {
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(220, 39, 67, 0.3);
}

/* --- ENCAPSULATION WPFORMS CESC RIVIERA --- */
.contact-hero__form-wrapper {
    background: var(--cr-blanc);
    border: 1px solid rgba(26, 26, 26, 0.1);
    border-radius: 32px;
    padding: 40px;
    box-shadow: 0 20px 40px rgba(0,0,0,0.04);
}

.contact-hero__form-title {
    font-family: var(--cr-font-playfair);
    font-size: 24px;
    font-weight: 700;
    color: var(--cr-noir);
    margin-top: 0;
    margin-bottom: 24px;
    text-align: center;
}

/* Style des champs WPForms */
.wpforms-container .wpforms-field-label {
    font-family: var(--cr-font-poppins) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--cr-noir) !important;
    margin-bottom: 8px !important;
}

.wpforms-container input[type="text"],
.wpforms-container input[type="email"],
.wpforms-container input[type="tel"],
.wpforms-container select,
.wpforms-container textarea {
    font-family: var(--cr-font-poppins) !important;
    background-color: var(--cr-beige) !important;
    border: 1px solid transparent !important;
    border-radius: 12px !important;
    padding: 12px 16px !important;
    font-size: 16px !important;
    color: var(--cr-anthracite) !important;
    transition: all 0.2s ease-in-out !important;
}

.wpforms-container input:focus, 
.wpforms-container textarea:focus {
    background-color: var(--cr-blanc) !important;
    border-color: var(--cr-dore) !important;
    box-shadow: 0 0 0 4px rgba(198, 167, 94, 0.15) !important;
    outline: none !important;
}

/* Bouton Envoyer Cesc Riviera */
.wpforms-container .wpforms-submit {
    font-family: var(--cr-font-poppins) !important;
    background-color: var(--cr-dore) !important;
    color: var(--cr-blanc) !important;
    border: none !important;
    padding: 16px 32px !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    border-radius: 9999px !important; /* Bouton pilule de ta charte */
    width: 100% !important;
    cursor: pointer !important;
    box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1) !important;
    transition: all 0.3s ease !important;
}

.wpforms-container .wpforms-submit:hover {
    background-color: #b59853 !important;
    transform: translateY(-4px) !important;
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.15) !important;
}

/* --- RESPONSIVE MOBILE --- */
@media (max-width: 1024px) {
    .contact-hero__container {
        grid-template-columns: 1fr;
        gap: 60px;
    }
    .contact-hero__content {
        position: static;
    }
}

@media (max-width: 768px) {
    .contact-hero {
        padding-top: 100px;
    }
    
    .contact-hero__content {
        align-items: center; 
        text-align: center;
    }

    .contact-hero__title {
        font-size: clamp(2.25rem, 4vw, 3rem); /* Taille adaptée mobile */
    }

    .contact-hero__checklist {
        align-items: flex-start;
        text-align: left;
    }

    .contact-manager-card {
        flex-direction: column;
        text-align: center;
        padding: 30px;
        width: 100%;
    }

    .contact-manager-card__info {
        align-items: center; 
    }

    .contact-hero__form-wrapper {
        padding: 24px;
        border-radius: 24px;
    }
}

/* --- SECTION COORDONNÉES --- */
.contact-info-section {
    padding: 20px 5% 80px;
    background-color: var(--cr-blanc);
    font-family: var(--cr-font-poppins);
}

.contact-info__container {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.contact-info__card {
    background-color: var(--cr-blanc);
    border: 1px solid rgba(26, 26, 26, 0.1);
    border-radius: 24px;
    padding: 32px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    text-decoration: none;
}

.contact-info__card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.04);
    border-color: var(--cr-dore);
}

.contact-info__icon-wrapper {
    width: 56px;
    height: 56px;
    background-color: var(--cr-blanc);
    border: 1px solid rgba(26, 26, 26, 0.1);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    color: var(--cr-dore);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.02);
}

.contact-info__icon-wrapper svg {
    width: 24px;
    height: 24px;
    stroke-width: 2;
}

.contact-info__title {
    font-family: var(--cr-font-playfair);
    font-size: 17px;
    font-weight: 600;
    color: var(--cr-noir);
    margin: 0 0 8px 0;
}

/* --- RESPONSIVE --- */
@media (max-width: 1024px) {
    .contact-info__container {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
}

@media (max-width: 600px) {
    .contact-info__container {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .contact-info__card {
        padding: 24px;
        flex-direction: row;
        text-align: left;
    }
    .contact-info__icon-wrapper {
        margin-bottom: 0;
        margin-right: 20px;
        flex-shrink: 0;
    }
}

/* --- CORRECTION CHECKBOX RGPD WPFORMS --- */
.wpforms-container input[type="checkbox"] {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 20px !important;
    height: 20px !important;
    border: 2px solid var(--cr-gris) !important; 
    border-radius: 6px !important;
    background-color: var(--cr-blanc) !important;
    cursor: pointer !important;
    position: relative !important;
    top: 4px; 
    margin-right: 10px !important;
    transition: all 0.2s ease !important;
    opacity: 1 !important; 
}

.wpforms-container input[type="checkbox"]:hover {
    border-color: var(--cr-noir) !important;
}

.wpforms-container input[type="checkbox"]:checked {
    background-color: var(--cr-dore) !important;
    border-color: var(--cr-dore) !important;
}

.wpforms-container input[type="checkbox"]:checked::after {
    content: '' !important;
    position: absolute !important;
    left: 6px !important;
    top: 2px !important;
    width: 4px !important;
    height: 10px !important;
    border: solid var(--cr-blanc) !important; 
    border-width: 0 2px 2px 0 !important;
    transform: rotate(45deg) !important;
    display: block !important;
}

/* ==========================================================================
   MENU MOBILE HORS-CHAMP (OFF-CANVAS)
   ========================================================================== */

/* Masquer le hamburger sur ordinateur */
@media (min-width: 1025px) {
    .cr-mobile-toggle,
    .cr-mobile-offcanvas {
        display: none !important;
    }
}

/* Bouton Hamburger */
.cr-mobile-toggle {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 30px;
    height: 21px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 100;
}

.cr-hamburger-line {
    width: 100%;
    height: 2px;
    background-color: var(--cr-noir);
    border-radius: 2px;
    transition: all 0.3s ease;
}

/* Conteneur principal Off-Canvas */
.cr-mobile-offcanvas {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s 0.4s, opacity 0.4s ease;
}

.cr-mobile-offcanvas.cr-is-open {
    visibility: visible;
    opacity: 1;
    transition: opacity 0.4s ease;
}

/* Overlay sombre */
.cr-offcanvas-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(26, 26, 26, 0.6);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

/* Panneau latéral (Glisse depuis la droite) */
.cr-offcanvas-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 85%;
    max-width: 400px;
    height: 100%;
    background-color: var(--cr-blanc);
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.1);
    transform: translateX(100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.cr-mobile-offcanvas.cr-is-open .cr-offcanvas-content {
    transform: translateX(0);
}

/* En-tête du panneau (Logo + Fermer) */
.cr-offcanvas-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 24px 40px;
}

.cr-offcanvas-logo {
    height: 45px;
    width: auto;
}

.cr-offcanvas-close {
    background: transparent;
    border: none;
    color: var(--cr-noir);
    cursor: pointer;
    padding: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: var(--cr-beige);
    transition: background-color 0.2s ease;
}

/* Liste des liens */
.cr-mobile-nav {
    flex-grow: 1;
    padding: 0 24px;
}

.cr-mobile-menu-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.cr-mobile-link,
.cr-mobile-dropdown-toggle {
    font-family: var(--cr-font-playfair);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--cr-noir);
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: transparent;
    border: none;
    padding: 8px 0;
    cursor: pointer;
    text-align: left;
}

/* Bouton Contact mis en évidence */
.cr-mobile-link-highlight {
    color: var(--cr-dore);
}

/* Accordéon des sous-menus */
.cr-chevron {
    transition: transform 0.3s ease;
    color: var(--cr-dore);
}

.cr-mobile-dropdown-toggle.cr-is-active .cr-chevron {
    transform: rotate(180deg);
}

.cr-mobile-submenu {
    list-style: none;
    padding: 0 0 0 16px;
    margin: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, margin 0.4s ease;
    border-left: 2px solid var(--cr-beige);
}

.cr-mobile-submenu.cr-is-open {
    max-height: 400px; /* Assez grand pour révéler les liens */
    margin: 12px 0;
}

.cr-mobile-submenu li {
    margin-bottom: 12px;
}

.cr-mobile-submenu li:last-child {
    margin-bottom: 0;
}

.cr-mobile-submenu a {
    font-family: var(--cr-font-poppins);
    font-size: 1.05rem;
    color: var(--cr-gris);
    text-decoration: none;
    display: block;
    padding: 4px 0;
}

.cr-mobile-submenu a:hover {
    color: var(--cr-dore);
}

/* Pied de page du menu (Contact & Réseaux) */
.cr-offcanvas-footer {
    padding: 40px 24px 32px;
    border-top: 1px solid var(--cr-beige);
    margin-top: auto;
}

.cr-offcanvas-contact {
    font-family: var(--cr-font-poppins);
    font-size: 0.95rem;
    color: var(--cr-gris);
    line-height: 1.6;
    margin: 0 0 20px 0;
}

.cr-offcanvas-contact a {
    color: var(--cr-noir);
    font-weight: 600;
    text-decoration: none;
    font-size: 1.1rem;
}

.cr-offcanvas-socials {
    display: flex;
    gap: 16px;
}

.cr-offcanvas-socials a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--cr-beige);
    color: var(--cr-noir);
    transition: all 0.3s ease;
}

.cr-offcanvas-socials a:hover {
    background-color: var(--cr-dore);
    color: var(--cr-blanc);
}

/* ==========================================================================
   STYLE DU MENU MOBILE (POUR LA ZONE HORS-CHAMP BLOCKSY)
   ========================================================================== */

.cr-bl-mobile-nav {
    padding: 20px 0;
}

.cr-bl-menu-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.cr-bl-link,
.cr-bl-dropdown-toggle {
    font-family: var(--cr-font-playfair);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--cr-noir) !important;
    text-decoration: none !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: transparent;
    border: none;
    padding: 8px 0;
    cursor: pointer;
    text-align: left;
}

/* Bouton Contact mis en évidence */
.cr-bl-link-highlight {
    color: var(--cr-dore) !important;
}

/* Accordéon des sous-menus */
.cr-chevron {
    transition: transform 0.3s ease;
    color: var(--cr-dore);
}

.cr-bl-dropdown-toggle.cr-is-active .cr-chevron {
    transform: rotate(180deg);
}

.cr-bl-submenu {
    list-style: none !important;
    padding: 0 0 0 16px !important;
    margin: 0 !important;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, margin 0.4s ease;
    border-left: 2px solid var(--cr-dore);
}

.cr-bl-submenu.cr-is-open {
    max-height: 400px;
    margin: 12px 0 !important;
}

.cr-bl-submenu li {
    margin-bottom: 12px;
}

.cr-bl-submenu li:last-child {
    margin-bottom: 0;
}

.cr-bl-submenu a {
    font-family: var(--cr-font-poppins);
    font-size: 1.05rem;
    color: var(--cr-gris) !important;
    text-decoration: none !important;
    display: block;
    padding: 4px 0;
}

.cr-bl-submenu a:hover {
    color: var(--cr-dore) !important;
}

/* Infos contact et réseaux en bas du menu */
.cr-bl-footer {
    padding-top: 30px;
    margin-top: 20px;
    border-top: 1px solid rgba(198, 167, 94, 0.2); /* Ligne dorée subtile */
}

.cr-bl-contact {
    font-family: var(--cr-font-poppins);
    font-size: 0.95rem;
    color: var(--cr-gris);
    line-height: 1.6;
    margin: 0 0 20px 0;
}

.cr-bl-contact a {
    color: var(--cr-noir) !important;
    font-weight: 600;
    text-decoration: none !important;
    font-size: 1.1rem;
}

.cr-bl-socials {
    display: flex;
    gap: 16px;
}

.cr-bl-socials a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--cr-beige);
    color: var(--cr-noir) !important;
    transition: all 0.3s ease;
}

.cr-bl-socials a:hover {
    background-color: var(--cr-dore);
    color: var(--cr-blanc) !important;
}

/* ==========================================================================
   FIX : PADDING TOP HERO SUR MOBILE
   ========================================================================== */
@media (max-width: 767px) {
    .cr-hero {
        padding-top: 1vh !important; /* Modifie cette valeur (ex: 120px ou 25vh) pour ajuster la hauteur */
    }
}

@media (max-width: 767px) {
    .cr-cta-group {
        margin-top: 2rem !important; /* Modifie cette valeur (ex: 1.5rem ou 30px) pour ajuster l'espace */
    }
}

/* ==========================================================================
   GESTION DES RETOURS À LA LIGNE RESPONSIVE
   ========================================================================== */

/* Par défaut (sur ordinateur), le saut de ligne s'affiche normalement */
.cr-br-desktop {
    display: block;
}

/* Sur tablette et mobile (en dessous de 992px), on annule le saut de ligne */
@media (max-width: 991px) {
    .cr-br-desktop {
        display: none !important;
    }
}

/* ==========================================================================
   WIDGET LEAD MAGNET HERO (STYLE DASHBOARD DARK)
   ========================================================================== */

/* Conteneur principal (Glassmorphism Dark) */
.cr-widget-magnet.cr-glass-dark {
    background: rgba(28, 42, 57, 0.95);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.5rem;
    padding: 1.75rem;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
    font-family: var(--cr-font-poppins);
    width: 20rem; /* Élargi pour accommoder les données */
}

/* En-tête */
.cr-magnet-surtitle {
    display: block;
    color: var(--cr-dore);
    font-size: 0.60rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 0.5rem;
}

.cr-magnet-price {
    font-family: var(--cr-font-playfair);
    font-size: 2rem;
    font-weight: 700;
    color: var(--cr-blanc);
    line-height: 1.1;
    margin-bottom: 0.25rem;
}

.cr-magnet-date {
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Badge de statut (perçus / à venir) */
.cr-magnet-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.5rem 0.8rem;
    border-radius: 50px;
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.65rem;
    font-weight: 500;
    margin: 1.5rem 0;
}

.cr-magnet-badge svg {
    color: rgba(255, 255, 255, 0.5);
}

/* Section Graphique en barres */
.cr-magnet-chart-section {
    margin-bottom: 0.5rem;
}

.cr-magnet-chart {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    height: 80px; 
    gap: 0.4rem;
    margin-top: 1rem;
}

.cr-magnet-chart .cr-bar-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    height: 100%;
    justify-content: flex-end;
}

.cr-magnet-chart .cr-bar {
    width: 100%;
    border-radius: 4px;
    transition: height 0.5s ease;
}

.cr-bar-past {
    background-color: rgba(255, 255, 255, 0.15); /* Gris/Blanc translucide pour le passé */
}

.cr-bar-future {
    background-color: var(--cr-dore); /* Or éclatant pour l'avenir */
    box-shadow: 0 4px 10px rgba(198, 167, 94, 0.2);
}

.cr-magnet-chart .cr-bar-label {
    font-size: 0.5rem;
    color: rgba(255, 255, 255, 0.6);
}

/* Grille inférieure (Les 2 petites cartes) */
.cr-magnet-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
}

.cr-magnet-minicard {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    padding: 1rem;
    display: flex;
    flex-direction: column;
}

.cr-minicard-title {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.65rem;
    margin-bottom: 0.5rem;
}

.cr-minicard-val {
    font-family: var(--cr-font-playfair);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--cr-blanc);
    line-height: 1;
    margin-bottom: 0.25rem;
}

.cr-minicard-sub {
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.65rem;
}

/* ==========================================================================
   AJUSTEMENTS POSITION WIDGET MAGNET (PC & MOBILE)
   ========================================================================== */

/* 1. Sur PC : On le descend d'environ 100px */
@media (min-width: 1725px) {
    .cr-widget-magnet.cr-glass-dark {
        /* On passe d'environ 8rem à 2rem pour le descendre */
        bottom: 2rem !important; 
        /* Au cas où d'autres règles bloquent, on force un décalage vers le bas */
        transform: translateY(20px); 
    }
}

/* 1. Sur PC : On le descend d'environ 100px */
@media (max-width: 1724px) {
    .cr-widget-magnet.cr-glass-dark {
        /* On passe d'environ 8rem à 2rem pour le descendre */
        bottom: 1rem !important;
        right: 4rem !important; 
        /* Au cas où d'autres règles bloquent, on force un décalage vers le bas */
        transform: translateY(20px); 
    }
}

/* 2. Sur Tablette et Mobile : Affichage sous les boutons */
@media (max-width: 1023px) {
    /* On autorise la section Hero à s'agrandir pour accueillir le widget */
    .cr-hero {
        height: auto !important;
        min-height: 100vh;
        padding-bottom: 4rem; /* Espace de respiration à la fin de la section */
    }

    /* On annule le masquage et on le place dans le flux naturel */
    .cr-widget-magnet.cr-glass-dark {
        display: block !important;
        position: relative !important;
        bottom: auto !important;
        right: auto !important;
        left: auto !important;
        top: auto !important;
        width: 100% !important;
        max-width: 400px;
        margin: 4rem auto 0 auto !important; /* Espace au-dessus (sous les boutons) et centré */
        transform: none !important;
        z-index: 10;
    }
}

/* ==========================================================================
   CORRECTION SÉCURISÉE DU HERO ET ÉCARTEMENT DU H1 SUR MOBILE
   ========================================================================== */
@media (max-width: 1023px) {
    /* On force la section à empiler ses enfants verticalement sans conflit */
    .cr-hero {
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;
        height: auto !important;
        min-height: 100vh !important;
        /* Padding global de la section (Haut / Droite / Bas / Gauche) */
        padding: 7rem 0 4rem 0 !important; /* On gère les marges latérales sur les enfants */
        box-sizing: border-box !important;
    }

    /* On isole le bloc de texte et on lui remet des marges de sécurité */
    .cr-main-content {
        position: relative !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 2rem 0 !important;
        text-align: center !important;
        /* AJOUT DE MARGES DE SÉCURITÉ SUR LE CONTENU POUR LE PAS ÉCRASER */
        padding-left: 20px !important;
        padding-right: 20px !important;
        box-sizing: border-box !important;
    }

    /* Le widget se place naturellement en dessous sans rien déformer */
    .cr-widget-magnet.cr-glass-dark {
        display: block !important;
        position: relative !important;
        bottom: auto !important;
        right: auto !important;
        left: auto !important;
        top: auto !important;
        width: 100% !important;
        max-width: 380px !important; /* Taille idéale pour les smartphones */
        margin: 1rem auto 0 auto !important;
        transform: none !important;
        z-index: 10 !important;
        box-sizing: border-box !important;
    }
}

@media (max-width: 767px) {
    .cr-widget-magnet.cr-glass-dark {
        padding: 1.25rem !important;
    }
    
    .cr-magnet-price {
        font-size: 2.2rem !important;
    }
    
    .cr-magnet-chart {
        height: 60px !important;
    }
    
    .cr-minicard-val {
        font-size: 1.4rem !important;
    }
}