/* =========================================================
   topvin Design System
   ========================================================= */
:root{
  --c-primary:#5b3fd6;
  --c-primary-dark:#4630b5;
  --c-primary-light:#7a63e6;
  --c-accent:#ffb627;
  --c-accent-2:#ff5a3c;
  --c-bg:#eef0fb;
  --c-bg-soft:#f6f7fc;
  --c-bg-alt:#dde2f4;
  --c-card:#ffffff;
  --c-text:#1f2240;
  --c-text-soft:#5a5e7d;
  --c-text-mute:#8a8fae;
  --c-border:#e3e6f2;
  --c-success:#21c07a;
  --c-warning:#ffb627;
  --c-danger:#e63946;
  --c-gradient:linear-gradient(135deg,#5b3fd6 0%,#7a63e6 100%);
  --c-gradient-hero:linear-gradient(180deg,#fff1cb 0%,#ffd97a 40%,#ff8a3c 100%);
  --c-gradient-accent:linear-gradient(135deg,#ffb627 0%,#ff5a3c 100%);
  --radius-sm:6px;
  --radius:12px;
  --radius-lg:18px;
  --radius-xl:24px;
  --shadow-sm:0 2px 6px rgba(31,34,64,0.06);
  --shadow:0 6px 18px rgba(31,34,64,0.10);
  --shadow-lg:0 12px 32px rgba(31,34,64,0.16);
  --container:1180px;
  --header-h:70px;
  --transition:all .25s ease;
  --font:'Segoe UI','Roboto','Helvetica Neue',Arial,'PingFang SC','Microsoft YaHei',sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  font-size:15px;
  line-height:1.65;
  color:var(--c-text);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--c-primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--c-primary-dark)}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* =========================================================
   Top Bar
   ========================================================= */
.topbar{
  background:#3b2aa0;
  color:#fff;
  font-size:13px;
  padding:6px 0;
}
.topbar-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.topbar-left span{margin-right:18px;opacity:.9}
.topbar-right{display:flex;gap:14px;opacity:.9}

/* =========================================================
   Header / Navigation
   ========================================================= */
.site-header{
  background:#fff;
  box-shadow:var(--shadow-sm);
  position:sticky;
  top:0;
  z-index:100;
}
.nav{
  max-width:var(--container);
  margin:0 auto;
  padding:0 18px;
  height:var(--header-h);
  display:flex;
  align-items:center;
  gap:18px;
}
.logo{
  display:flex;
  align-items:center;
  font-size:26px;
  font-weight:800;
  color:var(--c-primary);
  letter-spacing:.5px;
  white-space:nowrap;
}
.logo::before{
  content:"T";
  display:inline-flex;
  width:38px;height:38px;
  background:var(--c-gradient);
  color:#fff;
  border-radius:10px;
  align-items:center;justify-content:center;
  margin-right:8px;
  font-weight:800;
  font-size:20px;
  box-shadow:var(--shadow-sm);
}
.nav-menu{
  display:flex;
  align-items:center;
  gap:4px;
  flex:1;
  justify-content:center;
}
.nav-menu a{
  display:flex;
  align-items:center;
  gap:6px;
  padding:10px 16px;
  font-weight:600;
  font-size:14px;
  color:var(--c-text);
  border-radius:10px;
  white-space:nowrap;
}
.nav-menu a:hover{background:var(--c-bg-soft);color:var(--c-primary)}
.nav-menu a.active{
  background:var(--c-gradient);
  color:#fff;
  box-shadow:var(--shadow-sm);
}
.nav-cta{display:flex;gap:8px;align-items:center}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 20px;
  border-radius:10px;
  font-weight:700;
  font-size:14px;
  letter-spacing:.3px;
  transition:var(--transition);
  cursor:pointer;
  white-space:nowrap;
}
.btn-outline{
  background:#fff;
  color:var(--c-primary);
  border:2px solid var(--c-primary);
}
.btn-outline:hover{background:var(--c-primary);color:#fff}
.btn-primary{
  background:var(--c-gradient-accent);
  color:#fff;
  box-shadow:0 4px 12px rgba(255,90,60,.3);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(255,90,60,.4);color:#fff}
.btn-lg{padding:14px 32px;font-size:16px}
.btn-block{width:100%}

.menu-toggle{
  display:none;
  width:40px;height:40px;
  border-radius:8px;
  background:var(--c-bg-soft);
  align-items:center;justify-content:center;
}
.menu-toggle span{
  display:block;width:22px;height:2px;background:var(--c-text);
  position:relative;
}
.menu-toggle span::before,
.menu-toggle span::after{
  content:"";position:absolute;left:0;width:22px;height:2px;background:var(--c-text);
}
.menu-toggle span::before{top:-7px}
.menu-toggle span::after{top:7px}

/* =========================================================
   Hero Banner
   ========================================================= */
.hero{
  background:var(--c-gradient-hero);
  padding:48px 0 56px;
  overflow:hidden;
  position:relative;
}
.hero-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 18px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:32px;
  align-items:center;
}
.hero-text h1{
  font-size:42px;
  line-height:1.15;
  color:#3b2aa0;
  margin-bottom:14px;
  text-shadow:0 2px 0 rgba(255,255,255,.4);
}
.hero-text h1 span{
  display:block;
  color:#ff5a3c;
  font-size:38px;
}
.hero-text p.lead{
  font-size:17px;
  color:#5a3e10;
  margin-bottom:22px;
  font-weight:500;
}
.hero-badges{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px;
}
.hero-badge{
  background:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.8);
  padding:8px 14px;
  border-radius:20px;
  font-size:13px;
  font-weight:600;
  color:#3b2aa0;
  backdrop-filter:blur(6px);
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-img{
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  background:#fff;
  aspect-ratio:1/1;
  max-width:420px;
  margin-left:auto;
}
.hero-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
}

/* =========================================================
   Section base
   ========================================================= */
section{padding:54px 0}
.container{max-width:var(--container);margin:0 auto;padding:0 18px}
.section-title{
  text-align:center;
  margin-bottom:36px;
}
.section-title h2{
  font-size:30px;
  color:var(--c-text);
  margin-bottom:10px;
  position:relative;
  display:inline-block;
}
.section-title h2::after{
  content:"";
  position:absolute;
  left:50%;bottom:-10px;
  transform:translateX(-50%);
  width:60px;height:4px;
  background:var(--c-gradient-accent);
  border-radius:2px;
}
.section-title p{
  color:var(--c-text-soft);
  margin-top:18px;
  max-width:680px;
  margin-left:auto;margin-right:auto;
  font-size:15px;
}

/* =========================================================
   Category Cards
   ========================================================= */
.category-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
}
.cat-card{
  background:var(--c-gradient);
  border-radius:var(--radius);
  padding:18px 12px 16px;
  text-align:center;
  color:#fff;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  border:2px solid transparent;
}
.cat-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color:var(--c-accent);
}
.cat-card-img{
  width:100%;
  aspect-ratio:1/1;
  border-radius:10px;
  overflow:hidden;
  background:rgba(255,255,255,.1);
  margin-bottom:10px;
}
.cat-card-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
}
.cat-card h3{
  font-size:14px;
  margin-bottom:8px;
  color:#fff;
  font-weight:700;
}
.cat-card .play{
  display:inline-block;
  background:var(--c-accent);
  color:#3b2aa0;
  font-size:11px;
  font-weight:700;
  padding:5px 12px;
  border-radius:14px;
}

