/* ===================================================================
   TopVault — Slots page
   Gaming background (violet/cyan/arcade lean, distinct from home & bonuses)
   + demo lobby tiles, provider grid, slot-type cards, casino list, faq.
   =================================================================== */

/* ---- gaming background ---- */
body{
  background-color:#0a0a12;
  background-image:
    radial-gradient(1100px 620px at 50% -6%, rgba(160,107,255,.20), transparent 62%),
    radial-gradient(820px 700px at 6% 16%, rgba(47,224,255,.15), transparent 60%),
    radial-gradient(820px 700px at 94% 24%, rgba(122,240,160,.10), transparent 58%),
    radial-gradient(1000px 900px at 82% 98%, rgba(160,107,255,.12), transparent 60%),
    linear-gradient(180deg,#0b0b16,#08080f 55%,#0a0a12);
  background-attachment:fixed;background-repeat:no-repeat;
}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,.035) 0 1px, transparent 1px 28px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,.035) 0 1px, transparent 1px 28px);
  -webkit-mask-image:radial-gradient(130% 95% at 50% 0%, #000 28%, transparent 78%);
          mask-image:radial-gradient(130% 95% at 50% 0%, #000 28%, transparent 78%);}
body::after{content:"";position:fixed;right:14%;top:-12%;width:60vmax;height:60vmax;z-index:-1;pointer-events:none;
  background:radial-gradient(closest-side, rgba(47,224,255,.16), transparent 70%);
  filter:blur(12px);animation:tvDriftS 26s ease-in-out infinite alternate;}
@keyframes tvDriftS{0%{transform:translate(6%,-4%) scale(1);opacity:.55}100%{transform:translate(-10%,9%) scale(1.18);opacity:1}}
@media (prefers-reduced-motion:reduce){body::after{animation:none}}

/* ---- hero ---- */
.tv-shero{position:relative;overflow:hidden;padding:118px 0 64px;text-align:center}
.tv-shero__crumb{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:18px}
.tv-shero__crumb a{color:#2fe0ff}
.tv-shero__tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#7af0a0;border:1px solid rgba(122,240,160,.4);background:rgba(122,240,160,.08);padding:7px 16px;border-radius:999px}
.tv-shero h1{margin:20px auto 14px;font-size:clamp(34px,6vw,60px);font-weight:800;line-height:1.05;color:#fff;max-width:16ch}
.tv-shero h1 .g{background:linear-gradient(90deg,#a06bff,#2fe0ff 60%,#7af0a0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#a06bff}
.tv-shero p{max-width:64ch;margin:0 auto 30px;font-size:17px;color:rgba(255,255,255,.72);line-height:1.6}
.tv-shero__stats{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:6px}
.tv-shero__stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:12px 20px;min-width:120px}
.tv-shero__stat b{display:block;font-size:24px;font-weight:800;background:linear-gradient(90deg,#2fe0ff,#a06bff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#2fe0ff;line-height:1}
.tv-shero__stat span{display:block;margin-top:5px;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.55)}

/* ---- section shells ---- */
.tv-ssec{position:relative;z-index:1;padding:64px 0}
.tv-ssec--alt{background:rgba(255,255,255,.02);border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07)}
.tv-ssec[id]{scroll-margin-top:96px}
.tv-shead{text-align:center;max-width:760px;margin:0 auto 40px}
.tv-shead span{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#a06bff}
.tv-shead h2{margin:12px 0 12px;font-size:clamp(26px,4vw,38px);font-weight:800;color:#fff}
.tv-shead p{font-size:15px;color:rgba(255,255,255,.66);line-height:1.65;margin:0}
.tv-prose{max-width:820px;margin:26px auto 0;color:rgba(255,255,255,.6);font-size:14.5px;line-height:1.75}
.tv-prose p{margin:0 0 14px}
.tv-prose a{color:#2fe0ff}

/* ---- quick-nav ---- */
.tv-sqnav{position:relative;z-index:3;max-width:1180px;margin:0 auto;padding:0 20px}
.tv-sqnav__in{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;background:rgba(12,12,22,.72);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:14px;box-shadow:0 14px 40px rgba(0,0,0,.35)}
.tv-sqnav a{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:999px;font-size:13px;font-weight:700;color:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);transition:.2s}
.tv-sqnav a i{font-size:15px}
.tv-sqnav a:hover,.tv-sqnav a.on{color:#06121a;background:linear-gradient(135deg,#a06bff,#2fe0ff);border-color:transparent}

/* ---- filter chips ---- */
.tv-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 30px}
.tv-filter button{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:999px;font-size:13px;font-weight:700;color:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);cursor:pointer;transition:.2s}
.tv-filter button:hover{color:#fff;border-color:rgba(47,224,255,.5)}
.tv-filter button.on{color:#06121a;background:linear-gradient(135deg,#2fe0ff,#a06bff);border-color:transparent}

/* ---- demo lobby (tiles) — ported from home + extended ---- */
.tv-lobby{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;max-width:1240px;margin:0 auto}
.tv-tile{position:relative;aspect-ratio:3/4;border-radius:18px;overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,.08);background:#0c0c16;transition:transform .25s,box-shadow .25s,border-color .25s}
.tv-tile.is-hidden{display:none}
.tv-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s}
.tv-tile__scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,6,14,.94) 4%,rgba(6,6,14,.45) 34%,rgba(6,6,14,0) 58%)}
.tv-tile:hover{transform:translateY(-7px);border-color:#2fe0ff;box-shadow:0 18px 44px rgba(47,224,255,.32)}
.tv-tile:hover img{transform:scale(1.09)}
.tv-tile__tag{position:absolute;top:10px;left:10px;z-index:2;font-size:10.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#06121a;background:linear-gradient(135deg,#2fe0ff,#a06bff);padding:4px 9px;border-radius:8px;box-shadow:0 4px 14px rgba(47,224,255,.4)}
.tv-tile__fav{position:absolute;top:9px;right:9px;z-index:3;width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(10,10,18,.55);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.tv-tile__fav:hover{border-color:#ff4ddb;color:#ff4ddb}
.tv-tile__fav.on{color:#ff4ddb;border-color:#ff4ddb;background:rgba(255,77,219,.14)}
.tv-tile__play{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%) scale(.7);opacity:0;z-index:2;width:64px;height:64px;border-radius:50%;background:rgba(47,224,255,.94);color:#06121a;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 0 28px rgba(47,224,255,.6);transition:.3s;pointer-events:none}
.tv-tile:hover .tv-tile__play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.tv-tile__info{position:absolute;left:13px;right:13px;bottom:13px;z-index:2;transition:transform .3s}
.tv-tile:hover .tv-tile__info{transform:translateY(-30px)}
.tv-tile__name{display:block;color:#fff;font-weight:700;font-size:15px;line-height:1.2}
.tv-tile__prov{display:block;margin-top:3px;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.tv-tile__cta{position:absolute;left:0;right:0;bottom:0;z-index:2;transform:translateY(100%);transition:transform .3s;background:linear-gradient(90deg,#2fe0ff,#a06bff);color:#06121a;text-align:center;padding:10px;font-weight:800;font-size:13px;letter-spacing:.02em}
.tv-tile:hover .tv-tile__cta{transform:translateY(0)}
.tv-lobby__empty{display:none;text-align:center;color:rgba(255,255,255,.5);font-size:14px;padding:30px}
@media(max-width:1100px){.tv-lobby{grid-template-columns:repeat(4,1fr);gap:16px}}
@media(max-width:820px){.tv-lobby{grid-template-columns:repeat(3,1fr)}}
@media(max-width:540px){.tv-lobby{grid-template-columns:repeat(2,1fr);gap:12px}.tv-tile__name{font-size:13px}}

/* ---- slot-type cards ---- */
.tv-types{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1120px;margin:0 auto}
.tv-tcard{position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:26px 22px;transition:transform .25s,border-color .25s,box-shadow .25s}
.tv-tcard:hover{transform:translateY(-6px);border-color:rgba(160,107,255,.55);box-shadow:0 18px 44px rgba(160,107,255,.22)}
.tv-tcard__ic{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;color:#06121a;background:linear-gradient(135deg,#a06bff,#2fe0ff);box-shadow:0 8px 20px rgba(160,107,255,.4);margin-bottom:16px}
.tv-tcard h5{color:#fff;font-size:18px;font-weight:700;margin:0 0 9px}
.tv-tcard p{font-size:13.5px;color:rgba(255,255,255,.66);line-height:1.55;margin:0}
@media(max-width:900px){.tv-types{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tv-types{grid-template-columns:1fr}}

/* ---- provider cards ---- */
.tv-provs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1120px;margin:0 auto}
.tv-prov{display:flex;gap:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:22px;transition:.25s}
.tv-prov:hover{border-color:rgba(47,224,255,.45);transform:translateY(-4px)}
.tv-prov__ic{flex:none;width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#2fe0ff;background:rgba(47,224,255,.1);border:1px solid rgba(47,224,255,.3)}
.tv-prov h6{color:#fff;font-size:16px;font-weight:700;margin:0 0 5px}
.tv-prov p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.5;margin:0 0 8px}
.tv-prov__at{font-size:11.5px;color:rgba(255,255,255,.45)}
.tv-prov__at b{color:#7af0a0;font-weight:600}
@media(max-width:900px){.tv-provs{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tv-provs{grid-template-columns:1fr}}

/* ---- best casinos for slots ---- */
.tv-scas{display:flex;flex-direction:column;gap:12px;max-width:1080px;margin:0 auto}
.tv-scas__row{display:grid;grid-template-columns:54px 150px 1fr auto auto;gap:20px;align-items:center;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:16px 22px;transition:.25s}
.tv-scas__row:hover{border-color:rgba(160,107,255,.5);transform:translateY(-2px)}
.tv-scas__rank{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#06121a;background:linear-gradient(135deg,#a06bff,#2fe0ff)}
.tv-scas__logo img{max-width:120px;max-height:42px;object-fit:contain}
.tv-scas__hl b{display:block;color:#fff;font-size:15px;font-weight:700;margin-bottom:3px}
.tv-scas__hl span{font-size:12.5px;color:rgba(255,255,255,.55)}
.tv-scas__meta{text-align:center;font-size:12px;color:rgba(255,255,255,.6)}
.tv-scas__meta b{display:block;color:#7af0a0;font-size:18px;font-weight:800}
.tv-scas__btn{display:inline-flex;align-items:center;gap:6px;padding:11px 18px;border-radius:11px;font-weight:800;font-size:12.5px;letter-spacing:.03em;text-transform:uppercase;color:#1a0a14 !important;background:linear-gradient(90deg,#ffd24a,#ffb43a);white-space:nowrap;transition:transform .2s,box-shadow .2s}
.tv-scas__btn:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,180,58,.45)}
@media(max-width:860px){.tv-scas__row{grid-template-columns:46px 1fr auto;gap:14px}.tv-scas__logo,.tv-scas__meta{display:none}}

/* ---- how slots work terms ---- */
.tv-sterms{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1100px;margin:0 auto}
.tv-sterm{text-align:center;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px 18px}
.tv-sterm i{font-size:30px;color:#2fe0ff;margin-bottom:12px;display:block}
.tv-sterm h6{color:#fff;font-size:15px;font-weight:700;margin:0 0 7px}
.tv-sterm p{font-size:12.5px;color:rgba(255,255,255,.6);line-height:1.5;margin:0}
@media(max-width:760px){.tv-sterms{grid-template-columns:repeat(2,1fr)}}

/* ---- faq ---- */
.tv-sfaq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.tv-sfaq__item{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.09);border-radius:14px;overflow:hidden}
.tv-sfaq__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;color:#fff;font-size:15.5px;font-weight:600;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.tv-sfaq__q i{color:#2fe0ff;transition:transform .25s;flex:none}
.tv-sfaq__item.open .tv-sfaq__q i{transform:rotate(180deg)}
.tv-sfaq__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.tv-sfaq__a p{margin:0;padding:0 22px 18px;color:rgba(255,255,255,.66);font-size:14px;line-height:1.6}
.tv-sfaq__item.open .tv-sfaq__a{max-height:260px}

/* ---- claim / cta (reuse home look) ---- */
.tv-sclaim{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 26px;border-radius:12px;font-weight:800;font-size:15px;letter-spacing:.03em;text-transform:uppercase;color:#06121a !important;background:linear-gradient(90deg,#2fe0ff,#a06bff);box-shadow:0 8px 24px rgba(47,224,255,.4);transition:transform .2s,box-shadow .2s;overflow:hidden;white-space:nowrap}
.tv-sclaim:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 12px 32px rgba(47,224,255,.6)}
.tv-scta{text-align:center;max-width:900px;margin:0 auto;padding:48px 28px;border-radius:24px;background:radial-gradient(130% 160% at 50% 0%,rgba(160,107,255,.2),rgba(47,224,255,.06) 55%,transparent),#0c0c16;border:1px solid rgba(160,107,255,.35);box-shadow:0 20px 60px rgba(160,107,255,.22)}
.tv-scta h2{color:#fff;font-size:clamp(26px,4vw,34px);font-weight:800;margin:0 0 10px}
.tv-scta p{font-size:16px;color:rgba(255,255,255,.72);margin:0 0 24px}
.tv-scta__note{display:block;margin-top:14px;font-size:11px;color:rgba(255,255,255,.4)}
