/* =========================================================
   Dice Palace - feuille de style
   Convention : prefixe dp-* uniquement.
   ========================================================= */

:root{
  --dp-cream:#f4e5c8;
  --dp-cream-soft:#fbf2dd;
  --dp-cream-deep:#e8d3a8;
  --dp-wood:#6b3b15;
  --dp-wood-deep:#3d1f06;
  --dp-fire:#ee3e1a;
  --dp-fire-deep:#b22a0e;
  --dp-gold:#f4ba1d;
  --dp-gold-deep:#c98b00;
  --dp-azure:#1f6db5;
  --dp-azure-deep:#0f4a86;
  --dp-night:#22150a;
  --dp-ash:#7a6750;
  --dp-cloud:#ffffff;
  --dp-leaf:#3aa861;
  --dp-shadow:0 6px 14px rgba(61,31,6,.18);
  --dp-shadow-strong:0 14px 30px rgba(61,31,6,.28);
  --dp-radius-s:10px;
  --dp-radius-m:18px;
  --dp-radius-l:28px;
  --dp-font-head:"Fredoka","Baloo 2","Quicksand",system-ui,sans-serif;
  --dp-font-body:"Nunito","Quicksand",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--dp-font-body);
  color:var(--dp-night);
  background:var(--dp-cream);
  background-image:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(31,109,181,.18), transparent 60%),
    radial-gradient(ellipse 80% 60% at 50% 110%, rgba(244,186,29,.16), transparent 60%);
  line-height:1.55;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--dp-azure-deep);text-decoration:none}
a:hover{color:var(--dp-fire-deep)}
h1,h2,h3,h4{font-family:var(--dp-font-head);color:var(--dp-wood-deep);font-weight:700;line-height:1.15;letter-spacing:.01em}
h1{font-size:clamp(28px,4vw,44px)}
h2{font-size:clamp(22px,3vw,32px);margin:0 0 16px}
h3{font-size:clamp(18px,2.2vw,22px);margin:0 0 12px}
p{margin:0 0 14px}

/* ---------- conteneur principal ---------- */
.dp-page{max-width:1280px;margin:0 auto;padding:0 18px}
.dp-shell{padding:32px 0}
.dp-shell--tight{padding:18px 0}

/* ---------- bandeau haut (header) ---------- */
.dp-crown-bar{
  background:linear-gradient(180deg,#fff8e7 0%, #f0dfb6 100%);
  border-bottom:3px solid var(--dp-gold);
  position:sticky;top:0;z-index:50;
  box-shadow:0 2px 10px rgba(0,0,0,.08);
}
.dp-crown-bar__row{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 18px;max-width:1280px;margin:0 auto;gap:18px;
}
.dp-crown-bar__brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.dp-crown-bar__brand img{height:96px;width:auto;display:block}
.dp-crown-bar__nav{display:flex;gap:22px;flex:1;justify-content:center;flex-wrap:wrap}
.dp-crown-bar__nav a{
  color:var(--dp-wood-deep);font-weight:700;font-size:17px;
  padding:8px 4px;border-bottom:3px solid transparent;transition:border .2s;
  white-space:nowrap;
}
.dp-crown-bar__nav a:hover{border-bottom-color:var(--dp-fire)}
.dp-crown-bar__cta{display:flex;gap:10px;align-items:center;flex-shrink:0}

.dp-crown-bar__nav-mobonly{display:none}
.dp-crown-bar__cta-desktop{display:inline-flex}

/* bouton burger (mobile only) */
.dp-burger{
  display:none;
  width:46px;height:46px;border:2px solid var(--dp-wood-deep);
  background:#fff8e7;
  padding:10px 8px;cursor:pointer;border-radius:10px;
  flex-direction:column;justify-content:space-between;align-items:stretch;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
}
.dp-burger span{
  display:block;width:100%;height:3px;
  background:var(--dp-wood-deep);border-radius:2px;
  transition:transform .25s, opacity .2s;
}
.dp-burger--open span:nth-child(1){transform:translateY(11px) rotate(45deg)}
.dp-burger--open span:nth-child(2){opacity:0}
.dp-burger--open span:nth-child(3){transform:translateY(-11px) rotate(-45deg)}

@media (max-width:1100px){
  .dp-crown-bar__nav{gap:14px}
  .dp-crown-bar__nav a{font-size:15px}
}
@media (max-width:980px){
  /* burger visible + nav cachee par defaut, devient un dropdown plein largeur */
  .dp-burger{display:flex;order:3;margin-left:4px}
  .dp-crown-bar__brand{order:1}
  .dp-crown-bar__cta{order:2}
  .dp-crown-bar__brand img{height:64px}
  .dp-crown-bar__cta-desktop{display:none !important}
  .dp-crown-bar__nav-mobonly{display:block}
  .dp-crown-bar__nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;background:#fff8e7;
    border-top:3px solid var(--dp-gold);box-shadow:0 8px 18px rgba(0,0,0,.18);
    padding:8px 16px;gap:0;z-index:60;
  }
  .dp-crown-bar__nav--open{display:flex}
  .dp-crown-bar__nav a{
    border-bottom:1px solid var(--dp-cream-deep);padding:14px 8px;
    font-size:16px;width:100%;text-align:left;
  }
  .dp-crown-bar__nav a:last-child{border-bottom:none}
  .dp-crown-bar__row{position:relative;gap:10px;padding:8px 14px;justify-content:flex-start}
  .dp-crown-bar__brand{margin-right:auto}
}
@media (max-width:520px){
  .dp-crown-bar__brand img{height:52px}
  .dp-crown-bar__cta .dp-btn{padding:9px 14px;font-size:13px}
}