/* =========================================================
   Provider Tabs
   ========================================================= */
.providers{
  background:#fff;
  border:2px solid var(--c-primary-light);
  border-radius:50px;
  padding:10px;
  display:flex;
  gap:8px;
  overflow-x:auto;
  margin-bottom:28px;
  scrollbar-width:none;
}
.providers::-webkit-scrollbar{display:none}
.provider{
  flex:0 0 auto;
  padding:10px 16px;
  border-radius:30px;
  background:var(--c-bg-soft);
  font-weight:700;
  font-size:13px;
  color:var(--c-text-soft);
  white-space:nowrap;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  min-width:84px;
  cursor:pointer;
  transition:var(--transition);
}
.provider .pname{font-size:14px;color:var(--c-primary)}
.provider .ptag{font-size:10px;color:var(--c-text-mute);font-weight:500}
.provider.active,.provider:hover{
  background:var(--c-gradient);
  color:#fff;
}
.provider.active .pname,
.provider.active .ptag,
.provider:hover .pname,
.provider:hover .ptag{color:#fff}

/* =========================================================
   Game Grid
   ========================================================= */
.game-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
}
.game-card{
  background:var(--c-card);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  cursor:pointer;
}
.game-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.game-card-img{
  width:100%;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--c-bg-soft);
}
.game-card-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .35s ease;
}
.game-card:hover .game-card-img img{transform:scale(1.06)}
.game-card-body{
  padding:8px 8px 12px;
  text-align:center;
}
.game-card-body h4{
  font-size:13px;
  color:var(--c-text);
  font-weight:600;
  line-height:1.3;
  margin:0;
}

