/**
 * AccesID — Couche de design unifiée (Design System)
 * Charge APRÈS les autres feuilles : ré-aligne les systèmes hérités sur la
 * palette de marque .acx (Atkinson Hyperlegible + Fraunces, vert/encre/or/bleu)
 * sans toucher au markup existant. Plus les composants du « passeport ».
 *
 * @package AccesID
 * @since   1.13.0
 */

/* ============================================================
   1. TOKENS CANONIQUES (source unique, exposés à :root)
   ============================================================ */
:root {
	--acx-paper:#F7F4EE; --acx-card:#FFFFFF; --acx-ink:#16130F; --acx-muted:#6B655B;
	--acx-line:#E7E1D6; --acx-green:#0E7C66; --acx-green-d:#0A5F4E; --acx-gold:#C9A227;
	--acx-blue:#1F6FEB; --acx-red:#C0392B;
	--acx-green-soft:#F1F8F5; --acx-gold-soft:#FBF5E3; --acx-blue-soft:#EEF4FE;
	--acx-display:"Fraunces",Georgia,serif;
	--acx-body:"Atkinson Hyperlegible",system-ui,-apple-system,sans-serif;
	--acx-r-sm:10px; --acx-r-md:16px; --acx-r-lg:22px; --acx-r-full:999px;
	--acx-sh-sm:0 1px 3px rgba(22,19,15,.08); --acx-sh-md:0 6px 20px rgba(22,19,15,.10);
	--acx-sh-lg:0 18px 50px rgba(14,124,102,.16);
	--acx-focus:3px solid var(--acx-blue);
}

/* ============================================================
   2. PONT — ré-aligne les tokens hérités (wow.css) sur la marque.
   Tout composant .accesid-* qui consomme --acc-* adopte la marque.
   ============================================================ */
