:root{
  --bg-0:#0a0a14;
  --bg-1:#10101e;
  --bg-2:#171728;
  --bg-3:#1f1f33;
  --line:#2b2b45;
  --gold:#e9b949;
  --gold-2:#f7d774;
  --gold-deep:#c9952f;
  --rose:#e7779b;
  --marble:#f3efe6;
  --txt:#e9e7f2;
  --txt-soft:#b6b3c9;
  --txt-dim:#8a87a0;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;   /* iOS : pas de zoom auto du texte en rotation */
  text-size-adjust:100%;
  scroll-padding-top:78px;          /* ancres non masquées par la topbar sticky */
}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(233,185,73,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 20%, rgba(231,119,155,.08), transparent 55%),
    var(--bg-0);
  color:var(--txt);
  font-family:"Inter","Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
  line-height:1.7;
  font-size:16px;
  overflow-x:hidden;
  -webkit-tap-highlight-color:rgba(233,185,73,.18);  /* retour tactile discret */
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* mots très longs : pas de débordement horizontal sur petits écrans */
p,li,h1,h2,h3,h4,td,th,figcaption,summary{overflow-wrap:break-word;word-break:break-word}
/* blocage du scroll de page quand le menu mobile est ouvert */
body.menu-open{overflow:hidden}
a{color:var(--gold-2);text-decoration:none}
a:hover{color:var(--gold)}
img{max-width:100%;height:auto;display:block}

.serif{font-family:"Cinzel","Playfair Display",Georgia,serif}

.wrap{max-width:1120px;margin:0 auto;padding:0 18px}

