/* Dragonia Casino FR - Site 7 | prefix: zen | font: Source Sans 3 */
/* Mobile-first responsive: 320 -> 768 -> 1024 -> 1440 */

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

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

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

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

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

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

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

/* === SPLIT LAYOUT === */
.zen-split{display:flex;flex-direction:column;gap:24px}
.zen-split-img img{border-radius:20px;width:100%;box-shadow:0 8px 32px rgba(0,0,0,0.18)}

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

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

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

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

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

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

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

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

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

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

/* === RESPONSIVE 768px === */
@media(min-width:768px){
  .zen-trail{display:flex}
  .zen-burger{display:none}
  .zen-pulse-cta{display:inline-block}
  .zen-feature-inner{flex-direction:row;align-items:center}
  .zen-feature-text{flex:1}
  .zen-feature-img{flex:1}
  .zen-feature-text h1{font-size:36px}
  .zen-split{flex-direction:row;align-items:center}
  .zen-split-text{flex:1}
  .zen-split-img{flex:1}
  .zen-gallery{grid-template-columns:repeat(3,1fr)}
  .zen-atlas ol{columns:2}
  .zen-bedrock-grid{grid-template-columns:2fr 1fr 1fr}
}

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

/* === RESPONSIVE 1440px === */
@media(min-width:1440px){
  .zen-vessel{max-width:1140px}
  .zen-feature-text h1{font-size:48px}
  body{font-size:17px}
}

/* Guide Steps */
.zen-guide-steps{list-style:none;counter-reset:zen-g;display:flex;flex-direction:column;gap:18px;margin:20px 0;padding:0}
.zen-guide-steps li{counter-increment:zen-g;position:relative;display:flex;align-items:flex-start;gap:16px;padding:18px 20px;background:var(--zen-surface);border-radius:10px;border-top:2px solid var(--zen-accent)}
.zen-guide-steps li::before{content:counter(zen-g);min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--zen-accent);color:#1a1020;font-weight:800;border-radius:50%;font-size:13px;flex-shrink:0}
.zen-guide-steps li strong{display:block;margin-bottom:4px;color:var(--zen-primary)}
.zen-guide-steps li p{margin:0;color:var(--zen-txt2);font-size:15px;line-height:1.6}