:root {
	--acc-primary:var(--acx-green); --acc-primary-dark:var(--acx-green-d);
	--acc-secondary:var(--acx-green); --acc-secondary-dark:var(--acx-green-d);
	--acc-purple-grad:linear-gradient(135deg,#0E7C66 0%,#0A5F4E 100%);
	--acc-green-grad:linear-gradient(135deg,#0E7C66 0%,#0A5F4E 100%);
	--acc-orange-grad:linear-gradient(135deg,#C9A227 0%,#A8841C 100%);
	--acc-slate-50:#FAF8F3; --acc-slate-100:#F3EFE7; --acc-slate-200:#E7E1D6;
	--acc-slate-300:#D8D1C4; --acc-slate-500:#6B655B; --acc-slate-700:#3A352E; --acc-slate-900:#16130F;
	--acc-shadow-lg:var(--acx-sh-md); --acc-shadow-xl:var(--acx-sh-lg);
}

/* ============================================================
   3. NORMALISATIONS ciblées des composants accesid-single-*
   (les plus visibles) → cohérence typo + accents de marque.
   ============================================================ */
.accesid-single-place h1,
.accesid-single-place h2,
.accesid-single-place h3,
.accesid-single-hero-content h1 { font-family:var(--acx-display); letter-spacing:-.01em; }
.accesid-single-place { font-family:var(--acx-body); }

.accesid-single-action-primary,
.accesid-single-action.accesid-single-action-primary { background:var(--acx-green) !important; }
.accesid-single-action.accesid-single-action-primary:hover { background:var(--acx-green-d) !important; }

.accesid-btn-primary,
.accesid-single-place .accesid-btn-primary { background:var(--acx-green); border-color:var(--acx-green); color:#fff; }
.accesid-btn-primary:hover { background:var(--acx-green-d); border-color:var(--acx-green-d); }
.accesid-btn-outline { border-color:var(--acx-line); color:var(--acx-ink); }
.accesid-btn-outline:hover { border-color:var(--acx-ink); }

.accesid-single-verified-tag { background:rgba(14,124,102,.18); color:#EAFBF4; border-radius:var(--acx-r-full); padding:2px 9px; font-weight:700; }
.accesid-single-back:focus-visible,
.accesid-single-action:focus-visible,
.accesid-btn:focus-visible { outline:var(--acx-focus); outline-offset:3px; }

/* Étoiles d'avis → or de marque */
.accesid-star.is-filled { color:var(--acx-gold); }

/* ============================================================
   4. INTRO PASSEPORT (au-dessus du verdict [accesid_fit])
   ============================================================ */
.acx-passport-intro { margin:26px 0 4px; }
.acx-passport-intro__lead { color:var(--acx-muted); font-size:16px; max-width:64ch; margin:6px 0 0; }

/* ============================================================
   5. SCORE TEASÉ / VERROUILLÉ (héro, non-membres)
   ============================================================ */
.acx-scorebadge.is-locked .accesid-single-score-text strong { filter:blur(7px); opacity:.85; }
.acx-scorebadge__lock { letter-spacing:.06em; }
.acx-scorebadge__cta {
	display:inline-block; margin-top:8px; font-weight:800; font-size:13px;
	color:#fff; background:rgba(0,0,0,.42); border:1px solid rgba(255,255,255,.45);
	padding:5px 12px; border-radius:var(--acx-r-full); text-decoration:none; backdrop-filter:blur(2px);
}
.acx-scorebadge__cta:hover { background:rgba(0,0,0,.6); color:#fff; }

/* ============================================================
   6. PASSEPORT OB3 (certification vérifiable)
   ============================================================ */
.acx-passport-section h2 { margin-bottom:14px; }
.acx-passport {
	display:grid; grid-template-columns:auto 1fr auto; gap:clamp(16px,3vw,28px); align-items:center;
	background:linear-gradient(180deg,#FFFFFF 0%,var(--acx-green-soft) 100%);
	border:1px solid var(--acx-line); border-left:6px solid var(--acx-green);
	border-radius:var(--acx-r-lg); padding:clamp(18px,3vw,28px); box-shadow:var(--acx-sh-md);
}
.acx-passport__seal {
	display:flex; flex-direction:column; align-items:center; gap:4px; text-align:center;
	min-width:120px; padding:14px 12px; background:var(--acx-ink); color:var(--acx-paper);
	border-radius:var(--acx-r-md);
}
.acx-passport__sealicon { font-size:34px; line-height:1; }
.acx-passport__sealtier { font-family:var(--acx-display); font-weight:700; font-size:17px; }
.acx-passport__verified { font-size:11px; font-weight:700; color:#9FE9D2; letter-spacing:.02em; }
.acx-passport__title { font-family:var(--acx-display); font-size:20px; margin:0 0 8px; color:var(--acx-ink); }
.acx-passport__facts { list-style:none; margin:0 0 14px; padding:0; display:flex; flex-direction:column; gap:6px; }
.acx-passport__facts li { display:flex; align-items:center; gap:8px; color:var(--acx-muted); font-size:14px; }
.acx-passport__facts code { background:var(--acx-gold-soft); color:var(--acx-ink); padding:1px 6px; border-radius:6px; font-size:12px; }
.acx-passport__qr { text-align:center; display:flex; flex-direction:column; align-items:center; gap:6px; }
.acx-passport__qr img { border:1px solid var(--acx-line); border-radius:12px; background:#fff; padding:6px; }
.acx-passport__qr span { font-size:11px; color:var(--acx-muted); max-width:120px; }
@media (max-width:720px){ .acx-passport { grid-template-columns:1fr; text-align:center; } .acx-passport__facts li { justify-content:center; } .acx-passport__seal { margin:0 auto; } }

/* ============================================================
   7. OPHQ — labels + teaser non-membre + barres de marque
   ============================================================ */
.accesid-single-ophq-label { font-weight:700; color:var(--acx-ink); }
.accesid-single-ophq-bar { background:var(--acx-line); border-radius:var(--acx-r-full); overflow:hidden; }
.accesid-single-ophq-fill { border-radius:var(--acx-r-full); transition:width .9s cubic-bezier(.22,1,.36,1); }
@media (prefers-reduced-motion: reduce){ .accesid-single-ophq-fill { transition:none; } }
.acx-ophq-teaser { position:relative; }
.acx-ophq-teaser .accesid-single-ophq-fill { filter:blur(4px); opacity:.5; }
.acx-ophq-teaser__names { display:flex; flex-wrap:wrap; gap:8px; margin:0 0 14px; }
.acx-ophq-teaser__chip { background:var(--acx-blue-soft); color:var(--acx-green-d); border:1px solid var(--acx-line); border-radius:var(--acx-r-full); padding:5px 12px; font-size:13px; font-weight:700; }
.accesid-single-gate { background:var(--acx-paper); border:1px dashed var(--acx-line); border-radius:var(--acx-r-md); padding:20px; text-align:center; }

/* ============================================================
   8. .acx boutons (au cas où utilisés hors perso)
   ============================================================ */
.acx-btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--acx-body); font-weight:800; font-size:15px; padding:11px 18px; border-radius:var(--acx-r-full); border:2px solid transparent; cursor:pointer; text-decoration:none; line-height:1; }
.acx-btn--primary { background:var(--acx-green); color:#fff; }
.acx-btn--primary:hover { background:var(--acx-green-d); color:#fff; transform:translateY(-1px); }
.acx-btn:focus-visible { outline:var(--acx-focus); outline-offset:3px; }
@media (prefers-reduced-motion: reduce){ .acx-btn--primary:hover { transform:none; } }

/* Utilitaire lecteur d'écran (si le thème ne le fournit pas) */
.acx .screen-reader-text, .accesid-single-place .screen-reader-text { position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ============================================================
   9. OB3 (markup existant accesid-single-badge-*) → credential de marque
   ============================================================ */
.accesid-single-badge-section h2 { font-family:var(--acx-display); }
.accesid-single-badge-card {
	display:flex; align-items:center; gap:clamp(16px,3vw,28px); flex-wrap:wrap;
	background:linear-gradient(180deg,#FFFFFF 0%,var(--acx-green-soft) 100%);
	border:1px solid var(--acx-line); border-left:6px solid var(--acx-green);
	border-radius:var(--acx-r-lg); padding:clamp(18px,3vw,26px); box-shadow:var(--acx-sh-md);
}
.accesid-single-badge-qr { width:120px; height:120px; border:1px solid var(--acx-line); border-radius:12px; background:#fff; padding:6px; flex-shrink:0; }
.accesid-single-badge-meta p { margin:0 0 8px; color:var(--acx-muted); }
.accesid-single-badge-meta strong { color:var(--acx-ink); }
.accesid-single-badge-meta code { background:var(--acx-gold-soft); color:var(--acx-ink); padding:1px 6px; border-radius:6px; font-size:12px; }

/* Catégorie (héro) + adresse : garder lisible sur la photo */
.accesid-single-cat { border-radius:var(--acx-r-full); font-weight:700; }
.accesid-single-hero-content h1 { text-shadow:0 2px 16px rgba(0,0,0,.45); }

/* ============================================================
   10. Chips génériques (.acx-chip)
   ============================================================ */
.acx-chip { display:inline-flex; align-items:center; gap:5px; background:var(--acx-paper); border:1px solid var(--acx-line); border-radius:var(--acx-r-full); padding:4px 11px; font-size:12.5px; font-weight:700; color:var(--acx-muted); }
.acx-chip--pts { background:var(--acx-green-soft); color:var(--acx-green-d); border-color:rgba(14,124,102,.25); }

/* ============================================================
   11. Feuille de route ([accesid_feuille_route])
   ============================================================ */
.acx-roadmap { background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-lg); padding:clamp(20px,4vw,34px); box-shadow:var(--acx-sh-sm); }
.acx-roadmap__title { font-family:var(--acx-display); font-size:clamp(22px,3vw,30px); margin:4px 0 12px; }
.acx-roadmap__statline { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.acx-roadmap__score { font-family:var(--acx-display); font-weight:900; color:var(--t,#0E7C66); }
.acx-roadmap__score strong { font-size:34px; } .acx-roadmap__score small { color:var(--acx-muted); font-weight:700; }
.acx-roadmap__tier { color:#fff; font-weight:800; font-size:13px; padding:4px 12px; border-radius:var(--acx-r-full); }
.acx-roadmap__gap { color:var(--acx-muted); font-weight:700; font-size:14px; }
.acx-roadmap__summary { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:20px 0; }
.acx-roadmap__sumcard { background:var(--acx-paper); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:16px; text-align:center; }
.acx-roadmap__sumnum { display:block; font-family:var(--acx-display); font-weight:900; font-size:22px; color:var(--acx-green-d); }
.acx-roadmap__sumlbl { display:block; font-size:12.5px; color:var(--acx-muted); margin-top:4px; }
.acx-roadmap__list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.acx-roadmap__item { display:flex; align-items:center; gap:14px; background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:14px 16px; }
.acx-roadmap__ic { font-size:26px; flex-shrink:0; }
.acx-roadmap__body { flex:1; min-width:0; }
.acx-roadmap__itemtop { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:7px; }
.acx-roadmap__name { font-weight:800; color:var(--acx-ink); }
.acx-roadmap__quick { background:var(--acx-gold-soft); color:#8A6D12; font-weight:800; font-size:11.5px; padding:2px 9px; border-radius:var(--acx-r-full); }
.acx-roadmap__meta { display:flex; flex-wrap:wrap; gap:7px; }
.acx-roadmap__proj { font-family:var(--acx-display); font-weight:900; color:var(--acx-green-d); white-space:nowrap; }
.acx-roadmap__proj small { font-weight:400; }
.acx-roadmap__cta { margin-top:20px; padding:18px; background:var(--acx-green-soft); border-radius:var(--acx-r-md); display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.acx-roadmap__cta p { margin:0; font-weight:700; color:var(--acx-green-d); }
.acx-roadmap__done { background:var(--acx-green-soft); color:var(--acx-green-d); padding:18px; border-radius:var(--acx-r-md); font-weight:800; text-align:center; }
.acx-roadmap__disclaimer { color:var(--acx-muted); margin:14px 0 0; }
@media (max-width:640px){ .acx-roadmap__summary{grid-template-columns:1fr;} .acx-roadmap__item{flex-wrap:wrap;} .acx-roadmap__proj{width:100%;text-align:right;} }

/* ============================================================
   12. ROI ([accesid_roi])
   ============================================================ */
.acx-roi { background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-lg); padding:clamp(20px,4vw,34px); box-shadow:var(--acx-sh-sm); }
.acx-roi__title { font-family:var(--acx-display); font-size:clamp(20px,3vw,28px); margin:4px 0 2px; }
.acx-roi__sub { color:var(--acx-muted); margin:0 0 18px; font-weight:700; font-size:14px; }
.acx-roi__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.acx-roi__card { background:var(--acx-paper); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:16px; position:relative; }
.acx-roi__ic { font-size:20px; }
.acx-roi__num { display:block; font-family:var(--acx-display); font-weight:900; font-size:28px; color:var(--acx-ink); line-height:1.1; }
.acx-roi__lbl { display:block; font-size:12.5px; color:var(--acx-muted); margin-top:3px; }
.acx-roi__delta { position:absolute; top:14px; right:14px; font-size:12px; font-weight:800; }
.acx-roi__delta.is-up { color:var(--acx-green); } .acx-roi__delta.is-down { color:var(--acx-red); }
.acx-roi__spark { margin-top:18px; background:var(--acx-paper); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:16px; }
.acx-roi__sparkhead { display:flex; justify-content:space-between; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:12px; font-weight:700; font-size:13px; color:var(--acx-muted); }
.acx-roi__convo { color:var(--acx-green-d); }
.acx-roi__bars { display:flex; align-items:flex-end; gap:3px; height:80px; }
.acx-roi__bar { flex:1; background:linear-gradient(180deg,var(--acx-green) 0%,var(--acx-green-d) 100%); border-radius:3px 3px 0 0; min-height:4px; }
.acx-roi__foot { margin-top:18px; }
@media (max-width:640px){ .acx-roi__grid{grid-template-columns:repeat(2,1fr);} }

/* ============================================================
   13. Mon fil ([accesid_mon_fil])
   ============================================================ */
.acx-feed__hello { background:var(--acx-ink); color:var(--acx-paper); border-radius:var(--acx-r-lg); padding:clamp(20px,4vw,30px); margin-bottom:20px; }
.acx-feed__hello h2 { font-family:var(--acx-display); margin:0 0 6px; font-size:clamp(22px,4vw,30px); }
.acx-feed__hello p { margin:0 0 14px; color:#E7E1D6; }
.acx-feed__loading,.acx-feed__empty { color:var(--acx-muted); padding:16px 0; }
.acx-feed__sec { margin-bottom:26px; }
.acx-feed__sechead { display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin-bottom:12px; }
.acx-feed__sechead h3 { font-family:var(--acx-display); font-size:19px; margin:0; }
.acx-feed__sechead span { color:var(--acx-muted); font-size:12.5px; }
.acx-feed__cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:12px; }
.acx-feed__card { display:flex; align-items:center; gap:12px; background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:14px; text-decoration:none; color:inherit; transition:border-color .15s ease, transform .15s ease; }
.acx-feed__card:hover { border-color:var(--acx-green); transform:translateY(-1px); }
.acx-feed__score { font-family:var(--acx-display); font-weight:900; font-size:20px; color:#fff; background:var(--t,#0E7C66); width:46px; height:46px; border-radius:12px; display:grid; place-items:center; flex-shrink:0; }
.acx-feed__cardbody { min-width:0; display:flex; flex-direction:column; gap:3px; }
.acx-feed__name { font-weight:800; color:var(--acx-ink); }
.acx-feed__chk { color:var(--acx-green); }
.acx-feed__meta { font-size:12.5px; color:var(--acx-muted); }
.acx-feed__fit { align-self:flex-start; margin-top:3px; font-size:11.5px; font-weight:800; color:#fff; background:var(--f,#0E7C66); padding:2px 9px; border-radius:var(--acx-r-full); }
.acx-feed__outing { display:flex; align-items:center; gap:14px; background:var(--acx-green-soft); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:16px; text-decoration:none; color:inherit; }
.acx-feed__outing span:first-child { font-size:26px; }
.acx-feed__outing strong { display:block; color:var(--acx-ink); } .acx-feed__outing small { color:var(--acx-muted); }
.acx-feed__resume { margin-left:auto; font-weight:800; color:var(--acx-green-d); }
@media (prefers-reduced-motion: reduce){ .acx-feed__card:hover{transform:none;} }

/* Feuille de route live dans le quick scan */
.acc-eval-roadmap { margin:18px 0 6px; }
.acc-eval-roadmap[hidden] { display:none; }

/* ============================================================
   14. Bouton ghost
   ============================================================ */
.acx-btn--ghost { background:transparent; color:var(--acx-green-d); border:1px solid var(--acx-line); }
.acx-btn--ghost:hover { background:var(--acx-paper); }

/* ============================================================
   15. Contacter / Réserver ([accesid_contact_pro])
   ============================================================ */
.acx-contact { margin:14px 0; }
.acx-contact__panel { margin-top:12px; background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:16px; display:flex; flex-direction:column; gap:10px; }
.acx-contact__needs { margin:0; font-size:13px; color:var(--acx-green-d); background:var(--acx-green-soft); padding:8px 12px; border-radius:var(--acx-r-md); }
.acx-contact__row { display:flex; gap:10px; flex-wrap:wrap; }
.acx-contact__row > * { flex:1; min-width:160px; }
.acx-contact input, .acx-contact textarea { padding:10px 12px; border:1px solid var(--acx-line); border-radius:var(--acx-r-md); font:inherit; background:var(--acx-paper); color:var(--acx-ink); }
.acx-contact__feedback.is-err { color:var(--acx-red); font-weight:700; margin:0; }
.acx-contact__ok { color:var(--acx-green-d); font-weight:800; margin:0; }

/* ============================================================
   16. Console prospects ([accesid_prospects])
   ============================================================ */
.acx-prospects { margin:16px 0; }
.acx-prospects__title { font-family:var(--acx-display); font-size:clamp(20px,3vw,26px); margin:4px 0 16px; }
.acx-prospects__list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.acx-prospects__item { display:flex; gap:14px; justify-content:space-between; background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:14px 16px; flex-wrap:wrap; }
.acx-prospects__main { flex:1; min-width:240px; }
.acx-prospects__top { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:6px; }
.acx-prospects__status { color:#fff; font-size:11.5px; font-weight:800; padding:2px 9px; border-radius:var(--acx-r-full); }
.acx-prospects__top time { color:var(--acx-muted); font-size:12.5px; margin-left:auto; }
.acx-prospects__contact { display:flex; flex-wrap:wrap; gap:12px; font-size:13.5px; margin-bottom:6px; }
.acx-prospects__contact a { color:var(--acx-blue); text-decoration:none; }
.acx-prospects__place { color:var(--acx-muted); }
.acx-prospects__needs { margin:4px 0; font-size:13px; color:var(--acx-green-d); }
.acx-prospects__msg { margin:4px 0 0; color:var(--acx-ink); }
.acx-prospects__actions { display:flex; flex-direction:column; gap:8px; align-self:center; }

/* ============================================================
   17. Statut d accès temps réel — bandeau public ([accesid_statut_public])
   ============================================================ */
.acx-livestatus { display:flex; align-items:center; gap:12px; background:var(--acx-card); border:1px solid var(--acx-line); border-left:5px solid var(--sev,#C9A227); border-radius:var(--acx-r-md); padding:12px 16px; margin:0 0 16px; }
.acx-livestatus__ic { font-size:22px; }
.acx-livestatus__body { flex:1; display:flex; flex-direction:column; }
.acx-livestatus__body strong { color:var(--sev,#C9A227); }
.acx-livestatus__msg { font-size:13px; color:var(--acx-muted); }
.acx-livestatus__when { font-size:12.5px; font-weight:700; color:var(--sev,#C9A227); white-space:nowrap; }

/* ============================================================
   18. Statut — panneau commerçant ([accesid_statut_acces])
   ============================================================ */
.acx-statusadmin { margin:16px 0; background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-lg); padding:clamp(18px,3vw,28px); }
.acx-statusadmin__title { font-family:var(--acx-display); font-size:clamp(19px,3vw,24px); margin:4px 0 2px; }
.acx-statusadmin__sub { color:var(--acx-muted); margin:0 0 16px; font-size:14px; }
.acx-statusadmin__field { display:flex; flex-direction:column; gap:5px; margin-bottom:12px; }
.acx-statusadmin__field > span { font-weight:700; font-size:13px; }
.acx-statusadmin__field select, .acx-statusadmin__field input { padding:10px 12px; border:1px solid var(--acx-line); border-radius:var(--acx-r-md); font:inherit; background:var(--acx-paper); color:var(--acx-ink); }
.acx-statusadmin__actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:6px; }
.acx-statusadmin__feedback { margin:10px 0 0; font-weight:700; }
.acx-statusadmin__feedback.is-ok { color:var(--acx-green-d); } .acx-statusadmin__feedback.is-err { color:var(--acx-red); }

/* ============================================================
   19. Console avis ([accesid_console_avis]) + réponse publique
   ============================================================ */
.acx-avismod { margin:16px 0; }
.acx-avismod__title { font-family:var(--acx-display); font-size:clamp(20px,3vw,26px); margin:4px 0 16px; }
.acx-avismod__list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.acx-avismod__item { background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:14px 16px; }
.acx-avismod__top { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:6px; }
.acx-avismod__stars { color:var(--acx-gold); letter-spacing:1px; }
.acx-avismod__place { color:var(--acx-muted); font-size:13px; }
.acx-avismod__top time { color:var(--acx-muted); font-size:12.5px; margin-left:auto; }
.acx-avismod__text { margin:4px 0 10px; color:var(--acx-ink); }
.acx-avismod__reply { display:flex; gap:10px; align-items:flex-start; }
.acx-avismod__input { flex:1; padding:10px 12px; border:1px solid var(--acx-line); border-radius:var(--acx-r-md); font:inherit; background:var(--acx-paper); color:var(--acx-ink); }
.acx-avismod__saved { color:var(--acx-green); font-weight:800; align-self:center; }
.acc-review-owner-reply { margin:8px 0 0; padding:10px 14px; background:var(--acx-green-soft); border-left:3px solid var(--acx-green); border-radius:var(--acx-r-md); }
.acc-review-owner-reply__badge { font-size:12px; font-weight:800; color:var(--acx-green-d); }
.acc-review-owner-reply p { margin:4px 0 0; color:var(--acx-ink); font-size:13.5px; }

/* ============================================================
   20. Espace pro unifié ([accesid_espace_pro])
   ============================================================ */
.acx-pro { display:block; }
.acx-pro__header { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; flex-wrap:wrap; margin-bottom:18px; }
.acx-pro__hello { font-family:var(--acx-display); font-size:clamp(24px,4vw,34px); margin:4px 0 0; }
.acx-pro__kpis { display:flex; gap:10px; flex-wrap:wrap; }
.acx-pro__kpi { background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-md); padding:12px 16px; text-align:center; min-width:92px; }
.acx-pro__kpi.is-hot { border-color:var(--acx-blue); background:rgba(31,111,235,.06); }
.acx-pro__kpi.is-warn { border-color:var(--acx-gold); background:var(--acx-gold-soft); }
.acx-pro__kpi.is-live { border-color:var(--acx-green); background:var(--acx-green-soft); }
.acx-pro__kpinum { display:block; font-family:var(--acx-display); font-weight:900; font-size:24px; color:var(--acx-ink); line-height:1; }
.acx-pro__kpilbl { display:block; font-size:11.5px; color:var(--acx-muted); margin-top:4px; }
.acx-pro__tabs { display:flex; gap:6px; flex-wrap:wrap; border-bottom:2px solid var(--acx-line); margin-bottom:20px; }
.acx-pro__tab { appearance:none; background:transparent; border:0; border-bottom:3px solid transparent; margin-bottom:-2px; padding:10px 14px; font:inherit; font-weight:700; color:var(--acx-muted); cursor:pointer; display:inline-flex; align-items:center; gap:7px; border-radius:8px 8px 0 0; transition:color .15s ease, border-color .15s ease; }
.acx-pro__tab:hover { color:var(--acx-ink); }
.acx-pro__tab.is-active { color:var(--acx-green-d); border-bottom-color:var(--acx-green); }
.acx-pro__badge { background:var(--acx-red); color:#fff; font-size:11px; font-weight:800; min-width:18px; height:18px; padding:0 5px; border-radius:9px; display:inline-grid; place-items:center; }
.acx-pro__panel { animation:acxFade .2s ease; }
.acx-pro__panel[hidden] { display:none; }
@keyframes acxFade { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:none; } }
.acx-pro__rdmselect { display:flex; flex-direction:column; gap:5px; margin-bottom:16px; max-width:380px; }
.acx-pro__rdmselect > span { font-weight:700; font-size:13px; }
.acx-pro__rdmselect select { padding:10px 12px; border:1px solid var(--acx-line); border-radius:var(--acx-r-md); font:inherit; background:var(--acx-paper); color:var(--acx-ink); }
.acx-pro__rdm[hidden] { display:none; }
@media (prefers-reduced-motion: reduce){ .acx-pro__panel { animation:none; } }
@media (max-width:680px){ .acx-pro__header { flex-direction:column; } .acx-pro__kpis { width:100%; } .acx-pro__kpi { flex:1; min-width:0; } }

/* Préférence digest hebdo (dans l espace pro) */
.acx-pro__footer { margin-top:22px; padding-top:16px; border-top:1px solid var(--acx-line); }
.acx-digestpref__row { display:inline-flex; align-items:center; gap:10px; font-size:14px; color:var(--acx-ink); cursor:pointer; }
.acx-digestpref__cb { width:18px; height:18px; accent-color:var(--acx-green); }
.acx-digestpref__saved { color:var(--acx-green); font-weight:800; font-size:13px; }

/* ============================================================
   21. Infolettre usager ([accesid_infolettre])
   ============================================================ */
.acx-newsletter { background:var(--acx-card); border:1px solid var(--acx-line); border-radius:var(--acx-r-lg); padding:clamp(18px,3vw,26px); margin:16px 0; }
.acx-newsletter__head { display:flex; gap:14px; align-items:flex-start; margin-bottom:14px; }
.acx-newsletter__ic { font-size:30px; }
.acx-newsletter__title { font-family:var(--acx-display); font-size:clamp(17px,2.5vw,21px); margin:0 0 3px; }
.acx-newsletter__sub { margin:0; color:var(--acx-muted); font-size:13.5px; }
.acx-newsletter__active { color:var(--acx-green-d); }
.acx-newsletter__row { display:flex; gap:10px; flex-wrap:wrap; }
.acx-newsletter__row input[type=email], .acx-newsletter__row input[type=text]:not(.acx-newsletter__hp) { flex:1; min-width:170px; padding:11px 13px; border:1px solid var(--acx-line); border-radius:var(--acx-r-md); font:inherit; background:var(--acx-paper); color:var(--acx-ink); }
.acx-newsletter__feedback { margin:10px 0 0; font-weight:700; }
.acx-newsletter__feedback.is-ok { color:var(--acx-green-d); } .acx-newsletter__feedback.is-err { color:var(--acx-red); }
.acx-newsletter__legal { margin:10px 0 0; color:var(--acx-muted); }
