/* House of Sound — design system premium (rock noir/rouge). Léger, aéré, peu de cadres. */
@font-face{font-family:'Oswald';font-style:normal;font-weight:700;font-display:swap;
  src:url('/assets/fonts/oswald-700.woff2') format('woff2');
  size-adjust:96%;ascent-override:130%}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
:root{
  --bg:#08080a;--bg2:#101013;--card:#141418;--card2:#1a1a1f;--line:rgba(255,255,255,.085);
  --txt:#ededf0;--mut:#9a9aa6;--red:#e10600;--red2:#ff2d24;--red-d:#a30400;
  --silver:#cfd2d8;--ok:#3ad07e;--no:#ff5b5b;--rad:14px;--mw:1120px;--read:760px;
  --disp:'Oswald',system-ui,Impact,sans-serif}
body{margin:0;background:var(--bg);color:var(--txt);
  font:16px/1.7 system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-synthesis:none;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--disp);font-weight:700;line-height:1.05;letter-spacing:.01em;margin:0;text-transform:uppercase}
a{color:var(--red2);text-decoration:none;transition:color .15s}
img{max-width:100%;height:auto;display:block}
.conteneur{max-width:var(--mw);margin:0 auto;padding:0 22px}
.discret{color:var(--mut)}
/* ---------- header ---------- */
.entete{position:sticky;top:0;z-index:30;background:rgba(8,8,10,.8);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.entete::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:linear-gradient(90deg,transparent,var(--red),transparent)}
.entete-barre{display:flex;align-items:center;gap:14px;min-height:66px;padding:7px 0}
.logo{display:flex;align-items:center;gap:8px;font-family:var(--disp);font-size:1.18rem;color:#fff;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;flex:none}
.logo .embleme{width:23px;height:23px;flex:none;display:block}
.logo .accent{color:var(--red)}
.logo .point{width:9px;height:9px;border-radius:50%;background:var(--red);box-shadow:0 0 14px var(--red)}
.menu{margin-left:auto;display:flex;gap:1px;flex-wrap:wrap;row-gap:4px;justify-content:flex-end}
.menu a{color:var(--mut);font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.02em;padding:8px 9px;border-radius:9px;white-space:nowrap;transition:color .15s,background .15s}
.menu a.bouton-principal{padding-left:14px;padding-right:14px;margin-left:4px}
.menu a:hover{color:#fff;background:#1c1c22}
.menu a.bouton-principal{color:#fff;background:linear-gradient(180deg,var(--red),var(--red-d));box-shadow:0 4px 16px rgba(225,6,0,.35)}
/* menus déroulants (CSS only) */
.menu-bloc{position:relative;display:flex}
.sous-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:256px;background:#0d0d11;border:1px solid var(--line);border-radius:12px;padding:8px;display:none;flex-direction:column;box-shadow:0 18px 50px rgba(0,0,0,.6);z-index:50}
.menu-bloc:hover>.sous-menu,.menu-bloc:focus-within>.sous-menu{display:flex}
.sous-menu a{white-space:nowrap;padding:9px 12px;border-radius:8px;color:var(--mut);font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;font-weight:400;font-size:.9rem;text-transform:none;letter-spacing:0}
.sous-menu a:hover{background:#1c1c22;color:#fff}
.sous-menu a.voir-tout{color:var(--red2);font-weight:600;margin-top:2px;border-top:1px solid var(--line);border-radius:0 0 8px 8px}
/* ---------- hamburger (CSS only, zéro JS) ---------- */
/* Desktop (≥681px) : bouton + fermer cachés, checkbox hors-écran (focus clavier OK), menu = barre normale. */
.hamburger,.menu-fermer{display:none}
/* checkbox masquée mais FOCUSABLE au clavier (sr-only, pas de saut de scroll) */
.nav-toggle{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;opacity:0}
.hamburger-barres,.hamburger-barres::before,.hamburger-barres::after{display:block;width:24px;height:2px;background:var(--red2);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.hamburger-barres{position:relative}
.hamburger-barres::before,.hamburger-barres::after{content:"";position:absolute;left:0}
.hamburger-barres::before{top:-7px}
.hamburger-barres::after{top:7px}
/* ---------- menu mobile : panneau déroulant piloté par le hamburger ---------- */
@media(max-width:680px){
  /* IMPORTANT : backdrop-filter sur .entete = bloc conteneur des fixed enfants → casse le panneau.
     On le neutralise sur mobile pour que .menu (position:fixed) se réfère au VIEWPORT. */
  .entete{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(8,8,10,.96)}
  .entete-barre{flex-wrap:nowrap;gap:12px}
  .hamburger{display:flex;align-items:center;justify-content:center;margin-left:auto;width:44px;height:44px;flex:none;cursor:pointer;border:1px solid var(--line);border-radius:10px;background:#121216}
  .hamburger:active{background:#1c1c22}
  .nav-toggle:focus-visible ~ .hamburger{outline:2px solid var(--red2);outline-offset:2px}
  .menu{position:fixed;left:0;right:0;top:66px;bottom:0;z-index:40;margin:0;display:flex;flex-direction:column;flex-wrap:nowrap;align-items:stretch;justify-content:flex-start;gap:2px;padding:14px 18px calc(28px + env(safe-area-inset-bottom));background:#0b0b0e;border-top:1px solid var(--line);overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateX(100%);opacity:0;visibility:hidden;pointer-events:none;transition:transform .28s ease,opacity .2s ease,visibility .28s}
  .nav-toggle:checked ~ .menu{transform:translateX(0);opacity:1;visibility:visible;pointer-events:auto}
  .nav-toggle:checked ~ .hamburger .hamburger-barres{background:transparent}
  .nav-toggle:checked ~ .hamburger .hamburger-barres::before{top:0;transform:rotate(45deg)}
  .nav-toggle:checked ~ .hamburger .hamburger-barres::after{top:0;transform:rotate(-45deg)}
  .menu a{display:flex;align-items:center;min-height:48px;width:100%;font-size:1rem;padding:12px 14px;border-radius:10px;white-space:normal}
  .menu a:hover,.menu a:active{background:#1c1c22;color:#fff}
  .menu a.bouton-principal{justify-content:center;margin-top:10px}
  .menu-bloc{display:block;width:100%}
  .sous-menu{position:static;display:flex !important;min-width:0;background:transparent;border:0;box-shadow:none;padding:0 0 6px 12px;border-left:2px solid var(--line);margin:2px 0 8px 6px}
  .sous-menu a{min-height:44px;font-size:.92rem;color:var(--mut);white-space:normal}
  .sous-menu a.voir-tout{border-top:0;color:var(--red2)}
  .menu-fermer{display:flex;align-items:center;justify-content:flex-end;gap:8px;order:-1;position:sticky;top:0;align-self:flex-end;min-height:44px;padding:8px 6px;margin:-6px 0 4px;cursor:pointer;color:var(--mut);font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem}
  .menu-fermer:active{color:#fff}
  body{overflow-x:hidden}
}
/* ---------- hero éditorial ---------- */
.banniere{position:relative;overflow:hidden;background:
  radial-gradient(110% 80% at 82% -10%,rgba(225,6,0,.28),transparent 58%),
  radial-gradient(90% 70% at 0% 0%,rgba(120,120,140,.08),transparent 55%),
  linear-gradient(180deg,#000,var(--bg))}
.banniere::before{content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px);background-size:100% 7px}
.banniere-contenu{position:relative;padding:88px 0 70px;max-width:var(--read)}
.surtitre{display:inline-flex;align-items:center;gap:8px;color:#fff;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;border:1px solid var(--red);border-radius:50px;padding:6px 14px;margin-bottom:20px;background:rgba(225,6,0,.12)}
h1.grand-titre{font-size:clamp(2.3rem,6vw,4.1rem);color:#fff;text-shadow:0 2px 40px rgba(0,0,0,.6)}
h1.grand-titre em{color:var(--red2);font-style:normal}
.banniere p.accroche{color:#c4c4cf;max-width:660px;margin:26px 0 0;font-size:1.12rem;line-height:1.62}
.banniere .meta-info{color:#8a8a94;font-size:.82rem;margin-top:18px;letter-spacing:.02em}
.bouton{display:inline-flex;align-items:center;gap:8px;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.95rem;padding:13px 24px;border-radius:11px;border:0;cursor:pointer;transition:transform .12s,box-shadow .2s}
.bouton-rouge{color:#fff;background:linear-gradient(180deg,var(--red),var(--red-d));box-shadow:0 8px 26px rgba(225,6,0,.4)}
.bouton-rouge:hover{transform:translateY(-2px);box-shadow:0 12px 34px rgba(225,6,0,.55)}
.bouton-fantome{color:#fff;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.bouton-fantome:hover{border-color:var(--silver);background:rgba(255,255,255,.07)}
.banniere-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:36px}
/* ---------- rythme des sections (aéré) ---------- */
/* IMPORTANT : les pages utilisent <section class="conteneur"> (un seul élément). Comme .conteneur pose
   padding:0 22px avec une spécificité supérieure à `section`, il FAUT cibler section.conteneur pour que
   le padding VERTICAL s'applique réellement (sinon l'espacement entre blocs retombe à 0 = "ça colle"). */
section{padding:90px 0}
section.conteneur{padding-top:64px;padding-bottom:64px}
@media(max-width:680px){section{padding:48px 0}section.conteneur{padding-top:40px;padding-bottom:40px}}
.titre-section{font-size:clamp(1.6rem,3.6vw,2.3rem);color:#fff;margin:0 0 34px;display:flex;align-items:center;gap:14px}
.titre-section::before{content:"";width:32px;height:4px;flex:none;background:var(--red);border-radius:3px;box-shadow:0 0 14px rgba(225,6,0,.6)}
.sous-titre{color:var(--mut);margin:-2px 0 46px;max-width:var(--read);font-size:1.02rem;line-height:1.6}
/* ---------- prose éditoriale (paragraphes, pas de blocs) ---------- */
.paragraphes{max-width:var(--read)}
.paragraphes p{margin:0 0 19px;color:#c9c9d2;font-size:1.04rem;line-height:1.8}
.paragraphes p:last-child{margin-bottom:0}
.paragraphes p b,.paragraphes p strong{color:#fff}
.paragraphes h3{color:#fff;font-size:1.15rem;margin:40px 0 16px}
.chapo{max-width:var(--read);color:#c9c9d2;font-size:1.08rem;line-height:1.75;margin:0 0 24px}
/* ---------- grille catégories (à plat) ---------- */
.grille-univers{display:grid;grid-template-columns:repeat(6,1fr);gap:36px 24px}
@media(max-width:900px){.grille-univers{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.grille-univers{grid-template-columns:repeat(2,1fr)}}
.univers{display:block;padding:28px 0;border-top:1px solid var(--line);transition:opacity .15s}
.univers:hover{opacity:.92}
.univers .icone{font-size:1.7rem;margin-bottom:8px}
.univers h3{color:#fff;font-size:1.18rem;letter-spacing:.02em;transition:color .15s}
.univers:hover h3{color:var(--red2)}
.univers p{color:var(--mut);font-size:.92rem;margin:6px 0 0}
.univers .aller{color:var(--red2);font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.06em;margin-top:16px;display:inline-block}
/* ---------- top 3 (colonnes à plat, filet rouge) ---------- */
.podium{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:44px}
.choix{padding:24px 0 0;border-top:2px solid var(--red)}
.choix .etiquette{color:var(--red2);font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:.78rem;letter-spacing:.06em}
.choix h3{color:#fff;font-size:1.24rem;margin:12px 0 10px;letter-spacing:.01em}
.choix p{color:var(--mut);font-size:.95rem;margin:0;line-height:1.6}
/* ---------- cartes image (home / hub), sans cadre ---------- */
.grille-cartes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:48px 30px}
.carte{display:block}
.carte .photo{aspect-ratio:16/9;border-radius:var(--rad);overflow:hidden;background:linear-gradient(135deg,#1d1d24,#0b0b0e)}
.carte .photo img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.carte:hover .photo img{transform:scale(1.045)}
.carte .carte-texte{padding:16px 2px 4px}
.carte .carte-categorie{color:var(--red2);font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:.74rem;letter-spacing:.06em}
.carte h3{color:#fff;font-size:1.16rem;margin:9px 0 0;letter-spacing:.01em;transition:color .15s}
.carte:hover h3{color:var(--red2)}
.carte .meta-info{color:#8a8a94;font-size:.76rem;margin-top:11px;font-family:var(--disp);text-transform:uppercase;letter-spacing:.05em}
/* en-tête de section avec lien "tout voir" */
.entete-section{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:34px}
.entete-section .titre-section{margin:0}
.entete-section .lien-plus{color:var(--red2);font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:.78rem;letter-spacing:.06em;white-space:nowrap}
.entete-section .lien-plus:hover{color:#fff}
/* ---------- comparatif : tableau (CADRE conservé) ---------- */
.cadre-tableau{overflow-x:auto;border:1px solid var(--line);border-radius:var(--rad);background:var(--card)}
table{border-collapse:collapse;width:100%;min-width:660px;font-size:.9rem}
th,td{padding:16px 16px;text-align:left;border-bottom:1px solid var(--line)}
thead th{background:#000;color:#fff;font-family:var(--disp);text-transform:uppercase;font-size:.78rem;letter-spacing:.05em}
tbody tr:hover{background:#1b1b21}
td b{color:#fff}
/* ---------- fiches produit (CADRE conservé) ---------- */
.fiche{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;margin:46px 0;box-shadow:0 8px 30px rgba(0,0,0,.35)}
.fiche-haut{display:grid;grid-template-columns:210px 1fr}
@media(max-width:640px){.fiche-haut{grid-template-columns:1fr}}
.vignette{aspect-ratio:1/1;background:radial-gradient(80% 80% at 50% 30%,#26262e,#0c0c10);display:flex;align-items:center;justify-content:center;color:#4a4a56;font-family:var(--disp);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;border-right:1px solid var(--line);text-align:center}
@media(max-width:640px){.vignette{aspect-ratio:16/9;border-right:0;border-bottom:1px solid var(--line)}}
.fiche-corps{padding:26px 26px 22px}
.rang{display:inline-flex;align-items:center;gap:8px;color:var(--red2);font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:.82rem;letter-spacing:.05em;margin-bottom:6px}
.fiche h3{color:#fff;font-size:1.42rem;letter-spacing:.01em}
.fiche .description{color:#c9c9d2;margin:14px 0 0;font-size:.99rem;line-height:1.72}
.pour-contre{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:14px 24px 14px}
@media(max-width:560px){.pour-contre{grid-template-columns:1fr}}
.pour-contre ul{margin:0;padding:0;list-style:none}
.pour-contre li{position:relative;padding:5px 0 5px 26px;font-size:.93rem}
.pour .titre-mini,.contre .titre-mini{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:.78rem;letter-spacing:.05em;margin-bottom:6px}
.pour .titre-mini{color:var(--ok)}.contre .titre-mini{color:var(--no)}
.pour li::before{content:"✓";position:absolute;left:4px;color:var(--ok);font-weight:900}
.contre li::before{content:"✕";position:absolute;left:5px;color:var(--no);font-weight:900;font-size:.8rem}
.caracteristiques{display:flex;flex-wrap:wrap;gap:8px;padding:16px 24px 18px}
.caracteristiques span{background:#000;border:1px solid var(--line);border-radius:50px;padding:5px 12px;font-size:.78rem;color:var(--mut)}
.caracteristiques b{color:#fff}
.verdict{margin:14px 22px 24px;padding:16px 18px;border-left:3px solid var(--red);background:#000;border-radius:0 10px 10px 0;color:#e7e7e7;font-size:.96rem;line-height:1.6}
.verdict b{color:var(--red2);font-family:var(--disp);text-transform:uppercase;font-size:.76rem;letter-spacing:.05em;display:block;margin-bottom:3px}
.encart-offre{min-height:56px;margin:8px 22px 24px;border:1px dashed #33333c;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#7a7a84;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em}
/* ---------- "bien choisir" en colonnes à plat (pas de cadre) ---------- */
.criteres{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px 36px}
.critere{padding-top:20px;border-top:1px solid var(--line)}
.critere h3{color:#fff;font-size:1.06rem;margin-bottom:12px;letter-spacing:.01em}
.critere p{color:var(--mut);font-size:.94rem;margin:0;line-height:1.62}
/* ---------- FAQ (accordéon, fin) ---------- */
details{border-bottom:1px solid var(--line)}
summary{cursor:pointer;padding:23px 2px;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:#fff;font-size:1.04rem;list-style:none}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";float:right;color:var(--red2);font-weight:900}
details[open] summary::after{content:"–"}
details p{margin:0;padding:4px 2px 24px;color:var(--mut);font-size:.96rem;line-height:1.7;max-width:var(--read)}
/* ---------- bandeau éditorial (CTA, sans bordure) ---------- */
.bandeau{background:linear-gradient(120deg,#160a0b,#0b0b0e);border-radius:18px;padding:68px 40px;text-align:center}
.bandeau h2{color:#fff;font-size:clamp(1.6rem,3.5vw,2.3rem)}
.bandeau p{color:#c4c4cf;max-width:620px;margin:20px auto 0;line-height:1.65}
/* ---------- footer ---------- */
.pied{border-top:1px solid var(--line);background:#000;padding:62px 0 38px;color:var(--mut);font-size:.9rem;margin-top:58px;position:relative}
.pied::before{content:"";position:absolute;left:0;right:0;top:-1px;height:2px;background:linear-gradient(90deg,transparent,var(--red),transparent)}
.pied .colonnes{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}
.pied b{color:#fff;font-family:var(--disp);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem}
.pied a{color:var(--mut)}.pied a:hover{color:#fff}
.pied .pied-bas{margin-top:30px;color:#7a7a84;font-size:.82rem;border-top:1px solid var(--line);padding-top:24px}
.fil-ariane{color:#8a8a94;font-size:.82rem;margin-bottom:30px}
.fil-ariane a{color:#9a9aa6}
/* ---------- images (sans cadre, format large = moins haut) ---------- */
.carte .photo{padding:0}
.cadre-image{border-radius:var(--rad);overflow:hidden;background:#0b0b0e;margin:0}
.cadre-image img{width:100%;height:100%;object-fit:cover}
.image-une{margin:8px 0 28px;position:relative}
.image-une .cadre-image{height:clamp(210px,32vw,370px)}
.image-une figcaption{color:#7a7a84;font-size:.76rem;margin-top:8px}
.image-une figcaption span{float:right}
.image-une figcaption a{color:#8a8a94}
.image-moitie{max-width:480px;margin:32px 0 8px}
.image-moitie.cadre-image{height:clamp(200px,26vw,300px)}
/* ---------- réponse rapide (lead, filet rouge, sans cadre) ---------- */
.reponse-rapide{border-left:3px solid var(--red);padding:6px 0 6px 22px;margin:34px 0 44px}
.reponse-rapide .intitule{display:block;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--red2);font-size:.74rem;margin-bottom:7px}
.reponse-rapide p{margin:0;color:#e9e9ee;font-size:1.1rem;line-height:1.62;max-width:var(--read)}
.reponse-rapide b{color:#fff}
/* ---------- signature auteur ---------- */
.signature{display:flex;align-items:center;gap:11px;margin-top:28px;color:var(--mut);font-size:.85rem;flex-wrap:wrap}
.signature .avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(140deg,var(--red),var(--red-d));display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--disp);font-size:.84rem;flex:none}
.signature b{color:#fff}
.bloc-auteur{display:flex;gap:15px;padding:36px 0 0;margin-top:8px;border-top:1px solid var(--line)}
.bloc-auteur .avatar{width:52px;height:52px;flex:none;border-radius:50%;background:linear-gradient(140deg,var(--red),var(--red-d));display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--disp);font-size:1.3rem}
.bloc-auteur h4{margin:0 0 8px;color:#fff;font-family:var(--disp);text-transform:uppercase;letter-spacing:.02em;font-size:1.04rem}
.bloc-auteur p{margin:0;color:var(--mut);font-size:.92rem;line-height:1.6}
.bloc-auteur a{color:var(--silver)}
/* ---------- méthode / sources / maillage ---------- */
.annotation{font-size:.85rem;color:var(--mut);margin-top:18px;line-height:1.6;max-width:var(--read)}
.sources{font-size:.88rem;color:var(--mut)}
.sources ul{margin:12px 0 0;padding-left:18px;line-height:1.7}
.sources a{color:var(--silver)}
/* tags / liens (boutons arrondis) */
.liens-connexes,.mots-cles{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.liens-connexes a{display:inline-flex;align-items:center;gap:7px;color:#fff;font-size:.9rem;padding:9px 16px;border-radius:50px;border:1px solid var(--line);background:#121216;transition:border-color .15s,color .15s}
.liens-connexes a:hover{border-color:var(--red);color:var(--red2)}
.mots-cles a,.mots-cles span{display:inline-block;padding:7px 14px;border-radius:50px;background:#121216;border:1px solid var(--line);color:var(--mut);font-size:.82rem;transition:border-color .15s,color .15s}
.mots-cles a:hover{border-color:var(--red);color:#fff}
.ligne-mots-cles{margin-top:8px}
.ligne-mots-cles .intitule{display:block;color:#8a8a94;font-family:var(--disp);text-transform:uppercase;font-size:.72rem;letter-spacing:.06em;margin-bottom:14px}
/* ---------- home magazine ---------- */
.une-magazine{display:grid;grid-template-columns:1.7fr 1fr;gap:30px;margin-top:4px}
@media(max-width:840px){.une-magazine{grid-template-columns:1fr}}
.vedette{position:relative;display:block;border-radius:var(--rad);overflow:hidden;height:clamp(330px,33vw,440px);background:#0b0b0e}
.vedette>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s}
.vedette:hover>img{transform:scale(1.04)}
.vedette .calque{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,8,10,.04),rgba(8,8,10,.48) 50%,rgba(8,8,10,.96));display:flex;flex-direction:column;justify-content:flex-end;padding:34px}
.vedette h2{color:#fff;font-size:clamp(1.5rem,3vw,2.15rem);margin:16px 0 11px;line-height:1.06}
.vedette p{color:#dadae0;margin:0;max-width:600px;font-size:1rem;line-height:1.55}
.badge-categorie{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;background:var(--red);color:#fff;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;padding:5px 12px;border-radius:50px;box-shadow:0 4px 14px rgba(225,6,0,.4)}
/* "à la une" : liste à plat, filets fins */
.a-la-une{display:flex;flex-direction:column}
.a-la-une h3{color:#fff;font-size:1.05rem;margin:0 0 6px;letter-spacing:.02em;display:flex;align-items:center;gap:10px}
.a-la-une h3::before{content:"";width:22px;height:3px;background:var(--red);border-radius:3px}
.a-la-une a{display:block;padding:16px 0;border-bottom:1px solid var(--line);color:#fff;font-size:.98rem;line-height:1.3}
.a-la-une a:last-child{border-bottom:0}
.a-la-une a .categorie{display:block;color:var(--red2);font-family:var(--disp);text-transform:uppercase;font-size:.66rem;letter-spacing:.07em;margin-bottom:4px}
.a-la-une a:hover{color:var(--red2)}
/* bandeau de chiffres (filets, sans cadre) */
.chiffres{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px;padding:54px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.chiffre{text-align:center}
.chiffre b{display:block;font-family:var(--disp);font-size:2.1rem;color:#fff;line-height:1}
.chiffre span{color:var(--mut);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin-top:10px;display:block}
/* ---------- page catégorie : 2 colonnes (texte gauche / image droite) ---------- */
.deux-colonnes{display:grid;grid-template-columns:1.05fr .95fr;gap:38px;align-items:center;padding:60px 0 16px}
@media(max-width:760px){.deux-colonnes{grid-template-columns:1fr;gap:22px;padding:34px 0 4px}}
.deux-colonnes .colonne-texte .surtitre{margin-bottom:16px}
.deux-colonnes .colonne-texte h1{font-size:clamp(2rem,4.4vw,3rem);color:#fff;line-height:1.05}
.deux-colonnes .colonne-texte h1 em{color:var(--red2);font-style:normal}
.deux-colonnes .colonne-texte .accroche{color:#c4c4cf;font-size:1.08rem;line-height:1.6;margin:18px 0 0}
.deux-colonnes .colonne-image{border-radius:var(--rad);overflow:hidden;height:clamp(230px,30vw,380px)}
.deux-colonnes .colonne-image img{width:100%;height:100%;object-fit:cover}

/* ========================================================================
   RESPONSIVE MOBILE — tailles de texte + confort tactile (≤680px)
   Les titres en clamp() ont un min calibré desktop : on les borne pour mobile.
   ======================================================================== */
@media(max-width:680px){
  h1.grand-titre{font-size:1.7rem;line-height:1.12}
  .banniere p.accroche{font-size:1rem;margin-top:18px}
  .banniere-contenu{padding:56px 22px 44px}
  .deux-colonnes .colonne-texte h1{font-size:1.6rem}
  .deux-colonnes .colonne-texte .accroche{font-size:1rem}
  .vedette h2{font-size:1.3rem}
  .vedette .calque{padding:20px}
  .titre-section{font-size:1.35rem;margin:0 0 24px}
  .sous-titre{font-size:.95rem;margin:-2px 0 30px}
  .bandeau h2{font-size:1.4rem}
  .fiche h3{font-size:1.18rem}
  .choix h3{font-size:1.1rem}
  .reponse-rapide p{font-size:1rem}
  .paragraphes h3{font-size:1.05rem}
  .carte h3{font-size:1.05rem}
  .univers h3{font-size:1.05rem}
  .univers .icone{font-size:1.4rem}
  .chiffre b{font-size:1.7rem}
  .chiffres{padding:36px 0}
  .logo{font-size:1.2rem}
  summary{font-size:.98rem}
  /* cibles tactiles ≥44px */
  .mots-cles a,.mots-cles span{padding:10px 16px}
  .liens-connexes a{padding:11px 16px}
}

/* ========================================================================
   RESPONSIVE MOBILE — layout serré (≤560px) : grilles 1 col, paddings,
   débordement tableau, hauteurs d'images, largeur utile.
   ======================================================================== */
@media(max-width:560px){
  .conteneur{padding:0 20px}
  section.conteneur{padding-top:32px;padding-bottom:32px}
  .banniere-contenu{padding:52px 20px 40px}
  .bandeau{padding:40px 20px}
  .fiche-corps{padding:20px 18px}
  .pour-contre,.caracteristiques{padding-left:18px;padding-right:18px}
  .verdict,.encart-offre{margin-left:16px;margin-right:16px}
  .vedette .calque{padding:20px}
  .pied{padding:40px 0 28px}
  /* grilles : gaps resserrés à l'empilement */
  .grille-cartes{gap:30px}
  .podium{gap:26px}
  .criteres{gap:22px}
  .grille-univers{gap:22px 16px}
  .chiffres{padding:34px 0;gap:14px}
  .entete-section{flex-wrap:wrap}
  /* hauteurs d'images héro plus compactes */
  .vedette{height:clamp(260px,60vw,330px)}
  .deux-colonnes .colonne-image{height:200px}
  /* tableau comparatif : moins de scroll horizontal */
  table{min-width:560px}
  th,td{padding:11px 10px}
}

/* ========================================================================
   ACCESSIBILITÉ — focus clavier visible (WCAG 2.4.7) + reduced-motion
   ======================================================================== */
a:focus-visible,button:focus-visible,summary:focus-visible,.bouton:focus-visible,
label.hamburger:focus-visible,.menu-fermer:focus-visible,.nav-toggle:focus-visible ~ .hamburger{
  outline:2px solid var(--red2);outline-offset:3px;border-radius:6px}
:focus:not(:focus-visible){outline:none}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ---------- divulgation affiliation (transparence) ---------- */
.divulgation{font-size:.86rem;color:var(--mut);background:#101013;border:1px solid var(--line);border-left:3px solid var(--red);border-radius:10px;padding:12px 16px;margin:0;line-height:1.55;max-width:var(--read)}
.divulgation strong{color:#fff}
.divulgation a{color:var(--red2)}

/* Vidéo façade (iframe YouTube-nocookie chargée au clic — 0 requête tierce au chargement) */
.video-facade{position:relative;aspect-ratio:16/9;border-radius:14px;overflow:hidden;cursor:pointer;background:#0b0b0e;max-width:900px;margin-top:6px}
.video-facade img{width:100%;height:100%;object-fit:cover;display:block;opacity:.82;transition:opacity .25s}
.video-facade:hover img{opacity:1}
.video-facade iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-facade::after{content:"";position:absolute;inset:0;background:rgba(11,11,14,.22);pointer-events:none}
.video-facade .video-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:78px;height:78px;border-radius:999px;background:rgba(225,6,0,.92);z-index:2;transition:transform .2s,background .2s}
.video-facade:hover .video-play{transform:translate(-50%,-50%) scale(1.08);background:#ff2d24}
.video-facade .video-play::before{content:"";position:absolute;left:54%;top:50%;transform:translate(-50%,-50%);width:0;height:0;border-style:solid;border-width:15px 0 15px 24px;border-color:transparent transparent transparent #fff}
.video-facade.is-live::after,.video-facade.is-live .video-play{display:none}
