:root {
--ps-primary: #E63956;
--ps-secondary: #8C1D3A;
--ps-accent: #FFB86B;
--ps-bg: #0D0D12;
--ps-surface: #1A1A24;
--ps-text: #FAF1F3;
--ps-text-mut: #C6B4BA;
--ps-font-head: 'Playfair Display', serif;
--ps-font-body: 'Lato', sans-serif;
}
*,
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
body {
font-family: var(--ps-font-body);
background-color: var(--ps-bg);
color: var(--ps-text);
line-height: 1.6;
overflow-x: hidden;
padding-bottom: 60px;
}
h1, h2, h3, h4, h5, h6 {
font-family: var(--ps-font-head);
font-weight: 700;
margin-bottom: 1rem;
color: var(--ps-accent);
}
a {
color: var(--ps-accent);
text-decoration: none;
transition: opacity 0.2s;
}
a:hover {
opacity: 0.8;
}
.playspark_container {
width: 100%;
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
.playspark_header {
position: sticky;
top: 0;
background: rgba(26, 26, 36, 0.95);
backdrop-filter: blur(10px);
z-index: 100;
border-bottom: 1px solid var(--ps-secondary);
padding: 15px 0;
}
.playspark_header_inner {
display: flex;
justify-content: space-between;
align-items: center;
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
flex-wrap: wrap;
}
.playspark_logo a {
font-family: var(--ps-font-head);
font-size: 1.5rem;
color: var(--ps-primary);
font-weight: bold;
text-transform: uppercase;
letter-spacing: 1px;
}
.playspark_nav {
display: flex;
gap: 20px;
}
.playspark_nav a {
color: var(--ps-text);
font-size: 0.9rem;
font-weight: 500;
}
.playspark_nav a.playspark_active {
color: var(--ps-accent);
border-bottom: 1px solid var(--ps-accent);
}
.playspark_header_actions {
display: flex;
align-items: center;
gap: 15px;
flex-wrap: wrap;
justify-content: end;
}
.playspark_age_badge {
background: var(--ps-secondary);
color: var(--ps-text);
padding: 3px 8px;
border-radius: 4px;
font-size: 0.8rem;
font-weight: bold;
}
.playspark_btn {
background: var(--ps-primary);
color: var(--ps-text);
border: none;
padding: 10px 20px;
font-family: var(--ps-font-body);
font-weight: bold;
border-radius: 4px;
cursor: pointer;
transition: background 0.3s;
text-transform: uppercase;
font-size: 0.9rem;
}
.playspark_btn:hover {
background: var(--ps-secondary);
}
.playspark_btn_secondary {
background: var(--ps-surface);
border: 1px solid var(--ps-accent);
color: var(--ps-accent);
}
.playspark_btn_outline {
background: transparent;
border: 1px solid var(--ps-text-mut);
color: var(--ps-text-mut);
}
.playspark_burger {
display: none;
background: none;
border: none;
cursor: pointer;
flex-direction: column;
gap: 5px;
}
.playspark_burger_line {
width: 25px;
height: 2px;
background: var(--ps-text);
}
.playspark_hero {
position: relative;
padding: 80px 20px;
min-height: 60vh;
display: flex;
align-items: center;
}
.playspark_hero_bg_overlay {
background-image: linear-gradient(rgba(13, 13, 18, 0.8), rgba(13, 13, 18, 0.9)), url("images/hero-masquerade-ball.webp");
background-size: cover;
background-position: center;
}
.playspark_hero_content {
max-width: 1200px;
margin: 0 auto;
display: flex;
gap: 40px;
align-items: center;
width: 100%;
}
.playspark_hero_left {
flex: 1;
}
.playspark_hero_left h1 {
font-size: 3rem;
line-height: 1.1;
margin-bottom: 20px;
}
.playspark_hero_left p {
font-size: 1.2rem;
margin-bottom: 20px;
color: var(--ps-text-mut);
}
.playspark_no_rm_notice {
font-size: 0.85rem !important;
color: var(--ps-accent) !important;
font-style: italic;
}
.playspark_hero_rail {
flex: 0 0 320px;
display: flex;
flex-direction: column;
gap: 20px;
}
.playspark_preview_card {
background: var(--ps-surface);
border: 1px solid var(--ps-secondary);
border-radius: 8px;
overflow: hidden;
}
.playspark_preview_img {
width: 100%;
height: auto;
display: block;
}
.playspark_preview_info {
padding: 15px;
text-align: center;
}
.playspark_preview_info h4 {
margin-bottom: 5px;
font-size: 1.1rem;
}
.playspark_preview_info p {
font-size: 0.85rem;
color: var(--ps-text-mut);
}
.playspark_legal_strip {
background: rgba(13, 13, 18, 0.9);
border: 1px solid var(--ps-text-mut);
padding: 15px;
border-radius: 8px;
text-align: center;
font-size: 0.85rem;
color: var(--ps-text-mut);
}
.playspark_section {
padding: 60px 0;
}
.playspark_alt_bg {
background: var(--ps-surface);
}
.playspark_section_title {
text-align: center;
font-size: 2.2rem;
margin-bottom: 10px;
}
.playspark_section_subtitle {
text-align: center;
color: var(--ps-text-mut);
margin-bottom: 40px;
}
.playspark_social_games_zone {
display: grid;
grid-template-columns: 1fr;
max-width: clamp(820px, 72vw, 900px);
width: 100%;
margin-inline: auto;
gap: clamp(20px, 3vw, 28px);
padding-inline: clamp(14px, 3vw, 24px);
}
.playspark_game_card {
background: var(--ps-surface);
border: 1px solid var(--ps-secondary);
border-radius: 8px;
padding: 20px;
display: flex;
flex-direction: column;
align-items: center;
}
.playspark_game_title {
font-size: 1.5rem;
margin-bottom: 15px;
}
.playspark_game_stage {
background: #000;
border: 2px solid var(--ps-secondary);
border-radius: 4px;
width: 100%;
margin-bottom: 20px;
}
[data-slot-stage] {
min-height: clamp(240px, 18vw, 320px);
position: relative;
padding: 10px;
}
.playspark_payline {
position: absolute;
top: 50%;
left: 0;
right: 0;
height: 4px;
background: rgba(255, 184, 107, 0.5);
z-index: 50;
transform: translateY(-50%);
pointer-events: none;
}
[data-slot-reel-window] {
display: grid;
grid-template-columns: repeat(3, 1fr);
overflow: hidden;
height: 100%;
gap: 10px;
}
[data-slot-reel] {
display: flex;
align-items: center;
justify-content: center;
min-width: 0;
background: #111;
border: 1px solid #333;
}
[data-slot-symbol] {
display: block;
max-width: 100%;
max-height: 100%;
object-fit: contain;
transition: filter 0.2s;
}
[data-wheel-stage] {
aspect-ratio: 1/1;
position: relative;
display: grid;
max-width: 320px;
margin: 0 auto 20px auto;
}
[data-wheel-img] {
border-radius: 50%;
max-width: 100%;
max-height: 100%;
object-fit: contain;
transform-origin: center;
grid-area: 1/1;
}
[data-wheel-pointer] {
position: absolute;
grid-area: 1/1;
place-self: start center;
z-index: 10;
width: 0;
height: 0;
border-left: 15px solid transparent;
border-right: 15px solid transparent;
border-top: 25px solid var(--ps-accent);
transform: translateY(-10px);
}
.playspark_game_controls {
display: flex;
flex-wrap: wrap;
gap: 15px;
align-items: center;
justify-content: center;
width: 100%;
margin-bottom: 15px;
}
.playspark_bet_selector, .playspark_action_row {
display: flex;
align-items: center;
gap: 10px;
}
.playspark_bet_input {
background: var(--ps-bg);
color: var(--ps-text);
border: 1px solid var(--ps-secondary);
padding: 8px;
border-radius: 4px;
font-family: var(--ps-font-body);
}
.playspark_btn_spin {
background: var(--ps-accent);
color: var(--ps-bg);
}
.playspark_btn_spin:hover {
background: #e5a463;
}
.playspark_bet_options {
display: flex;
gap: 10px;
margin-bottom: 10px;
width: 100%;
justify-content: center;
}
.playspark_bet_btn {
background: var(--ps-bg);
border: 1px solid var(--ps-secondary);
color: var(--ps-text);
padding: 8px 15px;
border-radius: 4px;
cursor: pointer;
transition: 0.2s;
}
.playspark_bet_btn.is-active {
background: var(--ps-secondary);
color: var(--ps-text);
border-color: var(--ps-accent);
}
.playspark_game_result {
font-weight: bold;
color: var(--ps-accent);
min-height: 24px;
margin-bottom: 5px;
text-align: center;
}
.playspark_game_history {
font-size: 0.8rem;
color: var(--ps-text-mut);
text-align: center;
min-height: 20px;
}
.playspark_cta_row {
text-align: center;
margin-top: 30px;
}
.playspark_split {
display: flex;
gap: 40px;
align-items: center;
}
.playspark_split_text {
flex: 1;
}
.playspark_split_text p {
margin-bottom: 15px;
}
.playspark_split_visuals {
flex: 1;
display: flex;
gap: 20px;
justify-content: center;
}
.playspark_faction_img {
width: 150px;
height: 150px;
object-fit: cover;
border-radius: 50%;
border: 3px solid var(--ps-secondary);
}
.playspark_grid_3 {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 20px;
}
.playspark_info_card {
background: var(--ps-bg);
padding: 20px;
border: 1px solid var(--ps-secondary);
border-radius: 8px;
}
.playspark_info_card h3 {
font-size: 1.2rem;
margin-bottom: 10px;
}
.playspark_rank_list {
list-style: none;
max-width: 600px;
margin: 0 auto;
}
.playspark_rank_list li {
background: var(--ps-surface);
margin-bottom: 10px;
padding: 15px;
border-left: 4px solid var(--ps-accent);
border-radius: 4px;
}
.playspark_ticker_wrap {
background: var(--ps-secondary);
color: var(--ps-text);
padding: 15px 0;
overflow: hidden;
white-space: nowrap;
}
.playspark_ticker_track {
display: inline-block;
animation: psTicker 20s linear infinite;
}
.playspark_ticker_track span {
margin-right: 40px;
font-weight: bold;
}
@keyframes psTicker {
0% { transform: translateX(0); }
100% { transform: translateX(-50%); }
}
.playspark_text_center {
text-align: center;
max-width: 800px;
margin: 0 auto 20px auto;
}
.playspark_egg_container {
text-align: center;
margin-top: 30px;
}
.playspark_wax_seal {
width: 60px;
height: 60px;
cursor: pointer;
opacity: 0.6;
transition: opacity 0.3s;
}
.playspark_wax_seal:hover {
opacity: 1;
}
.playspark_footer {
background: var(--ps-surface);
padding: 40px 20px 80px 20px;
border-top: 1px solid var(--ps-secondary);
}
.playspark_footer_inner {
max-width: 1200px;
margin: 0 auto;
}
.playspark_footer_grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 30px;
margin-bottom: 30px;
}
.playspark_footer_col h4 {
font-size: 1.1rem;
margin-bottom: 15px;
color: var(--ps-text);
}
.playspark_footer_col p, .playspark_footer_col a {
font-size: 0.85rem;
color: var(--ps-text-mut);
display: block;
margin-bottom: 8px;
}
.playspark_partner_logos {
display: flex;
gap: 15px;
margin-top: 10px;
flex-wrap: wrap;
}
.playspark_partner_link img {
height: 40px;
width: auto;
display: block;
}
.playspark_dark_chip {
background: #111;
padding: 5px;
border-radius: 4px;
}
.playspark_light_chip {
background: #fff;
padding: 5px;
border-radius: 4px;
}
.playspark_footer_bottom {
border-top: 1px solid #333;
padding-top: 20px;
text-align: center;
font-size: 0.8rem;
color: var(--ps-text-mut);
}
.playspark_footer_bottom p {
margin-bottom: 10px;
}
.playspark_bottom_status_bar {
position: fixed;
bottom: 0;
left: 0;
right: 0;
background: rgba(26, 26, 36, 0.95);
backdrop-filter: blur(10px);
border-top: 1px solid var(--ps-secondary);
padding: 10px 20px;
z-index: 90;
}
.playspark_status_inner {
max-width: 1200px;
margin: 0 auto;
display: flex;
align-items: center;
justify-content: center;
gap: 15px;
font-weight: bold;
font-size: 1.1rem;
}
.playspark_wallet_balance {
color: var(--ps-accent);
}
.playspark_status_rank {
margin-left: auto;
font-size: 0.9rem;
color: var(--ps-text-mut);
}
.playspark_modal_overlay {
position: fixed;
top: 0; left: 0; right: 0; bottom: 0;
background: rgba(0,0,0,0.8);
display: none;
align-items: center;
justify-content: center;
z-index: 200;
}
.playspark_modal_overlay.is-active {
display: flex;
}
.playspark_modal {
background: var(--ps-surface);
padding: 30px;
border: 1px solid var(--ps-secondary);
border-radius: 8px;
max-width: 400px;
width: 90%;
position: relative;
}
.playspark_modal_close {
position: absolute;
top: 10px;
right: 15px;
background: none;
border: none;
color: var(--ps-text);
font-size: 1.5rem;
cursor: pointer;
}
.playspark_modal_title {
margin-bottom: 20px;
text-align: center;
}
.playspark_input {
width: 100%;
background: var(--ps-bg);
color: var(--ps-text);
border: 1px solid var(--ps-secondary);
padding: 12px;
border-radius: 4px;
margin-bottom: 15px;
font-family: var(--ps-font-body);
}
.playspark_modal_hint {
text-align: center;
font-size: 0.8rem;
color: var(--ps-text-mut);
margin-top: 15px;
}
.playspark_toast {
position: fixed;
top: 80px;
right: 20px;
background: var(--ps-secondary);
color: var(--ps-text);
padding: 15px 20px;
border-radius: 4px;
box-shadow: 0 4px 12px rgba(0,0,0,0.5);
z-index: 300;
transform: translateX(120%);
transition: transform 0.3s ease-in-out;
}
.playspark_toast.is-visible {
transform: translateX(0);
}
.playspark_lobby_header {
padding: 40px 20px;
text-align: center;
background: var(--ps-surface);
border-bottom: 1px solid var(--ps-secondary);
}
.playspark_lobby_split {
display: flex;
gap: 30px;
align-items: flex-start;
flex-direction: column;
}
.playspark_lobby_featured {
flex: 2;
}
.playspark_lobby_rail {
flex: 1;
display: flex;
flex-direction: column;
gap: 20px;
}

