/* vvd layout - dark casino shell */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --vvd-bg-deep:#0d0f18;
  --vvd-bg-panel:#151928;
  --vvd-bg-card:#1c2030;
  --vvd-bg-rail:#12151f;
  --vvd-accent:#e91e63;
  --vvd-accent-hover:#ff2d6f;
  --vvd-teal:#00d4aa;
  --vvd-orange:#ff8c42;
  --vvd-purple:#a855f7;
  --vvd-green:#4ade80;
  --vvd-gold:#fbbf24;
  --vvd-text:#f0f2f8;
  --vvd-muted:#8b92a8;
  --vvd-line:#2a3045;
  --vvd-radius:10px;
  --vvd-font:'Rubik',system-ui,-apple-system,sans-serif;
}

html{scroll-behavior:smooth}

body{
  font-family:var(--vvd-font);
  font-size:15px;
  line-height:1.55;
  color:var(--vvd-text);
  background:var(--vvd-bg-deep);
  background-image:radial-gradient(circle at 20% 0%,rgba(233,30,99,.06) 0%,transparent 45%),
    radial-gradient(circle at 80% 100%,rgba(168,85,247,.05) 0%,transparent 40%);
  min-height:100vh;
}

img{max-width:100%;height:auto;display:block}

a{color:inherit;text-decoration:none}

/* header shell */
.vvd-top-shell{
  position:sticky;
  top:0;
  z-index:900;
  background:var(--vvd-bg-deep);
  border-bottom:1px solid var(--vvd-line);
}

.vvd-top-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 20px;
  max-width:1280px;
  margin:0 auto;
}

.vvd-brand-zone{flex:0 0 auto}

.vvd-brand-mark img{
  height:32px;
  width:auto;
  max-width:160px;
  object-fit:contain;
}

.vvd-brand-text{
  font-size:1.5rem;
  font-weight:700;
  color:var(--vvd-accent);
  letter-spacing:.04em;
}

.vvd-auth-zone{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:auto;
}

.vvd-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 18px;
  border-radius:20px;
  font-size:.82rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.03em;
  transition:background .2s,transform .15s;
  white-space:nowrap;
}

.vvd-btn--login{
  color:var(--vvd-text);
  background:transparent;
  text-decoration:underline;
  text-underline-offset:3px;
  padding:8px 10px;
}

.vvd-btn--register{
  color:#fff;
  background:var(--vvd-accent);
}

.vvd-btn--register:hover{background:var(--vvd-accent-hover)}

.vvd-help-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--vvd-gold);
  color:#1a1200;
  font-weight:700;
  font-size:.85rem;
  cursor:default;
}

.vvd-drawer-trigger{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:40px;
  height:40px;
  padding:8px;
  border:none;
  border-radius:8px;
  background:var(--vvd-bg-card);
  cursor:pointer;
}

.vvd-drawer-bar{
  display:block;
  width:100%;
  height:2px;
  background:var(--vvd-text);
  border-radius:2px;
  transition:transform .25s,opacity .25s;
}

/* horizontal section rail */
.vvd-section-rail{
  background:var(--vvd-bg-rail);
  border-top:1px solid var(--vvd-line);
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}

.vvd-section-rail::-webkit-scrollbar{display:none}

.vvd-section-rail-list{
  display:flex;
  align-items:stretch;
  justify-content:center;
  gap:4px;
  list-style:none;
  max-width:1280px;
  margin:0 auto;
  padding:6px 12px;
}

.vvd-section-rail-entry{flex:0 0 auto}

.vvd-section-rail-anchor{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  padding:8px 16px;
  border-radius:var(--vvd-radius);
  color:var(--vvd-muted);
  font-size:.68rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  transition:color .2s,background .2s;
  min-width:72px;
}

.vvd-section-rail-anchor:hover{color:var(--vvd-text)}

.vvd-section-rail-anchor.is-active{
  color:var(--vvd-text);
  background:rgba(255,255,255,.04);
}

.vvd-section-rail-glyph{
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
}

.vvd-nav-glyph{width:28px;height:28px}

.vvd-section-rail-entry:nth-child(1) .vvd-nav-glyph{color:var(--vvd-teal)}
.vvd-section-rail-entry:nth-child(2) .vvd-nav-glyph{color:var(--vvd-orange)}
.vvd-section-rail-entry:nth-child(3) .vvd-nav-glyph{color:var(--vvd-purple)}
.vvd-section-rail-entry:nth-child(4) .vvd-nav-glyph{color:var(--vvd-green)}
.vvd-section-rail-entry:nth-child(5) .vvd-nav-glyph{color:var(--vvd-gold)}
.vvd-section-rail-entry:nth-child(6) .vvd-nav-glyph{color:var(--vvd-accent)}

.vvd-section-rail-anchor.is-active .vvd-nav-glyph{filter:drop-shadow(0 0 6px currentColor)}

/* mobile drawer */
.vvd-drawer-panel{
  position:fixed;
  top:0;
  right:0;
  width:min(300px,85vw);
  height:100vh;
  background:var(--vvd-bg-panel);
  border-left:1px solid var(--vvd-line);
  transform:translateX(100%);
  transition:transform .3s ease;
  z-index:1100;
  overflow-y:auto;
  padding:70px 16px 24px;
}

