/* ================================================================
   Premium Design – Single Email Agent
   Palette: Bleu nuit #0C1B33 · Violet #6C4AB6 · Doré #C8A66A · Ivoire #FAF9F7
   Typo conseillée : "Playfair Display" pour les titres + system-ui pour le texte
   ================================================================ */

/* ------------------------- Reset utile ------------------------- */
:root{
  --hai-bg: #FAF9F7;
  --hai-ink: #0C1B33;
  --hai-muted: #6B7280;
  --hai-accent: #6C4AB6;
  --hai-gold: #C8A66A;
  --hai-ivory: #ffffff;
  --hai-surface: rgba(255,255,255,0.7);
  --hai-blur: 10px;
  --hai-radius: 16px;
  --hai-radius-lg: 24px;
  --hai-shadow: 0 8px 30px rgba(12,27,51,.12);
  --hai-shadow-soft: 0 4px 18px rgba(12,27,51,.08);
  --hai-ring: 0 0 0 2px rgba(108,74,182,.15);
}

/* -------------------- Layout global & fond --------------------- */
body.single-hai_email_agent{
  background: radial-gradient(1200px 600px at 80% -10%, rgba(108,74,182,.08), transparent 60%),
              radial-gradient(1000px 600px at -10% 20%, rgba(200,166,106,.10), transparent 55%),
              var(--hai-bg);
  color: var(--hai-ink);
}

/* ======================== HERO BANNIÈRE ======================== */
/* Place cette section HTML au-dessus de ton header :
<section class="hai-hero-banner">
  <div class="hai-hero-bg" style="background-image:url('.../assets/img/oeil-celeste.webp');"></div>
  <div class="hai-hero-overlay"></div>
  <div class="hai-hero-inner">
    <div class="hai-hero-chip"><span class="chip-dot"></span><span>Titre / Pseudo</span></div>
  </div>
</section>
*/
/* ======================== HERO BANNIÈRE (clean) ======================== */
.hai-hero-banner{
  position: relative;
  height: clamp(160px, 20vh, 240px); /* ← réduit */
  border-radius: 0 0 24px 24px;
  overflow: hidden;
  margin: 0 auto 0;
  max-width: 2000px;
  box-shadow: 0 12px 30px rgba(12,27,51,0.08);
  isolation: isolate;
}
.hai-hero-banner .hai-hero-bg{
  position: absolute; inset: 0;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  transform: scale(1.06);
  filter: saturate(1.12) contrast(1.04);
  will-change: transform;
}
.hai-hero-banner .hai-hero-overlay{
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 60% at 50% 28%, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0) 70%),
    linear-gradient(to bottom, rgba(12,27,51,0.08), rgba(12,27,51,0.38) 80%, rgba(12,27,51,0.52));
  mix-blend-mode: multiply;
  pointer-events: none;
}
.hai-hero-banner .hai-hero-inner{
  position: relative; z-index: 2;
  height: 100%;
  display: grid; place-items: end center;
  padding: 20px 20px 24px;       /* fusion du padding + padding-bottom */
}
.hai-hero-banner .hai-hero-chip{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px; border-radius: 9999px;
  background: rgba(255,255,255,0.38);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  font-weight: 700; letter-spacing: .2px;
  box-shadow: 0 4px 16px rgba(12,27,51,0.12);
  color: #0a1f3d;
  border:1px solid rgba(255,255,255,.55);
}
.hai-hero-banner .hai-hero-chip .chip-dot{
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--hai-gold);
  box-shadow: 0 0 0 2px rgba(200,166,106,.25);
}
@media (min-width: 992px){
  .hai-hero-banner:hover .hai-hero-bg{
    transform: scale(1.08) translateY(-2px);
    transition: transform .6s ease;
  }
}
@media (prefers-reduced-motion: reduce){
  .hai-hero-banner .hai-hero-bg{ transform: none; }
}

/* === Overlap (Variante B : margin-top sur le header) === */
.hai-hero-banner + .hai-hero-header{ 
  margin-top: -72px;
}

/* On NE fait PAS de translateY sur .hai-agent-identity ; juste un z-index + ombre */
.hai-hero-banner + .hai-hero-header .hai-agent-identity{
  position: relative;
  z-index: 5;
  box-shadow: var(--hai-shadow);
}

@media (max-width:768px){
  .hai-hero-banner + .hai-hero-header{ 
  margin-top: -110px; 
  }
}