.playspark_faction_leaderboard {
background: var(--ps-surface);
padding: 20px;
border: 1px solid var(--ps-secondary);
border-radius: 8px;
}
.playspark_meter_bar {
background: var(--ps-bg);
height: 20px;
border-radius: 10px;
overflow: hidden;
margin-top: 10px;
}
.playspark_meter_fill {
background: var(--ps-primary);
height: 100%;
display: flex;
align-items: center;
padding-left: 10px;
font-size: 0.75rem;
color: #fff;
}
.playspark_content_page {
padding: 40px 0;
}
.playspark_editorial_block {
margin-bottom: 40px;
max-width: 800px;
}
.playspark_contact_reference {
background: var(--ps-surface);
padding: 20px;
border-left: 4px solid var(--ps-accent);
}
.playspark_form {
max-width: 500px;
}
.playspark_textarea {
resize: vertical;
}
.playspark_faq_block {
margin-top: 30px;
}
.playspark_faq_item {
margin-bottom: 10px;
background: var(--ps-surface);
border: 1px solid var(--ps-secondary);
border-radius: 4px;
}
.playspark_faq_item summary {
padding: 15px;
cursor: pointer;
font-weight: bold;
color: var(--ps-accent);
}
.playspark_faq_answer {
padding: 0 15px 15px 15px;
color: var(--ps-text-mut);
}
.playspark_policy_shell {
max-width: 800px;
background: var(--ps-surface);
padding: 30px;
border: 1px solid var(--ps-secondary);
border-radius: 8px;
margin-top: 20px;
}
@media (max-width: 768px) {
.playspark_burger {
display: flex;
}
.playspark_nav {
display: none;
position: absolute;
top: 100%;
left: 0;
right: 0;
background: var(--ps-surface);
flex-direction: column;
padding: 20px;
border-bottom: 1px solid var(--ps-secondary);
}
.playspark_nav.is-open {
display: flex;
}
.playspark_hero_content, .playspark_split, .playspark_lobby_split {
flex-direction: column;
}
.playspark_hero_rail, .playspark_lobby_rail {
width: 100%;
flex: none;
}
.playspark_social_games_zone {
padding-inline: 10px;
}
.playspark_status_rank {
display: none;
}
.playspark_hero h1 {
font-size: 2.2rem;
}
}