.vvd-drawer-panel.is-open{transform:translateX(0)}

.vvd-drawer-scrim{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.6);
  opacity:0;
  visibility:hidden;
  transition:opacity .3s,visibility .3s;
  z-index:1050;
}

.vvd-drawer-scrim.is-visible{opacity:1;visibility:visible}

.vvd-drawer-list{list-style:none}

.vvd-drawer-entry{border-bottom:1px solid var(--vvd-line)}

.vvd-drawer-anchor{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 8px;
  color:var(--vvd-text);
  font-weight:500;
}

.vvd-drawer-anchor.is-active{color:var(--vvd-accent)}

.vvd-drawer-glyph{width:32px;display:flex;align-items:center;justify-content:center}

.vvd-drawer-entry:nth-child(1) .vvd-nav-glyph{color:var(--vvd-teal)}
.vvd-drawer-entry:nth-child(2) .vvd-nav-glyph{color:var(--vvd-orange)}
.vvd-drawer-entry:nth-child(3) .vvd-nav-glyph{color:var(--vvd-purple)}
.vvd-drawer-entry:nth-child(4) .vvd-nav-glyph{color:var(--vvd-green)}
.vvd-drawer-entry:nth-child(5) .vvd-nav-glyph{color:var(--vvd-gold)}
.vvd-drawer-entry:nth-child(6) .vvd-nav-glyph{color:var(--vvd-accent)}

/* main content */
.vvd-page-body{
  max-width:1280px;
  margin:0 auto;
  padding:16px 20px 40px;
}

.vvd-crumb-trail{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px;
  margin-bottom:16px;
  font-size:.8rem;
  color:var(--vvd-muted);
}

.vvd-crumb-item{color:var(--vvd-muted);transition:color .2s}
.vvd-crumb-item:hover{color:var(--vvd-text)}
.vvd-crumb-sep{opacity:.5}

/* hero banners - natural dimensions */
.vvd-hero-strip{margin-bottom:20px}

.vvd-hero-frame{
  display:flex;
  justify-content:center;
  margin-bottom:12px;
}

.vvd-hero-frame picture{display:block;line-height:0}

.vvd-hero-visual{
  width:100%;
  height:auto;
  border-radius:var(--vvd-radius);
  display:block;
}

.vvd-hero-visual--wide{max-width:768px}
.vvd-hero-visual--compact{max-width:250px}

.vvd-hero-caption{
  text-align:center;
  padding:12px 16px;
  background:var(--vvd-bg-card);
  border-radius:var(--vvd-radius);
  border:1px solid var(--vvd-line);
}

.vvd-hero-heading{
  font-size:1rem;
  font-weight:600;
  margin-bottom:6px;
  color:var(--vvd-text);
}

.vvd-hero-sub{font-size:.85rem;color:var(--vvd-muted);margin-bottom:10px}

.vvd-hero-cta{
  display:inline-flex;
  padding:10px 24px;
  border-radius:20px;
  background:var(--vvd-accent);
  color:#fff;
  font-weight:600;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.vvd-hero-cta:hover{background:var(--vvd-accent-hover)}

/* game grid */
.vvd-slots-block{margin-bottom:28px}

.vvd-slots-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
  gap:12px;
}

.vvd-slots-label{
  font-size:1rem;
  font-weight:600;
  color:var(--vvd-text);
}

.vvd-slots-more{
  padding:6px 16px;
  border-radius:16px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  color:var(--vvd-muted);
  font-size:.78rem;
  font-weight:500;
  text-transform:uppercase;
  transition:border-color .2s,color .2s;
}

.vvd-slots-more:hover{border-color:var(--vvd-accent);color:var(--vvd-text)}

.vvd-slots-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
}

.vvd-slot-tile{
  border-radius:var(--vvd-radius);
  overflow:hidden;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  transition:transform .2s,border-color .2s;
}

.vvd-slot-tile:hover{
  transform:translateY(-2px);
  border-color:rgba(233,30,99,.4);
}

.vvd-slot-visual{position:relative;overflow:hidden;aspect-ratio:5/7}

.vvd-slot-visual img{width:100%;height:100%;object-fit:contain;display:block}

.vvd-slot-overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  background:rgba(0,0,0,.65);
  opacity:0;
  transition:opacity .25s;
}

.vvd-slot-tile:hover .vvd-slot-overlay{opacity:1}

.vvd-slot-play{
  padding:8px 20px;
  border-radius:16px;
  background:var(--vvd-green);
  color:#052e16;
  font-weight:700;
  font-size:.78rem;
  text-transform:uppercase;
}

.vvd-slot-name{
  padding:8px 10px;
  font-size:.75rem;
  font-weight:500;
  text-align:center;
  color:var(--vvd-muted);
  background:rgba(0,0,0,.25);
}

/* bonuses */
.vvd-promo-block{margin-bottom:36px}

.vvd-promo-block .vvd-slots-label{
  font-size:1.1rem;
  font-weight:700;
  margin-bottom:20px;
  padding-bottom:12px;
  border-bottom:2px solid var(--vvd-line);
  background:linear-gradient(90deg,var(--vvd-gold),var(--vvd-accent));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.vvd-promo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;
}

.vvd-promo-card{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  transition:transform .2s,box-shadow .25s,border-color .2s;
  display:flex;
  flex-direction:column;
}