/* -------------------- Header (sous la bannière) -------------------- */
.hai-hero-header{
  position: relative;
  padding: 40px 0 10px;
  background: linear-gradient(180deg, rgba(12,27,51,.02), transparent 60%);
}
.hai-hero-inner{
  max-width: 1200px;
  margin: 0 auto;
}

/* ---------------- Bloc identité (avatar + titres) ---------------- */
.hai-agent-identity{
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 28px;
  align-items: center;
  background: #fff;
  border-radius: var(--hai-radius-lg);
  padding: 24px;
  box-shadow: var(--hai-shadow-soft);
  border: 1px solid rgba(12,27,51,.06);
}

/* --------------------------- Avatar --------------------------- */
.hai-agent-avatar,
.hai-avatar-placeholder{
  width: 120px; height: 120px; border-radius: 50%;
  object-fit: cover; display: block; background: #e9e5dc;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.75), 0 10px 30px rgba(12,27,51,.15);
}


/* ----------------------- Titres & statuts ---------------------- */
.hai-agent-titles{ min-width: 0; }

.hai-email-agent-name{
  display:flex; 
  align-items:center; 
  gap:10px;
  font-size: clamp(24px, 2.6vw, 34px) !important;
  font-family: "Playfair Display", Georgia, serif;
  margin: 0 0 6px; 
  color: var(--hai-ink) !important;
}

.hai-agent-name-text {
    letter-spacing: .2px;
    font-size: 22px;
}

.hai-email-agent-study-text{
  color: var(--hai-accent);
  font-size: 18px; font-weight: 600; margin-bottom: 10px;
}

.hai-email-agent-specialties{
  display:flex; 
  flex-wrap:wrap; 
  gap:8px; 
  padding:0; 
  margin:26px 0 26px; 
  list-style:none;
  color: inherit;
  font-size: 15px;
}

.hai-chip{
  padding:6px 10px; border-radius: 999px;
  background: linear-gradient(180deg, rgba(108,74,182,.10), rgba(108,74,182,.06));
  border: 1px solid rgba(108,74,182,.18);
  color: var(--hai-ink);
}

