/* Dragonia Casino FR - Site 4 | prefix: vex | font: Plus Jakarta Sans */
/* Mobile-first responsive: 320 -> 768 -> 1024 -> 1440 */

/* === RESET & BASE === */
.vex-chassis{max-width:1160px;margin:0 auto;padding:0 20px}
a{color:var(--vex-accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--vex-accent-h)}
img{max-width:100%;height:auto;display:block}

/* === PROMO RIBBON === */
.vex-strip{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;background:var(--vex-primary);color:#fff;font-size:14px;text-align:center;flex-wrap:wrap}
.vex-strip-action{background:#fff;color:var(--vex-primary);padding:4px 14px;border-radius:12px;font-weight:600;font-size:13px;white-space:nowrap}
.vex-strip-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}

/* === HEADER === */
.vex-cap{position:sticky;top:0;z-index:100;background:var(--vex-bg);border-bottom:1px solid var(--vex-card-b);padding:12px 0}
.vex-cap-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.vex-logo img{height:40px;width:auto;object-fit:contain}
.vex-sitemap{display:none;gap:24px}
.vex-sitemap a{color:var(--vex-txt);font-weight:600;font-size:15px;padding:6px 0;border-bottom:2px solid transparent;transition:border-color .2s,color .2s}
.vex-sitemap a:hover,.vex-sitemap a[aria-current="page"]{color:var(--vex-accent);border-color:var(--vex-accent)}
.vex-launch-cta{display:none;background:var(--vex-cta);color:var(--vex-cta-txt);padding:8px 20px;border-radius:12px;font-weight:700;font-size:14px;white-space:nowrap;transition:background .2s,transform .2s}
.vex-launch-cta:hover{background:var(--vex-primary-h);color:#fff;transform:scale(1.05) translateY(-2px)}
.vex-burger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.vex-burger span{display:block;width:24px;height:2px;background:var(--vex-txt);border-radius:2px;transition:transform .3s,opacity .3s}
.vex-burger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.vex-burger.active span:nth-child(2){opacity:0}
.vex-burger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav */
.vex-sitemap.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--vex-bg);padding:20px;border-bottom:1px solid var(--vex-card-b);z-index:99}