.vvd-promo-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(0,0,0,.35),0 0 0 1px rgba(233,30,99,.2);
  border-color:rgba(233,30,99,.3);
}

.vvd-promo-card img{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  transition:transform .35s;
}

.vvd-promo-card:hover img{transform:scale(1.03)}

.vvd-promo-card::after{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:120px;
  background:linear-gradient(180deg,rgba(13,15,24,.5) 0%,transparent 100%);
  pointer-events:none;
}

.vvd-promo-body{
  padding:18px;
  display:flex;
  flex-direction:column;
  flex:1;
  gap:8px;
}

.vvd-promo-title{
  font-weight:700;
  font-size:.95rem;
  line-height:1.35;
  color:var(--vvd-text);
}

.vvd-promo-desc{
  font-size:.82rem;
  color:var(--vvd-muted);
  line-height:1.55;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.vvd-promo-value{
  display:inline-flex;
  align-self:flex-start;
  font-weight:800;
  font-size:.88rem;
  color:#1a1200;
  background:linear-gradient(135deg,var(--vvd-gold) 0%,#f59e0b 100%);
  padding:6px 14px;
  border-radius:20px;
  margin-top:4px;
  box-shadow:0 2px 12px rgba(251,191,36,.3);
}

.vvd-promo-tag{
  display:inline-flex;
  align-self:flex-start;
  padding:4px 12px;
  border-radius:20px;
  background:rgba(168,85,247,.15);
  border:1px solid rgba(168,85,247,.3);
  color:var(--vvd-purple);
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.vvd-promo-terms{
  margin-top:auto;
  padding-top:12px;
  border-top:1px solid var(--vvd-line);
  font-size:.72rem;
  color:var(--vvd-muted);
  line-height:1.5;
  font-style:italic;
}

/* seo article block - only place with h1-h3 */
.vvd-seo-article{
  max-width:900px;
  margin:32px auto 0;
  padding:32px 28px;
  background:var(--vvd-bg-panel);
  border-radius:16px;
  border:1px solid var(--vvd-line);
  position:relative;
  overflow:hidden;
}

.vvd-seo-article::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:2px;
  background:linear-gradient(90deg,var(--vvd-teal),var(--vvd-accent),var(--vvd-purple));
}

.vvd-seo-article h1{
  font-size:1.65rem;
  font-weight:800;
  margin-bottom:22px;
  line-height:1.3;
  letter-spacing:-.02em;
  padding-bottom:16px;
  border-bottom:1px solid var(--vvd-line);
}

.vvd-seo-article h2{
  font-size:1.2rem;
  font-weight:700;
  margin:32px 0 14px;
  padding:10px 0 10px 14px;
  border-left:3px solid var(--vvd-accent);
  color:var(--vvd-text);
  background:linear-gradient(90deg,rgba(233,30,99,.06) 0%,transparent 100%);
  border-radius:0 var(--vvd-radius) var(--vvd-radius) 0;
}

.vvd-seo-article h3{
  font-size:1.02rem;
  font-weight:600;
  margin:24px 0 10px;
  color:var(--vvd-teal);
}

.vvd-seo-article p{
  margin-bottom:16px;
  color:var(--vvd-muted);
  font-size:.9rem;
  line-height:1.75;
}

.vvd-seo-article a{
  color:var(--vvd-accent);
  text-decoration:none;
  font-weight:500;
  border-bottom:1px solid rgba(233,30,99,.3);
  transition:color .2s,border-color .2s;
}

.vvd-seo-article a:hover{
  color:var(--vvd-accent-hover);
  border-color:var(--vvd-accent);
}

.vvd-seo-article img{
  margin:20px 0;
  border-radius:var(--vvd-radius);
  border:1px solid var(--vvd-line);
}

.vvd-seo-article ul,.vvd-seo-article ol{
  margin:16px 0 20px;
  padding-left:0;
  list-style:none;
  color:var(--vvd-muted);
}

.vvd-seo-article li{
  position:relative;
  margin-bottom:8px;
  padding:6px 0 6px 20px;
  font-size:.88rem;
  line-height:1.65;
}

.vvd-seo-article ul li::before{
  content:'';
  position:absolute;
  left:0;
  top:12px;
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--vvd-accent);
}

.vvd-seo-article ol{counter-reset:vvd-list}

.vvd-seo-article ol li{counter-increment:vvd-list;padding-left:28px}

.vvd-seo-article ol li::before{
  content:counter(vvd-list);
  position:absolute;
  left:0;
  top:8px;
  width:20px;
  height:20px;
  line-height:20px;
  text-align:center;
  border-radius:6px;
  background:rgba(233,30,99,.15);
  color:var(--vvd-accent);
  font-size:.7rem;
  font-weight:700;
}

.vvd-seo-article blockquote{
  margin:20px 0;
  padding:16px 20px;
  border-left:3px solid var(--vvd-accent);
  background:rgba(233,30,99,.06);
  border-radius:0 var(--vvd-radius) var(--vvd-radius) 0;
  color:var(--vvd-muted);
  font-size:.88rem;
  line-height:1.65;
}

.vvd-seo-article .list-container{
  margin:14px 0 20px;
  padding:14px 18px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-radius:var(--vvd-radius);
}

/* tables - horizontal scroll on mobile */
.table-wrapper,.vvd-seo-article .table-wrapper{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  margin:18px 0;
  border-radius:var(--vvd-radius);
  border:1px solid var(--vvd-line);
}

.table-wrapper table,.vvd-seo-article table{
  width:100%;
  min-width:480px;
  border-collapse:collapse;
  font-size:.88rem;
}

.table-wrapper th,.table-wrapper td,.vvd-seo-article th,.vvd-seo-article td{
  padding:10px 14px;
  border-bottom:1px solid var(--vvd-line);
  text-align:left;
}

.table-wrapper th,.vvd-seo-article th{
  background:var(--vvd-bg-card);
  font-weight:600;
  color:var(--vvd-text);
  white-space:nowrap;
}

.table-wrapper td,.vvd-seo-article td{color:var(--vvd-muted)}

.table-wrapper caption,.vvd-seo-article caption{
  padding:10px;
  font-weight:600;
  text-align:left;
  color:var(--vvd-text);
}

/* faq / howto */
.faq-wrapper,.howto-wrapper{margin:18px 0}

.faq-item-block{
  margin-bottom:10px;
  border:1px solid var(--vvd-line);
  border-radius:var(--vvd-radius);
  overflow:hidden;
  background:var(--vvd-bg-card);
}

.faq-question-block{padding:14px;background:rgba(255,255,255,.03);border-bottom:1px solid var(--vvd-line)}
.faq-answer-block{padding:14px;color:var(--vvd-muted);font-size:.9rem}

.howto-wrapper{padding:18px;background:var(--vvd-bg-card);border-radius:var(--vvd-radius);border:1px solid var(--vvd-line)}

.howto-steps-list{list-style:none;counter-reset:vvd-step}

.howto-step-item{
  counter-increment:vvd-step;
  padding:14px;
  margin-bottom:8px;
  background:var(--vvd-bg-panel);
  border-radius:8px;
  border-left:3px solid var(--vvd-accent);
}

.howto-step-item::before{content:counter(vvd-step) ". ";font-weight:700;color:var(--vvd-accent)}
.howto-step-item strong{display:block;margin-bottom:6px}

.list-container{margin:14px 0;color:var(--vvd-muted)}

/* payments */
.vvd-pay-block{margin:28px 0}

.vvd-pay-label{font-size:1rem;font-weight:600;margin-bottom:14px}

.vvd-pay-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(110px,1fr));
  gap:12px;
}