.hai-email-agent-status{
  display:inline-flex; 
  align-items:center; 
  gap:8px;
  margin-left: 4px; 
  font-size: 14px; 
  font-weight: 600;
  padding:2px 10px; 
  border-radius:999px; 
  background: rgba(12,27,51,.05);
}
.hai-status-dot{
  width:10px; height:10px; border-radius:50%; display:inline-block;
  box-shadow: 0 0 0 3px rgba(12,27,51,.04) inset;
}
.hai-email-agent-status.available{ color:#1f7a4d; background: rgba(31,122,77,.10); }
.hai-email-agent-status.available .hai-status-dot{ background:#1f7a4d; }
.hai-email-agent-status.unavailable{ color:#b23b3b; background: rgba(178,59,59,.10); }
.hai-email-agent-status.unavailable .hai-status-dot{ background:#b23b3b; }

/* ----------------------------- CTA ----------------------------- */
.hai-cta-row{ display:flex; gap:12px; margin-top: 10px; flex-wrap: wrap; }
.hai-btn{
  --_padY: 10px; --_padX: 16px;
  display:inline-flex; align-items:center; justify-content:center;
  padding: var(--_padY) var(--_padX);
  border-radius: 999px; font-weight: 700; letter-spacing:.2px;
  text-decoration:none; transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
  box-shadow: var(--hai-shadow-soft);
  border: 1px solid transparent;
}
.hai-btn:hover{ transform: translateY(-1px); box-shadow: var(--hai-shadow); }
.hai-btn:active{ transform: translateY(0); }

.hai-btn-primary {
    background: linear-gradient(135deg, #8b56ff57, #b5995a);
    color: #fff !important;
    border-color: rgba(108, 74, 182, .25);
}

.hai-btn-primary:hover{ background: linear-gradient(135deg, #5a39b8, var(--hai-accent)); }

.hai-btn-ghost {
    background: rgba(12, 27, 51, .04);
    color: #323132 !important;
    border-color: rgba(12, 27, 51, .1);
}

.hai-btn-ghost:hover{ background: rgba(12,27,51,.07); }

/* --------------------------- Statistiques --------------------------- */
.hai-email-agent-stats{
  margin-top: 18px; color: var(--hai-ink); font-size: 16px;
}

.hai-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    padding: 8px 0;
    margin: 0;
    list-style: none;
}

.hai-stat{
  background: var(--hai-surface); backdrop-filter: blur(var(--hai-blur));
  border-radius: var(--hai-radius); padding: 16px;
  box-shadow: var(--hai-shadow-soft); border: 1px solid rgba(12,27,51,.06);
}

.hai-stat-label {
    display: block;
    font-size: 13px;
    color: #2a2c30;
    text-transform: uppercase;
    letter-spacing: .14em;
    margin-bottom: 6px;
}

.hai-stat-value {
    font-size: 16px;
    font-weight: 800;
    font-family: times;
    letter-spacing: .2px;
}

.hai-email-agent-average {
    color: #0c1b33;
}

/* ----------------------------- Prix ----------------------------- */
@keyframes hai-glow{
  0%,100%{ box-shadow: 0 0 0 rgba(200,166,106,0); }
  50%{ box-shadow: 0 0 24px rgba(200,166,106,.35); }
}
.hai-price-tag{
  background: linear-gradient(180deg, #fff, #fff7eb);
  border: 1px solid rgba(200,166,106,.45);
  color: #5b4630; display:inline-flex; align-items:center; gap:8px;
  padding: 10px 18px; font-weight: 800; font-size: 18px; border-radius: 999px;
  margin: 14px 0 6px; position: relative; animation: hai-glow 3.2s ease-in-out infinite;
}
.hai-price-tag::before{ content:"✨"; font-size: 18px; }

/* ----------------------------- Contenu ----------------------------- */
.hai-agent-content{
  display:grid; grid-template-columns: 2fr 1fr; gap: 40px;
  max-width: 1200px; margin: 24px auto 80px; padding: 0 12px;
}
.hai-agent-main .entry-content > *{ max-width: 68ch; }
.hai-agent-main .entry-content p{ line-height: 1.7; color: #1b2740; }

.hai-agent-aside{
  position: sticky; top: 90px; height: fit-content;
}
.hai-perks{
  background: var(--hai-surface);
  border: 1px solid rgba(12,27,51,.08);
  border-radius: var(--hai-radius);
  padding: 18px; box-shadow: var(--hai-shadow-soft);
}
.hai-perks h3{
  margin: 0 0 10px; font-family: "Playfair Display", Georgia, serif; font-size: 20px;
}
.hai-perks-list{ list-style: none; padding:0; margin:0; }
.hai-perks-list li{ padding:8px 0; border-bottom: 1px dashed rgba(12,27,51,.08); }
.hai-perks-list li:last-child{ border-bottom: 0; }

/* ------------------------- Formulaire contact ------------------------ */
.hai-email-agent-form{
  position: relative; padding: 22px; border-radius: var(--hai-radius);
  background: var(--hai-surface); backdrop-filter: blur(var(--hai-blur));
  box-shadow: var(--hai-shadow-soft); border: 1px solid rgba(12,27,51,.08);
  max-width: 720px; width: 100%; margin: 26px 0 56px;
}

#dynamic-hai-agent-form{ padding: 4px; position: relative; z-index:1; }
#dynamic-hai-agent-form p{ margin-bottom: 16px; }
#dynamic-hai-agent-form label{
  display:block; font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-size: 14px; font-weight: 700; letter-spacing:.02em; margin-bottom: 6px; color: var(--hai-muted);
}
#dynamic-hai-agent-form input,
#dynamic-hai-agent-form textarea,
#dynamic-hai-agent-form select{
  width:100%; padding: 12px 14px; border-radius: 12px;
  background:#fff; border:1px solid rgba(12,27,51,.12);
  color: var(--hai-ink); font-size: 15px; transition: box-shadow .2s ease,border-color .2s ease, transform .02s ease;
}
#dynamic-hai-agent-form input:focus,
#dynamic-hai-agent-form textarea:focus,
#dynamic-hai-agent-form select:focus{
  outline: none; border-color: rgba(108,74,182,.35); box-shadow: var(--hai-ring);
}
textarea, textarea.wp-editor-area{ min-height: 130px !important; resize: vertical; }
#dynamic-hai-agent-form input::placeholder,
#dynamic-hai-agent-form textarea::placeholder{ color: #9ca3af; }

#dynamic-hai-agent-form .form-navigation{
  display:flex; justify-content: flex-end; gap: 12px; margin-top: 18px;
}
#dynamic-hai-agent-form .form-navigation button{
  padding: 10px 16px; border-radius: 12px; cursor: pointer; border: 1px solid rgba(108,74,182,.28);
  background: linear-gradient(135deg, var(--hai-accent), #8a6ae0); color:#fff; font-weight: 700; font-size: 15px;
  box-shadow: var(--hai-shadow-soft); transition: transform .15s ease, box-shadow .15s ease;
}
#dynamic-hai-agent-form .form-navigation button:hover{ transform: translateY(-1px); box-shadow: var(--hai-shadow); }
#dynamic-hai-agent-form .form-navigation button[disabled]{ opacity:.55; cursor: not-allowed; }

.hai-agent-form-note-agent {
    margin-top: 18px;
    font-size: 18px;
    color: #000000;
    font-style: italic;
    text-align: center;
}

.dynamic-agent-form-wrapper {
    position: relative;
    overflow: hidden;
    background: #7c5bd67d;
    border: 1px solid #e6ebf0;
    border-radius: 14px;
    padding: 16px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .06);
}

/* étoile décorative optionnelle */
#hai-starfield-dynamic{
  position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.25;
}

/* ------------------------------ Avis ------------------------------ */
.hai-reviews-grid-container{ margin: 56px auto; max-width: 1200px; padding: 0 12px; }
.hai-review-filter-bar-agent{ display:flex; justify-content:center; margin: 20px 0; }
.hai-review-filter-form{
  display:flex; align-items:center; gap:10px; background:#fff; padding: 8px 12px;
  border-radius: 12px; border:1px solid rgba(12,27,51,.1); font-size:14px; color: var(--hai-ink);
}
.hai-review-filter-form label{ font-weight:700; font-size: 13px; color: var(--hai-muted); margin:0; }
.hai-review-filter-form select{ border:none; background:transparent; font-size:14px; color: var(--hai-ink); padding: 4px 6px; }

.hai-reviews-grid{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px;
}
.hai-review-agent-card {
    background: rgba(255, 255, 255, .75);
    backdrop-filter: blur(var(--hai-blur));
    border: 1px dashed rgb(127 94 208);
    border-radius: var(--hai-radius);
    padding: 18px;
    box-shadow: var(--hai-shadow-soft);
    position: relative;
    transition: transform .2s ease, box-shadow .2s ease;
}
.hai-review-agent-card:hover{ transform: translateY(-4px); box-shadow: var(--hai-shadow); }
.hai-review-agent-card::before{ content:"📧"; position:absolute; top:-12px; left:-12px; font-size: 20px; }

.hai-review-header{
  display:flex; justify-content:space-between; align-items:center;
  font-size: 13px; font-weight: 700; color: var(--hai-muted); margin-bottom: 10px;
}
.hai-review-stars{ color: #f59e0b; letter-spacing: 1px; }

.hai-review-pseudo-agent { 
color: var(--hai-accent); 
font-weight: 700; 
margin-bottom: 6px; 
}

.hai-review-text{ font-size: 15px; line-height: 1.6; color: var(--hai-ink); }

.hai-review-pagination .page-numbers{
  display:inline-block; padding: 8px 12px; margin: 2px; background: #fff;
  border-radius: 10px; color: #000000; text-decoration:none; font-weight: 700;
  border:1px solid rgba(12,27,51,.1);
}

.hai-review-pagination .page-numbers.current {
    background: #ffffff !important;
    color: #000000;
    border-color: transparent;
}

.hai-review-pagination .page-numbers:hover{ background: rgba(108,74,182,.12); }

.hai-review-empty{ text-align:center; color: var(--hai-muted); }

/* --------------------------- Badges --------------------------- */
.email-agent-ribbon-container {
    display: flex;
    justify-content: center;
    margin: 14px 0 26px;
}

.email-agent-badge-ribbon {
    position: relative;
    background: linear-gradient(135deg, #4da07a, #6abf94);
    color: #fff;
    font-family: "Cinzel", serif;
    padding: 7px 16px;
    font-size: 19px;
    line-height: 1;
    border-radius: 10px;
    box-shadow: var(--hai-shadow-soft);
}

.email-agent-badge-ribbon::before,
.email-agent-badge-ribbon::after{
  content:""; position:absolute; bottom:-8px; border-left:8px solid transparent; border-right:8px solid transparent; border-top:8px solid;
}
.email-agent-badge-ribbon::before{ left:8px; border-top-color:#4da07a; }
.email-agent-badge-ribbon::after{ right:8px; border-top-color:#6abf94; }
.email-agent-badge-ribbon:hover{ transform: translateY(-1px); transition: transform .15s ease; }



.hai-response-icon{ font-size:14px; line-height:1; transform: translateY(1px); }

.hai-response-text {
    font-size: 16px !important;
    color: #6c4ab6;
}

@media (min-width:768px){ .hai-response-text{ font-size:15px; } }

/* --------------------------- Headers H5 hérités --------------------------- */
h5{
  font-family: "Playfair Display", Georgia, serif;
  font-size: 20px !important; font-weight: 700; line-height:1.2;
  margin-top: 6px !important; margin-bottom: .8em; color: var(--hai-ink) !important;
}

/* ----------------------------- Grids responsive ----------------------------- */
@media (max-width: 1024px){
  .hai-agent-content{ grid-template-columns: 1fr; }
  .hai-stats-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .hai-agent-aside{ position: static; }
}
@media (max-width: 768px){
  .hai-agent-identity{ grid-template-columns: 96px 1fr; padding: 18px; }
  .hai-agent-avatar,.hai-avatar-placeholder{ width:96px; height:96px; }
  .hai-cta-row{ gap:10px; }
  .hai-stats-grid{ grid-template-columns: 1fr 1fr; gap: 12px; }
}

/* ------------------------------ Accessibilité ------------------------------ */
.screen-reader-text{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ===== Ajuste l'overlap de la carte identité sous la bannière ===== */
.hai-hero-banner{ 
  margin: 0 auto 0; /* on retire la marge basse pour rapprocher */
}

.hai-hero-banner + .hai-hero-header{ 
  margin-top: -72px; /* chevauchement propre de tout le header */
}

/* Optionnel : si tu préfères ne cibler QUE la carte */
.hai-hero-banner + .hai-hero-header .hai-agent-identity{
  position: relative;
  z-index: 5;
  box-shadow: var(--hai-shadow); /* un peu plus de relief quand ça chevauche */
}


/* Container générique (si pas déjà défini) */
.hai-email-agent-container{
  max-width: 1200px; margin: 0 auto; padding: 0 12px;
}


/* ------------------------------ bandeau confiance ------------------------------ */
.hai-form-topbar-agent {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    margin: 0 0 14px;
    background: linear-gradient(90deg, #7c5bd3, #b5995a);
    border: 1px solid #faf5eb;
    border-radius: 10px;
    font-size: 19px;
    color: #ffffff;
    box-shadow: 0 6px 22px rgba(0, 0, 0, .06);
}


.hai-form-panel-agent { 
margin:18px auto 28px; 
max-width:1440px; 

}

/* ------------------------------ chip étude réalisé ------------------------------ */

.hai-email-agent-study-chip {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(12, 27, 51, .05);
    border: 1px solid rgba(12, 27, 51, .08);
    color: #0c1b33;
    margin: 6px 0 2px;
    font-family: Times new romans;
}
.hai-email-agent-study-chip .chip-dot{
  width:8px; height:8px; border-radius:50%;
  background: var(--hai-accent);
  box-shadow: 0 0 0 2px rgba(108,74,182,.25);
}


/* === Chips de filtre “notes” =================================== */
.hai-rating-chips{
  display:flex; align-items:center; gap:10px; flex-wrap: wrap;
  background:#fff; padding:8px 12px;
  border-radius: 12px; border:1px solid rgba(12,27,51,.10);
  box-shadow: var(--hai-shadow-soft);
}

/* cacher les radios, mais accessibles clavier/lecteur d'écran */
.hai-rating-chips input[type="radio"]{
  position:absolute; width:1px; height:1px; margin:-1px; padding:0; border:0;
  clip:rect(0 0 0 0); overflow:hidden; white-space:nowrap;
}

.hai-rating-chips .chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:999px;
  background: rgba(12,27,51,.04);
  border:1px solid rgba(12,27,51,.10);
  font-weight:700; font-size:14px; cursor:pointer; user-select:none;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease, color .2s ease;
}
.hai-rating-chips .chip:hover{ transform: translateY(-1px); box-shadow: var(--hai-shadow-soft); }
.hai-rating-chips .chip .stars{ letter-spacing: 1px; }

/* état sélectionné (radio:checked + label) */
.hai-rating-chips input[type="radio"]:checked + .chip{
  background: linear-gradient(135deg, var(--hai-accent), #8a6ae0);
  color:#fff; border-color: transparent; box-shadow: var(--hai-shadow);
}

/* bouton reset */
.hai-rating-chips .chip-reset{
  background: transparent;
  border-style: dashed;
  opacity:.85;
}
.hai-rating-chips .chip-reset:hover{ opacity:1; }

/* responsive */
@media (max-width:480px){
  .hai-rating-chips{ gap:8px; }
  .hai-rating-chips .chip{ padding:7px 10px; font-size:13px; }
}

/* --- Patch anti-conflit pour le filtre d'avis --- */
.hai-rating-chips{ position:relative; }

/* on cache proprement les radios */
.hai-rating-chips input[type="radio"]{
  position:absolute; width:1px; height:1px; margin:-1px; padding:0; border:0;
  clip:rect(0 0 0 0); overflow:hidden; white-space:nowrap;
}

/* reset agressif du label qui suit un radio (le thème stylait ceci) */
.hai-rating-chips input[type="radio"] + label.chip{
  all: unset;                                /* remet le label à zéro */
  display:inline-flex; 
  align-items:center; 
  gap:8px;
  padding:8px 12px; 
  border-radius:999px;
  background: rgba(12,27,51,.04);
  border:1px solid rgba(12,27,51,.10);
  font: inherit; 
  font-weight:700; 
  font-size:14px;
  color: #b5995a;
  cursor:pointer; 
  user-select:none;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease, color .2s ease;
}

/* supprime les puces rondes ajoutées par le thème */
.hai-rating-chips input[type="radio"] + label.chip::before,
.hai-rating-chips input[type="radio"] + label.chip::after{
  content:none !important;
}

/* hover + sélection */
.hai-rating-chips input[type="radio"] + label.chip:hover{
  transform: translateY(-1px); box-shadow: var(--hai-shadow-soft);
}
.hai-rating-chips input[type="radio"]:checked + label.chip{
  background: linear-gradient(135deg, var(--hai-accent), #8a6ae0);
  color:#fff; border-color: transparent; box-shadow: var(--hai-shadow);
}

/* étoiles lisibles */
.hai-rating-chips .stars{ letter-spacing:1px; line-height:1; }


/* --- Lire plus / Lire moins pour les avis --- */
.hai-review-agent-card { position: relative; }

.hai-review-text{
  --lines: 5;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: var(--lines);
  overflow: hidden;
  position: relative;
  /* un peu d'air pour la fade */
  padding-bottom: 0.2em;
}

/* joli fondu sur le bas quand c'est tronqué */
.hai-review-agent-card:not(.is-expanded) .hai-review-text::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height: 2.2em;
  /* adapter au fond de la carte : blanc translucide */
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgb(255 255 255 / 24%));
  pointer-events:none;
}

/* quand on déplie, on retire le clamp et la fade */
.hai-review-agent-card.is-expanded .hai-review-text{
  -webkit-line-clamp: unset;
  overflow: visible;
}
.hai-review-agent-card.is-expanded .hai-review-text::after{ display:none; }

/* bouton lire plus */
.hai-review-agent-card .hai-readmore{
  display:inline-flex; align-items:center; gap:6px;
  margin-top:10px; padding:6px 10px;
  border-radius: 999px; border:1px solid rgba(12,27,51,.12);
  background: rgba(12,27,51,.04);
  color: var(--hai-accent); font-weight:700; font-size: 14px;
  cursor:pointer; user-select:none;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.hai-review-agent-card .hai-readmore:hover{
  transform: translateY(-1px); box-shadow: var(--hai-shadow-soft);
}
.hai-review-agent-card .hai-readmore[hidden]{ display:none; }

/* tu peux ajuster le nombre de lignes par breakpoint */
@media (max-width: 640px){
  .hai-review-agent-card .hai-review-text{ --lines: 6; }
}


/* ===== Mobile ≤640px : layout nettoyé + bon ordre ===== */
@media (max-width:640px){

  /* Le conteneur sous la bannière organise ses enfants en colonne :
     [carte identité] puis [CTA] */
  .hai-hero-header .hai-hero-inner{
    display: flex !important;
    flex-direction: column !important;
    gap: 12px;
    align-items: stretch;
  }

  .hai-hero-header .hai-btn{ width: 100%; }

  /* La carte identité en colonne */
  .hai-agent-identity{
    display: flex !important;
    flex-direction: column !important;
    align-items: center;
    gap: 14px;
    padding: 16px;
    text-align: center;
  }
  .hai-agent-avatar, .hai-avatar-placeholder{
    order: 1; width: 110px; height: 110px; margin: 0 auto;
  }
  .hai-agent-titles{
    order: 2; display: flex !important; flex-direction: column !important;
    align-items: center !important; gap: 6px; min-width: 0;
  }

  /* À l’intérieur des titres : Nom → Statut → Études → Spécialités */
  .hai-email-agent-name{
    order: 1; margin: 0 0 2px; justify-content: center;
    font-size: clamp(22px, 6vw, 28px) !important;
  }
  .hai-email-agent-status{
    order: 2; margin: 4px 0 6px; font-size: 13px; padding: 4px 10px;
  }
  .hai-email-agent-study-chip{
    order: 3; margin: 6px 0 4px; justify-content: center; font-size: 14px;
  }
  .hai-email-agent-specialties{
    order: 4; margin: 8px 0 12px; justify-content: center; gap: 6px;
  }
  .hai-chip{ padding: 5px 9px; font-size: 14px; }

  /* Stats en colonne + divers */
  .hai-stats-grid{ grid-template-columns: 1fr !important; gap: 12px; }
  .hai-price-tag{ margin-left: auto; margin-right: auto; }
  .hai-agent-content{ grid-template-columns: 1fr !important; gap: 20px; }
  .hai-agent-aside{ position: static; }
  .hai-form-topbar-agent{ flex-direction: column; text-align: center; }
}

/* --- Fix ordre interne des titres en mobile --- */
@media (max-width:640px){
  /* Tous les enfants des titres ont un ordre par défaut élevé,
     puis on réimpose l’ordre voulu */
  .hai-agent-titles{ 
    display:flex !important; 
    flex-direction:column !important; 
    align-items:center !important; 
    gap:6px;
  }
  /* On force les boutons à apparaître APRES les spécialités */
  .hai-agent-titles > *{ order:10; } /* par défaut tout à la fin */
  .hai-email-agent-name{ order:1; }
  .hai-email-agent-status{ order:2; }
  .hai-email-agent-study-chip{ order:3; }
  .hai-email-agent-study-text{ order:4; }
  .hai-email-agent-specialties{ order:5; }
  .hai-email-agent-study-mode{ order:6; }
  .hai-cta-row{ order:7; }

  /* Boutons : largeur max mais pas "bord à bord" */
  .hai-cta-row{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:10px;
    margin-top:8px;
  }
  .hai-cta-row .hai-btn{
    width:90%;             /* au lieu de 100% pour éviter de déborder */
    max-width:320px;       /* borne pour un rendu harmonieux */
  }
}


/* --- Correctifs finaux mobile --- */
@media (max-width:640px){

  /* Ordonner les blocs de .hai-hero-inner : Carte (1) -> CTA éventuelles (2) -> Stats (3) */
  .hai-hero-header .hai-hero-inner{ display:flex !important; flex-direction:column !important; }
  .hai-hero-header .hai-agent-identity{ order:1; }
  .hai-hero-header .hai-email-agent-stats{ order:3; }    /* évite que les stats passent avant */

  /* Nom au-dessus du statut (dans le H1) */
  .hai-email-agent-name{
    display:flex; 
    flex-direction:column;      /* <- empile le statut sous le nom */
    align-items:center;
    gap:4px;
  }
  .hai-email-agent-status{
    margin-left:0;              /* on retire le décalage à gauche */
  }
}


/* Aligner visuellement la bannière avec la carte en mobile */
@media (max-width:640px){
  /* on “dé-borde” la bannière des 12px de padding du container */
  .hai-hero-banner{
    margin-left: -12px;
    margin-right: -12px;
    border-radius: 0 0 16px 16px; /* option: arrondis plus doux en mobile */
  }

  /* Et on garde la carte centrée dans ses gouttières */
  .hai-hero-header .hai-hero-inner{
    padding-left: 12px;
    padding-right: 12px;
  }
}