/* === HERO === */
.vex-showcase{padding:40px 0 32px;background:linear-gradient(135deg,var(--vex-bg) 0%,var(--vex-bg2) 100%)}
.vex-showcase-inner{display:flex;flex-direction:column;gap:24px}
.vex-showcase-text h1{font-size:28px;font-weight:800;line-height:1.2;margin-bottom:16px;color:var(--vex-txt)}
.vex-showcase-text p{color:var(--vex-txt2);margin-bottom:20px}
.vex-showcase-img img{border-radius:16px;width:100%;box-shadow:0 6px 24px rgba(0,0,0,0.2)}
.vex-launch-primary{display:inline-block;background:var(--vex-cta);color:var(--vex-cta-txt);padding:12px 28px;border-radius:12px;font-weight:700;font-size:16px;transition:background .2s,transform .2s}
.vex-launch-primary:hover{background:var(--vex-primary-h);color:#fff;transform:scale(1.05) translateY(-2px)}

/* === TOC === */
.vex-overview{padding:20px 0;background:var(--vex-surface);border-top:1px solid var(--vex-card-b);border-bottom:1px solid var(--vex-card-b)}
.vex-overview strong{display:block;margin-bottom:12px;color:var(--vex-accent);font-size:18px}
.vex-overview ol{padding-left:20px;columns:1;gap:8px}
.vex-overview li{margin-bottom:6px}
.vex-overview a{color:var(--vex-txt2);font-size:14px}
.vex-overview a:hover{color:var(--vex-accent)}

/* === SECTIONS === */
.vex-segment-paris,.vex-segment-how,.vex-segment-games,.vex-segment-register,.vex-segment-payments,.vex-segment-play,.vex-segment-bonus,.vex-segment-win,.vex-segment-faq,.vex-segment-author{padding:48px 0}
.vex-segment-how,.vex-segment-payments,.vex-segment-win{background:var(--vex-bg2)}
h2{font-size:24px;font-weight:700;margin-bottom:16px;color:var(--vex-txt);line-height:1.3}
h3{font-size:20px;font-weight:600;margin:32px 0 12px;color:var(--vex-accent);line-height:1.3}
p{margin-bottom:16px;color:var(--vex-txt2);line-height:1.7}

/* === SPLIT LAYOUT === */
.vex-split{display:flex;flex-direction:column;gap:24px}
.vex-split-img img{border-radius:16px;width:100%;box-shadow:0 6px 24px rgba(0,0,0,0.2)}

/* === SPORT ICONS === */
.vex-sport-icons{display:flex;flex-wrap:wrap;gap:16px;margin:20px 0}
.vex-sport-item{display:flex;align-items:center;gap:8px;background:var(--vex-surface);padding:10px 16px;border-radius:16px;border:1px solid var(--vex-card-b);transition:background .2s}
.vex-sport-item:hover{background:var(--vex-surface-h)}
.vex-sport-icon{color:var(--vex-accent);display:flex;align-items:center}
.vex-sport-item span:last-child{font-size:14px;font-weight:500;color:var(--vex-txt)}

/* === STEPS === */
.vex-steps{display:flex;flex-direction:column;gap:16px;margin:20px 0}
.vex-step{display:flex;gap:16px;align-items:flex-start;background:var(--vex-card);padding:16px;border-radius:16px;border:1px solid var(--vex-card-b)}
.vex-step-num{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;background:var(--vex-primary);color:#fff;border-radius:50%;font-weight:800;font-size:16px;flex-shrink:0}
.vex-step-body strong{display:block;margin-bottom:6px;color:var(--vex-txt);font-size:16px}
.vex-step-body p{margin:0;font-size:14px;color:var(--vex-txt2)}

/* === GAME LISTS === */
.vex-game-list{padding-left:20px;margin:16px 0}
.vex-game-list li{margin-bottom:8px;color:var(--vex-txt2);font-size:15px}
.vex-game-list li::marker{color:var(--vex-accent)}

/* === CARD GRID (MOSAIC) === */
.vex-matrix{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin:20px 0}
.vex-slab{background:var(--vex-card);border-radius:16px;overflow:hidden;border:none;transition:transform .2s,box-shadow .2s}
.vex-slab:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,0.4)}
.vex-slab img{width:100%;height:180px;object-fit:cover;display:block}
.vex-slab-label{display:block;padding:10px 12px;font-size:14px;font-weight:600;color:var(--vex-txt);text-align:center}

/* CTA after grids */
section a.vex-launch-primary:not(:first-child){margin-top:28px}
.vex-matrix + a.vex-launch-primary,.vex-matrix-bonus + a.vex-launch-primary{margin-top:28px}

/* === PAYMENT ICONS === */
.vex-checkout-icons{display:flex;flex-wrap:wrap;gap:12px;margin:20px 0;align-items:center}
.vex-checkout-icons img{border:none;height:36px;max-width:80px;background:#fff;padding:4px 8px;border-radius:10px;object-fit:contain}

/* === TABLES === */
.vex-table-wrap{overflow-x:auto;margin:16px 0}
.vex-table{width:100%;border-collapse:collapse;font-size:14px}
.vex-table th{background:var(--vex-surface);color:var(--vex-accent);padding:10px 12px;text-align:left;font-weight:600;white-space:nowrap}
.vex-table td{padding:10px 12px;border-bottom:1px solid var(--vex-card-b);color:var(--vex-txt2)}
.vex-table tr:hover td{background:var(--vex-surface)}

/* === FAQ === */
.vex-qa{display:flex;flex-direction:column;gap:8px}
.vex-query{background:var(--vex-card);border:1px solid var(--vex-card-b);border-radius:16px;overflow:hidden}
.vex-query summary{padding:16px 20px;cursor:pointer;font-weight:600;color:var(--vex-txt);list-style:none;display:flex;align-items:center;justify-content:space-between;transition:background .2s}
.vex-query summary:hover{background:var(--vex-surface)}
.vex-query summary::after{content:'+';font-size:20px;color:var(--vex-accent);font-weight:700;flex-shrink:0;margin-left:12px;transition:transform .2s}
.vex-query[open] summary::after{content:'-';transform:rotate(180deg)}
.vex-query summary h3{font-size:16px;margin:0;color:var(--vex-txt)}
.vex-query p{padding:0 20px 16px;margin:0;color:var(--vex-txt2);font-size:15px}

/* === AUTHOR === */
.vex-pundit{display:flex;gap:22px;align-items:flex-start;background:var(--vex-card);padding:24px;border-radius:16px;border:1px solid var(--vex-card-b)}
.vex-pundit-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--vex-accent)}
.vex-pundit-info strong{display:block;font-size:18px;color:var(--vex-txt);margin-bottom:4px}
.vex-pundit-info span{display:block;font-size:14px;color:var(--vex-accent);margin-bottom:8px}
.vex-pundit-info p{margin:0;font-size:14px;color:var(--vex-txt2)}