.vvd-pay-item{
  padding:14px 10px;
  text-align:center;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-radius:var(--vvd-radius);
}

.vvd-pay-item img{max-height:32px;margin:0 auto 8px;object-fit:contain}
.vvd-pay-item span{font-size:.72rem;color:var(--vvd-muted);font-weight:500}

/* app info table */
.vvd-app-hero{
  margin:0 0 32px;
  position:relative;
}

.vvd-app-hero::before{
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:22px;
  background:linear-gradient(135deg,rgba(0,212,170,.3),rgba(233,30,99,.3),rgba(168,85,247,.2));
  z-index:0;
  opacity:.6;
}

.app-info-table-wrapper{margin:20px 0}

.vvd-app-hero.app-info-table-wrapper{margin:0 0 32px}

.app-info-table-container{
  position:relative;
  z-index:1;
  border-radius:20px;
  border:1px solid var(--vvd-line);
  overflow:hidden;
  background:var(--vvd-bg-card);
  box-shadow:0 12px 40px rgba(0,0,0,.35);
}

.app-info-table{width:100%;min-width:320px;border-collapse:collapse}

.app-info-row{
  border-bottom:1px solid var(--vvd-line);
  transition:background .2s;
}

.app-info-row:hover{background:rgba(255,255,255,.02)}

.app-info-row:last-child{border-bottom:none}

.app-info-row:first-child{
  background:linear-gradient(135deg,rgba(233,30,99,.1) 0%,rgba(168,85,247,.06) 100%);
}

.app-info-row:first-child .app-info-value-cell{
  font-size:1.05rem;
}

.app-info-label-cell{
  padding:16px 12px;
  text-align:center;
  width:72px;
  vertical-align:middle;
}

.app-info-label-wrapper{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:12px;
  background:var(--vvd-bg-panel);
  border:1px solid var(--vvd-line);
}

.app-info-icon{width:22px;height:22px}

.app-info-icon--name{color:var(--vvd-teal)}
.app-info-icon--desc{color:var(--vvd-purple)}
.app-info-icon--platform{color:var(--vvd-orange)}
.app-info-icon--size{color:var(--vvd-gold)}
.app-info-icon--version{color:var(--vvd-green)}
.app-info-icon--updated{color:var(--vvd-accent)}
.app-info-icon--download{color:var(--vvd-teal)}

.app-info-value-cell{
  padding:16px 20px 16px 8px;
  color:var(--vvd-muted);
  font-size:.88rem;
  line-height:1.55;
  vertical-align:middle;
}

.app-name-with-logo{display:flex;align-items:center;gap:14px}

.app-name-logo{
  width:52px;
  height:52px;
  object-fit:contain;
  border-radius:14px;
  padding:6px;
  background:var(--vvd-bg-panel);
  border:1px solid var(--vvd-line);
  box-shadow:0 4px 16px rgba(233,30,99,.2);
}

