/* ============================================================
   EspaceVirtuel PRO — Homepage Refresh v300
   ------------------------------------------------------------
   Crée le : 2026-05-25
   Portée  : UNIQUEMENT la page d'accueil publique (#p-auth)
             + écrans transverses : skip-link, toasts, 404, loading.
   Stratégie : surcouche cumulative, ZÉRO retrait des règles
   précédentes (v280→v291). On scope avec :
       body:has(#p-auth.on)  → home publique
       body.ev-home-on       → fallback set en JS si :has() KO
   Sécurité : pas de !important sauf pour neutraliser inline-styles
   legacy hérités (background:#FFFFFF;color:#0F172A…).
   ============================================================ */

/* ───────────────────────────────────────────────────────────
   §1  TYPOGRAPHIE + FONT-DISPLAY SWAP
   ─────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Space+Grotesk:wght@500;600;700&display=swap');

:root{
  --evh-font-display: "Space Grotesk", "Inter", system-ui, sans-serif;
  --evh-font-body:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --evh-bg:           #0A0A12;
  --evh-surface-1:    #14141F;
  --evh-surface-2:    #1B1B2A;
  --evh-border:       rgba(255,255,255,.08);
  --evh-border-hi:    rgba(255,255,255,.16);
  --evh-text:         #F1F5F9;
  --evh-text-dim:     #CBD5E1;
  --evh-text-mute:    #94A3B8;
  --evh-cyan:         #22D3EE;
  --evh-cyan-soft:    rgba(34,211,238,.12);
  --evh-cyan-glow:    rgba(34,211,238,.40);
  --evh-violet:       #A855F7;
  --evh-violet-soft:  rgba(168,85,247,.12);
  --evh-grad:         linear-gradient(135deg,#22D3EE 0%,#A855F7 100%);
  --evh-grad-radial:  radial-gradient(ellipse 80% 60% at 20% 30%,rgba(34,211,238,.10) 0%,transparent 60%),
                      radial-gradient(ellipse 70% 50% at 90% 80%,rgba(168,85,247,.12) 0%,transparent 60%);
  --evh-radius:       14px;
  --evh-radius-lg:    20px;
}

/* ───────────────────────────────────────────────────────────
   §2  GLOBAL — SKIP-LINK + FOCUS VISIBLE + REDUCED-MOTION
   ─────────────────────────────────────────────────────────── */
.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--evh-cyan);color:#0A0A12;
  padding:10px 16px;font-weight:700;z-index:99999;border-radius:0 0 8px 0;
}
.skip-link:focus{ left:0 !important }

/* Focus cyan visible partout (override navigateur grisâtre) */
body:has(#p-auth.on) :is(a,button,input,select,textarea,[tabindex]):focus-visible{
  outline:2px solid var(--evh-cyan) !important;
  outline-offset:2px;
  border-radius:6px;
  box-shadow:0 0 0 4px rgba(34,211,238,.20);
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}

/* ───────────────────────────────────────────────────────────
   §3  HOME — FOND + LAYOUT SPLIT-SCREEN HERO (≥1024px)
   ─────────────────────────────────────────────────────────── */
body:has(#p-auth.on){
  background:var(--evh-bg) !important;
  color:var(--evh-text);
  font-family:var(--evh-font-body);
  min-height:100vh;
}
body:has(#p-auth.on)::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:var(--evh-grad-radial);
}
body:has(#p-auth.on)::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.04;
  background-image:
    linear-gradient(to right,rgba(34,211,238,.4) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(34,211,238,.4) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 0%,transparent 70%);
}

/* Header fixé en haut, footer en bas, hero centré */
#p-auth{
  position:relative;z-index:1;
  min-height:100vh;
  padding:88px 16px 64px;
  box-sizing:border-box;
}
#p-auth .aw{ max-width:1280px;margin:0 auto;width:100%; }