/* === FOOTER === */
.vex-dock{background:var(--vex-footer);padding:48px 0 24px;border-top:1px solid var(--vex-card-b)}
.vex-dock-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:32px}
.vex-dock-brand img{height:36px;width:auto;margin-bottom:12px}
.vex-dock-brand p{font-size:13px;color:var(--vex-muted)}
.vex-dock-links{display:flex;flex-direction:column;gap:8px}
.vex-dock-links strong{color:var(--vex-txt);font-size:15px;margin-bottom:4px}
.vex-dock-links a{color:var(--vex-txt2);font-size:14px;transition:color .2s}
.vex-dock-links a:hover{color:var(--vex-accent)}
.vex-dock-info strong{color:var(--vex-txt);font-size:15px;display:block;margin-bottom:8px}
.vex-dock-info p{font-size:13px;color:var(--vex-muted);margin-bottom:6px}
.vex-dock-bottom{text-align:center;padding-top:20px;border-top:1px solid var(--vex-card-b)}
.vex-dock-bottom p{font-size:12px;color:var(--vex-muted);margin:0}

/* === RESPONSIVE 768px === */
@media(min-width:768px){
  .vex-sitemap{display:flex}
  .vex-burger{display:none}
  .vex-launch-cta{display:inline-block}
  .vex-showcase-inner{flex-direction:row;align-items:center}
  .vex-showcase-text{flex:1}
  .vex-showcase-img{flex:1}
  .vex-showcase-text h1{font-size:36px}
  .vex-split{flex-direction:row;align-items:center}
  .vex-split-text{flex:1}
  .vex-split-img{flex:1}
  .vex-matrix{grid-template-columns:repeat(3,1fr)}
  .vex-overview ol{columns:2}
  .vex-dock-grid{grid-template-columns:2fr 1fr 1fr}
}

/* === RESPONSIVE 1024px === */
@media(min-width:1024px){
  .vex-showcase-text h1{font-size:42px}
  .vex-matrix-slots{grid-template-columns:repeat(3,1fr)}
  .vex-matrix-live,.vex-matrix-table{grid-template-columns:repeat(4,1fr)}
  .vex-overview ol{columns:3}
  h2{font-size:28px}
  h3{font-size:22px}
}

/* === RESPONSIVE 1440px === */
@media(min-width:1440px){
  .vex-chassis{max-width:1160px}
  .vex-showcase-text h1{font-size:48px}
  body{font-size:17px}
}

/* Guide Steps */
.vex-guide-steps{list-style:none;counter-reset:vex-num;display:flex;flex-direction:column;gap:14px;margin:20px 0;padding:0}
.vex-guide-steps li{counter-increment:vex-num;display:flex;align-items:flex-start;gap:14px;padding:14px 18px;background:var(--vex-surface);border-radius:6px;border-bottom:2px solid var(--vex-primary)}
.vex-guide-steps li::before{content:counter(vex-num);min-width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--vex-primary);color:#fff;font-weight:700;border-radius:4px;font-size:13px;flex-shrink:0}
.vex-guide-steps li strong{display:block;margin-bottom:4px;color:var(--vex-accent)}
.vex-guide-steps li p{margin:0;color:var(--vex-txt2);font-size:15px;line-height:1.6}