/* =========================================================
   Feature Block
   ========================================================= */
.features{
  background:#fff;
}
.feature-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.feature-card{
  background:var(--c-bg-soft);
  border-radius:var(--radius);
  padding:24px 20px;
  text-align:left;
  border:1px solid var(--c-border);
  transition:var(--transition);
}
.feature-card:hover{
  border-color:var(--c-primary-light);
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.feature-ico{
  width:48px;height:48px;
  border-radius:12px;
  background:var(--c-gradient);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  font-weight:700;
  margin-bottom:14px;
}
.feature-card h3{
  font-size:17px;
  margin-bottom:8px;
  color:var(--c-text);
}
.feature-card p{
  color:var(--c-text-soft);
  font-size:14px;
  line-height:1.6;
}

/* =========================================================
   Content / Article block
   ========================================================= */
.content-block{
  background:var(--c-bg-soft);
}
.content-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:36px;
  align-items:start;
}
.content-grid h2{
  font-size:26px;color:var(--c-text);margin-bottom:14px;
}
.content-grid h3{
  font-size:19px;color:var(--c-primary-dark);margin:20px 0 8px;
}
.content-grid p{
  color:var(--c-text-soft);
  margin-bottom:14px;
  font-size:15px;
  line-height:1.75;
}
.content-grid ul{margin:10px 0 14px 0}
.content-grid ul li{
  position:relative;
  padding-left:22px;
  margin-bottom:8px;
  color:var(--c-text-soft);
}
.content-grid ul li::before{
  content:"✓";
  position:absolute;
  left:0;top:0;
  color:var(--c-success);
  font-weight:800;
}

/* =========================================================
   Stats
   ========================================================= */
.stats{
  background:var(--c-gradient);
  color:#fff;
}
.stats .section-title h2{color:#fff}
.stats .section-title h2::after{background:var(--c-accent)}
.stats .section-title p{color:rgba(255,255,255,.85)}
.stat-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.stat{
  text-align:center;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius);
  padding:24px 16px;
  backdrop-filter:blur(6px);
}
.stat-num{
  font-size:34px;font-weight:800;
  color:var(--c-accent);
  line-height:1;
  margin-bottom:8px;
}
.stat-label{font-size:14px;opacity:.92}

/* =========================================================
   Process Steps
   ========================================================= */
.steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  counter-reset:step;
}
.step{
  background:#fff;
  border-radius:var(--radius);
  padding:24px 20px 22px;
  box-shadow:var(--shadow-sm);
  border-top:4px solid var(--c-primary);
  position:relative;
}
.step::before{
  counter-increment:step;
  content:counter(step,decimal-leading-zero);
  position:absolute;
  top:-18px;right:20px;
  background:var(--c-gradient-accent);
  color:#fff;
  width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  font-weight:800;
  font-size:14px;
  box-shadow:var(--shadow-sm);
}
.step h3{
  font-size:17px;color:var(--c-text);margin-bottom:8px;
}
.step p{color:var(--c-text-soft);font-size:14px;line-height:1.65}