.app-name-text{
  font-weight:700;
  font-size:1.2rem;
  color:var(--vvd-text);
  letter-spacing:-.01em;
}

.app-info-row:last-child .app-info-value-cell{padding:20px}

.app-download-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 28px;
  border-radius:28px;
  background:linear-gradient(135deg,var(--vvd-teal) 0%,#00b894 100%);
  color:#0d0f18;
  font-weight:700;
  font-size:.88rem;
  letter-spacing:.02em;
  box-shadow:0 6px 24px rgba(0,212,170,.35);
  transition:transform .15s,box-shadow .2s;
}

.app-download-link:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(0,212,170,.5);
}

.app-download-link::after{
  content:'↓';
  font-size:1rem;
  line-height:1;
}

/* footer */
.vvd-page-footer{
  position:relative;
  background:var(--vvd-bg-panel);
  border-top:1px solid var(--vvd-line);
  margin-top:32px;
  overflow:hidden;
}

.vvd-footer-accent{
  height:3px;
  background:linear-gradient(90deg,var(--vvd-teal) 0%,var(--vvd-accent) 35%,var(--vvd-purple) 70%,var(--vvd-gold) 100%);
}

.vvd-footer-inner{
  max-width:1280px;
  margin:0 auto;
  padding:40px 20px 28px;
}

.vvd-footer-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr 1fr;
  gap:32px 40px;
  margin-bottom:36px;
}

.vvd-footer-col{display:flex;flex-direction:column;gap:16px}

.vvd-footer-col-title{
  font-size:.68rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--vvd-accent);
  margin-bottom:4px;
}

.vvd-footer-col-title--center{text-align:center}

.vvd-footer-brand{display:flex;justify-content:flex-start}

.vvd-brand-mark--footer img{height:32px;filter:drop-shadow(0 2px 8px rgba(233,30,99,.25))}

.vvd-footer-links-row{flex:1}

.vvd-footer-links{
  display:flex;
  flex-direction:column;
  gap:10px;
  list-style:none;
}

.vvd-footer-links a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.84rem;
  color:var(--vvd-muted);
  transition:color .2s,padding-left .2s;
  padding:2px 0;
}

.vvd-footer-links a::before{
  content:'';
  width:4px;
  height:4px;
  border-radius:50%;
  background:var(--vvd-line);
  transition:background .2s,transform .2s;
  flex-shrink:0;
}

.vvd-footer-links a:hover{
  color:var(--vvd-text);
  padding-left:4px;
}

.vvd-footer-links a:hover::before{
  background:var(--vvd-accent);
  transform:scale(1.4);
}

.vvd-footer-apps{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.vvd-app-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 20px;
  border-radius:24px;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.02em;
  border:1px solid var(--vvd-line);
  background:var(--vvd-bg-card);
  color:var(--vvd-text);
  transition:border-color .2s,transform .15s,box-shadow .2s;
  text-align:center;
}

.vvd-app-pill:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(0,0,0,.3);
}