/* DESKTOP : split-screen */
@media (min-width:1024px){
  #p-auth .aw{
    display:grid;
    grid-template-columns:minmax(0,3fr) minmax(420px,2fr);
    gap:56px;
    align-items:start;
  }
  /* Hero marketing à gauche */
  #p-auth .ahero,
  #p-auth #ev-promo-card,
  #p-auth .ev-reassur,
  #p-auth .ev-howitworks,
  #p-auth .ev-testimonials,
  #p-auth .ev-partners{ grid-column:1; }
  /* Auth (tabs + forms + footer-link bar) à droite, sticky */
  #p-auth .atabs,
  #p-auth #form-login,
  #p-auth #form-signup,
  #p-auth > .aw > div:last-child{ grid-column:2; }
  #p-auth .atabs{ position:sticky;top:88px; }
}

/* ───────────────────────────────────────────────────────────
   §4  HERO — TITRE GRADIENT + BASELINE + FEATURES
   ─────────────────────────────────────────────────────────── */
#p-auth .ahero{
  text-align:left;margin-bottom:32px;
}
#p-auth .ahero .hi{
  display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;border-radius:16px;
  background:var(--evh-grad);font-size:34px;
  box-shadow:0 8px 32px rgba(34,211,238,.30);
  margin-bottom:20px;
}
#p-auth .ahero h1{
  font-family:var(--evh-font-display);
  font-size:clamp(36px,5.5vw,68px);
  font-weight:700;line-height:1.05;letter-spacing:-.03em;
  margin:0 0 14px;
  background:var(--evh-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
#p-auth .ahero p{
  font-size:clamp(15px,1.6vw,19px);
  color:var(--evh-text-dim);
  line-height:1.55;max-width:560px;margin:0;
}
/* 3 features clés injectées en JS */
.ev-features{
  display:grid;grid-template-columns:1fr;gap:14px;margin:28px 0 0;
}
@media (min-width:640px){ .ev-features{ grid-template-columns:repeat(3,1fr); gap:18px; } }
.ev-feature{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px;border-radius:12px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--evh-border);
  transition:transform .15s ease-out,border-color .15s ease-out,box-shadow .15s ease-out;
}
.ev-feature:hover{
  transform:translateY(-2px);
  border-color:var(--evh-cyan-glow);
  box-shadow:0 8px 24px rgba(34,211,238,.10);
}
.ev-feature__ico{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:var(--evh-cyan-soft);color:var(--evh-cyan);
}
.ev-feature__ico svg{ width:20px;height:20px; }
.ev-feature__t{ font-weight:700;font-size:14px;color:var(--evh-text);margin:0 0 3px; }
.ev-feature__d{ font-size:12px;color:var(--evh-text-mute);margin:0;line-height:1.45; }

/* ───────────────────────────────────────────────────────────
   §5  REFONTE TRIO CARDS — Fidélité / Cashback / Parrainage
   on neutralise le legacy `#ev-promo-card` (fond blanc / vert /
   lavande) et on REMPLACE par 3 vraies cards homogènes injectées
   en JS dans #ev-promo-card.
   ─────────────────────────────────────────────────────────── */
