/* ============================================================================
   Template CAM X v2 - thème CLAIR premium (style livecampicks), mobile-first.
   Couleurs/typo via variables injectées par lib/theme.php (anti-footprint).
   ============================================================================ */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);background:var(--bg);color:var(--body);
  line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
h1,h2,h3,h4{color:var(--primary);line-height:1.2;letter-spacing:-.02em;margin:0 0 .5rem;font-weight:700}
h1{font-size:clamp(1.6rem,5vw,2.5rem)}
h2{font-size:clamp(1.3rem,3.5vw,1.9rem)}
h3{font-size:clamp(1.05rem,2.5vw,1.25rem)}
.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(1rem,4vw,1.5rem)}
/* #main en colonne flex : permet de placer le texte SEO HAUT dans le DOM et de le
   repositionner visuellement en bas via order (technique Damien). */
#main{display:flex;flex-direction:column}
.seo-late{order:99}
.section{padding:clamp(1.8rem,5vw,3rem) 0}
.section--alt{background:var(--bg-alt)}
.muted{color:var(--muted)}

/* ---- Boutons -------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  padding:.7em 1.2em;border-radius:.6rem;border:0;cursor:pointer;font:inherit;font-weight:600;
  text-align:center;transition:transform .12s,background .12s,box-shadow .12s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn--cta{color:#fff;background:var(--cta);box-shadow:0 4px 14px color-mix(in srgb,var(--cta) 35%,transparent)}
.btn--cta:hover{background:var(--cta-hover)}
.btn--brand{color:#fff;background:var(--brand)}
.btn--brand:hover{background:var(--brand-dark)}
.btn--ghost{background:#fff;color:var(--primary);border:1px solid var(--border)}
.btn--ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn--lg{padding:.85em 1.6em;font-size:1.05rem}
.btn--block{display:flex;width:100%}

/* ---- Header --------------------------------------------------------------- */
.hd{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.hd__in{display:flex;align-items:center;gap:1rem;height:64px;position:relative}
.hd__logo{font-weight:800;font-size:1.2rem;color:var(--primary);display:flex;align-items:center;gap:.4rem;letter-spacing:-.03em}
.hd__nav{display:none;gap:1.4rem}
.hd__nav a{color:var(--body);font-weight:500;font-size:.95rem}
.hd__nav a:hover{color:var(--brand)}
.hd__right{margin-left:auto;display:flex;align-items:center;gap:.6rem}
.langsel{display:flex;gap:.2rem;font-size:.8rem}
.langsel a{padding:.25em .5em;border-radius:.4rem;color:var(--muted)}
.langsel a.is-on{background:var(--brand);color:#fff}
.hd__cta{display:none}
/* Formulaire contact / DMCA */
.cform{display:grid;gap:.9rem;margin-top:1.2rem}
.cform label{display:grid;gap:.35rem;font-weight:600;font-size:.92rem}
.cform input,.cform select,.cform textarea{font:inherit;padding:.6rem .7rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--body);width:100%;box-sizing:border-box}
.cform textarea{resize:vertical}
.cform .hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0}
.cform button{justify-self:start;margin-top:.2rem}
.formok{padding:.85rem 1rem;border-radius:8px;background:#e7f7ee;color:#0a7a3f;font-weight:600;border:1px solid #b7e4c7}
.formerr{padding:.85rem 1rem;border-radius:8px;background:#fdecec;color:#c0392b;font-weight:600;border:1px solid #f5c6cb}

/* ---- Hero ----------------------------------------------------------------- */
.hero{padding:clamp(2rem,6vw,3.5rem) 0 clamp(1.5rem,4vw,2.5rem);text-align:center;
  background:linear-gradient(180deg,color-mix(in srgb,var(--brand) 7%,#fff),var(--bg))}
.hero h1{margin-bottom:.6rem;max-width:18ch;margin-inline:auto}
.hero__sub{font-size:clamp(1rem,2.2vw,1.15rem);max-width:46ch;margin:0 auto 1.2rem}
.trustbar{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:center;font-size:.9rem;font-weight:500;color:var(--primary)}
.trustbar b{color:var(--brand)}

/* ---- Catégories pills / site directory ------------------------------------ */
.pills{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1.2rem}
.pill{display:inline-flex;align-items:center;gap:.4em;padding:.5em 1em;border-radius:999px;
  background:#fff;border:1px solid var(--border);font-weight:600;font-size:.9rem;color:var(--primary)}
.pill:hover{border-color:var(--brand);color:var(--brand)}
.brandrow{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.brandchip{padding:.45em .9em;border-radius:.5rem;background:#fff;border:1px solid var(--border);
  font-weight:600;font-size:.88rem;color:var(--primary)}
.brandchip:hover{border-color:var(--brand);color:var(--brand)}

/* ---- Section head --------------------------------------------------------- */
.shead{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}
.shead p{margin:.1rem 0 0}
.shead a.more{color:var(--brand);font-weight:600;font-size:.9rem;white-space:nowrap}
.shead a.more:hover{text-decoration:underline}

/* ---- Grille modèles ------------------------------------------------------- */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.card{background:#fff;border:1px solid var(--border);border-radius:.75rem;overflow:hidden;
  transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:0 10px 28px #0000001a}
.card__media{position:relative;display:block;aspect-ratio:4/5;overflow:hidden;background:var(--bg-alt)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.card:hover .card__media img{transform:scale(1.05)}
.badge{position:absolute;font-size:.68rem;font-weight:700;letter-spacing:.03em;padding:.25em .55em;border-radius:.4rem}
.badge--live{top:.5rem;left:.5rem;background:var(--live);color:#fff;display:inline-flex;align-items:center;gap:.3em}
.badge--live .pulse{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.5s infinite}
.badge--off{top:.5rem;left:.5rem;background:#0008;color:#fff}
.badge--geo{top:.5rem;right:.5rem;background:#fff;color:var(--primary);box-shadow:0 1px 4px #0002}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
/* Nom en OVERLAY sur l'image (identité propre, ≠ livecampicks qui met le nom sous l'image). */
.card__overlay{position:absolute;left:0;right:0;bottom:0;padding:1.1rem .6rem .5rem;display:flex;flex-direction:column;gap:.05rem;
  background:linear-gradient(transparent,rgba(0,0,0,.55) 55%,rgba(0,0,0,.82));color:#fff}
.card__overlay .card__name{color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:baseline;gap:.35rem;text-shadow:0 1px 3px #0006}
.card__overlay .card__name .age{color:#ffffffcc;font-size:.8rem;font-weight:500}
.card__overlay .card__topic{color:#ffffffd0;font-size:.76rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card__body{padding:.55rem .6rem .65rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.card__tags{display:flex;flex-wrap:wrap;gap:.3rem;min-height:1.1rem}
.tagchip{font-size:.68rem;padding:.18em .5em;border-radius:.35rem;background:var(--bg-alt);color:var(--muted)}
.card__cta{margin-top:auto}

/* ---- Comparateur (sites/reviews) ------------------------------------------ */
.rankcard{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;
  background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1.1rem;margin-bottom:.9rem}
.rankcard--top{border-color:var(--brand);box-shadow:0 6px 22px color-mix(in srgb,var(--brand) 18%,transparent)}
.rankcard__rank{display:flex;flex-direction:column;align-items:center;gap:.2rem;min-width:54px}
.rankcard__rank .num{font-size:1.5rem;font-weight:800;color:var(--primary);line-height:1}
.rankcard__rank .score{background:var(--brand);color:#fff;font-weight:700;font-size:.85rem;padding:.15em .5em;border-radius:.4rem}
.rankcard__name{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.stars{color:#f59e0b;font-size:.9rem;letter-spacing:1px}
.rankcard__desc{margin:.4rem 0 .7rem;font-size:.95rem}
.rankcard__cta{display:flex;gap:.5rem;flex-wrap:wrap}
.badge-best{background:var(--cta);color:#fff;font-size:.7rem;font-weight:700;padding:.2em .55em;border-radius:.4rem}

/* ---- Page modèle ---------------------------------------------------------- */
.crumbs{font-size:.85rem;color:var(--muted);padding:1rem 0 .2rem}
.crumbs a:hover{color:var(--brand)}
.model{display:grid;gap:1.2rem;margin:.6rem 0 1.4rem}
.model__media{position:relative;border-radius:.75rem;overflow:hidden;aspect-ratio:16/10;background:#000}
.model__media img{width:100%;height:100%;object-fit:cover}
.livebox{display:block;position:relative;width:100%;height:100%}
.livebox iframe{width:100%;height:100%;border:0;pointer-events:none;display:block}
.livebox__cta,.offcta{position:absolute;left:0;right:0;bottom:0;padding:.8rem 1rem;color:#fff;font-weight:600;
  background:linear-gradient(transparent,#000c)}
.offcta{inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;background:#0006;text-align:center}
.model__info{display:flex;flex-direction:column;gap:.8rem}
.model__cta{display:flex;flex-direction:column;gap:.5rem}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:.1rem .8rem;background:var(--bg-alt);border-radius:.6rem;padding:.9rem 1rem}
.specs div{display:flex;justify-content:space-between;gap:.5rem;padding:.3rem 0;border-bottom:1px solid var(--border)}
.specs div:last-child,.specs div:nth-last-child(2){border-bottom:0}
.specs dt{color:var(--muted);font-size:.85rem}
.specs dd{margin:0;font-weight:600;color:var(--primary);font-size:.85rem;text-align:right}
.ratingrow{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--primary)}

/* ---- FAQ ------------------------------------------------------------------ */
.faq details{background:#fff;border:1px solid var(--border);border-radius:.6rem;padding:.2rem .9rem;margin-bottom:.6rem}
.faq summary{cursor:pointer;font-weight:600;color:var(--primary);padding:.7rem 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--brand);font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq p{margin:0 0 .8rem}

/* ---- Bloc SEO ------------------------------------------------------------- */
.prose{max-width:70ch}
.prose p{margin:.6rem 0}
.prose a{color:var(--brand);text-decoration:underline;text-underline-offset:2px}
.tagcloud{display:flex;flex-wrap:wrap;gap:.4rem}

/* ---- Cartes guides/blog --------------------------------------------------- */
.guidegrid{display:grid;grid-template-columns:1fr;gap:.9rem}
.guidecard{background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1.1rem;transition:box-shadow .15s}
.guidecard:hover{box-shadow:0 8px 22px #0000001a}
.guidecard h3{margin-bottom:.3rem}
.guidecard .more{color:var(--brand);font-weight:600;font-size:.9rem}

.pager{display:flex;gap:.6rem;justify-content:center;margin-top:1.4rem}
.empty{color:var(--muted);text-align:center;padding:2rem 0}

/* ---- Age gate ------------------------------------------------------------- */
.agegate{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;
  padding:1.2rem;background:#1e1e4acc;backdrop-filter:blur(8px)}
html.age-ok #agegate{display:none}
.agegate__box{max-width:420px;text-align:center;background:#fff;border-radius:1rem;padding:2rem 1.6rem;box-shadow:0 24px 60px #0006}
.agegate__brand{font-weight:800;color:var(--primary);margin:0 0 .8rem;font-size:1.2rem}
.agegate__cta{margin:1.3rem 0 .8rem}
.agegate__exit a{color:var(--muted);font-size:.85rem}

/* ---- Sticky CTA mobile ---------------------------------------------------- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:30;text-align:center;padding:.85rem;
  font-weight:700;color:#fff;background:var(--cta);box-shadow:0 -4px 16px #0002}

/* ---- Bandeau cookies (les 2 boutons -> offre = CTR max, technique Damien) -- */
.cookiebar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;align-items:center;gap:1rem;
  flex-wrap:wrap;padding:.9rem clamp(1rem,4vw,1.5rem);background:#fff;border-top:1px solid var(--border);
  box-shadow:0 -6px 22px #0000001f}
.cookiebar.is-shown{display:flex}
.cookiebar__txt{flex:1;min-width:200px;font-size:.85rem;color:var(--body);margin:0}
.cookiebar__cta{display:flex;gap:.5rem;flex-wrap:wrap}

/* ---- Footer --------------------------------------------------------------- */
.ft{background:var(--primary);color:#fff9;margin-top:1rem;padding:2.2rem 0 5rem}
.ft a{color:#fffc}
.ft a:hover{color:#fff}
.ft__cols{display:grid;grid-template-columns:1fr;gap:1.4rem}
.ft__logo{color:#fff;font-weight:800;font-size:1.1rem;margin:0 0 .4rem}
.ft h4{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .6rem}
.ft nav{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem}
.ft__legal{border-top:1px solid #ffffff22;margin-top:1.6rem;padding-top:1.2rem;font-size:.8rem;line-height:1.6}

/* ---- Desktop -------------------------------------------------------------- */
@media(min-width:720px){
  .hd__nav{display:flex;position:absolute;left:50%;transform:translateX(-50%)}
  .hd__cta{display:inline-flex}
  .grid{grid-template-columns:repeat(4,1fr);gap:1rem}
  .guidegrid{grid-template-columns:repeat(2,1fr)}
  .sticky-cta{display:none}
  .model{grid-template-columns:1.7fr 1fr;align-items:start}
  .ft__cols{grid-template-columns:2fr 1fr 1fr 1fr}
  .ft{padding-bottom:2.2rem}
}
@media(min-width:1040px){
  .grid{grid-template-columns:repeat(6,1fr)}
  .guidegrid{grid-template-columns:repeat(4,1fr)}
}

/* Review pages - safe screenshot style */
.reviewhero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);gap:2rem;align-items:center;padding:1.2rem 0 2rem}.reviewhero__copy .lead{font-size:1.08rem;color:var(--muted);max-width:62ch}.reviewhero__media{margin:0}.reviewhero__media img{display:block;width:100%;height:auto;border-radius:1.25rem;box-shadow:0 22px 70px rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.12)}.reviewhero__media figcaption{font-size:.78rem;color:var(--muted);margin-top:.55rem}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;font-weight:800;color:var(--brand);margin:0 0 .5rem}.reviewgrid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:2rem;align-items:start}.reviewbox{position:sticky;top:1rem;background:var(--card);border:1px solid var(--line);border-radius:1rem;padding:1rem;box-shadow:var(--shadow)}.proscons{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.proscons>div{background:var(--bg-alt);border-radius:.85rem;padding:1rem}.rtable{width:100%;border-collapse:collapse}.rtable th,.rtable td{border-bottom:1px solid var(--line);padding:.7rem;text-align:left;vertical-align:top}.btn--block{display:block;text-align:center;width:100%}.formok{background:#ecfdf3;color:#076b3a;padding:.8rem 1rem;border-radius:.75rem}.formerr{background:#fff1f2;color:#a11122;padding:.8rem 1rem;border-radius:.75rem}.cform{display:grid;gap:.85rem}.cform label{display:grid;gap:.35rem;font-weight:700}.cform input,.cform select,.cform textarea{width:100%;border:1px solid var(--line);border-radius:.65rem;padding:.75rem;background:var(--card);color:var(--text)}.hp{position:absolute;left:-9999px}
@media(max-width:850px){.reviewhero,.reviewgrid,.proscons{grid-template-columns:1fr}.reviewbox{position:static}}