.vvd-app-pill--primary{
  background:linear-gradient(135deg,var(--vvd-accent) 0%,#c2185b 100%);
  border-color:transparent;
  color:#fff;
  box-shadow:0 4px 20px rgba(233,30,99,.3);
}

.vvd-app-pill--primary:hover{box-shadow:0 6px 24px rgba(233,30,99,.45)}

.vvd-app-pill--secondary{
  background:transparent;
  border-color:var(--vvd-line);
}

.vvd-app-pill--secondary:hover{border-color:var(--vvd-muted)}

.vvd-app-pill--accent{
  background:linear-gradient(135deg,#16a34a 0%,#15803d 100%);
  border-color:transparent;
  color:#fff;
  box-shadow:0 4px 16px rgba(22,163,74,.25);
}

.vvd-footer-social{margin-top:8px}

.vvd-social-ring{
  display:flex;
  gap:10px;
  list-style:none;
}

.vvd-social-node{
  display:flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:12px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  overflow:hidden;
  color:var(--vvd-muted);
  transition:border-color .2s,transform .2s,background .2s,color .2s;
}

.vvd-social-node:hover{
  transform:translateY(-2px);
  border-color:var(--vvd-accent);
  color:var(--vvd-text);
}

.vvd-social-node--yt:hover{color:#ff4444;border-color:#ff4444}
.vvd-social-node--ig:hover{color:#e1306c;border-color:#e1306c}
.vvd-social-node--x:hover{color:var(--vvd-text);border-color:var(--vvd-text)}

.vvd-social-node img{width:22px;height:22px;object-fit:contain}

.vvd-social-svg{display:block}

.vvd-social-fallback{font-size:.6rem;font-weight:700;text-transform:uppercase}

.vvd-footer-payments{
  padding:24px 0;
  margin-bottom:28px;
  border-top:1px solid var(--vvd-line);
  border-bottom:1px solid var(--vvd-line);
}

.vvd-footer-pay-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:12px;
  margin-top:14px;
}

.vvd-footer-pay-item{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 16px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-radius:var(--vvd-radius);
  min-width:72px;
  transition:border-color .2s,transform .15s;
}

.vvd-footer-pay-item:hover{
  border-color:rgba(233,30,99,.4);
  transform:translateY(-1px);
}

.vvd-footer-pay-item img{max-height:28px;object-fit:contain}

.vvd-footer-legal{text-align:center}

.vvd-safe-strip{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:20px;
  list-style:none;
  margin-bottom:20px;
  padding:16px 20px;
  background:rgba(0,0,0,.2);
  border-radius:var(--vvd-radius);
  border:1px solid var(--vvd-line);
}

.vvd-safe-link{
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:.85;
  transition:opacity .2s,transform .15s;
}

.vvd-safe-link:hover{opacity:1;transform:scale(1.04)}

.vvd-safe-badge{max-width:80px;height:auto}

.vvd-footer-copy-wrap{
  display:flex;
  flex-direction:column;
  gap:6px;
  max-width:720px;
  margin:0 auto;
}

.vvd-footer-copy{font-size:.76rem;color:var(--vvd-text);line-height:1.5;font-weight:500}

.vvd-footer-disclaimer{font-size:.7rem;color:var(--vvd-muted);line-height:1.6}

/* 404 */
.vvd-page-body--404{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:calc(100vh - 200px);
  padding:40px 20px;
}

.vvd-error-panel{
  position:relative;
  text-align:center;
  padding:56px 36px 48px;
  max-width:480px;
  width:100%;
  margin:0 auto;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 0 60px rgba(233,30,99,.12),0 20px 60px rgba(0,0,0,.4);
}

.vvd-error-panel::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(233,30,99,.15) 0%,transparent 55%),
    radial-gradient(circle at 80% 80%,rgba(168,85,247,.1) 0%,transparent 40%);
  pointer-events:none;
}

.vvd-error-panel::after{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:linear-gradient(90deg,var(--vvd-teal),var(--vvd-accent),var(--vvd-purple),var(--vvd-gold));
}

.vvd-error-code{
  position:relative;
  font-size:6rem;
  font-weight:800;
  line-height:1;
  margin-bottom:20px;
  background:linear-gradient(135deg,var(--vvd-accent) 0%,var(--vvd-purple) 50%,var(--vvd-gold) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  filter:drop-shadow(0 4px 20px rgba(233,30,99,.4));
  letter-spacing:-.04em;
}

.vvd-error-title{
  position:relative;
  font-size:1.15rem;
  font-weight:700;
  margin-bottom:14px;
  color:var(--vvd-text);
  line-height:1.4;
}

.vvd-error-desc{
  position:relative;
  color:var(--vvd-muted);
  margin-bottom:32px;
  font-size:.9rem;
  line-height:1.6;
}

.vvd-page-body--404 .vvd-btn--register{
  position:relative;
  padding:14px 32px;
  font-size:.85rem;
  border-radius:28px;
  box-shadow:0 6px 24px rgba(233,30,99,.35);
  transition:transform .15s,box-shadow .2s;
}

.vvd-page-body--404 .vvd-btn--register:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(233,30,99,.5);
}

/* contact */
.vvd-page-body--contact .vvd-seo-article{
  max-width:640px;
  margin:0 auto;
  padding:0;
  background:transparent;
  border:none;
}

.vvd-page-body--contact .vvd-seo-article h1{
  text-align:center;
  font-size:2rem;
  font-weight:800;
  margin-bottom:12px;
  padding:40px 24px 32px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-radius:20px 20px 0 0;
  position:relative;
  overflow:hidden;
}

.vvd-page-body--contact .vvd-seo-article h1::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 30% 20%,rgba(0,212,170,.12) 0%,transparent 50%),
    radial-gradient(circle at 70% 80%,rgba(233,30,99,.1) 0%,transparent 45%);
  pointer-events:none;
}

.vvd-page-body--contact .vvd-seo-article > p:first-of-type{
  text-align:center;
  font-size:.95rem;
  color:var(--vvd-muted);
  padding:0 24px 28px;
  margin-bottom:0;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-top:none;
  border-radius:0 0 20px 20px;
  margin-bottom:28px;
}

.vvd-page-body--contact .vvd-seo-article h2{
  font-size:1rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--vvd-teal);
  margin:32px 0 16px;
  padding-bottom:10px;
  border-bottom:2px solid var(--vvd-line);
}

.vvd-page-body--contact .vvd-seo-article h3{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.92rem;
  font-weight:700;
  margin:0;
  padding:16px 20px;
  background:linear-gradient(135deg,rgba(233,30,99,.12) 0%,rgba(168,85,247,.08) 100%);
  border:1px solid var(--vvd-line);
  border-bottom:none;
  border-radius:14px 14px 0 0;
  color:var(--vvd-text);
}

.vvd-page-body--contact .vvd-seo-article h3::before{
  content:'';
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--vvd-accent);
  box-shadow:0 0 10px var(--vvd-accent);
  flex-shrink:0;
}

.vvd-page-body--contact .vvd-seo-article h3 + p{
  margin:0 0 16px;
  padding:16px 20px 20px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-top:none;
  border-radius:0 0 14px 14px;
  color:var(--vvd-text);
  font-size:.9rem;
  line-height:1.6;
}

.vvd-page-body--contact .vvd-seo-article h3 + p a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 14px;
  margin-top:6px;
  background:rgba(233,30,99,.15);
  border:1px solid rgba(233,30,99,.3);
  border-radius:20px;
  color:var(--vvd-accent);
  font-weight:600;
  text-decoration:none;
  transition:background .2s,transform .15s;
}