body:has(#p-auth.on) #ev-promo-card{
  background:transparent !important;
  border:0 !important;
  padding:0 !important;
  color:var(--evh-text) !important;
  margin-bottom:36px;
}
body:has(#p-auth.on) #ev-promo-card > div[style*="font-weight:800"]{
  /* Titre légacy "Programme de Fidélité EspaceVirtuel" -> on le retravaille */
  color:var(--evh-text) !important;
  font-family:var(--evh-font-display);
  font-size:22px !important;font-weight:700 !important;
  letter-spacing:-.02em;text-align:left !important;
  margin:0 0 18px !important;
}
/* Tous les blocs internes legacy sont cachés : le JS injecte un trio v300 */
body:has(#p-auth.on) #ev-promo-card > div.tw-flex,
body:has(#p-auth.on) #ev-promo-card > div.tw-flex + div,
body:has(#p-auth.on) #ev-promo-card > hr,
body:has(#p-auth.on) #ev-promo-card > #ev-parrainage-card{
  display:none !important;
}
/* Le trio v300 rendu par JS */
.ev-trio{
  display:grid;grid-template-columns:1fr;gap:16px;
}
@media (min-width:768px){ .ev-trio{ grid-template-columns:repeat(3,1fr);gap:18px; } }
.ev-card{
  position:relative;display:flex;flex-direction:column;
  background:var(--evh-surface-1);
  border:1px solid var(--evh-border);
  border-radius:var(--evh-radius);
  padding:22px 20px;
  transition:transform .18s ease-out,border-color .18s ease-out,box-shadow .18s ease-out;
}
.ev-card:hover{
  transform:translateY(-3px);
  border-color:var(--evh-cyan-glow);
  box-shadow:0 16px 48px -12px rgba(34,211,238,.18),0 4px 14px rgba(0,0,0,.30);
}
.ev-card__ico{
  display:flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:14px;margin-bottom:14px;
  background:var(--evh-cyan-soft);color:var(--evh-cyan);
}
.ev-card__ico--violet{ background:var(--evh-violet-soft);color:var(--evh-violet); }
.ev-card__ico svg{ width:24px;height:24px; }
.ev-card__t{ font-size:13px;font-weight:600;color:var(--evh-text-mute);text-transform:uppercase;letter-spacing:.06em;margin:0 0 6px; }
.ev-card__big{
  font-family:var(--evh-font-display);
  font-size:clamp(32px,4vw,44px);font-weight:800;line-height:1;letter-spacing:-.02em;
  background:var(--evh-grad);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin:0 0 10px;
}
.ev-card__d{ font-size:13px;color:var(--evh-text-dim);line-height:1.55;margin:0 0 14px; }
.ev-card__cta{
  margin-top:auto;display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;color:var(--evh-cyan);text-decoration:none;
}
.ev-card__cta:hover{ text-decoration:underline; }

/* ───────────────────────────────────────────────────────────
   §6  FORMULAIRES LOGIN / SIGNUP — refonte
   ─────────────────────────────────────────────────────────── */
/* Tabs avec underline animée */
body:has(#p-auth.on) .atabs{
  display:flex;gap:0;position:relative;
  background:var(--evh-surface-1);
  border:1px solid var(--evh-border);
  border-radius:12px;padding:4px;margin-bottom:18px;
}
body:has(#p-auth.on) .atab{
  flex:1;text-align:center;padding:11px 14px;cursor:pointer;
  font-size:14px;font-weight:600;color:var(--evh-text-mute);
  border-radius:8px;transition:color .2s ease-out;position:relative;
}
body:has(#p-auth.on) .atab.on{
  color:var(--evh-text);
  background:linear-gradient(180deg,rgba(34,211,238,.10),rgba(34,211,238,.04));
  box-shadow:inset 0 0 0 1px rgba(34,211,238,.30);
}
body:has(#p-auth.on) .atab:not(.on):hover{ color:var(--evh-text-dim); }

/* Cards de formulaire */
body:has(#p-auth.on) .acard{
  background:var(--evh-surface-1) !important;
  border:1px solid var(--evh-border) !important;
  border-radius:var(--evh-radius-lg);
  padding:24px !important;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  color:var(--evh-text) !important;
}
@media (min-width:1024px){
  body:has(#p-auth.on) .acard{
    padding:28px !important;
    box-shadow:0 24px 60px -20px rgba(0,0,0,.50);
  }
}
body:has(#p-auth.on) .fg{ margin-bottom:14px;position:relative; }
body:has(#p-auth.on) .fl{
  display:block;font-size:12px;font-weight:600;color:var(--evh-text-dim);
  margin-bottom:6px;letter-spacing:.01em;
}
body:has(#p-auth.on) .fi{
  width:100%;box-sizing:border-box;
  height:46px;
  background:var(--evh-surface-2) !important;
  border:1px solid var(--evh-border-hi) !important;
  border-radius:10px;
  color:var(--evh-text) !important;
  font-size:14px;padding:0 14px 0 40px;
  transition:border-color .15s,box-shadow .15s,background-color .15s;
}
body:has(#p-auth.on) .fi::placeholder{ color:var(--evh-text-mute);opacity:.7; }
body:has(#p-auth.on) .fi:focus{
  outline:none;
  border-color:var(--evh-cyan) !important;
  box-shadow:0 0 0 3px rgba(34,211,238,.18);
  background:rgba(34,211,238,.04) !important;
}
/* Bouton submit */
body:has(#p-auth.on) .btn.ba{
  width:100%;height:48px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-size:15px;font-weight:700;letter-spacing:.01em;
  background:var(--evh-grad) !important;
  color:#0A0A12 !important;
  border:0;border-radius:12px;cursor:pointer;
  transition:transform .15s ease-out,box-shadow .15s ease-out,filter .15s;
  box-shadow:0 8px 24px -6px rgba(34,211,238,.40);
  position:relative;
}
body:has(#p-auth.on) .btn.ba:hover{
  transform:translateY(-1px) scale(1.01);
  box-shadow:0 12px 32px -8px rgba(34,211,238,.55);
  filter:brightness(1.05);
}
body:has(#p-auth.on) .btn.ba:active{ transform:translateY(0) scale(.98); }
body:has(#p-auth.on) .btn.ba[disabled],
body:has(#p-auth.on) .btn.ba.is-loading{ opacity:.7;cursor:wait; }
body:has(#p-auth.on) .btn.ba.is-loading::after{
  content:"";display:inline-block;width:16px;height:16px;
  border:2px solid rgba(10,10,18,.30);border-top-color:#0A0A12;
  border-radius:50%;animation:evhSpin .7s linear infinite;
}
@keyframes evhSpin{ to{ transform:rotate(360deg); } }

/* Eye toggle */
body:has(#p-auth.on) .pw-eye{
  color:var(--evh-text-mute) !important;
  opacity:.85 !important;
  transition:color .15s,opacity .15s;
}
body:has(#p-auth.on) .pw-eye:hover{ color:var(--evh-cyan) !important;opacity:1 !important; }

/* Erreurs / OK */
body:has(#p-auth.on) .aerr{
  color:#FCA5A5;background:rgba(239,68,68,.08);
  border:1px solid rgba(239,68,68,.30);border-radius:8px;
  padding:8px 12px;font-size:12px;margin-top:10px;min-height:0;
}
body:has(#p-auth.on) .aerr:empty{ display:none; }
body:has(#p-auth.on) .aok{
  color:#86EFAC;background:rgba(34,197,94,.08);
  border:1px solid rgba(34,197,94,.30);border-radius:8px;
  padding:8px 12px;font-size:12px;margin-top:10px;
}
body:has(#p-auth.on) .aok:empty{ display:none; }

/* Inline validation */
.ev-inline-err{
  font-size:11px;color:#FCA5A5;margin-top:4px;
  display:none;
}
.ev-inline-err.on{ display:block; }

/* ───────────────────────────────────────────────────────────
   §7  HEADER fixe + burger mobile (injecté JS dans body)
   ─────────────────────────────────────────────────────────── */
.ev-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;
  background:rgba(10,10,18,.55);
  backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  border-bottom:1px solid transparent;
  transition:background-color .25s,border-color .25s;
}
.ev-header.is-scrolled{
  background:rgba(10,10,18,.85);
  border-bottom-color:var(--evh-border);
}
.ev-header__brand{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--evh-text);text-decoration:none;font-weight:700;
}
.ev-header__brand-mono{
  width:32px;height:32px;border-radius:9px;
  background:var(--evh-grad);
  display:inline-flex;align-items:center;justify-content:center;
  color:#0A0A12;font-weight:900;font-size:14px;letter-spacing:-.02em;
  box-shadow:0 4px 14px rgba(34,211,238,.30);
}
.ev-header__name{ font-family:var(--evh-font-display);font-size:16px;letter-spacing:-.01em; }
.ev-header__nav{ display:none; }
@media (min-width:900px){
  .ev-header__nav{ display:flex;gap:6px; }
  .ev-header__nav a{
    padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;
    color:var(--evh-text-dim);text-decoration:none;
    transition:color .15s,background-color .15s;
  }
  .ev-header__nav a:hover{ color:var(--evh-text);background:rgba(255,255,255,.05); }
}
.ev-header__cta{
  display:none;align-items:center;gap:6px;
  padding:8px 16px;height:36px;
  border-radius:9px;background:var(--evh-cyan-soft);
  color:var(--evh-cyan);border:1px solid var(--evh-cyan-glow);
  font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;
}
@media (min-width:900px){ .ev-header__cta{ display:inline-flex; } }
.ev-header__cta:hover{ background:rgba(34,211,238,.18); }
.ev-burger{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,.05);border:1px solid var(--evh-border);
  color:var(--evh-text);cursor:pointer;
}
@media (min-width:900px){ .ev-burger{ display:none; } }
.ev-burger svg{ width:20px;height:20px; }

/* Drawer mobile */
.ev-drawer{
  position:fixed;inset:0;z-index:1100;display:none;
  background:rgba(10,10,18,.85);backdrop-filter:blur(8px);
}
.ev-drawer.on{ display:flex;flex-direction:column; }
.ev-drawer__panel{
  margin:62px 16px 16px;background:var(--evh-surface-1);
  border:1px solid var(--evh-border);border-radius:16px;padding:12px;
  animation:evhSlideDown .25s ease-out;
}
.ev-drawer a{
  display:flex;align-items:center;gap:10px;padding:14px 12px;
  color:var(--evh-text-dim);text-decoration:none;font-size:14px;font-weight:500;
  border-radius:10px;
}
.ev-drawer a:hover{ background:rgba(255,255,255,.05);color:var(--evh-text); }
@keyframes evhSlideDown{ from{ opacity:0;transform:translateY(-8px); } to{ opacity:1;transform:none; } }

/* ───────────────────────────────────────────────────────────
   §8  FOOTER 4 colonnes
   ─────────────────────────────────────────────────────────── */
.ev-footer{
  position:relative;z-index:1;margin-top:80px;padding:48px 24px 32px;
  border-top:1px solid var(--evh-border);
  background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.30) 100%);
}
.ev-footer__inner{ max-width:1280px;margin:0 auto; }
.ev-footer__top{
  display:flex;align-items:center;gap:14px;margin-bottom:32px;
}
.ev-footer__brand{ font-family:var(--evh-font-display);font-size:18px;font-weight:700; }
.ev-footer__tagline{ color:var(--evh-text-mute);font-size:13px; }
.ev-footer__cols{
  display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:32px;
}
@media (min-width:720px){ .ev-footer__cols{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .ev-footer__cols{ grid-template-columns:repeat(4,1fr);gap:48px; } }
.ev-footer__col h5{
  font-size:11px;font-weight:700;color:var(--evh-text);
  text-transform:uppercase;letter-spacing:.10em;margin:0 0 14px;
}
.ev-footer__col ul{ list-style:none;padding:0;margin:0; }
.ev-footer__col li{ margin-bottom:10px; }
.ev-footer__col a{
  color:var(--evh-text-mute);text-decoration:none;font-size:13px;
  display:inline-flex;align-items:center;gap:8px;
  transition:color .15s;
}
.ev-footer__col a:hover{ color:var(--evh-cyan); }
.ev-footer__social{ display:flex;gap:10px; }
.ev-footer__social a{
  width:36px;height:36px;border-radius:10px;
  background:var(--evh-surface-1);border:1px solid var(--evh-border);
  display:inline-flex;align-items:center;justify-content:center;
}
.ev-footer__social a:hover{ border-color:var(--evh-cyan-glow);color:var(--evh-cyan); }
.ev-footer__copyright{
  text-align:center;padding-top:24px;border-top:1px solid var(--evh-border);
  color:var(--evh-text-mute);font-size:12px;
}

/* ───────────────────────────────────────────────────────────
   §9  RÉASSURANCE — Stats / How-it-works / Témoignages / Partners
   ─────────────────────────────────────────────────────────── */
/* Section heading */
.ev-section-h{
  font-family:var(--evh-font-display);
  font-size:clamp(22px,3vw,30px);font-weight:700;line-height:1.2;
  letter-spacing:-.02em;color:var(--evh-text);margin:48px 0 8px;
}
.ev-section-sub{
  color:var(--evh-text-mute);font-size:14px;margin:0 0 24px;line-height:1.55;
}

/* Stats bar */
.ev-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  background:var(--evh-surface-1);border:1px solid var(--evh-border);
  border-radius:var(--evh-radius-lg);padding:24px;margin:32px 0 0;
}
@media (min-width:768px){ .ev-stats{ grid-template-columns:repeat(4,1fr);padding:32px; } }
.ev-stat{ text-align:center; }
.ev-stat__n{
  font-family:var(--evh-font-display);
  font-size:clamp(28px,3.5vw,40px);font-weight:800;line-height:1;
  background:var(--evh-grad);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;
}
.ev-stat__l{ font-size:12px;color:var(--evh-text-mute);margin-top:6px;line-height:1.4; }
.ev-stat__ph{ color:#FCD34D;font-size:10px;display:block;margin-top:4px;font-weight:600; }

/* How it works */
.ev-howitworks{ display:grid;grid-template-columns:1fr;gap:18px;margin-top:24px; }
@media (min-width:768px){ .ev-howitworks{ grid-template-columns:repeat(3,1fr); } }
.ev-step{
  position:relative;background:var(--evh-surface-1);border:1px solid var(--evh-border);
  border-radius:var(--evh-radius);padding:22px;
}
.ev-step__n{
  position:absolute;top:14px;right:14px;
  font-family:var(--evh-font-display);font-size:38px;font-weight:800;line-height:1;
  color:rgba(255,255,255,.06);
}
.ev-step__ico{
  width:48px;height:48px;border-radius:14px;
  background:var(--evh-cyan-soft);color:var(--evh-cyan);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.ev-step__ico svg{ width:24px;height:24px; }
.ev-step__t{ font-size:15px;font-weight:700;color:var(--evh-text);margin:0 0 6px; }
.ev-step__d{ font-size:13px;color:var(--evh-text-dim);line-height:1.55;margin:0; }

/* Testimonials */
.ev-testimonials{ display:grid;grid-template-columns:1fr;gap:18px;margin-top:24px; }
@media (min-width:768px){ .ev-testimonials{ grid-template-columns:repeat(3,1fr); } }
.ev-testim{
  background:var(--evh-surface-1);border:1px solid var(--evh-border);
  border-radius:var(--evh-radius);padding:22px;display:flex;flex-direction:column;
}
.ev-testim__quote{
  color:var(--evh-text);font-size:14px;line-height:1.6;margin:0 0 16px;
  flex:1;font-style:italic;
}
.ev-testim__quote::before{ content:"« ";color:var(--evh-cyan);font-weight:700; }
.ev-testim__quote::after{ content:" »";color:var(--evh-cyan);font-weight:700; }
.ev-testim__a{ display:flex;align-items:center;gap:12px; }
.ev-testim__av{
  width:40px;height:40px;border-radius:50%;
  background:var(--evh-grad);
  display:flex;align-items:center;justify-content:center;
  color:#0A0A12;font-weight:800;font-size:14px;
  font-family:var(--evh-font-display);
}
.ev-testim__nm{ font-size:13px;font-weight:700;color:var(--evh-text);margin:0; }
.ev-testim__ct{ font-size:11px;color:var(--evh-text-mute);margin:0; }
.ev-placeholder-flag{
  display:inline-block;font-size:9px;font-weight:700;
  background:rgba(252,211,77,.15);color:#FCD34D;
  border:1px solid rgba(252,211,77,.40);
  padding:2px 6px;border-radius:4px;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:10px;
}

/* Partners */
.ev-partners{
  display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:center;
  margin:24px 0 0;padding:24px;
  background:var(--evh-surface-1);border:1px solid var(--evh-border);
  border-radius:var(--evh-radius-lg);
  opacity:.78;
}
.ev-partner{
  display:inline-flex;align-items:center;gap:8px;
  height:42px;padding:0 18px;
  background:var(--evh-surface-2);border:1px dashed var(--evh-border-hi);
  border-radius:10px;color:var(--evh-text-mute);font-size:12px;font-weight:600;
}
.ev-partner svg{ width:18px;height:18px; }

/* ───────────────────────────────────────────────────────────
   §10  TOASTS
   ─────────────────────────────────────────────────────────── */
.ev-toasts{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  display:flex;flex-direction:column;gap:10px;
  max-width:360px;pointer-events:none;
}
.ev-toast{
  pointer-events:auto;
  background:var(--evh-surface-1);border:1px solid var(--evh-border-hi);
  border-radius:12px;padding:14px 16px;
  display:flex;align-items:flex-start;gap:10px;
  box-shadow:0 16px 48px -16px rgba(0,0,0,.60);
  animation:evhSlideInRight .25s ease-out;
  color:var(--evh-text);font-size:13px;line-height:1.4;
}
.ev-toast.is-ok   { border-left:3px solid #22C55E; }
.ev-toast.is-err  { border-left:3px solid #EF4444; }
.ev-toast.is-warn { border-left:3px solid #F59E0B; }
.ev-toast.is-info { border-left:3px solid var(--evh-cyan); }
@keyframes evhSlideInRight{
  from{ opacity:0;transform:translateX(24px); }
  to  { opacity:1;transform:none; }
}
.ev-toast__x{
  background:none;border:0;color:var(--evh-text-mute);cursor:pointer;
  font-size:16px;line-height:1;padding:2px;
}

/* ───────────────────────────────────────────────────────────
   §11  ANIMATIONS — fade-up / hover lift
   ─────────────────────────────────────────────────────────── */
.ev-fadeup{ opacity:0;transform:translateY(16px);transition:opacity .55s ease-out,transform .55s ease-out; }
.ev-fadeup.is-in{ opacity:1;transform:none; }

/* ───────────────────────────────────────────────────────────
   §12  LOADING SCREEN GLOBAL (boot)
   ─────────────────────────────────────────────────────────── */
.ev-boot{
  position:fixed;inset:0;z-index:99999;
  background:#0A0A12;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  transition:opacity .35s ease-out;
}
.ev-boot.is-out{ opacity:0;pointer-events:none; }
.ev-boot__mono{
  width:88px;height:88px;border-radius:24px;
  background:var(--evh-grad);
  display:flex;align-items:center;justify-content:center;
  color:#0A0A12;font-family:var(--evh-font-display);font-weight:900;font-size:38px;
  letter-spacing:-.04em;
  box-shadow:0 0 0 0 rgba(34,211,238,.4);
  animation:evhBootPulse 1.6s ease-in-out infinite;
  position:relative;
}
.ev-boot__mono::after{
  content:"";position:absolute;inset:-8px;border-radius:30px;
  border:2px solid transparent;border-top-color:var(--evh-cyan);
  animation:evhBootSpin 1.2s linear infinite;
}
@keyframes evhBootPulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(34,211,238,.45); }
  50%    { box-shadow:0 0 0 18px rgba(34,211,238,0); }
}
@keyframes evhBootSpin{ to{ transform:rotate(360deg); } }
.ev-boot__lbl{ color:var(--evh-text-mute);font-size:13px;letter-spacing:.04em; }

/* ───────────────────────────────────────────────────────────
   §13  RESPONSIVE — sanity checks
   ─────────────────────────────────────────────────────────── */
body:has(#p-auth.on),
body:has(#p-auth.on) *{ box-sizing:border-box; }
body:has(#p-auth.on) img{ max-width:100%;height:auto; }

@media (max-width:1023px){
  #p-auth{ padding:80px 16px 48px; }
  #p-auth .ahero{ text-align:center; }
  #p-auth .ahero .hi{ margin-left:auto;margin-right:auto; }
  #p-auth .ahero p{ margin-left:auto;margin-right:auto; }
}
@media (max-width:480px){
  #p-auth{ padding:72px 12px 40px; }
  #p-auth .ahero .hi{ width:54px;height:54px;font-size:28px; }
  body:has(#p-auth.on) .acard{ padding:18px !important; }
}

/* Empêche tout overflow horizontal sur la home */
body:has(#p-auth.on){ overflow-x:hidden; }