/* =========================================================
   FAQ
   ========================================================= */
.faq{
  background:#fff;
}
.faq-list{
  max-width:880px;
  margin:0 auto;
}
.faq-item{
  background:var(--c-bg-soft);
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:18px 22px;
  margin-bottom:14px;
  transition:var(--transition);
}
.faq-item:hover{
  border-color:var(--c-primary-light);
  box-shadow:var(--shadow-sm);
}
.faq-item h4{
  font-size:16px;
  color:var(--c-primary-dark);
  margin-bottom:8px;
  position:relative;
  padding-left:26px;
}
.faq-item h4::before{
  content:"?";
  position:absolute;left:0;top:0;
  width:20px;height:20px;
  background:var(--c-gradient);
  color:#fff;
  border-radius:50%;
  font-size:12px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.faq-item p{
  color:var(--c-text-soft);
  font-size:14.5px;
  line-height:1.7;
  padding-left:26px;
}
.faq-item ul{margin:8px 0 0 26px}
.faq-item ul li{color:var(--c-text-soft);font-size:14px;margin-bottom:4px;list-style:disc}

/* =========================================================
   Testimonial
   ========================================================= */
.testimonial{
  background:var(--c-bg-alt);
}
.testi-card{
  max-width:760px;
  margin:0 auto;
  background:#fff;
  border-radius:var(--radius-lg);
  padding:30px 32px;
  box-shadow:var(--shadow);
  position:relative;
}
.testi-card::before{
  content:"“";
  font-size:80px;
  color:var(--c-primary-light);
  position:absolute;
  top:-10px;left:18px;
  opacity:.35;
  font-family:Georgia,serif;
  line-height:1;
}
.testi-card p{
  font-size:16px;color:var(--c-text);font-style:italic;
  line-height:1.75;
  position:relative;z-index:1;
}
.testi-meta{
  margin-top:14px;
  font-size:13px;
  color:var(--c-text-mute);
  font-weight:600;
}

/* =========================================================
   CTA Strip
   ========================================================= */
.cta-strip{
  background:var(--c-gradient-accent);
  color:#fff;
  padding:40px 0;
  text-align:center;
}
.cta-strip h2{font-size:26px;margin-bottom:10px;color:#fff}
.cta-strip p{margin-bottom:18px;font-size:15px;opacity:.95}
.cta-strip .btn-outline{
  background:#fff;color:var(--c-accent-2);border-color:#fff;
}
.cta-strip .btn-outline:hover{background:#3b2aa0;color:#fff;border-color:#3b2aa0}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  background:#2a1d7e;
  color:rgba(255,255,255,.85);
  padding:50px 0 22px;
  font-size:14px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:30px;
  margin-bottom:32px;
}
.footer-col h4{
  color:#fff;
  font-size:15px;
  margin-bottom:14px;
  text-transform:uppercase;
  letter-spacing:.5px;
}
.footer-col p{margin-bottom:10px;line-height:1.7;opacity:.85}
.footer-col ul li{margin-bottom:8px}
.footer-col ul a{color:rgba(255,255,255,.8)}
.footer-col ul a:hover{color:var(--c-accent)}
.footer-pay{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;
}
.footer-pay span{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  padding:5px 10px;
  border-radius:6px;
  font-size:12px;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.15);
  padding-top:18px;
  text-align:center;
  font-size:13px;
  opacity:.78;
}
.responsible-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(255,255,255,.1);
  padding:6px 14px;
  border-radius:20px;
  margin-bottom:12px;
  font-weight:600;
}
.responsible-tag::before{
  content:"18+";
  background:var(--c-danger);
  color:#fff;
  font-weight:800;
  padding:2px 8px;
  border-radius:14px;
  font-size:12px;
}

/* =========================================================
   Floating
   ========================================================= */
