/* PAGE : DONNER AVIS (FORMULAIRE DE TÉMOIGNAGES CLIENTS) */

/* --- SECTION PRINCIPALE DU FORMULAIRE D'AVIS --- */
.container{width:100%;max-width:1150px;margin-left:auto;margin-right:auto;padding-left:1.5rem;padding-right:1.5rem}
.testimonial-form-section{position:relative;padding:8rem 0 6rem;overflow:hidden}

/* --- CARTE PRINCIPALE DU FORMULAIRE AVEC REFLET SUPÉRIEUR --- */
.testimonial-form-card{max-width:800px;margin:0 auto;background-color:var(--glass-bg);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.07);border-radius:2.5rem;padding:2rem;position:relative;z-index:1;overflow:hidden}
.testimonial-form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent)}
@media(min-width:768px){.testimonial-form-card{padding:3.5rem}}

/* --- EN-TÊTE DU FORMULAIRE D'AVIS --- */
.testimonial-form-header{text-align:center;margin-bottom:2.5rem}
.testimonial-title{font-size:2rem;font-weight:800;margin:0 0 1rem;color:var(--cpw-text);letter-spacing:-.025em;line-height:1.2}
@media(min-width:768px){.testimonial-title{font-size:2.5rem}}
.text-gradient{background:linear-gradient(135deg,var(--cpw-primary),#60a5fa);-webkit-background-clip:text;color:transparent;display:inline-block}
.testimonial-subtitle{font-size:1rem;color:var(--cpw-text);opacity:.7;max-width:36rem;margin:0 auto;line-height:1.7}

/* --- CORPS DU FORMULAIRE --- */
.testimonial-form{display:flex;flex-direction:column;gap:1.75rem}

/* --- ANTI-SPAM MASQUÉ --- */
.anti-spam-hp{position:absolute;z-index:-1;opacity:0;pointer-events:none;height:0;width:0;overflow:hidden}

/* --- SYSTÈME DE NOTATION PAR ÉTOILES --- */
.rating-group{text-align:center;background-color:var(--hover-bg);border-radius:1.75rem;padding:1.75rem;border:1px solid var(--glass-border);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.rating-stars{display:flex;justify-content:center;gap:.875rem}
.rating-stars i{font-size:2.25rem;cursor:pointer;color:var(--cpw-muted)}
.rating-stars i:hover,.rating-stars i.active{color:#f59e0b;transform:scale(1.12)}
.rating-stars i.hover{color:#f59e0b}
.rating-stars i:focus-visible{outline:2px solid var(--cpw-primary);outline-offset:4px;border-radius:4px}

/* --- ZONE DE DÉPÔT DE PHOTO DE PROFIL --- */
.photo-upload-area{border:2px dashed var(--glass-border);border-radius:1.5rem;padding:2rem 1.5rem;text-align:center;cursor:pointer;background-color:var(--hover-bg);position:relative;overflow:hidden}
.photo-upload-area::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}
.photo-upload-area:hover,.photo-upload-area.drag-over{border-color:var(--cpw-primary);background-color:rgba(0,123,255,.04)}
.photo-upload-area:focus-visible{outline:2px solid var(--cpw-primary);border-style:solid}
.photo-placeholder .drop-icon{width:3rem;height:3rem;border-radius:50%;background:linear-gradient(135deg,rgba(0,123,255,.12),rgba(96,165,250,.15));color:var(--cpw-primary);font-size:1.375rem;display:flex;align-items:center;justify-content:center;margin:0 auto .875rem;box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}
.photo-placeholder .drop-text{font-size:.9375rem;font-weight:700;color:var(--cpw-text);margin-bottom:.25rem}
.photo-placeholder .drop-subtext{font-size:.75rem;color:var(--cpw-muted);margin:0}
.photo-preview{position:relative;display:inline-block}
.photo-preview img{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--cpw-primary);box-shadow:0 8px 20px -4px rgba(0,123,255,.35)}
.photo-remove{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.photo-remove:hover{transform:scale(1.1)}
#testimonialPhoto{display:none}

/* --- CHAMPS DU FORMULAIRE --- */
.testimonial-form .form-row{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.testimonial-form .form-row{grid-template-columns:repeat(2,1fr)}}
.testimonial-form .form-group{display:flex;flex-direction:column;gap:.5rem}
.testimonial-form .form-label{font-size:.8125rem;font-weight:800;color:var(--cpw-text);padding-left:.25rem;letter-spacing:-.01em}
.testimonial-form .input-wrapper{position:relative;display:flex;align-items:center;width:100%}
.testimonial-form .input-wrapper.align-top .input-icon{top:1.125rem;align-self:flex-start}
.testimonial-form .input-icon{position:absolute;left:1.25rem;color:var(--cpw-muted);pointer-events:none;font-size:.875rem}
.testimonial-form .input-wrapper:focus-within .input-icon{color:var(--cpw-primary)}
.testimonial-form .glass-input{width:100%;background-color:var(--hover-bg);border:1.5px solid var(--glass-border);border-radius:1rem;padding:.9375rem 1rem .9375rem 3.25rem;font-family:inherit;font-size:.9375rem;font-weight:500;color:var(--cpw-text);outline:none;box-shadow:inset 0 2px 4px rgba(0,0,0,.04)}
.testimonial-form .glass-input:hover{border-color:rgba(0,123,255,.2);background-color:var(--glass-bg)}
.testimonial-form .glass-input:focus{border-color:var(--cpw-primary);background-color:var(--glass-bg);box-shadow:0 0 0 3px rgba(0,123,255,.12),inset 0 2px 4px rgba(0,0,0,.04)}
.testimonial-form .glass-input::placeholder{color:var(--cpw-muted);opacity:.65;font-weight:400}
.testimonial-form .textarea-resize{resize:vertical}

/* --- BOUTONS D'ACTION DU FORMULAIRE --- */
.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}
.form-actions .btn-outline{background:transparent;border:1.5px solid var(--glass-border);color:var(--cpw-text);padding:.9375rem 1.5rem;border-radius:9999px;font-weight:700;font-size:.9375rem;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap;box-shadow:var(--shadow-ios)}
.form-actions .btn-outline:hover{background-color:var(--hover-bg);border-color:var(--cpw-primary);color:var(--cpw-primary)}
.form-actions .btn-outline:hover i{transform:translateX(-3px)}
.form-actions .btn-primary{background:linear-gradient(135deg,var(--cpw-primary),#2563eb);color:#fff;border:none;padding:.9375rem 2rem;border-radius:9999px;font-weight:700;font-size:.9375rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.625rem;box-shadow:0 8px 20px -4px rgba(0,123,255,.4),inset 0 1px 0 rgba(255,255,255,.2);white-space:nowrap;position:relative;overflow:hidden}
.form-actions .btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);border-radius:9999px;pointer-events:none}
.form-actions .btn-primary:hover:not(:disabled){box-shadow:0 12px 28px -4px rgba(0,123,255,.5),inset 0 1px 0 rgba(255,255,255,.2)}
.form-actions .btn-primary:disabled{opacity:.45;cursor:not-allowed}
@media(max-width:640px){
    .form-actions{flex-direction:column-reverse}
    .form-actions .btn-primary,.form-actions .btn-outline{width:100%;justify-content:center}
}

/* --- MESSAGE DE SUCCÈS APRÈS SOUMISSION --- */
.testimonial-success{padding:2rem}
@media(min-width:768px){.testimonial-success{padding:3rem}}
.success-box{border-radius:2rem;padding:3rem 2rem;text-align:center;background:linear-gradient(135deg,rgba(34,197,94,.07),rgba(34,197,94,.11));border:1px solid rgba(34,197,94,.25);position:relative;overflow:hidden}
.success-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(34,197,94,.3),transparent)}
.success-box i{font-size:4rem;color:#22c55e;margin-bottom:1.5rem;display:block;filter:drop-shadow(0 4px 12px rgba(34,197,94,.4))}
.success-box h2{font-size:1.75rem;font-weight:800;margin-bottom:.75rem;color:var(--cpw-text);letter-spacing:-.025em}
@media(min-width:768px){.success-box h2{font-size:2rem}}
.success-box p{font-size:1rem;color:var(--cpw-muted);margin-bottom:2rem;line-height:1.7;max-width:32rem;margin-left:auto;margin-right:auto}
.btn-primary-success{background:linear-gradient(135deg,var(--cpw-primary),#2563eb);color:#fff;border:none;padding:.9375rem 2rem;border-radius:9999px;font-weight:700;font-size:.9375rem;display:inline-flex;align-items:center;gap:.625rem;box-shadow:0 8px 20px -4px rgba(0,123,255,.4),inset 0 1px 0 rgba(255,255,255,.2);text-decoration:none;position:relative;overflow:hidden}
.btn-primary-success::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);border-radius:9999px;pointer-events:none}
.btn-primary-success:hover{box-shadow:0 12px 28px -4px rgba(0,123,255,.5),inset 0 1px 0 rgba(255,255,255,.2)}

/* --- MASQUAGE RECAPTCHA ET MENTIONS LÉGALES --- */
.grecaptcha-badge{visibility:hidden!important;opacity:0!important;display:none!important}
.recaptcha-legal{text-align:center;margin-top:.5rem;font-size:.7rem;color:var(--cpw-muted)}
.recaptcha-legal i{margin-right:.375rem;color:var(--cpw-primary)}
.recaptcha-legal a{color:var(--cpw-primary);text-decoration:none}
.recaptcha-legal a:hover{text-decoration:underline;text-underline-offset:2px}

/* --- NOTIFICATIONS TOAST --- */
.cpw-toast{position:fixed;top:24px;left:50%;transform:translateX(-50%) translateY(-140px);z-index:99999;min-width:300px;max-width:90vw;padding:16px 20px;border-radius:1.25rem;display:flex;align-items:flex-start;gap:14px;box-shadow:0 20px 50px -8px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.06);opacity:0;pointer-events:none;border:1px solid rgba(255,255,255,.08);background:#1e293b}
.cpw-toast.cpw-toast--show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.cpw-toast--success{background:#0f2318;border-color:rgba(34,197,94,.3)}
.cpw-toast--error{background:#1f0f0f;border-color:rgba(239,68,68,.3)}
.cpw-toast--info{background:#0c1a33;border-color:rgba(59,130,246,.3)}
.cpw-toast__icon{font-size:1.375rem;flex-shrink:0;margin-top:2px}
.cpw-toast--success .cpw-toast__icon{color:#22c55e}
.cpw-toast--error .cpw-toast__icon{color:#ef4444}
.cpw-toast--info .cpw-toast__icon{color:#60a5fa}
.cpw-toast__body{flex:1}
.cpw-toast__title{font-weight:800;font-size:.9375rem;color:#f1f5f9;margin-bottom:4px;letter-spacing:-.01em}
.cpw-toast__message{font-size:.8125rem;color:#94a3b8;line-height:1.55}
.cpw-toast__countdown{font-size:.75rem;color:#60a5fa;margin-top:6px;font-weight:700;display:none}
.toast-container{position:fixed;top:2rem;right:2rem;z-index:6000;display:flex;flex-direction:column;gap:1rem;pointer-events:none}

/* --- ACCESSIBILITÉ --- */
.visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.text-danger{color:#ef4444;font-weight:700;font-size:.8125rem}
.hidden{display:none!important}

/* --- HERO BADGE --- */
.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: .625rem;
    padding: .5rem 1.25rem;
    border-radius: 9999px;
    background-color: var(--glass-bg);
    border: 1px solid var(--glass-border);
    box-shadow: var(--shadow-ios), inset 0 1px 0 rgba(255,255,255,.06);
}
.badge-dot-wrapper { position: relative; display: flex; width: .5rem; height: .5rem; }
.badge-dot { width: 100%; height: 100%; border-radius: 50%; background-color: var(--cpw-primary); box-shadow: 0 0 10px var(--cpw-primary); }
.badge-text { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--cpw-text); }

/* --- RESUME NOTE GLOBALE --- */
.reviews-summary-bar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 2rem;
    padding: 1rem 2rem;
    background-color: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 9999px;
    box-shadow: var(--shadow-ios), inset 0 1px 0 rgba(255,255,255,.06);
}

.reviews-summary-rating {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.reviews-summary-score {
    font-size: 2.5rem;
    font-weight: 900;
    background: linear-gradient(135deg, var(--cpw-primary), #60a5fa);
    -webkit-background-clip: text;
    color: transparent;
    line-height: 1;
}

.reviews-summary-stars {
    display: flex;
    align-items: center;
    gap: .375rem;
    flex-wrap: wrap;
}

.reviews-summary-stars .star-active { color: #f59e0b; font-size: 1.125rem; }
.reviews-summary-stars .star-empty  { color: var(--cpw-muted); font-size: 1.125rem; opacity: .4; }

.reviews-summary-count {
    font-size: .8125rem;
    font-weight: 700;
    color: var(--cpw-text);
    opacity: .6;
    margin-left: .25rem;
}

/* --- SECTION GRILLE DES AVIS --- */
.reviews-grid-section {
    padding: 4rem 0 5rem;
}

.reviews-full-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-bottom: 3rem;
}

/* --- CARTE AVIS (herite du style home) --- */
.testimonial-card {
    background-color: var(--glass-bg);
    backdrop-filter: blur(40px) saturate(200%);
    -webkit-backdrop-filter: blur(40px) saturate(200%);
    border: 1px solid var(--glass-border);
    box-shadow: var(--shadow-ios), inset 0 1px 0 rgba(255,255,255,.07);
    border-radius: 2rem;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    position: relative;
    overflow: hidden;
}

.testimonial-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.1), transparent);
}

.testimonial-card:hover {
    border-color: rgba(0,123,255,.15);
    box-shadow: 0 20px 40px -10px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.08);
}

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

.testimonial-stars { display: flex; gap: .25rem; }
.testimonial-stars .fas.active { color: #f59e0b; font-size: .9rem; }
.testimonial-stars .fas:not(.active) { color: var(--cpw-muted); font-size: .9rem; opacity: .3; }
.testimonial-quote-mark { color: var(--cpw-primary); opacity: .15; font-size: 1.5rem; }

.testimonial-text {
    font-size: .9375rem;
    color: var(--cpw-text);
    opacity: .78;
    line-height: 1.75;
    flex: 1;
    font-style: italic;
    margin: 0;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: .875rem;
    padding-top: 1rem;
    border-top: 1px solid var(--glass-border);
    margin-top: auto;
}

.testimonial-avatar {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    border: 2px solid var(--glass-border);
}

.testimonial-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.testimonial-avatar-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--cpw-primary), #2563eb);
    color: #fff;
    font-weight: 800;
    font-size: 1.125rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.author-name {
    display: block;
    font-size: .9375rem;
    font-weight: 800;
    color: var(--cpw-text);
    letter-spacing: -.01em;
}

.author-role {
    font-size: .8125rem;
    color: var(--cpw-text);
    opacity: .55;
    display: block;
    margin-top: .1rem;
}

.review-date {
    font-size: .7rem;
    color: var(--cpw-muted);
    opacity: .5;
    display: flex;
    align-items: center;
    gap: .375rem;
    font-weight: 600;
    margin-top: -.5rem;
}

/* --- PAGINATION --- */
.reviews-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
    margin-top: 3rem;
    flex-wrap: wrap;
}

.pagination-btn {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--glass-bg);
    border: 1px solid var(--glass-border);
    color: var(--cpw-text);
    text-decoration: none;
    font-size: .875rem;
    box-shadow: var(--shadow-ios);
}

.pagination-btn:hover:not(.disabled) {
    background-color: var(--cpw-primary);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 6px 16px -4px rgba(0,123,255,.4);
}

.pagination-btn.disabled {
    opacity: .3;
    cursor: not-allowed;
    pointer-events: none;
}

.pagination-pages {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.pagination-page {
    min-width: 2.75rem;
    height: 2.75rem;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--glass-bg);
    border: 1px solid var(--glass-border);
    color: var(--cpw-text);
    text-decoration: none;
    font-size: .875rem;
    font-weight: 700;
    box-shadow: var(--shadow-ios);
    padding: 0 .75rem;
}

.pagination-page:hover {
    background-color: rgba(0,123,255,.08);
    border-color: rgba(0,123,255,.2);
    color: var(--cpw-primary);
}

.pagination-page.active {
    background: linear-gradient(135deg, var(--cpw-primary), #2563eb);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 6px 16px -4px rgba(0,123,255,.4);
}

.pagination-ellipsis {
    color: var(--cpw-muted);
    font-weight: 700;
    padding: 0 .25rem;
}

/* --- SEPARATEUR ENTRE GRILLE ET FORMULAIRE --- */
.reviews-divider-section {
    padding: 2rem 0;
}

.reviews-divider-inner {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.reviews-divider-line {
    flex: 1;
    height: 1px;
    background: var(--glass-border);
}

.reviews-divider-text {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: .875rem;
    font-weight: 700;
    color: var(--cpw-muted);
    white-space: nowrap;
    padding: .5rem 1.25rem;
    border-radius: 9999px;
    border: 1px solid var(--glass-border);
    background-color: var(--glass-bg);
}

/* --- EMPTY STATE --- */
.reviews-empty {
    text-align: center;
    padding: 5rem 2rem;
    color: var(--cpw-muted);
}

.reviews-empty i {
    font-size: 3rem;
    margin-bottom: 1rem;
    display: block;
    opacity: .25;
}

/* --- RESPONSIVE --- */
@media (min-width: 640px) {
    .reviews-full-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .reviews-full-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* BADGE ET BOUTON AVIS GOOGLE */
.google-reviews-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.625rem 1.25rem;
    border-radius: 100px;
    margin-top: 1.5rem;
    transition: all 0.3s ease;
    text-decoration: none;
    color: var(--text-color);
}

.google-reviews-badge:hover {
    background: rgba(255, 255, 255, 0.1);
    transform: translateY(-2px);
    border-color: #4285F4;
}

.google-icon-brand {
    color: #4285F4;
    font-size: 1.25rem;
}

.google-badge-text {
    font-size: 0.875rem;
    font-weight: 500;
}

.google-badge-stars {
    color: #FBBC05;
    font-size: 0.75rem;
    margin-left: 0.25rem;
}

.form-google-cta {
    text-align: center;
    margin-bottom: 2rem;
    padding: 1.5rem;
    border-radius: 1.25rem;
    background: rgba(66, 133, 244, 0.05);
    border: 1px dashed rgba(66, 133, 244, 0.2);
}

.btn-google-review {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: #4285F4;
    font-weight: 600;
    text-decoration: none;
    transition: opacity 0.3s ease;
}

.btn-google-review:hover {
    text-decoration: underline;
    opacity: 0.8;
}

/* OPTIMISATION RESPONSIVE BADGE GOOGLE */
.reviews-summary-bar {
    display: flex;
    flex-direction: column; /* Par défaut en colonne sur mobile */
    align-items: center;
    gap: 1.5rem;
    margin-top: 2rem;
}

@media (min-width: 768px) {
    .reviews-summary-bar {
        flex-direction: row; /* Repasse en ligne sur tablette/PC */
        justify-content: center;
        gap: 3rem;
    }
}

.google-reviews-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 1rem;
    border-radius: 100px;
    text-decoration: none;
    color: var(--text-color);
    transition: all 0.3s ease;
    max-width: fit-content;
}

.google-icon-brand {
    color: #4285F4;
    font-size: 1.1rem;
}

.google-badge-text {
    font-size: 0.8rem;
    font-weight: 500;
    white-space: nowrap;
}

.google-badge-stars {
    color: #FBBC05;
    font-size: 0.65rem;
    display: flex;
    gap: 1px;
}

/* Ajustement spécifique pour le texte de la note interne pour harmoniser */
.reviews-summary-score {
    font-size: 2.5rem;
    line-height: 1;
}

@media (max-width: 480px) {
    .google-reviews-badge {
        padding: 0.4rem 0.8rem;
    }
    .google-badge-text {
        font-size: 0.75rem;
    }
}

/* DESIGN COMPACT : NOTES & GOOGLE BADGE */
.reviews-summary-bar {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    margin-top: 1.5rem;
}

@media (min-width: 768px) {
    .reviews-summary-bar {
        flex-direction: row;
        justify-content: center;
        gap: 2rem;
    }
}

.reviews-summary-rating {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.reviews-summary-score {
    font-size: 2.25rem; /* Réduit de 2.5rem */
    font-weight: 700;
    line-height: 1;
    color: var(--primary-color);
}

.reviews-summary-stars {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}

.reviews-summary-stars i {
    font-size: 0.7rem;
}

.google-reviews-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.35rem 0.75rem; /* Plus compact */
    border-radius: 50px;
    text-decoration: none;
    color: var(--text-color);
    transition: all 0.3s ease;
}

.google-reviews-badge:hover {
    border-color: #4285F4;
    background: rgba(66, 133, 244, 0.05);
}

.google-icon-brand {
    color: #4285F4;
    font-size: 1rem;
}

.google-badge-text {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.3px;
}

.google-badge-stars {
    color: #FBBC05;
    font-size: 0.6rem;
    display: flex;
    gap: 1px;
}

@media (max-width: 480px) {
    .reviews-summary-score { font-size: 2rem; }
    .google-reviews-badge { padding: 0.3rem 0.6rem; }
}

/* HERO SECTION PADDING */
.testimonial-hero-section {
    padding-top: 8rem;
    padding-bottom: 3rem;
    text-align: center;
}

/* FORMULAIRE BOTTOM SECTION PADDING */
.testimonial-form-bottom-section {
    padding-top: 4rem;
    padding-bottom: 6rem;
}

/* TITRE FORMULAIRE — version réduite */
.testimonial-title--small {
    font-size: 1.75rem;
}
@media (min-width: 768px) {
    .testimonial-title--small { font-size: 2rem; }
}

/* RATING LABEL ET ERREUR */
.rating-label {
    display: block;
    text-align: center;
    margin-bottom: 1rem;
}
.rating-error {
    display: block;
    text-align: center;
    margin-top: 0.5rem;
}

/* GOOGLE CTA TEXT */
.form-google-cta-text {
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
    opacity: 0.8;
    margin-top: 0;
}

/* REVIEWS SUMMARY BAR — version unifiée, sans doublons */
.reviews-summary-bar {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    margin-top: 1.5rem;
    padding: 1rem 2rem;
    background-color: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 9999px;
    box-shadow: var(--shadow-ios), inset 0 1px 0 rgba(255,255,255,.06);
}
@media (min-width: 768px) {
    .reviews-summary-bar {
        flex-direction: row;
        justify-content: center;
        gap: 2rem;
    }
}

.reviews-summary-rating {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.reviews-summary-score {
    font-size: 2.25rem;
    font-weight: 900;
    background: linear-gradient(135deg, var(--cpw-primary), #60a5fa);
    -webkit-background-clip: text;
    color: transparent;
    line-height: 1;
}

.reviews-summary-stars {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}

.reviews-summary-stars i { font-size: 0.7rem; }
.reviews-summary-stars .star-active { color: #f59e0b; }
.reviews-summary-stars .star-empty  { color: var(--cpw-muted); opacity: 0.4; }

.reviews-summary-count {
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--cpw-text);
    opacity: 0.6;
    margin-left: 0.25rem;
}

/* GOOGLE REVIEWS BADGE — version unifiée, sans doublons */
.google-reviews-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.35rem 0.875rem;
    border-radius: 50px;
    text-decoration: none;
    color: var(--cpw-text);
    transition: all 0.3s ease;
    max-width: fit-content;
}
.google-reviews-badge:hover {
    border-color: #4285F4;
    background: rgba(66, 133, 244, 0.06);
    transform: translateY(-2px);
}
.google-icon-brand {
    color: #4285F4;
    font-size: 1rem;
}
.google-badge-text {
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.3px;
    white-space: nowrap;
}
.google-badge-stars {
    color: #FBBC05;
    font-size: 0.6rem;
    display: flex;
    gap: 1px;
}

@media (max-width: 480px) {
    .reviews-summary-score    { font-size: 2rem; }
    .google-reviews-badge     { padding: 0.3rem 0.625rem; }
    .google-badge-text        { font-size: 0.75rem; }
}

/* REVIEWS SUMMARY BAR — version compacte corrigée */
.reviews-summary-bar {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 1.5rem;
    padding: 0.625rem 1.75rem;
    background-color: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 9999px;
    box-shadow: var(--shadow-ios), inset 0 1px 0 rgba(255,255,255,.06);
}

.reviews-summary-rating {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.625rem;
}

.reviews-summary-stars {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 2px;
}

.reviews-summary-stars i {
    font-size: 0.8125rem;
}

.reviews-summary-score {
    font-size: 1.5rem;
    font-weight: 900;
    line-height: 1;
}

.reviews-summary-count {
    font-size: 0.75rem;
    white-space: nowrap;
}