.vvd-page-body--contact .vvd-seo-article h3 + p a:hover{
  background:rgba(233,30,99,.25);
  transform:translateY(-1px);
}

/* legal pages - privacy & terms */
.vvd-page-body--legal .vvd-seo-article{
  counter-reset:vvd-legal-section;
  max-width:780px;
  margin:0 auto;
  padding:36px 32px 40px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  border-radius:20px;
  position:relative;
  overflow:hidden;
}

.vvd-page-body--legal .vvd-seo-article::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:linear-gradient(90deg,var(--vvd-purple),var(--vvd-accent),var(--vvd-teal));
}

.vvd-page-body--legal .vvd-seo-article::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 100% 0%,rgba(168,85,247,.06) 0%,transparent 40%);
  pointer-events:none;
}

.vvd-page-body--legal .vvd-seo-article h1{
  font-size:1.75rem;
  font-weight:800;
  margin-bottom:20px;
  padding-bottom:18px;
  border-bottom:1px solid var(--vvd-line);
  background:linear-gradient(135deg,var(--vvd-text) 60%,var(--vvd-purple) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.vvd-page-body--legal .vvd-seo-article > p:first-of-type{
  font-size:.92rem;
  line-height:1.7;
  color:var(--vvd-muted);
  padding:16px 18px;
  background:rgba(168,85,247,.06);
  border-left:3px solid var(--vvd-purple);
  border-radius:0 var(--vvd-radius) var(--vvd-radius) 0;
  margin-bottom:28px;
}

.vvd-page-body--legal .vvd-seo-article h2{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:1.1rem;
  font-weight:700;
  margin:36px 0 14px;
  padding:12px 0 12px 16px;
  border-left:3px solid var(--vvd-accent);
  color:var(--vvd-text);
  background:linear-gradient(90deg,rgba(233,30,99,.08) 0%,transparent 100%);
  border-radius:0 var(--vvd-radius) var(--vvd-radius) 0;
}

.vvd-page-body--legal .vvd-seo-article h2::before{
  content:counter(vvd-legal-section);
  counter-increment:vvd-legal-section;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  height:28px;
  border-radius:8px;
  background:var(--vvd-accent);
  color:#fff;
  font-size:.75rem;
  font-weight:800;
  flex-shrink:0;
}

.vvd-page-body--legal .vvd-seo-article p{
  font-size:.88rem;
  line-height:1.75;
  color:var(--vvd-muted);
}

.vvd-page-body--legal .vvd-seo-article .list-container{
  margin:14px 0 20px;
  padding:16px 20px;
  background:var(--vvd-bg-panel);
  border:1px solid var(--vvd-line);
  border-radius:var(--vvd-radius);
}

.vvd-page-body--legal .vvd-seo-article ul,
.vvd-page-body--legal .vvd-seo-article ol{
  margin:0;
  padding-left:0;
  list-style:none;
}

.vvd-page-body--legal .vvd-seo-article li{
  position:relative;
  padding:8px 0 8px 22px;
  font-size:.86rem;
  line-height:1.6;
  color:var(--vvd-muted);
  border-bottom:1px solid rgba(42,48,69,.5);
}

.vvd-page-body--legal .vvd-seo-article li:last-child{border-bottom:none}

.vvd-page-body--legal .vvd-seo-article li::before{
  content:'';
  position:absolute;
  left:0;
  top:14px;
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--vvd-teal);
}

.vvd-page-body--legal .vvd-seo-article a{
  color:var(--vvd-accent);
  font-weight:500;
}

.vvd-page-body--legal .vvd-seo-article blockquote{
  margin:20px 0;
  padding:18px 22px;
  border-left:3px solid var(--vvd-gold);
  background:rgba(251,191,36,.06);
  border-radius:0 var(--vvd-radius) var(--vvd-radius) 0;
}

/* legacy class mapping for PHP templates */
.main-content-wrapper{
  max-width:1280px;
  margin:0 auto;
  padding:16px 20px 40px;
}

.game-section,.vvd-slots-block{margin-bottom:28px}

.section-header,.vvd-slots-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
}

.section-title,.vvd-slots-label{font-size:1rem;font-weight:600}

.show-all-btn,.vvd-slots-more{
  padding:6px 16px;
  border-radius:16px;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
  color:var(--vvd-muted);
  font-size:.78rem;
  font-weight:500;
  text-transform:uppercase;
}

.games-grid,.vvd-slots-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
}

.game-card,.vvd-slot-tile{
  border-radius:var(--vvd-radius);
  overflow:hidden;
  background:var(--vvd-bg-card);
  border:1px solid var(--vvd-line);
}

.game-image-wrapper{position:relative;aspect-ratio:4/3;overflow:hidden}

.vvd-slot-visual{position:relative;aspect-ratio:5/7;overflow:hidden}

.game-image{width:100%;height:100%;object-fit:cover}

.vvd-slot-visual img{width:100%;height:100%;object-fit:contain;display:block}

.game-play-btn,.vvd-slot-play{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.65);
  color:var(--vvd-green);
  font-weight:700;
  font-size:.78rem;
  text-transform:uppercase;
  opacity:0;
  transition:opacity .25s;
}