.floating{
  position:fixed;
  right:18px;bottom:24px;
  z-index:90;
  display:flex;flex-direction:column;gap:10px;
}
.floating a{
  width:48px;height:48px;
  background:var(--c-gradient);
  color:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;
  box-shadow:var(--shadow-lg);
  font-size:18px;
}
.floating a:hover{transform:scale(1.08);color:#fff}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1024px){
  .category-grid{grid-template-columns:repeat(3,1fr)}
  .game-grid{grid-template-columns:repeat(4,1fr)}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .content-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-text h1{font-size:34px}
  .hero-text h1 span{font-size:30px}
}
@media (max-width:768px){
  .topbar{display:none}
  .nav{height:60px}
  .menu-toggle{display:flex}
  .nav-menu{
    position:absolute;
    top:60px;left:0;right:0;
    background:#fff;
    flex-direction:column;
    align-items:stretch;
    padding:10px;
    gap:4px;
    box-shadow:var(--shadow);
    display:none;
  }
  .nav-menu.open{display:flex}
  .nav-menu a{padding:12px 14px}
  .nav-cta .btn{padding:8px 12px;font-size:13px}
  .hero{padding:34px 0 40px}
  .hero-inner{grid-template-columns:1fr;gap:24px}
  .hero-img{max-width:100%;margin:0 auto}
  .hero-text h1{font-size:28px;text-align:center}
  .hero-text h1 span{font-size:24px}
  .hero-text p.lead{text-align:center}
  .hero-cta{justify-content:center}
  .hero-badges{justify-content:center}
  section{padding:40px 0}
  .section-title h2{font-size:24px}
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .game-grid{grid-template-columns:repeat(2,1fr)}
  .game-card-body h4{font-size:12px}
  .feature-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .stat-num{font-size:26px}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .cta-strip h2{font-size:22px}
}
@media (max-width:420px){
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .game-grid{grid-template-columns:repeat(2,1fr)}
  .hero-text h1{font-size:24px}
  .btn-lg{padding:12px 22px;font-size:14px}
}

/* Utility */
.text-center{text-align:center}
.mt-20{margin-top:20px}
.mb-20{margin-bottom:20px}
.section-title h2::after img{width:100%;height:100%;object-fit:cover;object-position:center}
.step::before img{width:100%;height:100%;object-fit:cover;object-position:center}
.faq-item h4::before img{width:100%;height:100%;object-fit:cover;object-position:center}
.floating a img{width:100%;height:100%;object-fit:cover;object-position:center}