/* ===== LAYOUT WITH SIDEBAR ===== */
:root{--sidebar-w:268px}
.layout{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar-w);flex:0 0 var(--sidebar-w);
  position:fixed;top:0;left:0;bottom:0;z-index:60;
  background:linear-gradient(180deg,#0d0d1a,#0a0a14);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  padding:18px 16px;overflow-y:auto;
}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:3px}
.sb-brand{display:flex;justify-content:center;padding:8px 0 18px}
.sb-brand img{height:34px;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.6))}
.sb-promo{
  display:flex;align-items:center;gap:12px;text-decoration:none;
  background:linear-gradient(120deg,#1b3a8f,#2155c7);
  border:1px solid #3f6fe0;border-radius:14px;padding:11px 14px;margin-bottom:18px;
  box-shadow:0 6px 18px rgba(33,85,199,.35);transition:transform .15s ease,box-shadow .15s ease;
}
.sb-promo:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(33,85,199,.5)}
.sb-promo .sb-promo-ico{font-size:24px;flex:0 0 auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}
.sb-promo b{display:block;color:#fff;font-size:14px;line-height:1.2}
.sb-promo span{display:block;color:#cdd9ff;font-size:12px}
.sb-nav{display:flex;flex-direction:column;gap:7px}
.sb-link{
  display:flex;align-items:center;gap:13px;text-decoration:none;
  color:var(--txt-soft);font-weight:700;font-size:15px;
  padding:13px 15px;border-radius:12px;border:1px solid transparent;
  background:rgba(255,255,255,.02);transition:background .15s ease,color .15s ease,border-color .15s ease;
}
.sb-link .sb-ico{font-size:18px;width:22px;text-align:center;flex:0 0 auto}
.sb-link:hover{background:rgba(255,255,255,.05);color:#fff}
.sb-link.active{
  color:#fff;border-color:#2f5bd0;
  background:linear-gradient(120deg,rgba(33,85,199,.28),rgba(20,20,40,.4));
  box-shadow:inset 0 0 0 1px rgba(63,111,224,.25),0 4px 14px rgba(33,85,199,.2);
}
.sb-section-title{color:var(--txt-dim);font-size:12px;letter-spacing:1.2px;text-transform:uppercase;font-weight:700;margin:22px 4px 10px}
.sb-game{display:flex;align-items:center;gap:12px;padding:8px 6px;border-radius:12px;text-decoration:none;transition:background .15s ease}
.sb-game:hover{background:rgba(255,255,255,.04)}
.sb-game .sb-thumb{width:42px;height:42px;border-radius:9px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:18px;border:1px solid var(--line)}
.sb-thumb.g1{background:linear-gradient(135deg,#3a2a10,#6b4a14)}
.sb-thumb.g2{background:linear-gradient(135deg,#1c3320,#2e5a37)}
.sb-thumb.g3{background:linear-gradient(135deg,#2a1830,#5a2c52)}
.sb-game .sb-g-meta{flex:1;min-width:0}
.sb-game .sb-g-meta b{display:block;color:#fff;font-size:13.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-game .sb-g-meta span{display:block;color:var(--txt-dim);font-size:12px}
.sb-game .sb-play{width:26px;height:26px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,var(--gold-2),var(--gold-deep));color:#2a1d05;font-size:11px;box-shadow:0 3px 8px rgba(201,149,47,.4)}
.sb-foot{margin-top:auto;padding-top:18px;display:flex;align-items:center;gap:8px}
.sb-lang{flex:1;display:flex;align-items:center;gap:9px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:9px 12px;color:var(--txt-soft);font-size:13px;font-weight:600}
.sb-lang .flag{width:22px;height:15px;border-radius:3px;background:linear-gradient(90deg,#0055A4 33%,#fff 33% 66%,#EF4135 66%);flex:0 0 auto}
.sb-foot .sb-ibtn{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--bg-2);border:1px solid var(--line);color:var(--txt-soft);font-size:15px;cursor:pointer}

.main-area{flex:1;min-width:0;margin-left:var(--sidebar-w)}

/* topbar inside main */
.topbar{
  position:sticky;top:0;z-index:40;height:64px;
  display:flex;align-items:center;gap:14px;justify-content:space-between;
  padding:0 22px;background:rgba(10,10,20,.85);backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar .tb-search{flex:1;max-width:420px;display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:9px 14px;color:var(--txt-dim);font-size:14px}
.topbar .tb-actions{display:flex;gap:10px;align-items:center}
.sb-toggle{display:none;background:var(--bg-2);border:1px solid var(--line);color:var(--txt);border-radius:9px;padding:8px 11px;font-size:18px;cursor:pointer}
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:55}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,10,20,.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:14px;height:68px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:40px;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
.nav{display:flex;gap:20px;align-items:center}
.nav a{color:var(--txt-soft);font-size:14px;font-weight:500;letter-spacing:.2px}
.nav a:hover{color:var(--gold-2)}
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  background:linear-gradient(180deg,var(--gold-2),var(--gold-deep));
  color:#2a1d05;font-weight:800;border:none;border-radius:10px;
  padding:11px 20px;cursor:pointer;letter-spacing:.3px;
  box-shadow:0 6px 18px rgba(201,149,47,.35);transition:transform .15s ease,box-shadow .15s ease;
  font-size:14px;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(201,149,47,.5);color:#2a1d05}
.btn-ghost{
  background:transparent;border:1px solid var(--gold-deep);color:var(--gold-2);
  box-shadow:none;font-weight:700;
}
.btn-ghost:hover{background:rgba(233,185,73,.08);color:var(--gold-2)}
.menu-toggle{display:none;background:none;border:1px solid var(--line);color:var(--txt);border-radius:8px;padding:8px 10px;font-size:18px}

/* HERO BANNER (image de fond) */
.hero-banner{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--gold-deep);
  margin:22px 0 8px;box-shadow:0 18px 50px rgba(0,0,0,.55)}
.hero-banner img{width:100%;display:block}
.hero-banner .hb-overlay{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:flex-start;
  padding:0 0 18px 0;}
.hero-banner .hb-cta{display:none}
.hero-text{padding:30px 4px 8px}
.hero-text .eyebrow{display:inline-block;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-2);
  border:1px solid var(--gold-deep);border-radius:30px;padding:5px 14px;margin-bottom:16px;background:rgba(233,185,73,.06)}
.hero-text h1{font-size:clamp(28px,4.4vw,46px);line-height:1.12;margin:0 0 14px;color:#fff;font-weight:800}
.hero-text h1 .accent{background:linear-gradient(90deg,var(--gold-2),var(--rose));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-text p.lead{font-size:17px;color:var(--txt-soft);margin:0 0 22px;max-width:680px}
.hero-text .hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* HERO (ancien, conservé pour compat) */
.hero{position:relative;padding:54px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.eyebrow{display:inline-block;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-2);
  border:1px solid var(--gold-deep);border-radius:30px;padding:5px 14px;margin-bottom:18px;background:rgba(233,185,73,.06)}
.hero h1{font-size:clamp(30px,5vw,52px);line-height:1.12;margin:0 0 16px;color:#fff;font-weight:800}
.hero h1 .accent{background:linear-gradient(90deg,var(--gold-2),var(--rose));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:18px;color:var(--txt-soft);margin:0 0 26px;max-width:540px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:22px;margin-top:28px;flex-wrap:wrap}
.hero-badge{display:flex;flex-direction:column}
.hero-badge b{font-size:24px;color:var(--gold-2);font-weight:800}
.hero-badge span{font-size:13px;color:var(--txt-dim)}
.hero-art{position:relative}
.hero-art .frame{
  border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 24px 60px rgba(0,0,0,.55);
}
.hero-art .promo{
  position:absolute;left:-14px;bottom:-14px;background:linear-gradient(180deg,#1a1226,#120c1d);
  border:1px solid var(--gold-deep);border-radius:14px;padding:12px 16px;box-shadow:0 12px 30px rgba(0,0,0,.5)}
.hero-art .promo b{display:block;color:var(--gold-2);font-size:22px;font-weight:800;line-height:1}
.hero-art .promo span{font-size:12px;color:var(--txt-soft)}

/* QUICK FACTS */
.quickfacts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:30px}
.qf{background:linear-gradient(180deg,var(--bg-2),var(--bg-1));border:1px solid var(--line);border-radius:14px;padding:18px 16px;text-align:center;position:relative;overflow:hidden}
.qf::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--gold-2),var(--rose))}
.qf .qf-ico{font-size:20px;color:var(--gold-2);margin-bottom:8px}
.qf b{display:block;color:#fff;font-size:20px;font-weight:800;line-height:1.1}
.qf span{display:block;color:var(--txt-dim);font-size:12.5px;margin-top:5px}

/* SECTIONS */
section{padding:46px 0;border-top:1px solid rgba(43,43,69,.6)}
.section-head{margin-bottom:24px;max-width:760px}
.section-head h2{font-size:clamp(24px,3.4vw,34px);margin:0 0 10px;color:#fff;font-weight:800}
.section-head .kicker{color:var(--gold-2);font-size:13px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;display:block;margin-bottom:8px}
.section-head p{color:var(--txt-soft);margin:0;font-size:16px}
.prose p{color:var(--txt-soft);margin:0 0 16px}
.prose strong{color:var(--marble)}

/* LISTS */
ul.feat{list-style:none;padding:0;margin:18px 0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
ul.feat li{position:relative;padding:12px 14px 12px 42px;background:var(--bg-1);border:1px solid var(--line);border-radius:12px;color:var(--txt-soft);font-size:15px}
ul.feat li::before{content:"";position:absolute;left:14px;top:15px;width:16px;height:16px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--gold-2),var(--gold-deep));box-shadow:0 0 0 3px rgba(233,185,73,.12)}
ul.feat li b{color:var(--marble)}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.card{background:linear-gradient(180deg,var(--bg-2),var(--bg-1));border:1px solid var(--line);border-radius:16px;padding:22px;transition:transform .18s ease,border-color .18s ease}
.card:hover{transform:translateY(-4px);border-color:var(--gold-deep)}
.card .ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;
  background:rgba(233,185,73,.1);color:var(--gold-2);margin-bottom:14px;border:1px solid var(--gold-deep)}
.card h3{margin:0 0 8px;color:#fff;font-size:18px}
.card p{margin:0;color:var(--txt-soft);font-size:14.5px}

/* TABLE */
.table-wrap{
  overflow-x:auto;border:1px solid var(--line);border-radius:14px;margin:22px 0;
  -webkit-overflow-scrolling:touch;            /* défilement fluide sur iOS */
  scrollbar-width:thin;
  /* ombres latérales : indiquent que la table peut se faire glisser */
  background:
    linear-gradient(90deg, var(--bg-1) 30%, transparent),
    linear-gradient(90deg, transparent, var(--bg-1) 70%) 100% 0,
    radial-gradient(farthest-side at 0 50%, rgba(0,0,0,.4), transparent),
    radial-gradient(farthest-side at 100% 50%, rgba(0,0,0,.4), transparent) 100% 0;
  background-repeat:no-repeat;
  background-size:40px 100%,40px 100%,14px 100%,14px 100%;
  background-attachment:local,local,scroll,scroll;
}
.table-wrap::-webkit-scrollbar{height:7px}
.table-wrap::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:4px}
table{width:100%;border-collapse:collapse;min-width:460px;font-size:15px}
caption{caption-side:top;text-align:left;color:var(--txt-dim);font-size:13px;padding:12px 16px 0;font-style:italic}
th,td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line)}
thead th{background:rgba(233,185,73,.07);color:var(--gold-2);font-weight:700;text-transform:uppercase;font-size:12.5px;letter-spacing:.5px}
tbody tr:nth-child(even){background:rgba(255,255,255,.015)}
tbody tr:hover{background:rgba(233,185,73,.05)}
td b{color:var(--marble)}
.table-note{font-size:13px;color:var(--txt-dim);font-style:italic;margin:-8px 0 20px;line-height:1.5}

/* BANNER BLOCK */
.banner-block{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--gold-deep);margin:8px 0;box-shadow:0 18px 44px rgba(0,0,0,.5)}
.banner-block img{width:100%;display:block}
.banner-cta{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:0 6%;
  background:linear-gradient(90deg,rgba(8,8,16,.78) 0%,rgba(8,8,16,.35) 55%,transparent 100%)}
.banner-cta h3{margin:0 0 6px;font-size:clamp(20px,3vw,30px);color:#fff;max-width:60%}
.banner-cta p{margin:0 0 14px;color:var(--txt-soft);max-width:54%}

/* PROMO BLOCK (sans image) */
.promo-strip{position:relative;overflow:hidden;border-radius:18px;border:1px solid var(--gold-deep);
  background:
    radial-gradient(600px 200px at 85% 0%, rgba(231,119,155,.18), transparent 60%),
    linear-gradient(120deg,#1c1430 0%,#120c1d 60%,#14101f 100%);
  padding:34px 38px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  box-shadow:0 18px 44px rgba(0,0,0,.5)}
.promo-strip::before{content:"";position:absolute;right:-40px;top:-40px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(233,185,73,.22),transparent 65%);pointer-events:none}
.promo-strip .ps-left{display:flex;align-items:center;gap:22px;min-width:260px}
.promo-strip .ps-amount{font-family:"Cinzel",Georgia,serif;font-size:clamp(42px,7vw,64px);font-weight:800;line-height:.9;
  background:linear-gradient(180deg,var(--gold-2),var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 2px 18px rgba(233,185,73,.25)}
.promo-strip .ps-text h3{margin:0 0 4px;color:#fff;font-size:20px}
.promo-strip .ps-text p{margin:0;color:var(--txt-soft);font-size:14.5px}

/* SCREEN SHOT */
.shot{border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 18px 40px rgba(0,0,0,.5)}

/* FAQ */
.faq details{background:var(--bg-1);border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 18px;font-weight:600;color:#fff;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-2);font-size:22px;font-weight:700;transition:transform .2s}
.faq details[open] summary::after{content:"\2212"}
.faq details p{padding:0 18px 16px;margin:0;color:var(--txt-soft)}

/* STEPS */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:8px}
.step{background:var(--bg-1);border:1px solid var(--line);border-radius:14px;padding:20px 18px;position:relative}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-14px;left:18px;width:32px;height:32px;border-radius:50%;
  background:linear-gradient(180deg,var(--gold-2),var(--gold-deep));color:#2a1d05;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:15px}
.step h4{margin:10px 0 6px;color:#fff;font-size:16px}
.step p{margin:0;color:var(--txt-soft);font-size:14px}

/* CTA STRIP */
.cta-strip{background:linear-gradient(120deg,#1a1226,#120c1d);border:1px solid var(--gold-deep);border-radius:18px;padding:34px;text-align:center;margin:8px 0}
.cta-strip h2{margin:0 0 10px;color:#fff;font-size:clamp(22px,3.4vw,32px)}
.cta-strip p{margin:0 0 20px;color:var(--txt-soft);max-width:600px;margin-left:auto;margin-right:auto}

/* PROS/CONS */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
.pc .box{border:1px solid var(--line);border-radius:14px;padding:20px;background:var(--bg-1)}
.pc .box.pos{border-color:rgba(120,200,140,.4)}
.pc .box.neg{border-color:rgba(220,120,120,.35)}
.pc h4{margin:0 0 12px;color:#fff;font-size:17px;display:flex;align-items:center;gap:8px}
.pc ul{margin:0;padding-left:20px;color:var(--txt-soft)}
.pc ul li{margin-bottom:8px}

/* FOOTER */
.site-footer{border-top:1px solid var(--line);background:var(--bg-1);padding:40px 0 28px;margin-top:30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.foot-grid h5{color:#fff;margin:0 0 14px;font-size:15px;text-transform:uppercase;letter-spacing:.6px}
.foot-grid a{display:block;color:var(--txt-soft);font-size:14px;margin-bottom:9px}
.foot-grid p{color:var(--txt-dim);font-size:13.5px;margin:0 0 12px}
.foot-bottom{border-top:1px solid var(--line);margin-top:28px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--txt-dim);font-size:13px;align-items:center}
.age-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:30px;padding:4px 12px;color:var(--txt-soft);font-size:12.5px}
.age-badge .ico18{width:24px;height:24px;border-radius:50%;background:#b23a48;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}

/* ============================================================
   RESPONSIVE — système de points de rupture mobile-first
   ============================================================ */

/* ---- ≤1000px : sidebar coulissante (tablette / mobile) ---- */
@media (max-width:1000px){
  .sidebar{transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 40px rgba(0,0,0,.6);width:min(86vw,300px);flex-basis:min(86vw,300px)}
  .sidebar.open{transform:translateX(0)}
  .main-area{margin-left:0}
  .sb-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}
  .sb-overlay.show{display:block}
  .nav{display:none}                 /* nav d'en-tête masquée, menu = sidebar */
}

/* ---- ≤900px : grilles à 2/1 colonnes ---- */
@media (max-width:900px){
  .quickfacts{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr}
  ul.feat{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .pc{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero-grid{grid-template-columns:1fr;gap:24px}
  section{padding:38px 0}
  .promo-strip{padding:26px 22px}
  .cta-strip{padding:28px 22px}
  .banner-cta h3{max-width:80%;font-size:clamp(18px,4.2vw,26px)}
  .banner-cta p{max-width:78%}
}

/* ---- ≤680px : passage mobile « plein écran » ---- */
@media (max-width:680px){
  body{font-size:15.5px}
  .wrap{padding:0 14px}
  section{padding:30px 0}
  .section-head{margin-bottom:18px}
  .topbar{height:58px;padding:0 14px;gap:10px}
  .topbar .tb-search{display:none}
  .topbar .tb-actions{gap:8px}
  .topbar .tb-actions .btn-ghost{display:none}
  .topbar .tb-actions .btn{padding:10px 16px;font-size:13.5px}
  .hero-text{padding:18px 0 4px}
  .hero-text p.lead{font-size:15.5px}
  .quickfacts{gap:10px;margin-top:22px}
  .qf{padding:14px 10px}
  .qf b{font-size:17px}
  .qf span{font-size:11.5px}
  .cards{gap:14px}
  .card{padding:18px}
  .foot-grid{grid-template-columns:1fr;gap:22px}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:10px}
  /* tables compactes mais lisibles */
  table{min-width:0;font-size:14px}
  th,td{padding:10px 12px}
  thead th{font-size:11.5px}
  caption{font-size:12.5px;padding:10px 12px 0}
  .promo-strip{padding:22px 18px;text-align:center;justify-content:center}
  .promo-strip .ps-left{flex-direction:column;text-align:center;min-width:0;gap:12px}
  .cta-strip{padding:24px 18px}
  /* CTA fluides : pleine largeur, faciles à toucher */
  .hero-cta,.cta-strip .btn,.banner-cta{align-items:stretch}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .btn{padding:13px 20px;min-height:46px}
  .related-links a{min-height:42px}
  .faq summary{padding:14px 16px;min-height:48px}
}

/* ---- ≤480px : très petits écrans ---- */
@media (max-width:480px){
  .quickfacts{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .section-head h2{font-size:clamp(21px,6vw,26px)}
  .banner-cta{position:static;background:none;padding:14px 0 0}
  .banner-cta h3,.banner-cta p{max-width:100%}
  .sb-brand img{height:30px}
}

/* ---- ≤380px : iPhone SE / petits Android ---- */
@media (max-width:380px){
  body{font-size:15px}
  .wrap{padding:0 12px}
  .quickfacts{grid-template-columns:1fr}
  .topbar .tb-actions .btn{padding:9px 13px;font-size:13px}
  ul.feat li{padding:11px 12px 11px 38px;font-size:14px}
}

/* ---- paysage mobile court : on réduit les hauteurs ---- */
@media (max-height:480px) and (orientation:landscape){
  .topbar{height:52px}
  section{padding:24px 0}
  .sidebar{padding:12px 14px}
}

/* ---- confort tactile : cibles ≥44px sur appareils sans survol ---- */
@media (hover:none){
  .sb-link{padding:14px 15px}
  .sb-ibtn{width:44px;height:44px}
  .nav a{padding:6px 2px}
  .foot-grid a{padding:4px 0;min-height:34px}
  .card:hover,.btn:hover,.sb-promo:hover{transform:none}  /* pas d'effet hover « collant » au tap */
}

/* ============ BANNERS / VISUELS (images intégrales, sans rognage) ============ */
.banner-figure{margin:0;padding:0}
.banner-figure img{
  display:block;width:100%;height:auto;       /* image entière, jamais coupée */
  border-radius:16px;
  border:1px solid rgba(212,175,110,.22);
  box-shadow:0 14px 40px rgba(0,0,0,.45);
  background:#0a0a14;
}
.banner-figure figcaption{
  margin-top:10px;color:var(--muted,#9aa0b5);
  font-size:13.5px;text-align:center;
}
/* Bandeau d'atouts (image large 7.5:1) */
.banner-strip{margin:18px 0 2px}
/* Visuels de catalogue : pleine largeur du contenu */
.banner-catalog{margin-top:6px}
/* Visuels de compte (bonus / inscription / connexion) */
.account-visuals{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start;
}
.account-visuals .banner-figure img{border-color:rgba(232,138,42,.28)}
@media (max-width:900px){
  .account-visuals{grid-template-columns:1fr}
}

/* ============ PAGES INTERNES (légales + guides) ============ */
.legal-page{padding:26px 0 10px}
.crumbs{font-size:13px;color:var(--muted,#9aa0b5);margin:6px 0 22px;display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.crumbs a{color:var(--muted,#9aa0b5);text-decoration:none}
.crumbs a:hover{color:#e8a85a;text-decoration:underline}
.crumb-sep{opacity:.5}
.crumb-cur{color:#d6c08a}

.page-head{max-width:820px;margin-bottom:8px}
.page-head .kicker{display:inline-block;font-family:'Cinzel',serif;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#e8a85a;margin-bottom:10px}
.page-head h1{font-family:'Cinzel',serif;font-size:clamp(28px,4.4vw,42px);line-height:1.12;margin:0 0 14px;color:#f4ecd8}
.page-head .page-lead{font-size:17px;line-height:1.6;color:#c8cce0;margin:0 0 8px}
.page-head .updated{font-size:13px;color:var(--muted,#9aa0b5);margin:6px 0 0}

.legal-page .prose{max-width:820px}
.legal-page .prose h2{font-family:'Cinzel',serif;font-size:23px;color:#f4ecd8;margin:32px 0 12px;padding-top:14px;border-top:1px solid rgba(212,175,110,.14)}
.legal-page .prose h3{font-size:18px;color:#f0e6cf;margin:6px 0 8px}
.legal-page .prose p{line-height:1.72;margin:0 0 14px}
.legal-page .prose a{color:#e8a85a}
.legal-page .prose a:hover{text-decoration:underline}

/* listes ordonnées "étapes" */
ol.steps-num{counter-reset:st;list-style:none;padding:0;margin:14px 0 4px;display:grid;gap:10px}
ol.steps-num li{position:relative;padding:12px 14px 12px 50px;background:rgba(255,255,255,.03);border:1px solid rgba(212,175,110,.14);border-radius:12px;line-height:1.55}
ol.steps-num li::before{counter-increment:st;content:counter(st);position:absolute;left:12px;top:11px;width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#e88a2a,#c25e12);color:#fff;font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center}

/* encadré conseil */
.callout{background:rgba(232,138,42,.08);border:1px solid rgba(232,138,42,.3);border-left:3px solid #e88a2a;border-radius:12px;padding:14px 16px;line-height:1.6}

/* pages liées (maillage interne) */
.related{max-width:820px;margin:34px 0 6px;padding-top:18px;border-top:1px solid rgba(212,175,110,.14)}
.related h2{font-family:'Cinzel',serif;font-size:18px;color:#f0e6cf;margin:0 0 14px}
.related-links{display:flex;flex-wrap:wrap;gap:10px}
.related-links a{display:inline-flex;align-items:center;padding:9px 14px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(212,175,110,.2);color:#d6c08a;text-decoration:none;font-size:14px;font-weight:600;transition:.15s}
.related-links a:hover{background:rgba(212,175,110,.12);border-color:rgba(212,175,110,.4)}
.related-links a.rel-cta{background:linear-gradient(135deg,#e88a2a,#c25e12);border-color:transparent;color:#fff}

/* formulaire de contact */
.contact-form{max-width:640px;display:grid;gap:14px;margin-top:6px}
.contact-form .cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:#c8cce0}
.contact-form input,.contact-form textarea{font:inherit;font-weight:400;padding:11px 13px;border-radius:10px;border:1px solid rgba(212,175,110,.22);background:rgba(10,10,20,.6);color:#f4ecd8}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#e88a2a;box-shadow:0 0 0 3px rgba(232,138,42,.18)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#6b7088}
.contact-form button{justify-self:start;margin-top:4px}
.contact-form .cf-note{font-size:12.5px;color:var(--muted,#9aa0b5);margin:0}
.contact-form .cf-note a{color:#e8a85a}

@media (max-width:680px){
  .contact-form .cf-row{grid-template-columns:1fr}
  .legal-page{padding:18px 0 6px}
}