.game-card:hover .game-play-btn,.vvd-slot-tile:hover .vvd-slot-play{opacity:1}

.game-title,.vvd-slot-name{
  padding:8px 10px;
  font-size:.75rem;
  text-align:center;
  color:var(--vvd-muted);
}

.bonuses-section,.vvd-promo-block{margin-bottom:28px}
.bonuses-grid,.vvd-promo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.bonus-card,.vvd-promo-card{border-radius:var(--vvd-radius);overflow:hidden;background:var(--vvd-bg-card);border:1px solid var(--vvd-line)}
.bonus-image,.vvd-promo-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.bonus-content,.vvd-promo-body{padding:14px}
.bonus-name,.vvd-promo-title{font-weight:600;margin-bottom:8px}
.bonus-description,.vvd-promo-desc{font-size:.85rem;color:var(--vvd-muted);margin-bottom:8px}
.bonus-value,.vvd-promo-value{font-weight:700;color:var(--vvd-gold)}
.bonus-category-badge,.vvd-promo-tag{display:inline-block;padding:3px 10px;border-radius:12px;background:rgba(168,85,247,.2);color:var(--vvd-purple);font-size:.72rem}
.bonus-terms,.vvd-promo-terms{margin-top:10px;padding-top:10px;border-top:1px solid var(--vvd-line);font-size:.75rem;color:var(--vvd-muted)}

.payment-methods-section,.vvd-pay-block{margin:28px 0}
.payment-methods-grid,.vvd-pay-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}
.payment-method-card,.vvd-pay-item{padding:14px 10px;text-align:center;background:var(--vvd-bg-card);border:1px solid var(--vvd-line);border-radius:var(--vvd-radius)}
.payment-method-image{max-height:32px;margin:0 auto 8px}
.payment-method-name{font-size:.72rem;color:var(--vvd-muted)}

.btn-primary{
  display:inline-flex;
  padding:10px 24px;
  border-radius:20px;
  background:var(--vvd-accent);
  color:#fff;
  font-weight:600;
  font-size:.82rem;
}

.promotional-banners,.vvd-hero-strip{margin-bottom:20px}
.promo-banner,.vvd-hero-frame{margin-bottom:12px}
.promo-banner picture,.vvd-hero-frame picture{display:flex;justify-content:center}
.promo-banner-image,.vvd-hero-visual{width:100%;height:auto;border-radius:var(--vvd-radius);max-width:768px}
.promo-banner-content,.vvd-hero-caption{text-align:center;padding:12px 16px;background:var(--vvd-bg-card);border-radius:var(--vvd-radius);border:1px solid var(--vvd-line)}
.promo-banner-title,.vvd-hero-heading{font-size:1rem;font-weight:600;margin-bottom:6px}
.promo-banner-text,.vvd-hero-sub{font-size:.85rem;color:var(--vvd-muted);margin-bottom:10px}
.promo-banner-btn,.vvd-hero-cta{display:inline-flex;padding:10px 24px;border-radius:20px;background:var(--vvd-accent);color:#fff;font-weight:600;font-size:.82rem;text-transform:uppercase}

/* responsive */
@media(max-width:992px){
  .games-grid,.vvd-slots-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:768px){
  .vvd-top-row{
    position:relative;
    flex-wrap:wrap;
    justify-content:center;
    padding:10px 50px 10px 14px;
  }

  .vvd-brand-zone{
    width:100%;
    display:flex;
    justify-content:center;
    order:1;
  }

  .vvd-brand-zone--empty{display:none}

  .vvd-brand-mark img{height:26px}

  .vvd-auth-zone{
    order:2;
    width:100%;
    justify-content:center;
    margin-left:0;
    gap:8px;
  }

  .vvd-btn--login{font-size:.75rem;padding:6px 6px}
  .vvd-btn--register{font-size:.75rem;padding:7px 14px}

  .vvd-section-rail{display:none}

  .vvd-drawer-trigger{
    display:flex;
    position:absolute;
    top:10px;
    right:14px;
  }

  .games-grid,.vvd-slots-grid{grid-template-columns:repeat(2,1fr);gap:8px}

  .vvd-hero-frame picture{display:flex;justify-content:center}
  .vvd-hero-visual--wide{max-width:250px;width:100%;aspect-ratio:1/1}

  .vvd-seo-article{padding:16px;margin-top:20px}
  .vvd-seo-article h1{font-size:1.3rem}

  .vvd-footer-grid{
    grid-template-columns:1fr;
    gap:28px;
    text-align:center;
  }

  .vvd-footer-brand,.vvd-social-ring{justify-content:center}

  .vvd-footer-links{align-items:center}

  .vvd-footer-links a:hover{padding-left:0}

  .vvd-footer-apps{align-items:stretch}

  .vvd-footer-pay-grid{gap:8px}

  .vvd-footer-pay-item{min-width:60px;padding:8px 12px}
}

@media(min-width:769px) and (max-width:1024px){
  .vvd-footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .vvd-footer-col--cta{grid-column:1/-1}
  .vvd-footer-apps{flex-direction:row;flex-wrap:wrap}
}

@media(max-width:480px){
  .vvd-auth-zone .vvd-help-chip{display:none}
}
