/* =================================================================
   Calque démo "genre moderne" (ClearVision-like) — travail original
   Additif : ne remplace rien, se superpose à styles.css
   ================================================================= */
.cv-wrap{--cv-accent:#4f7cf0;--cv-ink:#16233c}

/* ---------- HERO clair ---------- */
.cv-hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#ffffff 0%,#eaf1fb 100%);padding:clamp(2.4rem,5vw,4.6rem) 0 clamp(3rem,6vw,5.4rem)}
.cv-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(58% 52% at 80% 26%,rgba(79,124,240,.20),transparent 70%);pointer-events:none}
.cv-hero__grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,4.5rem);align-items:center}

.cv-pill{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);color:#b3261e;font-weight:600;font-size:.9rem;padding:.42rem .85rem;border-radius:999px;text-decoration:none}
.cv-pill .dot{width:.5rem;height:.5rem;border-radius:50%;background:#d93025;box-shadow:0 0 0 0 rgba(217,48,37,.5);animation:pulseDot 2.2s infinite}
.cv-hero h1{font-size:clamp(2.5rem,1.85rem+3.4vw,4.35rem);line-height:1.02;letter-spacing:-.04em;margin:1.15rem 0 0;color:var(--cv-ink)}
.cv-hero h1 .accent{color:var(--primary);background:linear-gradient(100deg,var(--primary) 36%,#86abe8 50%,var(--primary) 64%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shine 5s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.cv-hero h1 .accent{animation:none;-webkit-text-fill-color:var(--primary)}}
.cv-hero__lead{font-size:clamp(1.08rem,1rem+.4vw,1.28rem);color:var(--ink-soft);max-width:46ch;margin:1.2rem 0 0;line-height:1.6}
.cv-hero__lead strong{color:var(--cv-ink);font-weight:650}
.cv-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
.cv-rating{display:flex;align-items:center;gap:.85rem;margin-top:1.9rem;flex-wrap:wrap}
.cv-avatars{display:flex}
.cv-avatars span{width:36px;height:36px;border-radius:50%;border:2px solid #fff;margin-left:-11px;display:grid;place-items:center;font-size:.78rem;font-weight:600;color:#fff;background:var(--primary)}
.cv-avatars span:first-child{margin-left:0}
.cv-rating__txt{line-height:1.25}
.cv-stars{color:#f5a623;letter-spacing:.12em;font-size:1.02rem}
.cv-rating__txt small{color:var(--ink-soft);font-size:.86rem}
.cv-rating__txt a{font-weight:600}

.cv-hero__media{position:relative;justify-self:center;width:min(418px,100%);text-align:center}
.cv-team-eyebrow{display:block;font-family:var(--font-body);font-weight:600;font-size:var(--fs-300);letter-spacing:.04em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:.8rem}
.cv-photo-wrap{position:relative;width:100%}
.cv-photo-wrap img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;border-radius:28px;box-shadow:0 26px 60px rgba(20,35,60,.26);background:#dfe8f6;display:block}
/* carte conventionné : verre translucide, posée en bas-gauche de la photo */
.cv-floatcard{position:absolute;left:1rem;bottom:1rem;background:rgba(255,255,255,.14);-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);border:1px solid rgba(255,255,255,.3);border-radius:14px;padding:.62rem .85rem;display:flex;align-items:center;gap:.6rem;max-width:230px}
.cv-floatcard svg{width:34px;height:34px;flex:0 0 auto;color:#fff;background:rgba(255,255,255,.22);border-radius:10px;padding:8px;box-sizing:border-box}
.cv-floatcard b{display:block;font-size:.92rem;color:#fff;line-height:1.15;font-weight:700}
.cv-floatcard small{color:rgba(255,255,255,.85);font-size:.78rem}
.cv-team-name{display:block;margin-top:1rem;font-weight:700;color:var(--cv-ink);font-size:1.02rem;line-height:1.25}
.cv-team-name span{display:block;font-weight:500;color:var(--ink-soft);font-size:.9rem;margin-top:.12rem}

@media(max-width:880px){
  .cv-hero__grid{grid-template-columns:1fr;gap:2.2rem}
  .cv-hero__media{order:-1;width:min(338px,86%)}
  .cv-hero__content{text-align:center}
  .cv-hero__content .cv-pill,.cv-hero__content .cv-actions,.cv-hero__content .cv-rating{justify-content:center}
  .cv-hero__lead{margin-inline:auto}
}

/* ---------- Bandeau "le centre" (photos réelles) ---------- */
.cv-showcase{background:#fff}
.cv-showcase__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.cv-shot{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow);background:linear-gradient(160deg,#e2eaf7,#c6d6ee);margin:0}
.cv-shot img{width:100%;height:100%;object-fit:cover}
.cv-shot figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.5rem 1.05rem .95rem;color:#fff;font-weight:600;font-size:.98rem;background:linear-gradient(transparent,rgba(15,34,68,.8))}
.cv-shot--empty{display:grid;place-items:center;text-align:center;padding:1rem}
.cv-shot--empty svg{width:44px;height:44px;color:var(--primary);opacity:.55}
.cv-shot--empty span{display:block;margin-top:.65rem;font-weight:600;color:#5f6f88;font-size:.92rem;line-height:1.35}
@media(max-width:760px){
  .cv-showcase__grid{grid-template-columns:1fr 1fr}
  .cv-shot:nth-child(3){grid-column:1 / -1;aspect-ratio:16/10}
}

/* ---------- Bento "le centre" (photos réelles) ---------- */
.cv-bento{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.cv-bento figure{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);margin:0;background:#dfe8f6}
.cv-bento img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s var(--ease-out)}
.cv-bento figure:hover img{transform:scale(1.045)}
.cv-bento__feature{grid-column:1 / -1;aspect-ratio:16/9}
.cv-bento__side{aspect-ratio:4/3}
.cv-bento figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.35rem 1.05rem .95rem;color:#fff;font-weight:600;font-size:.98rem;background:linear-gradient(transparent,rgba(15,34,68,.82))}
@media(max-width:620px){
  .cv-bento{grid-template-columns:1fr}
  .cv-bento__feature,.cv-bento__side{aspect-ratio:16/10}
}