/* ---------- boutons ---------- */
.dp-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;border-radius:999px;font-weight:700;font-family:var(--dp-font-head);
  font-size:15px;text-transform:uppercase;letter-spacing:.04em;
  border:none;cursor:pointer;transition:transform .15s, box-shadow .2s;
  text-decoration:none;
}
.dp-btn--flame{
  background:linear-gradient(180deg,#ff6a3a 0%, #d52a0a 100%);
  color:#fff;
  box-shadow:0 4px 0 #8a1d04, 0 8px 16px rgba(213,42,10,.4);
  border:2px solid #ffd8b0;
}
.dp-btn--flame:hover{transform:translateY(-2px);color:#fff}
.dp-btn--ghost{
  background:transparent;color:var(--dp-wood-deep);border:2px solid var(--dp-wood);
  padding:10px 18px;
}
.dp-btn--ghost:hover{background:var(--dp-wood);color:#fff}
.dp-btn--royal{
  background:linear-gradient(180deg,#3d9adf 0%, #185196 100%);
  color:#fff;
  box-shadow:0 4px 0 #0c3361, 0 8px 16px rgba(15,74,134,.35);
  border:2px solid #c5e0f7;
}
.dp-btn--royal:hover{transform:translateY(-2px);color:#fff}
.dp-btn--gilded{
  background:linear-gradient(180deg,#ffd665 0%, #d99a0d 100%);
  color:var(--dp-wood-deep);
  box-shadow:0 3px 0 #8a5a02, 0 6px 12px rgba(217,154,13,.35);
  border:2px solid #fff1c2;
}
.dp-btn--gilded:hover{transform:translateY(-2px)}

/* ---------- hero boxé (image entière, scale-down) ---------- */
.dp-grand-hall{
  position:relative;
  max-width:1380px;
  margin:14px auto 0;
  overflow:hidden;
  border-radius:22px;
  border:3px solid var(--dp-gold);
  box-shadow:var(--dp-shadow-strong);
  background:#1f6db5;
}
.dp-grand-hall__art{
  display:block;width:100%;height:auto;
  object-fit:contain;
}
.dp-grand-hall__art--desktop{display:block}
.dp-grand-hall__art--mobile{display:none}
@media (max-width:720px){
  .dp-grand-hall__art--desktop{display:none}
  .dp-grand-hall__art--mobile{display:block;max-height:none}
}

/* panneau bonus pose a cote de la mascotte */
.dp-grand-hall__offer{
  position:absolute;
  top:65%;left:73%;transform:translate(-50%,-50%);
  background:linear-gradient(180deg,#fff7e0 0%, #f6d987 100%);
  border:3px solid var(--dp-gold);
  border-radius:var(--dp-radius-m);
  padding:10px 26px;text-align:center;
  box-shadow:0 10px 24px rgba(0,0,0,.42);
  max-width:380px;width:380px;
  z-index:2;
}
.dp-grand-hall__offer-h1{
  font-family:var(--dp-font-head);font-size:clamp(20px,1.9vw,24px);
  color:var(--dp-wood-deep);font-weight:800;line-height:1.1;
  margin:0 0 6px;letter-spacing:.02em;
  text-shadow:0 1px 0 rgba(255,255,255,.6);
}
.dp-grand-hall__offer-rib{
  display:inline-block;background:var(--dp-fire);color:#fff;
  padding:3px 13px;border-radius:999px;font-weight:700;font-size:11px;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px;
}
.dp-grand-hall__offer-sum{
  font-family:var(--dp-font-head);font-size:clamp(19px,2vw,26px);
  color:var(--dp-fire-deep);font-weight:800;line-height:1.1;
  margin-bottom:2px;
}
.dp-grand-hall__offer-spins{
  font-family:var(--dp-font-head);font-size:clamp(13px,1.3vw,16px);
  color:var(--dp-wood-deep);font-weight:700;margin-bottom:8px;
}
.dp-grand-hall__offer-cta{
  width:100%;font-size:15px;padding:9px 18px;
}
.dp-grand-hall__offer-fine{
  display:block;font-size:10.5px;line-height:1.25;margin-top:6px;
}
.dp-grand-hall__offer-fine{
  display:block;font-size:11px;color:var(--dp-wood);
  margin-top:10px;line-height:1.3;
}
@media (max-width:980px){
  .dp-grand-hall__offer{left:60%;max-width:300px;width:auto;padding:10px 18px}
  .dp-grand-hall__offer-sum{font-size:18px}
}
@media (max-width:720px){
  .dp-grand-hall{
    max-width:none;margin:0;border-radius:0;border:none;border-bottom:4px solid var(--dp-gold);
  }
  /* banniere mobile : hauteur adaptee, on garde le haut (logo + castle) */
  .dp-grand-hall__art--mobile{
    max-height:560px;object-fit:cover;object-position:center 70%;
  }
  /* panneau bonus overlay en milieu de banniere style aquaspins */
  .dp-grand-hall__offer{
    position:absolute;top:27%;left:60%;bottom:auto;
    transform:translate(-50%,-50%);
    width:calc(100% - 28px);max-width:320px;
    padding:14px 18px;
    box-shadow:0 8px 22px rgba(0,0,0,.55);
  }
  .dp-grand-hall__offer-h1{font-size:18px;margin-bottom:4px}
  .dp-grand-hall__offer-rib{font-size:10px;padding:3px 11px;margin-bottom:4px}
  .dp-grand-hall__offer-sum{font-size:21px;margin-bottom:2px}
  .dp-grand-hall__offer-spins{font-size:13px;margin-bottom:8px}
  .dp-grand-hall__offer-cta{font-size:14px;padding:9px 16px}
  .dp-grand-hall__offer-fine{font-size:10px;margin-top:5px}
}
@media (max-width:520px){
  .dp-grand-hall__art--mobile{max-height:480px}
  .dp-grand-hall__offer{max-width:290px;padding:12px 14px;top:25%;left:60%}
  .dp-grand-hall__offer-h1{font-size:16px;margin-bottom:3px}
  .dp-grand-hall__offer-sum{font-size:19px}
  .dp-grand-hall__offer-spins{font-size:12px}
  .dp-grand-hall__offer-cta{font-size:13px;padding:8px 14px}
}
@media (max-width:380px){
  .dp-grand-hall__art--mobile{max-height:420px}
  .dp-grand-hall__offer{max-width:260px;padding:10px 12px}
  .dp-grand-hall__offer-sum{font-size:17px}
}

/* ---------- ruban d'entrees rapides (categories) ---------- */
.dp-portal{
  display:grid;grid-template-columns:repeat(7,1fr);gap:14px;margin:34px 0;
}
.dp-portal__door{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:14px 8px;border-radius:var(--dp-radius-m);
  background:var(--dp-cream-soft);border:2px solid transparent;
  text-decoration:none;transition:transform .15s, border .15s, background .2s;
}
.dp-portal__door:hover{
  transform:translateY(-3px);border-color:var(--dp-gold);
  background:#fff;
}
.dp-portal__door img{
  width:64px;height:64px;object-fit:contain;object-position:center;display:block;
}
.dp-portal__door span{
  font-weight:700;font-size:13px;color:var(--dp-wood-deep);
  text-align:center;font-family:var(--dp-font-head);
}
@media (max-width:980px){
  .dp-portal{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:720px){
  /* Scroll horizontal type tiles de jeux */
  .dp-portal{
    display:grid;grid-auto-flow:column;grid-auto-columns:108px;grid-template-columns:none;
    overflow-x:auto;gap:10px;padding-bottom:10px;
    scroll-snap-type:x mandatory;
    scrollbar-color:var(--dp-gold) var(--dp-cream);
  }
  .dp-portal::-webkit-scrollbar{height:8px}
  .dp-portal::-webkit-scrollbar-thumb{background:var(--dp-gold);border-radius:8px}
  .dp-portal__door{scroll-snap-align:start;padding:12px 6px;gap:6px}
  .dp-portal__door img{width:54px;height:54px}
  .dp-portal__door span{font-size:12px}
}

/* ---------- bandeaux de jeux (sections horizontales) ---------- */
.dp-quest{margin:38px 0}
.dp-quest__head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;gap:12px;
}
.dp-quest__head h2{margin:0}
.dp-quest__more{
  font-weight:700;color:var(--dp-fire-deep);font-size:14px;
  text-transform:uppercase;letter-spacing:.06em;
}
.dp-quest__rail{
  display:grid;grid-auto-flow:column;grid-auto-columns:160px;
  gap:14px;overflow-x:auto;padding-bottom:8px;
  scroll-snap-type:x mandatory;scrollbar-color:var(--dp-gold) var(--dp-cream);
}
.dp-quest__rail--wide{grid-auto-columns:220px}
.dp-quest__rail--tall{grid-auto-columns:160px}
.dp-quest__rail::-webkit-scrollbar{height:10px}
.dp-quest__rail::-webkit-scrollbar-thumb{background:var(--dp-gold);border-radius:10px}

.dp-card-game{
  scroll-snap-align:start;
  background:#fff;border-radius:var(--dp-radius-s);overflow:hidden;
  box-shadow:var(--dp-shadow);position:relative;
  transition:transform .2s;
}
.dp-card-game:hover{transform:translateY(-4px)}
.dp-card-game img{width:100%;height:auto;aspect-ratio:2/3;object-fit:cover}
.dp-card-game--wide img{aspect-ratio:3/2}
.dp-card-game__tag{
  position:absolute;top:8px;left:8px;
  background:var(--dp-fire);color:#fff;font-size:11px;
  padding:3px 8px;border-radius:6px;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;
}
.dp-card-game__tag--gold{background:var(--dp-gold);color:var(--dp-wood-deep)}
.dp-card-game__tag--royal{background:var(--dp-azure)}
.dp-card-game__caption{
  padding:8px 10px;font-size:13px;font-weight:600;color:var(--dp-wood-deep);
  display:flex;justify-content:space-between;align-items:center;gap:6px;
}
.dp-card-game__caption span:last-child{
  color:var(--dp-ash);font-size:11px;font-weight:500;text-transform:uppercase;
}

/* ---------- variante : tile Live Casino (numerotee + studio) ---------- */
.dp-card-live{
  scroll-snap-align:start;
  background:#fff;border-radius:var(--dp-radius-s);overflow:hidden;
  box-shadow:var(--dp-shadow);position:relative;
  transition:transform .2s;text-decoration:none;
}
.dp-card-live:hover{transform:translateY(-4px)}
.dp-card-live__media{position:relative}
.dp-card-live__media img{
  width:100%;height:auto;aspect-ratio:1/1.75;object-fit:cover;display:block;
}
.dp-card-live__num{
  position:absolute;top:8px;left:8px;z-index:2;
  background:rgba(20,10,4,.78);color:#ffd76a;
  font-family:var(--dp-font-head);font-weight:700;font-size:13px;
  padding:3px 8px;border-radius:6px;letter-spacing:.06em;
  border:1px solid rgba(244,186,29,.5);
}
.dp-card-live__body{padding:10px 12px 12px}
.dp-card-live__title{
  display:block;font-weight:700;font-size:14px;color:var(--dp-wood-deep);
  line-height:1.25;
}
.dp-card-live__studio{
  display:block;margin-top:4px;font-size:11px;color:var(--dp-ash);
  font-weight:600;letter-spacing:.08em;text-transform:uppercase;
}

/* rail live : 7 colonnes desktop pour plus de tiles visibles */
.dp-quest__rail--live{
  grid-auto-columns:minmax(140px, 1fr);grid-auto-flow:column;
}

/* ---------- panneau de bonus ---------- */
.dp-vault{
  margin:40px 0;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
@media (max-width:880px){.dp-vault{grid-template-columns:1fr}}
.dp-vault__chest{
  background:linear-gradient(180deg,#fffaee 0%, #f7e7c2 100%);
  border:3px solid var(--dp-gold);border-radius:var(--dp-radius-m);
  padding:22px;text-align:center;position:relative;
  box-shadow:var(--dp-shadow);
}
.dp-vault__chest--feature{
  background:linear-gradient(180deg,#2a6fb0 0%, #143f6b 100%);
  border-color:var(--dp-gold);color:#fff;
}
.dp-vault__chest--feature h3{color:#ffe06a}
.dp-vault__chest--feature p{color:#e9f1fc}
.dp-vault__chest img{
  width:96px;height:96px;object-fit:contain;display:block;margin:0 auto 12px;
}
.dp-vault__chest h3{margin:0 0 10px}
.dp-vault__chest .dp-vault__sum{
  font-family:var(--dp-font-head);font-weight:800;font-size:26px;
  color:var(--dp-fire-deep);display:block;margin:6px 0 12px;
}
.dp-vault__chest--feature .dp-vault__sum{color:#ffe06a}

/* ---------- table & fournisseurs ---------- */
.dp-providers{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
  padding:20px;background:#fff;border-radius:var(--dp-radius-m);
  border:2px solid var(--dp-cream-deep);
}
.dp-providers__chip{
  padding:14px 10px;text-align:center;font-weight:700;
  color:var(--dp-wood-deep);background:var(--dp-cream-soft);
  border-radius:var(--dp-radius-s);font-size:14px;letter-spacing:.02em;
  border:1px solid var(--dp-cream-deep);
}
@media (max-width:880px){.dp-providers{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.dp-providers{grid-template-columns:repeat(2,1fr)}}

/* ---------- programme VIP (la cour royale) ---------- */
.dp-court{
  background:linear-gradient(180deg,#1a4978 0%, #0d2c4f 100%);
  border-radius:var(--dp-radius-l);padding:32px;color:#fff;
  border:4px solid var(--dp-gold);
}
.dp-court h2{color:#ffe06a}
.dp-court__grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:18px;
}
.dp-court__rank{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,224,106,.4);
  border-radius:var(--dp-radius-s);padding:18px 12px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.dp-court__rank-badge{
  width:auto;height:130px;object-fit:contain;display:block;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.35));
}
.dp-court__rank-perk{font-size:13px;color:#cfdcec;margin-top:6px}
@media (max-width:780px){.dp-court__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){
  .dp-court{padding:22px 16px}
  .dp-court__grid{grid-template-columns:1fr;gap:14px}
  .dp-court__rank{padding:16px 18px;flex-direction:row;text-align:left;gap:14px}
  .dp-court__rank-badge{width:90px;height:90px;flex-shrink:0}
  .dp-court__rank-perk{margin-top:0;font-size:14px}
}

/* ---------- table de paiements ---------- */
.dp-cashier{
  display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:30px 0;
}
@media (max-width:780px){.dp-cashier{grid-template-columns:1fr}}
.dp-cashier__pane{
  background:#fff;border-radius:var(--dp-radius-m);padding:22px;
  box-shadow:var(--dp-shadow);
}
.dp-cashier table{width:100%;border-collapse:collapse;font-size:14px}
.dp-cashier th,.dp-cashier td{
  text-align:left;padding:10px 8px;border-bottom:1px solid var(--dp-cream-deep);
}
.dp-cashier th{
  color:var(--dp-wood-deep);font-weight:700;text-transform:uppercase;
  font-size:12px;letter-spacing:.05em;background:var(--dp-cream-soft);
}

/* ---------- 4 atouts du palais ---------- */
.dp-perks{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:34px 0;
}
.dp-perks__pillar{
  background:var(--dp-cream-soft);border-radius:var(--dp-radius-m);
  padding:22px 18px;text-align:center;border:2px solid var(--dp-cream-deep);
  display:flex;flex-direction:column;align-items:center;
}
.dp-perks__pillar img{
  width:96px;height:96px;object-fit:contain;object-position:center;
  display:block;margin:0 auto 10px;
}
.dp-perks__pillar h3{margin:6px 0 8px;font-size:18px}
.dp-perks__pillar p{font-size:14px;color:var(--dp-ash);margin:0}
@media (max-width:780px){.dp-perks{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.dp-perks{grid-template-columns:1fr}}

/* ---------- avis joueurs ---------- */
.dp-voices{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
@media (max-width:880px){.dp-voices{grid-template-columns:1fr}}
.dp-voices__quote{
  background:#fff;border-radius:var(--dp-radius-m);padding:20px;
  box-shadow:var(--dp-shadow);
}
.dp-voices__stars{color:var(--dp-gold);font-size:18px;margin-bottom:8px}
.dp-voices__author{
  font-weight:700;color:var(--dp-wood-deep);margin-top:10px;font-size:14px;
}

/* ---------- inscription en 4 etapes ---------- */
.dp-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  counter-reset:dpstep;
}
.dp-steps__act{
  background:#fff;border-radius:var(--dp-radius-m);padding:22px;
  border-top:5px solid var(--dp-fire);box-shadow:var(--dp-shadow);
  position:relative;counter-increment:dpstep;
}
.dp-steps__act::before{
  content:counter(dpstep);
  position:absolute;top:-18px;left:18px;
  background:var(--dp-fire);color:#fff;font-family:var(--dp-font-head);
  font-size:18px;font-weight:800;width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:3px solid #fff;box-shadow:var(--dp-shadow);
}
.dp-steps__act h3{margin:14px 0 8px;font-size:17px}
@media (max-width:880px){.dp-steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.dp-steps{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.dp-scroll{
  background:#fff;border-radius:var(--dp-radius-m);padding:8px;
  box-shadow:var(--dp-shadow);
}
.dp-scroll details{
  border-bottom:1px solid var(--dp-cream-deep);padding:14px 16px;
}
.dp-scroll details:last-child{border-bottom:none}
.dp-scroll summary{
  cursor:pointer;font-weight:700;color:var(--dp-wood-deep);
  font-family:var(--dp-font-head);font-size:16px;
  display:flex;justify-content:space-between;align-items:center;
}
.dp-scroll summary::after{content:"+";color:var(--dp-fire);font-size:22px;font-weight:700}
.dp-scroll details[open] summary::after{content:"\2013"}
.dp-scroll details p{margin-top:10px;color:var(--dp-night)}

/* ---------- jeu responsable bandeau ---------- */
.dp-vow{
  background:#fff;border:2px solid var(--dp-fire);
  border-radius:var(--dp-radius-m);padding:24px;margin:30px 0;
  display:flex;gap:18px;align-items:center;flex-wrap:wrap;
}
.dp-vow__mark{
  background:var(--dp-fire);color:#fff;font-family:var(--dp-font-head);
  font-size:22px;font-weight:800;width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.dp-vow__lines{flex:1;min-width:240px}
.dp-vow__lines h3{margin:0 0 6px}

/* ---------- pied de page ---------- */
.dp-base{
  background:linear-gradient(180deg,#2a160a 0%, #150904 100%);
  color:#d9c9a8;margin-top:60px;padding:48px 0 28px;
}
.dp-base__cols{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;
  max-width:1280px;margin:0 auto;padding:0 18px;
}
.dp-base__brand img{height:130px;width:auto;margin-bottom:14px;display:block}
.dp-base__brand p{font-size:14px;color:#b8a37d}
.dp-base h4{
  color:#ffd76a;font-size:15px;text-transform:uppercase;letter-spacing:.06em;
  margin:0 0 12px;font-family:var(--dp-font-head);
}
.dp-base ul{list-style:none;padding:0;margin:0}
.dp-base ul li{margin-bottom:8px}
.dp-base ul a{color:#d9c9a8;font-size:14px}
.dp-base ul a:hover{color:#ffd76a}
.dp-base__legal{
  max-width:1280px;margin:30px auto 0;padding:24px 18px 0;
  border-top:1px solid #4a2d12;font-size:12px;color:#9a8460;text-align:center;
}
.dp-base__legal strong{color:#ffd76a}
@media (max-width:780px){
  .dp-base__cols{grid-template-columns:1fr;text-align:center}
  .dp-base__brand img{margin:0 auto 14px}
}

/* ---------- texte editorial ---------- */
.dp-scroll-text{
  background:var(--dp-cream-soft);border-radius:var(--dp-radius-m);
  padding:28px;border:2px solid var(--dp-cream-deep);margin:30px 0;
}
.dp-scroll-text h2{margin-bottom:14px}
.dp-scroll-text p{margin-bottom:14px;color:var(--dp-night);font-size:15.5px}
.dp-scroll-text ul{padding-left:22px;margin:0 0 18px}
.dp-scroll-text ul li{margin-bottom:6px}

/* ---------- H1 sr-only (conserve pour SEO/a11y, invisible visuellement) ---------- */
.dp-sronly{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ---------- bloc verdict (notre avis) ---------- */
.dp-verdict{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:22px 0;
}
@media (max-width:780px){.dp-verdict{grid-template-columns:1fr}}
.dp-verdict__col{
  background:#fff;border-radius:var(--dp-radius-s);padding:18px 22px;
  border:1px solid var(--dp-cream-deep);
}
.dp-verdict__col ul{margin:8px 0 0;padding-left:22px}
.dp-verdict__col ul li{margin-bottom:6px;font-size:14.5px}
.dp-verdict__title{
  display:block;font-family:var(--dp-font-head);font-size:16px;
  color:var(--dp-fire-deep);text-transform:uppercase;letter-spacing:.05em;
  margin-bottom:6px;
}
.dp-verdict__card{
  background:#fff;border-radius:var(--dp-radius-s);padding:18px 22px;
  border:1px solid var(--dp-cream-deep);margin-top:20px;
}
.dp-verdict__card table{width:100%;border-collapse:collapse;margin-top:8px;font-size:14.5px}
.dp-verdict__card th{
  text-align:left;padding:8px 12px;font-weight:700;color:var(--dp-wood-deep);
  width:38%;background:var(--dp-cream-soft);border-bottom:1px solid var(--dp-cream-deep);
}
.dp-verdict__card td{
  padding:8px 12px;border-bottom:1px solid var(--dp-cream-deep);
  color:var(--dp-night);
}
.dp-verdict__card tr:last-child th,
.dp-verdict__card tr:last-child td{border-bottom:none}

/* utilitaires */
.dp-hidden{display:none!important}
.dp-spaced-top{margin-top:32px}

/* ---------- titre de page (pages secondaires) ---------- */
.dp-pagehead{
  background:linear-gradient(180deg,#fff8e7 0%, #f0dfb6 100%);
  border-bottom:3px solid var(--dp-gold);
  padding:38px 18px 30px;text-align:center;
  border-radius:0 0 24px 24px;
  box-shadow:0 4px 16px rgba(0,0,0,.08);
}
.dp-pagehead h1{margin:0 0 8px;color:var(--dp-wood-deep);font-size:clamp(28px,3.6vw,40px)}
.dp-pagehead p{margin:0 auto;max-width:760px;font-size:clamp(15px,1.5vw,17px);color:var(--dp-wood)}

/* ---------- pack bonus detaille ---------- */
.dp-bonus-pack{
  background:linear-gradient(180deg,#fff7e0 0%, #f6d987 100%);
  border:4px solid var(--dp-gold);border-radius:var(--dp-radius-l);
  padding:34px;margin:30px 0;
  box-shadow:var(--dp-shadow);
}
.dp-bonus-pack h2{margin-top:0;text-align:center}
.dp-bonus-pack__amount{
  font-family:var(--dp-font-head);font-size:clamp(28px,4vw,44px);
  color:var(--dp-fire-deep);font-weight:800;text-align:center;
  margin:8px 0 24px;
}
.dp-bonus-pack__deposits{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:20px 0;
}
.dp-bonus-pack__step{
  background:#fff;border:2px solid var(--dp-cream-deep);
  border-radius:var(--dp-radius-m);padding:18px;text-align:center;
}
.dp-bonus-pack__step-no{
  font-family:var(--dp-font-head);font-weight:800;font-size:13px;
  color:var(--dp-fire);text-transform:uppercase;letter-spacing:.08em;
}
.dp-bonus-pack__step-amount{
  font-family:var(--dp-font-head);font-size:22px;color:var(--dp-wood-deep);
  font-weight:800;margin:6px 0 4px;
}
.dp-bonus-pack__step-spins{font-size:13px;color:var(--dp-ash)}
@media (max-width:780px){.dp-bonus-pack__deposits{grid-template-columns:repeat(2,1fr)}}

/* ---------- table de bonus ---------- */
.dp-bonus-table{
  width:100%;border-collapse:collapse;
  background:#fff;border-radius:var(--dp-radius-m);overflow:hidden;
  box-shadow:var(--dp-shadow);margin:20px 0;
}
.dp-bonus-table th,.dp-bonus-table td{
  padding:14px 16px;text-align:left;border-bottom:1px solid var(--dp-cream-deep);
  font-size:14.5px;
}
.dp-bonus-table th{
  background:var(--dp-cream-soft);color:var(--dp-wood-deep);
  font-family:var(--dp-font-head);font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;font-size:12px;
}
/* Table responsive : passe en cards stackees sur mobile */
@media (max-width:620px){
  .dp-bonus-table{display:block;background:transparent;box-shadow:none;border-radius:0}
  .dp-bonus-table thead{display:none}
  .dp-bonus-table tbody{display:block}
  .dp-bonus-table tr{
    display:block;background:#fff;border-radius:var(--dp-radius-s);
    box-shadow:var(--dp-shadow);margin-bottom:12px;padding:6px 0;
  }
  .dp-bonus-table td,.dp-bonus-table th{
    display:block;padding:8px 14px;border-bottom:1px dashed var(--dp-cream-deep);
    font-size:14px;
  }
  .dp-bonus-table td:last-child,.dp-bonus-table th:last-child{border-bottom:none}
  .dp-bonus-table tr td:first-child,.dp-bonus-table tr th:first-child{
    background:var(--dp-cream-soft);font-weight:700;font-size:13px;
    color:var(--dp-wood-deep);text-transform:uppercase;letter-spacing:.04em;
  }
}

/* ---------- formulaire de contact / login ---------- */
.dp-form{
  background:#fff;border-radius:var(--dp-radius-m);padding:28px;
  box-shadow:var(--dp-shadow);max-width:520px;margin:0 auto;
}
.dp-form__field{margin-bottom:16px;display:block !important;width:100%}
.dp-form .dp-form__field label{
  display:block !important;width:100%;font-weight:700;color:var(--dp-wood-deep);
  margin:0 0 6px;font-size:14px;clear:both;float:none;
}
.dp-form .dp-form__field input,
.dp-form .dp-form__field textarea,
.dp-form .dp-form__field select{
  display:block !important;width:100% !important;box-sizing:border-box;
  padding:11px 14px;border:2px solid var(--dp-cream-deep);
  border-radius:var(--dp-radius-s);font-size:15px;
  background:var(--dp-cream-soft);color:var(--dp-night);
  font-family:inherit;transition:border .15s;
  margin:0;clear:both;float:none;
}
.dp-form__field input:focus,.dp-form__field textarea:focus{
  outline:none;border-color:var(--dp-fire);background:#fff;
}
.dp-form__field textarea{min-height:120px;resize:vertical}
.dp-form__submit{width:100%;margin-top:8px}
.dp-form__alt{
  text-align:center;margin-top:18px;font-size:14px;color:var(--dp-ash);
}
.dp-form__alt a{color:var(--dp-fire-deep);font-weight:700}

/* ---------- providers detailled grid ---------- */
.dp-prov-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0;
}
@media (max-width:880px){.dp-prov-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.dp-prov-grid{grid-template-columns:1fr}}
.dp-prov-card{
  background:#fff;border:2px solid var(--dp-cream-deep);
  border-radius:var(--dp-radius-m);padding:20px;
  box-shadow:var(--dp-shadow);
}
.dp-prov-card h3{margin:0 0 8px;color:var(--dp-wood-deep);font-size:18px}
.dp-prov-card p{margin:0;color:var(--dp-night);font-size:14px;line-height:1.5}
.dp-prov-card__tag{
  display:inline-block;background:var(--dp-fire);color:#fff;
  font-size:10px;padding:2px 8px;border-radius:6px;
  text-transform:uppercase;letter-spacing:.08em;font-weight:700;
  margin-bottom:8px;
}
.dp-prov-card__tag--gold{background:var(--dp-gold);color:var(--dp-wood-deep)}

/* ---------- support cards ---------- */
.dp-support-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0;
}
@media (max-width:780px){.dp-support-grid{grid-template-columns:1fr;gap:14px}}
.dp-support-card{
  background:var(--dp-cream-soft);border:2px solid var(--dp-cream-deep);
  border-radius:var(--dp-radius-m);padding:24px;text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.dp-support-card img{width:80px;height:80px;object-fit:contain;margin-bottom:10px}
.dp-support-card h3{margin:4px 0 8px}
.dp-support-card p{font-size:14px;color:var(--dp-ash);margin:0 0 14px}
@media (max-width:520px){
  .dp-support-card{padding:18px 14px}
  .dp-support-card img{width:64px;height:64px}
}

/* Form responsive */
@media (max-width:520px){
  .dp-form{padding:18px 14px}
  .dp-form__field input,.dp-form__field textarea,.dp-form__field select{
    font-size:16px; /* iOS evite le zoom auto sur focus */
  }
}

/* Pagehead responsive */
@media (max-width:520px){
  .dp-pagehead{padding:24px 14px 20px;border-radius:0 0 16px 16px}
  .dp-pagehead h1{font-size:24px}
  .dp-pagehead p{font-size:14px}
}

/* ---------- pack bonus large card (page bonus) ---------- */
.dp-pack{
  background:linear-gradient(180deg,#fff7e0 0%, #f4d480 100%);
  border:4px solid var(--dp-gold);border-radius:var(--dp-radius-l);
  padding:38px 32px;margin:34px 0;
  box-shadow:var(--dp-shadow-strong);
  display:grid;grid-template-columns:1.1fr 1fr;gap:32px;align-items:center;
}
.dp-pack__sum{
  font-family:var(--dp-font-head);
  font-size:clamp(28px,4vw,42px);
  color:var(--dp-fire-deep);font-weight:800;line-height:1.05;
  margin:0 0 16px;
}
.dp-pack__sum span{display:block;font-size:.55em;color:var(--dp-wood-deep);margin-top:4px}
.dp-pack__txt p{font-size:15.5px;color:var(--dp-wood-deep);margin-bottom:18px}
.dp-pack__tags{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 22px}
.dp-pack__tag{
  background:#fff;border:2px solid var(--dp-fire);color:var(--dp-fire-deep);
  padding:5px 12px;border-radius:999px;font-weight:700;font-size:13px;
}
.dp-pack__visu{
  background:rgba(255,255,255,.4);border:3px solid #fff;border-radius:var(--dp-radius-m);
  padding:18px;text-align:center;
}
.dp-pack__visu-no{
  font-family:var(--dp-font-head);font-weight:800;text-transform:uppercase;
  color:var(--dp-fire);font-size:11px;letter-spacing:.1em;
}
.dp-pack__visu table{width:100%;border-collapse:collapse;font-size:13px;margin-top:10px}
.dp-pack__visu td{padding:6px 4px;border-bottom:1px dashed rgba(107,59,21,.25)}
.dp-pack__visu td:last-child{text-align:right;font-weight:700;color:var(--dp-wood-deep)}
.dp-pack__visu tr:last-child td{border-bottom:none}
@media (max-width:780px){
  .dp-pack{grid-template-columns:1fr;padding:24px 18px;gap:20px}
}

/* ---------- 4 etapes de reclamation (sequence visuelle) ---------- */
.dp-claim{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:22px 0;
}
.dp-claim__step{
  background:#fff;border-radius:var(--dp-radius-m);
  padding:22px 18px;text-align:center;
  border:2px solid var(--dp-cream-deep);position:relative;
  display:flex;flex-direction:column;align-items:center;
}
.dp-claim__step-num{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(180deg,var(--dp-fire),var(--dp-fire-deep));
  color:#fff;font-family:var(--dp-font-head);font-size:22px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  margin:-44px auto 12px;
  border:4px solid #fff;box-shadow:0 4px 8px rgba(0,0,0,.18);
}
.dp-claim__step h3{margin:6px 0 8px;font-size:16px}
.dp-claim__step p{font-size:14px;color:var(--dp-ash);margin:0}
@media (max-width:880px){.dp-claim{grid-template-columns:repeat(2,1fr);margin-top:50px}}
@media (max-width:480px){.dp-claim{grid-template-columns:1fr}}

/* ---------- grid promos recurrentes (page bonus) ---------- */
.dp-promos{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0;
}
@media (max-width:880px){.dp-promos{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.dp-promos{grid-template-columns:1fr}}
.dp-promo{
  background:#fff;border:2px solid var(--dp-cream-deep);
  border-radius:var(--dp-radius-m);padding:22px;
  box-shadow:var(--dp-shadow);position:relative;
  display:flex;flex-direction:column;
}
.dp-promo--gold{background:linear-gradient(180deg,#fff7e0, #f6d987);border-color:var(--dp-gold)}
.dp-promo__rib{
  align-self:flex-start;background:var(--dp-fire);color:#fff;
  padding:3px 10px;border-radius:6px;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;
}
.dp-promo--gold .dp-promo__rib{background:var(--dp-gold);color:var(--dp-wood-deep)}
.dp-promo h3{margin:0 0 8px;font-size:18px}
.dp-promo__amount{
  font-family:var(--dp-font-head);font-weight:800;color:var(--dp-fire-deep);
  font-size:22px;margin:6px 0 10px;
}
.dp-promo p{margin:0 0 14px;font-size:14px;color:var(--dp-wood);line-height:1.5}
.dp-promo__cta{margin-top:auto}

/* ---------- conditions en colonnes ---------- */
.dp-conditions{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:22px 0;
}
@media (max-width:780px){.dp-conditions{grid-template-columns:1fr}}
.dp-condition{
  background:var(--dp-cream-soft);border:1px solid var(--dp-cream-deep);
  border-radius:var(--dp-radius-m);padding:20px;
}
.dp-condition h3{margin:0 0 8px;font-size:16px;color:var(--dp-wood-deep)}
.dp-condition__title{
  margin:0 0 8px;font-size:16px;color:var(--dp-wood-deep);
  font-family:var(--dp-font-head);
}
.dp-condition__title strong{font-weight:700}
.dp-condition p{margin:0;font-size:14px;line-height:1.55;color:var(--dp-night)}

/* ---------- inscription page : progress + redirect ---------- */
.dp-redirect{
  text-align:center;padding:60px 20px;max-width:680px;margin:0 auto;
}
.dp-redirect__steps{
  display:flex;justify-content:space-between;margin:32px 0 18px;
  counter-reset:dpstep;gap:10px;
}
.dp-redirect__step{
  flex:1;text-align:center;font-size:12px;color:var(--dp-ash);
  position:relative;padding-top:42px;
}
.dp-redirect__step::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:32px;height:32px;border-radius:50%;background:var(--dp-cream-deep);
  border:3px solid var(--dp-cream-deep);
}
.dp-redirect__step--done::before{
  background:var(--dp-leaf);border-color:var(--dp-leaf);
  content:"\2713";color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center;line-height:1;
}
.dp-redirect__step--active::before{
  background:var(--dp-fire);border-color:var(--dp-fire);
  animation:dp-pulse 1.2s ease-in-out infinite;
}
@keyframes dp-pulse{0%,100%{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.18)}}
.dp-redirect__bar{
  width:100%;height:14px;background:var(--dp-cream-deep);
  border-radius:999px;overflow:hidden;margin:22px 0 14px;
  border:1px solid var(--dp-cream-deep);
}
.dp-redirect__bar-fill{
  height:100%;background:linear-gradient(90deg,var(--dp-fire),var(--dp-gold));
  width:0;transition:width 1.5s linear;
  border-radius:999px;
}
.dp-redirect__msg{color:var(--dp-wood-deep);font-weight:700;margin-top:10px}
.dp-redirect__manual{
  margin-top:32px;font-size:14px;color:var(--dp-ash);
}
.dp-redirect__manual a{
  display:inline-block;margin-top:8px;font-weight:700;color:var(--dp-fire-deep);
}