/* footer-logo-contrast-guard-v2 */
a[href*="begambleaware.org"],
a[href*="gambleaware"] {
  background: #ffffff !important;
  color: #111111 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0.45rem 0.7rem !important;
  border-radius: 0.7rem !important;
  box-sizing: border-box !important;
}

a[href*="begambleaware.org"] img,
a[href*="begambleaware.org"] picture,
a[href*="begambleaware.org"] .partner-logo,
img[src*="gambleaware"],
img[alt*="BeGambleAware" i],
img[alt*="GambleAware" i] {
  background: #ffffff !important;
  padding: 0.45rem 0.7rem !important;
  border-radius: 0.7rem !important;
  box-sizing: border-box !important;
}

a[href*="gamcare.org"] {
  background: #fff !important;
  color: #ffffff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0.45rem 0.7rem !important;
  border-radius: 0.7rem !important;
  box-sizing: border-box !important;
}

a[href*="gamcare.org"] img,
a[href*="gamcare.org"] picture,
a[href*="gamcare.org"] .partner-logo,
img[src*="gamcare"],
img[alt*="GamCare" i] {
  background: #fff !important;
  padding: 0.45rem 0.7rem !important;
  border-radius: 0.7rem !important;
  box-sizing: border-box !important;
}

/* social-game-layering-guard-v4 */
[data-home-live-game],
[data-game-card],
[data-slot-game],
[data-slot-stage],
[data-wheel-game],
[data-wheel-stage],
[data-mechanic],
[class*="game_wrapper"],
[class*="game-wrapper"],
[class*="game_board"],
[class*="game-board"],
[class*="slot_board"],
[class*="slot-board"],
[class*="roulette_board"],
[class*="roulette-board"] {
  position: relative !important;
  isolation: isolate !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

[class*="slot"][class*="frame"],
[class*="slot"][class*="bg"],
[class*="slot"][class*="background"],
img[class*="slot_frame"],
img[class*="slot-frame"],
img[class*="frame_img"],
img[class*="frame-img"],
[data-game-mechanic="slot"] [class*="game_visual"] > img:first-child,
[data-game-mechanic="slot"] [class*="game-visual"] > img:first-child,
[data-game-mechanic="slot"] img[class*="game_bg"],
[data-game-mechanic="slot"] img[class*="game-bg"] {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

[class*="roulette"][class*="wheel"] img,
img[class*="roulette"][class*="wheel"],
[data-wheel-img] {
  position: relative !important;
  z-index: 1 !important;
  display: block !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  transform-origin: center !important;
  border-radius: 50% !important;
  clip-path: circle(50% at 50% 50%) !important;
  pointer-events: none !important;
}

[data-wheel-stage],
[data-wheel-game] [class*="wheel_stage"],
[data-wheel-game] [class*="wheel-stage"],
[class*="wheel_board"],
[class*="wheel-board"],
[class*="roulette_board"],
[class*="roulette-board"] {
  aspect-ratio: 1 / 1 !important;
  position: relative !important;
  overflow: hidden !important;
  display: grid !important;
  place-items: center !important;
}

[data-game-mechanic="slot"] [class*="game_visual"],
[data-game-mechanic="slot"] [class*="game-visual"] {
  min-height: clamp(260px, 42vw, 560px) !important;
  aspect-ratio: 4 / 3 !important;
  position: relative !important;
  overflow: hidden !important;
}

[data-slot-stage],
[data-slot-game] [class*="slot_stage"],
[data-slot-game] [class*="slot-stage"],
[data-game-mechanic="slot"] [class*="slot_board"],
[data-game-mechanic="slot"] [class*="slot-board"] {
  position: relative !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  align-items: center !important;
}

[data-slot-reel-window],
[data-slot-game] [class*="slot_reel_window"],
[data-slot-game] [class*="slot-reel-window"],
[data-slot-game] [class*="reel_window"],
[data-slot-game] [class*="reel-window"] {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  /* min-height: clamp(170px, 22vw, 320px) !important; */
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  align-items: stretch !important;
  gap: clamp(0.55rem, 1.5vw, 1.2rem) !important;
  overflow: hidden !important;
  position: relative !important;
}

[class*="slot_reels"],
[class*="slot-reels"],
[class*="reels"],
[data-home-live-game] [data-reel-index] {
  position: absolute !important;
  left: 10% !important;
  right: 10% !important;
  top: 35% !important;
  bottom: 35% !important;
  width: auto !important;
  height: auto !important;
  transform: none !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  align-items: stretch !important;
  gap: clamp(0.45rem, 1.4vw, 1.1rem) !important;
  z-index: 60 !important;
  pointer-events: none !important;
}

[data-slot-symbol],
[class*="slot_symbol"],
[class*="slot-symbol"],
[class*="reel"] img,
[data-home-live-game] [data-reel-index] img {
  position: relative !important;
  z-index: 70 !important;
  display: block !important;
  width: clamp(72px, 62%, 170px) !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: 88% !important;
  object-fit: contain !important;
}

[class*="slot_reel"]:not([class*="window"]),
[class*="slot-reel"]:not([class*="window"]),
[data-slot-reel],
[data-home-live-game] [data-reel-index] {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  /* min-height: clamp(72px, 10vw, 150px) !important; */
  background: rgba(2, 8, 18, 0.88) !important;
  border: 2px solid rgba(255,255,255,0.78) !important;
  border-radius: 0.85rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.16), 0 0.9rem 1.8rem rgba(0,0,0,0.35) !important;
}

[class*="roulette"][class*="pointer"],
[class*="wheel"][class*="pointer"],
[data-wheel-pointer],
[data-home-live-game] [data-roulette-bet],
[data-home-live-game] [class*="game_ui"],
[data-home-live-game] [class*="game-ui"],
[data-home-live-game] [class*="game_controls"],
[data-home-live-game] [class*="game-controls"],
[data-home-live-game] [class*="bet"],
[data-home-live-game] [class*="result"],
[data-home-live-game] [class*="status"],
[data-home-live-game] button,
[data-home-live-game] select,
[data-home-live-game] input {
  position: relative !important;
  z-index: 90 !important;
}