/* codex-design-system-v2: reusable full-site components */
:root{
  --ds-bg:var(--page-bg,#090014);
  --ds-surface:var(--card-bg,#1a1230);
  --ds-surface-2:var(--section-bg,#2a0730);
  --ds-text:var(--text,#ffffff);
  --ds-muted:var(--muted,#d8c8e6);
  --ds-accent:var(--accent,#e92a88);
  --ds-accent-2:var(--accent-2,#ffca2c);
  --ds-border:rgba(255,255,255,.18);
  --ds-radius:8px;
  --ds-shadow:0 18px 44px rgba(0,0,0,.28);
  --ds-container:1180px;
}
html{scroll-behavior:smooth}
body{background:var(--ds-bg);color:var(--ds-text)}
body a{color:inherit}
.main-nav,.nav-links{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.main-nav ul,.nav-links ul{display:contents;list-style:none;margin:0;padding:0}
.main-nav li,.nav-links li{display:contents;margin:0;padding:0}
.main-nav a,.nav-links a{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;white-space:nowrap}
.main-nav a.active,.nav-links a.active{background:var(--ds-accent-2);color:#111;border-radius:var(--ds-radius)}
.container,.site-container,.inner,.wrap{width:min(var(--ds-container),calc(100% - 40px));margin-inline:auto}
.section,.section-pad,.content-section{padding:64px 0}
.section-tight{padding:42px 0}
.breadcrumb,.breadcrumbs{width:min(var(--ds-container),calc(100% - 40px));margin:0 auto;padding:22px 0;color:var(--ds-muted);font-size:14px}
.breadcrumb a,.breadcrumbs a{color:var(--ds-accent-2);text-decoration:none}
.story,.page-hero,.hero,.hero-section{position:relative;overflow:hidden;background:var(--ds-surface-2);color:var(--ds-text)}
.story>.container,.hero .container,.hero-section .container{width:min(var(--ds-container),calc(100% - 40px));margin-inline:auto}
.story-flex,.hero-split,.inner-hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(280px,.8fr);align-items:center;gap:56px;padding:70px 0}
.story-copy,.hero-copy,.inner-hero-copy{max-width:680px}
.story-copy h1,.hero-copy h1,.page-hero h1,.inner-hero h1{font-size:clamp(34px,5vw,64px);line-height:1.05;letter-spacing:0;margin:0 0 22px;color:#fff}
.story-copy p,.hero-copy p,.inner-hero p,.lead{font-size:clamp(16px,1.4vw,19px);line-height:1.75;color:var(--ds-muted);margin:0 0 18px}
.story-media,.hero-media,.inner-hero-media{border:1px solid var(--ds-border);border-radius:var(--ds-radius);overflow:hidden;box-shadow:var(--ds-shadow);background:#000}
.story-media img,.hero-media img,.inner-hero-media img{display:block;width:100%;aspect-ratio:16/10;object-fit:cover}
.btn,.button,.cta-button,.primary-btn,.secondary-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 22px;border-radius:999px;font-weight:800;text-decoration:none;border:1px solid transparent;line-height:1}
.primary-btn,.btn-primary,.cta-button{background:var(--ds-accent);color:#fff;box-shadow:0 12px 28px color-mix(in srgb,var(--ds-accent) 35%,transparent)}
.secondary-btn,.btn-secondary{background:transparent;color:#fff;border-color:var(--ds-border)}
.btn:hover,.button:hover,.cta-button:hover{transform:translateY(-1px)}
.content-card,.info-card,.feature-card,.step-card,.related-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-radius);box-shadow:var(--ds-shadow);padding:28px;color:var(--ds-text)}
.content-card h2,.info-card h3,.feature-card h3,.step-card h3,.related-card h3{color:var(--ds-text);margin:0 0 12px;line-height:1.25}
.content-card p,.info-card p,.feature-card p,.step-card p,.related-card p{color:var(--ds-muted);line-height:1.72;margin:0}
.feature-grid,.cards-grid,.related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;width:min(var(--ds-container),calc(100% - 40px));margin-inline:auto}
.step-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;width:min(860px,calc(100% - 40px));margin-inline:auto}
.step-card .num,.step-number{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:var(--ds-accent-2);color:#111;font-weight:900;margin-bottom:14px}
.faq,.faq-section{width:min(860px,calc(100% - 40px));margin-inline:auto}
.faq details,.faq-item{border:1px solid var(--ds-border);border-radius:var(--ds-radius);background:rgba(255,255,255,.04);margin-bottom:12px;overflow:hidden}
.faq summary,.faq-question{cursor:pointer;padding:18px 20px;color:var(--ds-text);font-weight:800}
.faq details p,.faq-answer{padding:0 20px 18px;color:var(--ds-muted);line-height:1.72}
.related-links{width:min(860px,calc(100% - 40px));margin-inline:auto}
.related-links a{color:var(--ds-accent-2);font-weight:800}
.cta-band,.final-cta{background:var(--ds-accent);color:#fff;text-align:center;padding:56px 20px}
.cta-band h2,.final-cta h2{color:#fff;margin:0 0 12px;font-size:clamp(26px,3vw,42px)}
.cta-band p,.final-cta p{width:min(720px,100%);margin:0 auto 22px;color:#fff;line-height:1.7}
footer,.footer{background:#090014;color:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:34px;width:min(var(--ds-container),calc(100% - 40px));margin-inline:auto}
footer h3,footer h4,.footer h3,.footer h4{color:#fff;margin:0 0 14px}
footer p,footer li,footer a,.footer p,.footer li,.footer a{color:var(--ds-muted);line-height:1.65;text-decoration:none}
input,select,textarea{width:100%;border:1px solid var(--ds-border);border-radius:var(--ds-radius);padding:13px 14px;background:#fff;color:#111;font:inherit}
label{display:block;color:var(--ds-text);font-weight:700;margin-bottom:8px}
table{width:100%;border-collapse:collapse;background:var(--ds-surface);color:var(--ds-text);border-radius:var(--ds-radius);overflow:hidden}
th,td{padding:14px 16px;border-bottom:1px solid var(--ds-border);text-align:left}
th{color:var(--ds-text);background:rgba(255,255,255,.06)}
.text-safe,.content-section p,.content-section li{color:var(--ds-muted)}
.content-section h1,.content-section h2,.content-section h3{color:var(--ds-text)}
@media (max-width:900px){
  .story-flex,.hero-split,.inner-hero{grid-template-columns:1fr;gap:28px;padding:52px 0}
  .feature-grid,.cards-grid,.related-grid,.step-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .container,.site-container,.inner,.wrap,.breadcrumb,.breadcrumbs{width:min(100% - 28px,var(--ds-container))}
  .section,.section-pad,.content-section{padding:44px 0}
  .story-copy h1,.hero-copy h1,.page-hero h1,.inner-hero h1{font-size:34px}
  .footer-grid{grid-template-columns:1fr}
}

/* Uniform media grids: keep side-by-side images aligned */
.games-grid,
.game-grid,
.cards-grid,
.cat-grid,
.category-grid,
.overview-grid,
.slot-grid,
.casino-grid,
.game-gallery,
.game-list,
.featured-games,
.popular-games,
.grid {
  align-items: stretch;
  justify-content: center;
}
.games-grid img,
.game-grid img,
.slot-grid img,
.casino-grid img,
.game-gallery img,
.game-list img,
.featured-games img,
.popular-games img,
.game-tile img,
.slot-card img,
.casino-card img,
.game-card img,
.cat-card img,
.category-card img,
.cards-grid img,
.overview-grid img {
  width: 100% !important;
  height: 180px !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}
.game-card,
.game-tile,
.slot-card,
.casino-card,
.cat-card,
.category-card {
  display: grid !important;
  grid-template-rows: auto 1fr !important;
  align-content: start !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 14px !important;
}
.game-card > :not(img),
.game-tile > :not(img),
.slot-card > :not(img),
.casino-card > :not(img),
.cat-card > :not(img),
.category-card > :not(img) {
  margin-left: 18px !important;
  margin-right: 18px !important;
}
.game-card > img:first-child,
.game-tile > img:first-child,
.slot-card > img:first-child,
.casino-card > img:first-child,
.cat-card > img:first-child,
.category-card > img:first-child {
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  height: 180px !important;
  aspect-ratio: 16 / 10 !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  margin: 0 0 18px 0 !important;
  border-radius: 14px 14px 0 0 !important;
}
.game-card > img:first-child + *,
.game-tile > img:first-child + *,
.slot-card > img:first-child + *,
.casino-card > img:first-child + *,
.cat-card > img:first-child + *,
.category-card > img:first-child + * {
  margin-top: 0 !important;
}
.strip-inner img,
.partner-strip img,
.logo-strip img {
  width: 110px !important;
  height: 110px !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center !important;
}
@media (max-width: 640px) {
  .games-grid img,
  .game-grid img,
  .slot-grid img,
  .casino-grid img,
  .game-gallery img,
  .game-list img,
  .featured-games img,
  .popular-games img,
  .game-tile img,
  .slot-card img,
  .casino-card img,
  .game-card img,
  .cat-card img,
  .category-card img,
  .cards-grid img,
  .overview-grid img {
    height: 150px !important;
  }
}
.feat-card img,
.feature-card img,
.service-card img,
.news-card img {
  flex-shrink: 0 !important;
  object-fit: cover !important;
  object-position: center !important;
}

