@charset "UTF-8";
/* 
 * MAIN STYLESHEET
 * Entry point for all styles
 */
/* === THEME V5 === */
:root {
  --primary-900: #0C1E15;
  --primary-800: #123524;
  --primary-700: #1E5035;
  --primary-600: #2B6B41;
  --primary-500: #3F8E50;
  --primary-400: #5FA969;
  --primary-300: #81C189;
  --primary-200: #B0E1BB;
  --primary-100: #DAF3DF;
  --primary-50: #F4FCF6;
  /* Main background and layout colors */
  --main-bg: var(--neutral-900);
  --primary: var(--primary-500);
  --header-features: var(--neutral-900);
  --stroke: var(--primary-800);
  /* Button colors - Primary */
  --primary-button-default: var(--primary-500);
  --primary-button-hover: var(--primary-400);
  --primary-button-text: var(--primary-50);
  /* Button colors - Secondary */
  --secondary-button-default: var(--body-0);
  --secondary-button-hover: var(--primary-500);
  --secondary-button-text: var(--primary-500);
  --secondary-button-hover-text: var(--primary-900);
  --secondary-button-stroke: var(--primary-500);
  /* Button colors - Ghost */
  --ghost-button-default: var(--body-0);
  --ghost-button-text: var(--primary-500);
  /* Button colors - Float */
  --float-button-text: var(--primary-900);
  --float-button-default: var(--primary-100);
  /* Card colors */
  --card-bg-default: var(--neutral-800);
  --card-stroke: var(--primary-800);
  --card-bg-premium: var(--primary-900);
  --logo-bg: var(--neutral-900);
  /* Badge colors */
  --badge-bg: var(--primary-900);
  --badge-text: var(--body-white);
  --button-bg-top: var(--primary-500);
  --button-bg-bottom: var(--primary-600);
  --button-text-default: var(--body-white);
}

:root {
  --font-primary: "Calistoga", sans-serif;
  --font-secondary: "Nunito", sans-serif;
}

/* === CUSTOMS === */
/* Global custom styles */
/* Import adaptive disclaimer component */
.top-bar-disclaimer.disclaimer-light-bg p {
  color: var(--neutral-900) !important;
}
.top-bar-disclaimer.disclaimer-dark-bg p {
  color: var(--neutral-50) !important;
}
.footer-disclaimer.disclaimer-light-bg .disclaimer-text p {
  color: var(--neutral-900) !important;
}
.footer-disclaimer.disclaimer-dark-bg .disclaimer-text p {
  color: var(--neutral-50) !important;
}
/* Base styles */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* Hero section general styles */
.hero-section .hero__image {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  width: 100%;
  height: auto;
}
.hero-section .hero__image .hero__main-image {
  display: flex;
  justify-content: center;
  align-items: flex-end; /* Align hero-img.png to bottom */
  width: 100%;
  position: relative;
  height: 300px;
}
.hero-section .hero__image .hero__main-image img {
  width: auto;
  height: auto;
  max-width: 100%;
  object-fit: contain;
  display: block;
  margin: 0 auto;
  position: relative;
}

/* Versions 2-5: Add background image for all hero sections */
body.v2 .hero-section, body.v3 .hero-section, body.v4 .hero-section, body.v5 .hero-section {
  position: relative;
  /* CSS custom properties for parallax */
  --parallax-x: 0px;
  --parallax-y: 0px;
  /* Create background layer for entire hero section */
  /* Ensure all hero content is above background */
}
body.v2 .hero-section::before, body.v3 .hero-section::before, body.v4 .hero-section::before, body.v5 .hero-section::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) translate(var(--parallax-x), var(--parallax-y));
  width: 1400px;
  height: 395px;
  background-image: url("img/hero-img-f.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: 0;
  pointer-events: none; /* Don't interfere with interactions */
  transition: transform 0.1s ease-out; /* Smooth parallax animation */
}
body.v2 .hero-section .container, body.v3 .hero-section .container, body.v4 .hero-section .container, body.v5 .hero-section .container {
  position: relative;
  z-index: 1;
}
body.v2 .hero-section .hero__image .hero__main-image, body.v3 .hero-section .hero__image .hero__main-image, body.v4 .hero-section .hero__image .hero__main-image, body.v5 .hero-section .hero__image .hero__main-image {
  max-width: 426px;
  max-height: 260px;
  position: relative;
  right: -160px;
  height: 100%;
  /* Preserve original styling without interference */
}
@media (max-width: 768px) {
  body.v2 .hero-section .hero__image .hero__main-image, body.v3 .hero-section .hero__image .hero__main-image, body.v4 .hero-section .hero__image .hero__main-image, body.v5 .hero-section .hero__image .hero__main-image {
    right: 0;
  }
}

body.v1.page-index {
  /* Version 1 specific styles */
}
body.v1.page-index .header-content {
  background-color: rgba(255, 255, 255, 0.5) !important;
}
body.v1.page-index .top-bar-disclaimer {
  background-color: rgba(255, 255, 255, 0.01) !important;
}

body.v3.page-index,
body.v4.page-index,
body.v5.page-index {
  /* Version 3-5 specific styles */
}
body.v3.page-index .header-content,
body.v4.page-index .header-content,
body.v5.page-index .header-content {
  background-color: rgba(0, 0, 0, 0.5) !important;
}
body.v3.page-index .header-content .desktop-nav a,
body.v4.page-index .header-content .desktop-nav a,
body.v5.page-index .header-content .desktop-nav a {
  color: var(--body-white) !important;
}
body.v3.page-index .header-content .desktop-nav a:hover,
body.v4.page-index .header-content .desktop-nav a:hover,
body.v5.page-index .header-content .desktop-nav a:hover {
  color: var(--primary-300) !important;
}
body.v3.page-index .top-bar-disclaimer,
body.v4.page-index .top-bar-disclaimer,
body.v5.page-index .top-bar-disclaimer {
  background-color: rgba(0, 0, 0, 0.01) !important;
}

body.v1 {
  /* Hero image styles for v1 with waves and fisherman */
}
body.v1 .secondary-button:hover {
  color: var(--secondary-button-hover-text) !important;
}
body.v1 .secondary-button:hover .button-icon path {
  fill: var(--secondary-button-hover-text) !important;
}
body.v1 .hero-section {
  /* Wave backgrounds */
  /* Fisherman swimming in container with stops */
  /* Mobile optimizations */
}
body.v1 .hero-section .hero__image {
  display: flex;
  justify-content: center;
  height: 220px;
  position: relative;
  overflow: visible;
}
body.v1 .hero-section .hero__wave {
  position: absolute;
  top: 0;
  height: 220px;
  background-repeat: repeat-x;
  background-position: bottom;
  background-size: auto;
  width: calc(100vw + 200px);
  margin-left: calc(-50vw + 50% - 100px);
}
body.v1 .hero-section .hero__wave--primary {
  background-image: url("img/wave-1.svg");
  z-index: 0;
  animation: wave-drift 4s ease-in-out infinite;
}
body.v1 .hero-section .hero__wave--secondary {
  background-image: url("img/wave-1.svg");
  z-index: -2;
  left: -50px;
  animation: wave-drift-reverse 12s ease-in-out infinite;
}
body.v1 .hero-section .hero__wave--background {
  background-image: url("img/wave-2.svg");
  z-index: -3;
  left: -25px;
  top: -37px;
  animation: wave-drift 8s ease-in-out infinite reverse;
}
body.v1 .hero-section .hero__fisherman {
  position: absolute;
  top: 0;
  left: calc(50% - 150px);
  height: 220px;
  width: 300px;
  background-image: url("img/fisherman.png");
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
  z-index: -1;
  animation: fisherman-journey 20s ease-in-out infinite;
}
@media (max-width: 1200px) {
  body.v1 .hero-section .hero__image, body.v1 .hero-section .hero__wave, body.v1 .hero-section .hero__fisherman {
    overflow: visible;
    height: 160px;
  }
}
@media (max-width: 768px) {
  body.v1 .hero-section .hero__image {
    height: 160px;
  }
  body.v1 .hero-section .hero__wave {
    height: 160px;
  }
  body.v1 .hero-section .hero__fisherman {
    height: 160px;
    width: 200px;
    left: calc(50% - 100px);
  }
}
@media (max-width: 480px) {
  body.v1 .hero-section .hero__image {
    height: 120px;
  }
  body.v1 .hero-section .hero__wave {
    height: 120px;
  }
  body.v1 .hero-section .hero__wave--primary {
    top: 20px;
  }
  body.v1 .hero-section .hero__fisherman {
    height: 120px;
    width: 150px;
    left: calc(50% - 75px) !important;
  }
}

/* Wave animations */
@keyframes wave-drift {
  0%, 100% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(30px);
  }
}
@keyframes wave-drift-reverse {
  0%, 100% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(-25px);
  }
}
/* Mobile fisherman animations */
@media (max-width: 768px) {
  @keyframes fisherman-journey {
    0% {
      transform: translateX(0) translateY(0) scale(1);
    }
    10% {
      transform: translateX(30%) translateY(0) scale(1);
    }
    12% {
      transform: translateX(30%) translateY(-2px) scale(0.9) rotate(-3deg);
    }
    15% {
      transform: translateX(31%) translateY(1px) scale(1) rotate(0deg);
    }
    18% {
      transform: translateX(30%) translateY(-1px) scale(0.9) rotate(3deg);
    }
    21% {
      transform: translateX(29%) translateY(0) scale(1) rotate(0deg);
    }
    25% {
      transform: translateX(30%) translateY(0) scale(1);
    }
    35% {
      transform: translateX(0) translateY(0) scale(1);
    }
    37% {
      transform: translateX(0) translateY(-3px) scale(0.9) rotate(-4deg);
    }
    40% {
      transform: translateX(1%) translateY(2px) scale(1) rotate(0deg);
    }
    43% {
      transform: translateX(0) translateY(-1px) scale(0.9) rotate(4deg);
    }
    46% {
      transform: translateX(-1%) translateY(1px) scale(1) rotate(0deg);
    }
    50% {
      transform: translateX(0) translateY(0) scale(1);
    }
    60% {
      transform: translateX(-30%) translateY(0) scale(1);
    }
    62% {
      transform: translateX(-30%) translateY(-2px) scale(0.9) rotate(-3deg);
    }
    65% {
      transform: translateX(-29%) translateY(1px) scale(1) rotate(0deg);
    }
    68% {
      transform: translateX(-30%) translateY(-1px) scale(0.9) rotate(3deg);
    }
    71% {
      transform: translateX(-31%) translateY(0) scale(1) rotate(0deg);
    }
    75% {
      transform: translateX(-30%) translateY(0) scale(1);
    }
    85% {
      transform: translateX(0) translateY(0) scale(1);
    }
    87% {
      transform: translateX(0) translateY(-3px) scale(0.9) rotate(-2deg);
    }
    90% {
      transform: translateX(1%) translateY(2px) scale(1) rotate(0deg);
    }
    93% {
      transform: translateX(0) translateY(-1px) scale(0.9) rotate(2deg);
    }
    96% {
      transform: translateX(-1%) translateY(1px) scale(1) rotate(0deg);
    }
    100% {
      transform: translateX(0) translateY(0) scale(1);
    }
  }
}
@media (max-width: 480px) {
  @keyframes fisherman-journey {
    0% {
      transform: translateX(0) translateY(0) scale(1);
    }
    10% {
      transform: translateX(25%) translateY(0) scale(1);
    }
    12% {
      transform: translateX(25%) translateY(-2px) scale(0.9) rotate(-2deg);
    }
    15% {
      transform: translateX(26%) translateY(1px) scale(1) rotate(0deg);
    }
    18% {
      transform: translateX(25%) translateY(-1px) scale(0.9) rotate(2deg);
    }
    21% {
      transform: translateX(24%) translateY(0) scale(1) rotate(0deg);
    }
    25% {
      transform: translateX(25%) translateY(0) scale(1);
    }
    35% {
      transform: translateX(0) translateY(0) scale(1);
    }
    37% {
      transform: translateX(0) translateY(-2px) scale(0.9) rotate(-3deg);
    }
    40% {
      transform: translateX(1%) translateY(1px) scale(1) rotate(0deg);
    }
    43% {
      transform: translateX(0) translateY(-1px) scale(0.9) rotate(3deg);
    }
    46% {
      transform: translateX(-1%) translateY(1px) scale(1) rotate(0deg);
    }
    50% {
      transform: translateX(0) translateY(0) scale(1);
    }
    60% {
      transform: translateX(-25%) translateY(0) scale(1);
    }
    62% {
      transform: translateX(-25%) translateY(-2px) scale(0.9) rotate(-2deg);
    }
    65% {
      transform: translateX(-24%) translateY(1px) scale(1) rotate(0deg);
    }
    68% {
      transform: translateX(-25%) translateY(-1px) scale(0.9) rotate(2deg);
    }
    71% {
      transform: translateX(-26%) translateY(0) scale(1) rotate(0deg);
    }
    75% {
      transform: translateX(-25%) translateY(0) scale(1);
    }
    85% {
      transform: translateX(0) translateY(0) scale(1);
    }
    87% {
      transform: translateX(0) translateY(-2px) scale(0.9) rotate(-2deg);
    }
    90% {
      transform: translateX(1%) translateY(1px) scale(1) rotate(0deg);
    }
    93% {
      transform: translateX(0) translateY(-1px) scale(0.9) rotate(2deg);
    }
    96% {
      transform: translateX(-1%) translateY(1px) scale(1) rotate(0deg);
    }
    100% {
      transform: translateX(0) translateY(0) scale(1);
    }
  }
}
/* Fisherman journey with stops and nervous behavior */
@keyframes fisherman-journey {
  /* Start in center */
  0% {
    left: calc(50% - 150px);
    transform: translateY(0) scale(1);
  }
  /* Move right (2 sec) */
  10% {
    left: calc(100% - 300px);
    transform: translateY(0) scale(1);
  }
  /* Stop right - nervous behavior (3 sec) */
  12% {
    left: calc(100% - 300px);
    transform: translateY(-3px) scale(0.9) rotate(-3deg);
  }
  15% {
    left: calc(100% - 295px);
    transform: translateY(2px) scale(1) rotate(0deg);
  }
  18% {
    left: calc(100% - 300px);
    transform: translateY(-2px) scale(0.9) rotate(3deg);
  }
  21% {
    left: calc(100% - 302px);
    transform: translateY(0) scale(1) rotate(0deg);
  }
  25% {
    left: calc(100% - 300px);
    transform: translateY(0) scale(1);
  }
  /* Move to center (2 sec) */
  35% {
    left: calc(50% - 150px);
    transform: translateY(0) scale(1);
  }
  /* Stop center - nervous behavior (3 sec) */
  37% {
    left: calc(50% - 150px);
    transform: translateY(-4px) scale(0.9) rotate(-4deg);
  }
  40% {
    left: calc(50% - 148px);
    transform: translateY(3px) scale(1) rotate(0deg);
  }
  43% {
    left: calc(50% - 150px);
    transform: translateY(-1px) scale(0.9) rotate(4deg);
  }
  46% {
    left: calc(50% - 152px);
    transform: translateY(1px) scale(1) rotate(0deg);
  }
  50% {
    left: calc(50% - 150px);
    transform: translateY(0) scale(1);
  }
  /* Move left (2 sec) */
  60% {
    left: 0;
    transform: translateY(0) scale(1);
  }
  /* Stop left - nervous behavior (3 sec) */
  62% {
    left: 0;
    transform: translateY(-3px) scale(0.9) rotate(-3deg);
  }
  65% {
    left: 3px;
    transform: translateY(2px) scale(1) rotate(0deg);
  }
  68% {
    left: 0;
    transform: translateY(-1px) scale(0.9) rotate(3deg);
  }
  71% {
    left: -2px;
    transform: translateY(0) scale(1) rotate(0deg);
  }
  75% {
    left: 0;
    transform: translateY(0) scale(1);
  }
  /* Move right to center (2 sec) */
  85% {
    left: calc(50% - 150px);
    transform: translateY(0) scale(1);
  }
  /* Stop in center - nervous behavior (3 sec) */
  87% {
    left: calc(50% - 150px);
    transform: translateY(-4px) scale(0.9) rotate(-4deg);
  }
  90% {
    left: calc(50% - 148px);
    transform: translateY(3px) scale(1) rotate(0deg);
  }
  93% {
    left: calc(50% - 150px);
    transform: translateY(-1px) scale(0.9) rotate(4deg);
  }
  96% {
    left: calc(50% - 152px);
    transform: translateY(1px) scale(1) rotate(0deg);
  }
  100% {
    left: calc(50% - 150px);
    transform: translateY(0) scale(1);
  }
}
/* Styles for v3 */
body.v3 .hero-section .hero__image {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  overflow: hidden;
  height: auto;
}
body.v3 .hero-section .hero__image .hero__main-image--v3 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  height: auto;
  position: relative;
}

/* Styles for v4 */
body.v4 {
  /* Media queries for smaller screens */
}
body.v4 .hero-section .hero__image {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  width: 100%;
}
body.v4 .hero-section .hero__image .hero__main-image--v4 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 700px;
  height: auto;
  aspect-ratio: 700/260; /* Maintain the aspect ratio */
  position: relative;
  margin: 0 auto; /* Ensure centering */
}
body.v4 .hero-section .hero__image .hero__main-image--v4 .hero__background-image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
body.v4 .hero-section .hero__image .hero__main-image--v4 .hero__roulette-container {
  position: absolute;
  top: 29%; /* Using percentage for better proportional scaling */
  left: 50%;
  transform: translateX(-50%);
  margin-left: -204px;
  width: 400px;
  max-width: 400px;
  display: flex;
  justify-content: center;
  /* Add continuous rotation animation */
  animation: wheelSpin 20s linear infinite;
}
body.v4 .hero-section .hero__image .hero__main-image--v4 .hero__roulette-container img {
  width: 100%;
  height: auto;
}
@media (max-width: 768px) {
  body.v4 .hero-section .hero__image .hero__main-image--v4 {
    max-width: 90vw;
  }
  body.v4 .hero-section .hero__image .hero__main-image--v4 .hero__roulette-container {
    width: 57%; /* Make width a percentage instead of fixed px for better scaling */
    max-width: 300px;
    margin-left: -130px;
  }
}
@media (max-width: 480px) {
  body.v4 .hero-section .hero__image .hero__main-image--v4 .hero__roulette-container {
    width: 57%;
    max-width: 220px;
    margin-left: -90px;
  }
}

/* Styles for v5 */
body.v5 .hero-section .hero__image {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  overflow: hidden;
}
body.v5 .hero-section .hero__image .hero__main-image--v5 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  position: relative;
}
body.v5 .hero-section .hero__image .hero__main-image--v5 .hero__background {
  z-index: 1;
}
body.v5 .hero-section .hero__image .hero__main-image--v5 .hero__background img {
  width: auto;
  height: auto;
  max-width: 100%;
}
body.v5 .hero-section .hero__image .hero__main-image--v5 .hero__foreground {
  position: absolute;
  top: 100px;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
}
body.v5 .hero-section .hero__image .hero__main-image--v5 .hero__foreground img {
  width: auto;
  height: auto;
  max-width: 100%;
  animation: floatImage 4s ease-in-out infinite;
}
@keyframes floatImage {
  0% {
    transform: translateY(0) rotate(0deg) scale(1);
    filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.3));
  }
  25% {
    transform: translateY(-20px) rotate(2deg) scale(1.03);
  }
  50% {
    transform: translateY(-25px) rotate(0deg) scale(1.05);
    filter: drop-shadow(0 25px 30px rgba(0, 0, 0, 0.4));
  }
  75% {
    transform: translateY(-10px) rotate(-2deg) scale(1.03);
  }
  100% {
    transform: translateY(0) rotate(0deg) scale(1);
    filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.3));
  }
}

/* Mobile padding for casino card RO-5-H */
@media (max-width: 768px) {
  .casino-card--ro-5-h {
    padding: 20px !important;
  }
  /* Ensure feature text elements have actual size and are centered */
  .casino-card__feature-text {
    width: auto !important;
    max-width: 100% !important;
    text-align: center !important;
    display: inline-block !important;
    margin: 0 auto !important;
  }
  .casino-card__feature-item {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }
  /* Forced mobile order for casino card CTA elements */
  .casino-card--ro-5-h .casino-card__cta {
    display: flex !important;
    flex-direction: column !important;
  }
  /* Force the button to be first (top position) */
  .casino-card--ro-5-h .casino-card__cta .button-primary,
  .casino-card--ro-5-h .casino-card__cta .button-secondary,
  .casino-card--ro-5-h .casino-card__cta .button-ghost {
    order: 1 !important;
  }
  /* Force online users count to be second (below button) */
  .casino-card--ro-5-h .casino-card__cta .casino-card__online-users {
    order: 2 !important;
    margin-top: 0 !important;
  }
}
/* Stars - single icon */
.casino-card-stars {
  display: flex;
  align-items: center;
}
.casino-card-stars img {
  width: auto;
  height: var(--size-16);
}

/* Casino card online users icon */
.casino-card-online-users::before {
  content: "";
  display: inline-block;
  width: var(--size-16);
  height: var(--size-16);
  background-image: url("img/icon-user-online.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
}

/* === UTILITIES === */
/* 
 * CORE STYLES
 * Core imports for styling framework
 */
/* === CORE IMPORTS === */
/* Import CSS reset for consistent rendering */
/*
 * CSS RESET
 * Standardizes rendering across browsers by resetting default styles
 */
/* ==========================================
   UNIVERSAL RESET
   ========================================== */
/* Reset box model for all elements */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ==========================================
   BASE ELEMENTS
   ========================================== */
/* HTML and body reset */
html {
  scroll-behavior: smooth;
}

/* Media elements reset */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Form elements reset */
input,
button,
textarea,
select {
  font: inherit;
  background: none;
  border: none;
  outline: none;
}

/* List reset */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* Link reset */
a {
  color: var(--body-muted);
  text-decoration: none;
}

/* Button reset */
button {
  cursor: pointer;
  background: none;
}

/* Table reset */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/*
 * BASE LAYOUT COMPONENTS
 * Foundational layout elements used throughout the site
 */
/* ==========================================
   CONTAINER COMPONENTS
   Responsive width-limited containers
   ========================================== */
/* Default container with auto margin and padding */
.container {
  margin-inline: auto;
  padding-inline: var(--spacing-16);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/* Large container (1400px max width) */
.container-lg {
  width: 100%;
  max-width: var(--container-lg);
  margin-inline: auto;
  box-sizing: border-box;
}

/* Medium container (1162px max width) */
.container-md {
  width: 100%;
  max-width: var(--container-md);
  margin-inline: auto;
  box-sizing: border-box;
}

/* Small container (924px max width) */
.container-sm {
  width: 100%;
  max-width: var(--container-sm);
  margin-inline: auto;
  box-sizing: border-box;
}

/* Extra small container (686px max width) */
.container-xs {
  width: 100%;
  max-width: var(--container-xs);
  margin-inline: auto;
  box-sizing: border-box;
}

/* Mobile responsive containers */
@media (max-width: 768px) {
  .container,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xs {
    padding-inline: var(--spacing-12);
    max-width: 100vw;
  }
}
/* ==========================================
   SECTION COMPONENTS
   Content sections with consistent spacing
   ========================================== */
/* Standard section with default padding */
.section {
  padding-block: var(--section-tb-all);
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

/* Contact section with extended padding */
.section-contact {
  padding-block: var(--section-tb-all);
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

/* 
 * BREAKPOINT MIXINS
 * Standardized media query breakpoints
 */
/* Mobile-first breakpoint mixins */
/* Specific breakpoint mixins */
.mt-0 {
  margin-top: var(--spacing-0);
}

.mb-0 {
  margin-bottom: var(--spacing-0);
}

.ml-0 {
  margin-left: var(--spacing-0);
}

.mr-0 {
  margin-right: var(--spacing-0);
}

.pt-0 {
  padding-top: var(--spacing-0);
}

.pb-0 {
  padding-bottom: var(--spacing-0);
}

.pl-0 {
  padding-left: var(--spacing-0);
}

.pr-0 {
  padding-right: var(--spacing-0);
}

.gap-0 {
  gap: var(--spacing-0);
}

.my-0 {
  margin-block: var(--spacing-0);
}

.mx-0 {
  margin-inline: var(--spacing-0);
}

.py-0 {
  padding-block: var(--spacing-0);
}

.px-0 {
  padding-inline: var(--spacing-0);
}

.mt-2 {
  margin-top: var(--spacing-2);
}

.mb-2 {
  margin-bottom: var(--spacing-2);
}

.ml-2 {
  margin-left: var(--spacing-2);
}

.mr-2 {
  margin-right: var(--spacing-2);
}

.pt-2 {
  padding-top: var(--spacing-2);
}

.pb-2 {
  padding-bottom: var(--spacing-2);
}

.pl-2 {
  padding-left: var(--spacing-2);
}

.pr-2 {
  padding-right: var(--spacing-2);
}

.gap-2 {
  gap: var(--spacing-2);
}

.my-2 {
  margin-block: var(--spacing-2);
}

.mx-2 {
  margin-inline: var(--spacing-2);
}

.py-2 {
  padding-block: var(--spacing-2);
}

.px-2 {
  padding-inline: var(--spacing-2);
}

.mt-4 {
  margin-top: var(--spacing-4);
}

.mb-4 {
  margin-bottom: var(--spacing-4);
}

.ml-4 {
  margin-left: var(--spacing-4);
}

.mr-4 {
  margin-right: var(--spacing-4);
}

.pt-4 {
  padding-top: var(--spacing-4);
}

.pb-4 {
  padding-bottom: var(--spacing-4);
}

.pl-4 {
  padding-left: var(--spacing-4);
}

.pr-4 {
  padding-right: var(--spacing-4);
}

.gap-4 {
  gap: var(--spacing-4);
}

.my-4 {
  margin-block: var(--spacing-4);
}

.mx-4 {
  margin-inline: var(--spacing-4);
}

.py-4 {
  padding-block: var(--spacing-4);
}

.px-4 {
  padding-inline: var(--spacing-4);
}

.mt-8 {
  margin-top: var(--spacing-8);
}

.mb-8 {
  margin-bottom: var(--spacing-8);
}

.ml-8 {
  margin-left: var(--spacing-8);
}

.mr-8 {
  margin-right: var(--spacing-8);
}

.pt-8 {
  padding-top: var(--spacing-8);
}

.pb-8 {
  padding-bottom: var(--spacing-8);
}

.pl-8 {
  padding-left: var(--spacing-8);
}

.pr-8 {
  padding-right: var(--spacing-8);
}

.gap-8 {
  gap: var(--spacing-8);
}

.my-8 {
  margin-block: var(--spacing-8);
}

.mx-8 {
  margin-inline: var(--spacing-8);
}

.py-8 {
  padding-block: var(--spacing-8);
}

.px-8 {
  padding-inline: var(--spacing-8);
}

.mt-12 {
  margin-top: var(--spacing-12);
}

.mb-12 {
  margin-bottom: var(--spacing-12);
}

.ml-12 {
  margin-left: var(--spacing-12);
}

.mr-12 {
  margin-right: var(--spacing-12);
}

.pt-12 {
  padding-top: var(--spacing-12);
}

.pb-12 {
  padding-bottom: var(--spacing-12);
}

.pl-12 {
  padding-left: var(--spacing-12);
}

.pr-12 {
  padding-right: var(--spacing-12);
}

.gap-12 {
  gap: var(--spacing-12);
}

.my-12 {
  margin-block: var(--spacing-12);
}

.mx-12 {
  margin-inline: var(--spacing-12);
}

.py-12 {
  padding-block: var(--spacing-12);
}

.px-12 {
  padding-inline: var(--spacing-12);
}

.mt-16 {
  margin-top: var(--spacing-16);
}

.mb-16 {
  margin-bottom: var(--spacing-16);
}

.ml-16 {
  margin-left: var(--spacing-16);
}

.mr-16 {
  margin-right: var(--spacing-16);
}

.pt-16 {
  padding-top: var(--spacing-16);
}

.pb-16 {
  padding-bottom: var(--spacing-16);
}

.pl-16 {
  padding-left: var(--spacing-16);
}

.pr-16 {
  padding-right: var(--spacing-16);
}

.gap-16 {
  gap: var(--spacing-16);
}

.my-16 {
  margin-block: var(--spacing-16);
}

.mx-16 {
  margin-inline: var(--spacing-16);
}

.py-16 {
  padding-block: var(--spacing-16);
}

.px-16 {
  padding-inline: var(--spacing-16);
}

.mt-20 {
  margin-top: var(--spacing-20);
}

.mb-20 {
  margin-bottom: var(--spacing-20);
}

.ml-20 {
  margin-left: var(--spacing-20);
}

.mr-20 {
  margin-right: var(--spacing-20);
}

.pt-20 {
  padding-top: var(--spacing-20);
}

.pb-20 {
  padding-bottom: var(--spacing-20);
}

.pl-20 {
  padding-left: var(--spacing-20);
}

.pr-20 {
  padding-right: var(--spacing-20);
}

.gap-20 {
  gap: var(--spacing-20);
}

.my-20 {
  margin-block: var(--spacing-20);
}

.mx-20 {
  margin-inline: var(--spacing-20);
}

.py-20 {
  padding-block: var(--spacing-20);
}

.px-20 {
  padding-inline: var(--spacing-20);
}

.mt-24 {
  margin-top: var(--spacing-24);
}

.mb-24 {
  margin-bottom: var(--spacing-24);
}

.ml-24 {
  margin-left: var(--spacing-24);
}

.mr-24 {
  margin-right: var(--spacing-24);
}

.pt-24 {
  padding-top: var(--spacing-24);
}

.pb-24 {
  padding-bottom: var(--spacing-24);
}

.pl-24 {
  padding-left: var(--spacing-24);
}

.pr-24 {
  padding-right: var(--spacing-24);
}

.gap-24 {
  gap: var(--spacing-24);
}

.my-24 {
  margin-block: var(--spacing-24);
}

.mx-24 {
  margin-inline: var(--spacing-24);
}

.py-24 {
  padding-block: var(--spacing-24);
}

.px-24 {
  padding-inline: var(--spacing-24);
}

.mt-32 {
  margin-top: var(--spacing-32);
}

.mb-32 {
  margin-bottom: var(--spacing-32);
}

.ml-32 {
  margin-left: var(--spacing-32);
}

.mr-32 {
  margin-right: var(--spacing-32);
}

.pt-32 {
  padding-top: var(--spacing-32);
}

.pb-32 {
  padding-bottom: var(--spacing-32);
}

.pl-32 {
  padding-left: var(--spacing-32);
}

.pr-32 {
  padding-right: var(--spacing-32);
}

.gap-32 {
  gap: var(--spacing-32);
}

.my-32 {
  margin-block: var(--spacing-32);
}

.mx-32 {
  margin-inline: var(--spacing-32);
}

.py-32 {
  padding-block: var(--spacing-32);
}

.px-32 {
  padding-inline: var(--spacing-32);
}

.mt-40 {
  margin-top: var(--spacing-40);
}

.mb-40 {
  margin-bottom: var(--spacing-40);
}

.ml-40 {
  margin-left: var(--spacing-40);
}

.mr-40 {
  margin-right: var(--spacing-40);
}

.pt-40 {
  padding-top: var(--spacing-40);
}

.pb-40 {
  padding-bottom: var(--spacing-40);
}

.pl-40 {
  padding-left: var(--spacing-40);
}

.pr-40 {
  padding-right: var(--spacing-40);
}

.gap-40 {
  gap: var(--spacing-40);
}

.my-40 {
  margin-block: var(--spacing-40);
}

.mx-40 {
  margin-inline: var(--spacing-40);
}

.py-40 {
  padding-block: var(--spacing-40);
}

.px-40 {
  padding-inline: var(--spacing-40);
}

.mt-48 {
  margin-top: var(--spacing-48);
}

.mb-48 {
  margin-bottom: var(--spacing-48);
}

.ml-48 {
  margin-left: var(--spacing-48);
}

.mr-48 {
  margin-right: var(--spacing-48);
}

.pt-48 {
  padding-top: var(--spacing-48);
}

.pb-48 {
  padding-bottom: var(--spacing-48);
}

.pl-48 {
  padding-left: var(--spacing-48);
}

.pr-48 {
  padding-right: var(--spacing-48);
}

.gap-48 {
  gap: var(--spacing-48);
}

.my-48 {
  margin-block: var(--spacing-48);
}

.mx-48 {
  margin-inline: var(--spacing-48);
}

.py-48 {
  padding-block: var(--spacing-48);
}

.px-48 {
  padding-inline: var(--spacing-48);
}

.mt-64 {
  margin-top: var(--spacing-64);
}

.mb-64 {
  margin-bottom: var(--spacing-64);
}

.ml-64 {
  margin-left: var(--spacing-64);
}

.mr-64 {
  margin-right: var(--spacing-64);
}

.pt-64 {
  padding-top: var(--spacing-64);
}

.pb-64 {
  padding-bottom: var(--spacing-64);
}

.pl-64 {
  padding-left: var(--spacing-64);
}

.pr-64 {
  padding-right: var(--spacing-64);
}

.gap-64 {
  gap: var(--spacing-64);
}

.my-64 {
  margin-block: var(--spacing-64);
}

.mx-64 {
  margin-inline: var(--spacing-64);
}

.py-64 {
  padding-block: var(--spacing-64);
}

.px-64 {
  padding-inline: var(--spacing-64);
}

.mt-80 {
  margin-top: var(--spacing-80);
}

.mb-80 {
  margin-bottom: var(--spacing-80);
}

.ml-80 {
  margin-left: var(--spacing-80);
}

.mr-80 {
  margin-right: var(--spacing-80);
}

.pt-80 {
  padding-top: var(--spacing-80);
}

.pb-80 {
  padding-bottom: var(--spacing-80);
}

.pl-80 {
  padding-left: var(--spacing-80);
}

.pr-80 {
  padding-right: var(--spacing-80);
}

.gap-80 {
  gap: var(--spacing-80);
}

.my-80 {
  margin-block: var(--spacing-80);
}

.mx-80 {
  margin-inline: var(--spacing-80);
}

.py-80 {
  padding-block: var(--spacing-80);
}

.px-80 {
  padding-inline: var(--spacing-80);
}

.mt-160 {
  margin-top: var(--spacing-160);
}

.mb-160 {
  margin-bottom: var(--spacing-160);
}

.ml-160 {
  margin-left: var(--spacing-160);
}

.mr-160 {
  margin-right: var(--spacing-160);
}

.pt-160 {
  padding-top: var(--spacing-160);
}

.pb-160 {
  padding-bottom: var(--spacing-160);
}

.pl-160 {
  padding-left: var(--spacing-160);
}

.pr-160 {
  padding-right: var(--spacing-160);
}

.gap-160 {
  gap: var(--spacing-160);
}

.my-160 {
  margin-block: var(--spacing-160);
}

.mx-160 {
  margin-inline: var(--spacing-160);
}

.py-160 {
  padding-block: var(--spacing-160);
}

.px-160 {
  padding-inline: var(--spacing-160);
}

/* === DESIGN TOKENS === */
/* 
 * DESIGN TOKENS BUNDLE
 * Global design tokens and variables
 */
/* === TOKEN IMPORTS === */
/* 
 * SPACING TOKENS
 * Defines the spacing and sizing variables used throughout the site
 */
:root {
  /* Base spacing scale */
  --spacing-0: 0px;
  --spacing-2: 2px;
  --spacing-4: 4px;
  --spacing-8: 8px;
  --spacing-12: 12px;
  --spacing-16: 16px;
  --spacing-20: 20px;
  --spacing-24: 24px;
  --spacing-28: 28px;
  --spacing-32: 32px;
  --spacing-40: 40px;
  --spacing-48: 48px;
  --spacing-64: 64px;
  --spacing-80: 80px;
  --spacing-160: 160px;
  /* Section-specific spacing */
  --section-tb-all: 64px; /* Default top/bottom padding for sections */
  --section-tb-contact: 160px; /* Top/bottom padding for contact section */
  /* Component-specific spacing */
  --spacing-card-20: 20px; /* Card internal spacing */
  --spacing-card-16: 16px; /* Alternative card spacing */
  --spacing-8-bonus: 8px; /* Special casino bonus spacing */
}

/* 
 * Responsive spacing adjustments for mobile
 * Reduces spacing proportionally for smaller screens
 */
@media (max-width: 768px) {
  :root {
    /* Reduced spacing scale for mobile */
    --spacing-4: 2px;
    --spacing-8: 4px;
    --spacing-12: 8px;
    --spacing-16: 8px;
    --spacing-20: 12px;
    --spacing-24: 14px;
    --spacing-28: 16px;
    --spacing-32: 24px;
    --spacing-40: 32px;
    --spacing-48: 40px;
    --spacing-64: 48px;
    --spacing-80: 64px;
    --spacing-160: 80px;
    /* Reduced section spacing for mobile */
    --section-tb-all: 24px;
    --section-tb-contact: 24px;
  }
}
/* 
 * BORDER RADIUS TOKENS
 * Defines the corner radius styles used throughout the site
 */
:root {
  /* Border radius scale */
  --radius-0: 0px; /* No radius (square corners) */
  --radius-2: 2px; /* Subtle radius */
  --radius-4: 4px; /* Very small radius */
  --radius-8: 8px; /* Small radius */
  --radius-12: 12px; /* Medium-small radius */
  --radius-16: 16px; /* Medium radius */
  --radius-24: 24px; /* Medium-large radius */
  --radius-32: 32px; /* Large radius */
  --radius-40: 40px; /* Very large radius */
  --radius-48: 48px; /* Extra large radius */
  --radius-64: 64px; /* Dramatic large radius */
  --radius-80: 80px; /* Extreme radius */
  --radius-full: 999px; /* Fully rounded (pill shape) */
}

/* 
 * Responsive radius adjustments for mobile
 * Reduces border radius proportionally for smaller screens
 */
@media (max-width: 768px) {
  :root {
    /* Mobile radius scale */
    --radius-4: 2px;
    --radius-8: 4px;
    --radius-12: 8px;
    --radius-16: 12px;
    --radius-24: 16px;
    --radius-32: 16px;
    --radius-40: 24px;
    --radius-48: 32px;
    --radius-64: 48px;
    --radius-80: 64px;
  }
}
/* 
 * SIZE TOKENS
 * Defines the sizes for containers and UI elements
 */
:root {
  /* Container widths */
  --container-lg: 1400px; /* Large container (main content) */
  --container-md: 1162px; /* Medium container */
  --container-sm: 924px; /* Small container (text sections) */
  --container-xs: 686px; /* Extra small container */
  /* Element-specific sizes */
  --hero-img: 240px; /* Hero image height */
  --logo-size: 40px; /* Logo height */
  /* Standard size tokens */
  --size-48: 48px; /* Extra large element size */
  --size-40: 40px; /* Large element size */
  --size-32: 32px; /* Medium-large element size */
  --size-28: 28px; /* Medium element size */
  --size-24: 24px; /* Medium element size */
  --size-20: 20px; /* Small-medium element size */
  --size-16: 16px; /* Small element size */
  --size-12: 12px; /* Extra small element size */
  --size-8: 8px; /* Tiny element size */
  --size-4: 4px; /* Micro element size */
  /* Breakpoint sizes */
  --breakpoint-mobile: 480px; /* Small mobile devices */
  --breakpoint-tablet: 768px; /* Tablets and medium screens */
  --breakpoint-desktop: 992px; /* Small desktops and larger tablets */
  --breakpoint-large: 1200px; /* Large desktops */
}

/* 
 * Responsive size adjustments for mobile
 * Reduces sizes proportionally for smaller screens
 */
@media (max-width: 768px) {
  :root {
    /* Mobile sizes */
    --hero-img: 100px;
    --logo-size: 30px;
    --size-48: 32px;
    --size-40: 24px;
    --size-32: 20px;
    --size-28: 18px;
    --size-24: 16px;
    --size-20: 14px;
    --size-16: 12px;
    --size-12: 10px;
    --size-8: 6px;
    --size-4: 3px;
  }
}
/* 
 * Z-INDEX TOKENS
 * Defines the stacking order of elements
 */
:root {
  /* Base element levels */
  --z-base: 1; /* Default level for most elements */
  --z-content: 10; /* Content that should appear above the base */
  /* Interactive element levels */
  --z-overlay: 100; /* Overlay elements like backdrops */
  --z-modal: 1000; /* Modal dialogs */
  --z-toast: 1100; /* Toast notifications */
  --z-tooltip: 1200; /* Tooltips */
  /* Maximum z-index for emergency overlays */
  --z-max: 9999; /* Reserved for critical UI elements */
}

:root {
  --neutral-900: #040404;
  --neutral-800: #121212;
  --neutral-700: #1B1B1B;
  --neutral-600: #2B2B2B;
  --neutral-500: #3F3F3F;
  --neutral-400: #5B5B5B;
  --neutral-300: #7A7A7A;
  --neutral-200: #A3A3A3;
  --neutral-100: #D0D0D0;
  --neutral-50: #EEEEEE;
  --body-100: rgba(255, 255, 255, 1);
  --body-90: rgba(255, 255, 255, 0.9);
  --body-80: rgba(255, 255, 255, 0.8);
  --body-70: rgba(255, 255, 255, 0.7);
  --body-60: rgba(255, 255, 255, 0.6);
  --body-50: rgba(255, 255, 255, 0.5);
  --body-40: rgba(255, 255, 255, 0.4);
  --body-30: rgba(255, 255, 255, 0.3);
  --body-20: rgba(255, 255, 255, 0.2);
  --body-10: rgba(255, 255, 255, 0.1);
  --body-0: rgba(255, 255, 255, 0);
  --body-white: var(--body-100);
  --body-main: var(--body-80);
  --body-muted: var(--body-50);
  --main-border: var(--neutral-800);
  --global-stroke: var(--body-10);
  --error: #D80027;
  --success: #24A148;
  --warning: #FFA000;
  --gold: #FFD700; /* For star ratings */
}

:root {
  --display-large-size: 56px;
  --display-large-line-height: 64px;
  --display-large-weight: 800;
  --display-large-letter-spacing: -2px;
  --display-large-family: var(--font-primary);
  --display-medium-size: 40px;
  --display-medium-line-height: 56px;
  --display-medium-weight: 800;
  --display-medium-letter-spacing: 0px;
  --display-medium-family: var(--font-primary);
  --display-small-size: 36px;
  --display-small-line-height: 44px;
  --display-small-weight: 800;
  --display-small-letter-spacing: 0px;
  --display-small-family: var(--font-primary);
  --headline-large-size: 40px;
  --headline-large-line-height: 56px;
  --headline-large-weight: 600;
  --headline-large-letter-spacing: 0px;
  --headline-large-family: var(--font-primary);
  --headline-medium-size: 32px;
  --headline-medium-line-height: 40px;
  --headline-medium-weight: 600;
  --headline-medium-letter-spacing: 0px;
  --headline-medium-family: var(--font-primary);
  --headline-small-size: 24px;
  --headline-small-line-height: 32px;
  --headline-small-weight: 600;
  --headline-small-letter-spacing: 0px;
  --headline-small-family: var(--font-primary);
  --title-large-size: 24px;
  --title-large-line-height: 32px;
  --title-large-weight: 600;
  --title-large-letter-spacing: 0px;
  --title-large-family: var(--font-primary);
  --title-medium-size: 20px;
  --title-medium-line-height: 28px;
  --title-medium-weight: 600;
  --title-medium-letter-spacing: 0px;
  --title-medium-family: var(--font-primary);
  --title-small-size: 16px;
  --title-small-line-height: 24px;
  --title-small-weight: 800;
  --title-small-letter-spacing: 0px;
  --title-small-family: var(--font-primary);
  --body-large-size: 16px;
  --body-large-line-height: 24px;
  --body-large-weight: 400;
  --body-large-letter-spacing: 0px;
  --body-large-family: var(--font-secondary);
  --body-medium-size: 14px;
  --body-medium-line-height: 20px;
  --body-medium-weight: 400;
  --body-medium-letter-spacing: 0px;
  --body-medium-family: var(--font-secondary);
  --body-small-size: 12px;
  --body-small-line-height: 16px;
  --body-small-weight: 400;
  --body-small-letter-spacing: 0px;
  --body-small-family: var(--font-secondary);
  --body-large-bold-size: 16px;
  --body-large-bold-line-height: 24px;
  --body-large-bold-weight: 800;
  --body-large-bold-letter-spacing: 0px;
  --body-large-bold-family: var(--font-secondary);
  --label-large-size: 20px;
  --label-large-line-height: 20px;
  --label-large-weight: 800;
  --label-large-letter-spacing: 0px;
  --label-large-family: var(--font-secondary);
  --label-large-text-transform: uppercase;
  --label-medium-size: 16px;
  --label-medium-line-height: 16px;
  --label-medium-weight: 800;
  --label-medium-letter-spacing: 0px;
  --label-medium-family: var(--font-secondary);
  --label-small-size: 12px;
  --label-small-line-height: 12px;
  --label-small-weight: 800;
  --label-small-letter-spacing: 0px;
  --label-small-family: var(--font-secondary);
}

@media (max-width: 768px) {
  :root {
    --display-large-size: 32px;
    --display-large-line-height: 40px;
    --display-medium-size: 28px;
    --display-medium-line-height: 40px;
    --display-small-size: 24px;
    --display-small-line-height: 32px;
    --headline-large-size: 24px;
    --headline-large-line-height: 32px;
    --headline-medium-size: 20px;
    --headline-medium-line-height: 28px;
    --headline-small-size: 16px;
    --headline-small-line-height: 24px;
    --title-large-size: 16px;
    --title-large-line-height: 24px;
    --title-medium-size: 14px;
    --title-medium-line-height: 20px;
    --title-small-size: 12px;
    --title-small-line-height: 16px;
    --body-large-size: 12px;
    --body-large-line-height: 16px;
    --body-medium-size: 11px;
    --body-medium-line-height: 14px;
    --body-small-size: 10px;
    --body-small-line-height: 12px;
    --body-large-bold-size: 12px;
    --body-large-bold-line-height: 16px;
    --label-large-size: 16px;
    --label-large-line-height: 16px;
    --label-medium-size: 12px;
    --label-medium-line-height: 12px;
    --label-small-size: 10px;
    --label-small-line-height: 10px;
  }
}
/* === COMPONENTS === */
/* 
 * COMPONENTS BUNDLE
 * Imports for all UI components
 */
/* === LAYOUT COMPONENTS === */
/* === START: layout/global-layout.scss === */
/* ==========================================
   BODY BACKGROUND - ALL PAGES
   ========================================== */
html {
  min-height: 100vh;
  /* Prevent horizontal scroll on mobile */
  overflow-x: hidden;
  box-sizing: border-box;
  background-color: var(--main-bg);
}

*, *::before, *::after {
  box-sizing: inherit;
}

/* Background only on homepage */
html.homepage {
  background-image: url("img/main-bg-top.png");
  background-position: top center;
  background-size: auto;
  background-repeat: repeat-x;
  background-attachment: scroll;
}

body {
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
  font-size: var(--body-large-size);
  color: var(--body-main);
  font-family: var(--font-secondary);
  line-height: var(--body-large-line-height);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* Ensure body doesn't exceed viewport width */
  max-width: 100vw;
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--body-white);
}

.site-wrapper {
  min-height: 100vh;
  /* Prevent horizontal overflow */
  overflow-x: hidden;
  max-width: 100vw;
  width: 100%;
}

a:hover {
  color: var(--primary-500);
  text-decoration: none;
}

/* Mobile-specific global fixes */
@media (max-width: 768px) {
  html, body, .site-wrapper {
    overflow-x: hidden;
    max-width: 100vw;
    width: 100%;
  }
}
/* === END: layout/global-layout.scss === */
/* ==========================================
   HEADER COMPONENTS
   ========================================== */
/* === START: layout/header.scss === */
/* Main header structure */
.header {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  z-index: var(--z-content);
  background-color: transparent;
}

.header-content {
  background-color: rgba(255, 255, 255, 0.5);
  padding: var(--spacing-16) var(--spacing-32);
  border-radius: var(--radius-full);
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.main-nav {
  display: flex;
  align-items: center;
}

/* Age disclaimer bar at top */
.top-bar-disclaimer {
  width: 100%;
  display: flex;
  align-items: center;
  color: var(--body-white);
  font-size: var(--body-small-size);
  gap: var(--spacing-8);
  padding-top: var(--spacing-8);
  padding-bottom: var(--spacing-8);
  position: relative;
  z-index: var(--z-content);
}

.top-bar-disclaimer .container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-8);
}

.top-bar-disclaimer .age-restriction {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.top-bar-disclaimer img {
  width: 32px;
  height: 32px;
}

.top-bar-disclaimer p {
  margin: 0;
}

@media (max-width: 768px) {
  .top-bar-disclaimer {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-12);
  }
}
/* Main header area with logo and navigation */
.header-main {
  position: relative;
  z-index: var(--z-content);
}
@media (max-width: 1028px) {
  .header-main {
    padding: var(--spacing-2) 0;
  }
}
.header-main .header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}
@media (max-width: 1028px) {
  .header-main .header-content {
    justify-content: space-between;
    padding: var(--spacing-12) var(--spacing-16);
  }
  .header-main .header-content .desktop-nav-left,
  .header-main .header-content .desktop-nav-right {
    display: none !important; /* Hide desktop nav on mobile with !important */
  }
}
@media (max-width: 768px) {
  .header-main .header-content {
    padding: var(--spacing-8) var(--spacing-16);
  }
}
.header-main .logo {
  display: flex;
  align-items: center;
  gap: var(--spacing-8);
  text-decoration: none;
  z-index: var(--z-modal);
}
.header-main .logo img {
  height: var(--logo-size);
  width: auto;
}
.header-main .logo .logo-text {
  font-size: 20px;
  font-weight: bold;
  color: var(--body-white);
}
.header-main .logo .logo-text .domain {
  opacity: 0.7;
}
@media (max-width: 1028px) {
  .header-main .logo {
    position: relative;
    left: 0;
    transform: none;
    margin-right: auto; /* Push logo to the left */
  }
}

/* Desktop navigation */
@media (max-width: 1028px) {
  .desktop-nav {
    display: none;
  }
}
.desktop-nav ul {
  display: flex;
  gap: var(--spacing-32);
  list-style: none;
  padding: 0;
  margin: 0;
}
.desktop-nav li {
  margin: 0;
}
.desktop-nav a {
  color: var(--primary-900);
  text-decoration: none;
  font-size: var(--body-large-size);
  font-weight: 700;
  transition: color 0.2s ease;
}
.desktop-nav a.active {
  color: var(--primary-300);
  position: relative;
}
.desktop-nav a:hover {
  color: var(--primary-500);
}

/* Left navigation styles */
.desktop-nav-left {
  flex: 1;
  display: flex;
  justify-content: flex-start;
  margin-right: 20px;
}
@media (max-width: 1028px) {
  .desktop-nav-left {
    display: none;
  }
}

/* Right navigation styles */
.desktop-nav-right {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  margin-left: 20px;
}
@media (max-width: 1028px) {
  .desktop-nav-right {
    display: none;
  }
}

/* Adjust logo to be centered */
.header-main .logo {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
}
@media (max-width: 1028px) {
  .header-main .logo {
    position: relative;
    left: 0;
    transform: none;
    margin-right: auto; /* Push logo to the left */
  }
}

/* Mobile navigation controls */
.hamburger-btn {
  display: none;
  cursor: pointer;
  width: 40px;
  height: 40px;
  min-width: 40px;
  flex: 0 0 40px;
  position: relative;
  z-index: 10000;
  border-radius: 8px;
  border: none;
  padding: 0;
  margin: 0;
  background: transparent;
}
.hamburger-btn .hamburger-icon {
  display: block;
  width: 24px;
  height: 2px;
  background-color: var(--body-white);
  position: relative;
  transition: background-color 0.3s ease;
}
.hamburger-btn .hamburger-icon::before, .hamburger-btn .hamburger-icon::after {
  content: "";
  position: absolute;
  width: 24px;
  height: 2px;
  background-color: var(--body-white);
  transition: transform 0.3s ease;
}
.hamburger-btn .hamburger-icon::before {
  top: -8px;
}
.hamburger-btn .hamburger-icon::after {
  bottom: -8px;
}

@media (max-width: 1028px) {
  .hamburger-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    margin-left: auto; /* Push burger to the right */
  }
}
/* Mobile menu (initially hidden) */
.mobile-menu {
  display: none; /* Hidden by default */
  position: fixed; /* Use fixed positioning to escape container overflow */
  left: 0;
  right: 0;
  width: 100%;
  background-color: var(--neutral-900); /* Dark background */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Stronger shadow */
  z-index: 9999;
  overflow-y: auto; /* Enable scrolling if menu is long */
  transition: transform 0.3s ease-in-out; /* Smooth transition */
  transform: translateY(-10px); /* Slight initial translateY for transition */
  opacity: 0; /* Start with 0 opacity for fade-in */
  border-radius: var(--radius-24);
  margin-top: 0;
}
.mobile-menu nav ul {
  flex-direction: column; /* Stack menu items vertically */
  padding: var(--spacing-32);
}
.mobile-menu nav ul li {
  width: 100%;
  margin-bottom: var(--spacing-8); /* Space between items */
}
.mobile-menu nav ul li a {
  display: block;
  padding: var(--spacing-12) var(--spacing-16);
  border-bottom: 1px solid var(--border-color); /* Optional separator */
}
.mobile-menu nav ul li a:hover {
  color: var(--primary-500);
}

/* Style for when the menu is toggled open */
#menu-toggle:checked ~ .mobile-menu {
  display: block; /* Show the menu when checkbox is checked */
  transform: translateY(0); /* Slide in */
  opacity: 1; /* Fade in */
}

/* Animate hamburger icon */
#menu-toggle:checked ~ * .hamburger-btn .hamburger-icon,
#menu-toggle:checked ~ * * .hamburger-btn .hamburger-icon,
#menu-toggle:checked ~ * * * .hamburger-btn .hamburger-icon {
  background-color: transparent !important; /* Hide the middle line completely */
}
#menu-toggle:checked ~ * .hamburger-btn .hamburger-icon::before,
#menu-toggle:checked ~ * * .hamburger-btn .hamburger-icon::before,
#menu-toggle:checked ~ * * * .hamburger-btn .hamburger-icon::before {
  transform: translateY(8px) rotate(45deg); /* Rotate and position to form a cross */
}
#menu-toggle:checked ~ * .hamburger-btn .hamburger-icon::after,
#menu-toggle:checked ~ * * .hamburger-btn .hamburger-icon::after,
#menu-toggle:checked ~ * * * .hamburger-btn .hamburger-icon::after {
  transform: translateY(-8px) rotate(-45deg); /* Rotate and position to form a cross */
}

/* Show hamburger button on mobile */
@media (max-width: 1028px) {
  .header-main .header-content .hamburger-btn {
    display: flex; /* Show hamburger on screens <= 1028px */
    align-items: center;
    justify-content: center;
  }
}
@media (max-width: 768px) {
  .header-main .header-content .hamburger-btn {
    display: flex !important; /* Ensure hamburger is visible on small screens */
    align-items: center;
    justify-content: center;
  }
}

/* Mobile menu styles */
.mobile-menu {
  display: none;
  position: fixed;
  left: var(--spacing-16);
  right: var(--spacing-16);
  width: calc(100% - var(--spacing-16) * 2);
  background-color: var(--neutral-900);
  z-index: 99999;
  padding: var(--spacing-24);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
  border-radius: var(--radius-24);
  transition: all 0.3s ease;
  opacity: 0;
  transform: translateY(-10px);
}

/* Show menu when checkbox is checked */
#menu-toggle:checked + .mobile-menu {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.mobile-nav {
  width: 100%;
  display: flex; /* Make mobile-nav a flex container to center content */
  justify-content: center; /* Center horizontally */
  align-items: center; /* Center vertically */
}
.mobile-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: center; /* Center text inside list items */
  width: 100%; /* Allow ul to take full width for centering */
}
.mobile-nav ul li {
  margin-bottom: var(--spacing-24); /* Increase space between items */
}
.mobile-nav ul li:last-child {
  margin-bottom: 0;
}
.mobile-nav ul li a {
  color: var(--body-white);
  text-decoration: none;
  font-size: var(--body-large-size); /* Apply headline-medium size */
  font-weight: var(--body-large-weight); /* Apply headline-medium weight */
  line-height: var(--body-large-line-height); /* Apply headline-medium line height */
  display: block; /* Make link a block to fill width for centering */
}
.mobile-nav ul li a:hover {
  color: var(--primary-500);
}

/* Hide the menu toggle checkbox but keep it functional */
.menu-toggle {
  display: none;
}

/* Header background for internal pages (not homepage) */
html:not(.homepage) .header-content {
  background-color: var(--neutral-800);
}

/* Header links color for internal pages */
html:not(.homepage) .header-content .desktop-nav a {
  color: var(--body-main);
}
html:not(.homepage) .header-content .desktop-nav a:hover {
  color: var(--primary-500);
}
html:not(.homepage) .header-content .desktop-nav a.active {
  color: var(--primary-300);
}

/* Adaptive navigation classes for light/dark header backgrounds */
.header-content.header-light-bg .desktop-nav a {
  color: var(--primary-900) !important;
}
.header-content.header-light-bg .desktop-nav a:hover {
  color: var(--primary-500) !important;
}
.header-content.header-light-bg .desktop-nav a.active {
  color: var(--primary-300) !important;
}

.header-content.header-dark-bg .desktop-nav a {
  color: var(--body-main) !important;
}
.header-content.header-dark-bg .desktop-nav a:hover {
  color: var(--primary-500) !important;
}
.header-content.header-dark-bg .desktop-nav a.active {
  color: var(--primary-300) !important;
}

/* === END: layout/header.scss === */
/* 
 * HERO SECTION STYLES
 * Styles for the main hero section with different layouts
 */
/* === BASE HERO STYLES === */
.hero-section {
  text-align: center;
  overflow: visible;
  /* Add text shadow for h1 and h2 elements */
}
.hero-section .container {
  padding-inline: 0;
}
.hero-section .hero__text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-12);
  justify-content: center;
}
.hero-section .hero__image {
  display: flex;
  justify-content: center;
  height: auto;
  position: relative;
  overflow: visible;
}
.hero-section h1, .hero-section h2 {
  text-shadow: 0 4px 30px rgba(0, 0, 0, 0.8);
}

/* === HERO TOP VARIANT === */
.hero--top, .hero-section.hero--a {
  overflow: visible;
}
.hero--top .container, .hero-section.hero--a .container {
  overflow: visible;
  padding-inline: 0;
  padding-inline: var(--spacing-16);
  overflow: visible;
}
.hero--top .hero__text, .hero-section.hero--a .hero__text {
  margin-top: var(--spacing-16);
  margin-bottom: var(--spacing-16);
}
.hero--top .hero__image, .hero-section.hero--a .hero__image {
  margin-top: var(--spacing-8);
}

/* === HERO BOTTOM VARIANT === */
.hero--bottom .hero__image {
  margin-bottom: var(--spacing-16);
}
.hero--bottom .hero__text {
  margin-top: var(--spacing-8);
}

/* === HERO LEFT & RIGHT VARIANTS === */
.hero--left .hero__container, .hero.hero--b .hero__container,
.hero--right .hero__container {
  display: flex;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-16);
  overflow: visible;
  justify-content: space-between;
}
@media (max-width: 1200px) {
  .hero--left .hero__container, .hero.hero--b .hero__container,
  .hero--right .hero__container {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .hero--left .hero__container .hero__text, .hero.hero--b .hero__container .hero__text,
  .hero--right .hero__container .hero__text {
    margin-bottom: var(--spacing-32);
    text-align: center;
    align-items: center;
  }
  .hero--left .hero__container .hero-features, .hero.hero--b .hero__container .hero-features,
  .hero--right .hero__container .hero-features {
    justify-content: center;
    align-items: center;
    text-align: center;
  }
  .hero--left .hero__container .hero__image, .hero.hero--b .hero__container .hero__image,
  .hero--right .hero__container .hero__image {
    display: none;
  }
}
@media (max-width: 768px) {
  .hero--left .hero__container, .hero.hero--b .hero__container,
  .hero--right .hero__container {
    grid-template-columns: 1fr;
    gap: var(--spacing-12);
  }
  .hero--left .hero__container .hero__image, .hero.hero--b .hero__container .hero__image,
  .hero--right .hero__container .hero__image {
    display: none;
  }
}
.hero--left .hero__image, .hero.hero--b .hero__image,
.hero--right .hero__image {
  width: 700px;
  height: 350px;
}
@media (max-width: 768px) {
  .hero--left .hero__image, .hero.hero--b .hero__image,
  .hero--right .hero__image {
    width: 100%;
    height: 300px;
  }
}
.hero--left .hero__text, .hero.hero--b .hero__text,
.hero--right .hero__text {
  text-align: left;
}
@media (max-width: 768px) {
  .hero--left .hero__text, .hero.hero--b .hero__text,
  .hero--right .hero__text {
    text-align: center;
  }
}

/* === HERO LEFT SPECIFIC === */
.hero--left .hero__container, .hero.hero--b .hero__container {
  grid-template-areas: "text image";
}
@media (max-width: 768px) {
  .hero--left .hero__container, .hero.hero--b .hero__container {
    grid-template-areas: "image" "text";
  }
}
.hero--left .hero__text, .hero.hero--b .hero__text {
  grid-area: text;
}
.hero--left .hero__image, .hero.hero--b .hero__image {
  grid-area: image;
}

/* === HERO RIGHT SPECIFIC === */
.hero--right .hero__container {
  grid-template-areas: "image text";
}
@media (max-width: 768px) {
  .hero--right .hero__container {
    grid-template-areas: "image" "text";
  }
}
.hero--right .hero__text {
  grid-area: text;
}
.hero--right .hero__image {
  grid-area: image;
}

/* === LEGACY HERO STYLES (for backward compatibility) === */
/* === ROULETTE & ANIMATIONS (legacy) === */
.hero-img {
  height: var(--hero-img);
  display: flex;
  justify-content: center;
  position: relative;
  overflow: visible;
  z-index: 0;
  /* New background with coins - ANIMATED */
  /* Special animation state - can be toggled with JS */
}
.hero-img .hero-img-background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("img/hero-img/hero-coins.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: auto auto;
  pointer-events: none;
  overflow: visible !important;
  height: 478px;
  /* Beautiful floating animation for coins */
  animation: coins-float 8s ease-in-out infinite;
  transform-origin: center center;
  /* Add subtle glow effect on hover */
  transition: filter 0.3s ease;
}
.hero-img .hero-img-background:hover {
  filter: drop-shadow(0 0 15px rgba(255, 215, 0, 0.3)) brightness(1.1);
  animation-duration: 6s; /* Speed up on hover */
}
.hero-img .hero-img-background.shimmer {
  animation: coins-shimmer 4s ease-in-out infinite;
}
.hero-img .hero-img-background.excited {
  animation: coins-float 3s ease-in-out infinite;
  filter: drop-shadow(0 0 20px rgba(255, 215, 0, 0.5)) brightness(1.2);
}

/* === ANIMATIONS === */
/* Subtle floating animation for parallax effect */
@keyframes subtle-float {
  0% {
    transform: translate(0, 0);
  }
  25% {
    transform: translate(-1%, 1%);
  }
  50% {
    transform: translate(1%, 0%);
  }
  75% {
    transform: translate(0%, -1%);
  }
  100% {
    transform: translate(-1%, -0.5%);
  }
}
/* Beautiful floating animation for coins */
@keyframes coins-float {
  0% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    filter: brightness(1);
  }
  20% {
    transform: translate(1%, -0.5%) scale(1.01) rotate(0.5deg);
    filter: brightness(1.05);
  }
  40% {
    transform: translate(-0.5%, 0.8%) scale(1.02) rotate(-0.3deg);
    filter: brightness(1.1);
  }
  60% {
    transform: translate(0.8%, 0.3%) scale(1.01) rotate(0.8deg);
    filter: brightness(1.02);
  }
  80% {
    transform: translate(-0.3%, -0.8%) scale(1.02) rotate(-0.5deg);
    filter: brightness(1.08);
  }
  100% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    filter: brightness(1);
  }
}
/* Alternative animation - coins shimmer */
@keyframes coins-shimmer {
  0%, 100% {
    transform: translate(0, 0) scale(1);
    filter: brightness(1) saturate(1);
  }
  25% {
    transform: translate(1%, -1%) scale(1.03);
    filter: brightness(1.2) saturate(1.2);
  }
  50% {
    transform: translate(-1%, 1%) scale(0.98);
    filter: brightness(0.9) saturate(0.8);
  }
  75% {
    transform: translate(0.5%, 0.5%) scale(1.02);
    filter: brightness(1.1) saturate(1.1);
  }
}
/* Parallax animation for coins background */
@keyframes parallax-float {
  0% {
    transform: translate(0, 0) scale(1);
  }
  25% {
    transform: translate(2%, -1%) scale(1.02);
  }
  50% {
    transform: translate(-1%, 1%) scale(1);
  }
  75% {
    transform: translate(1%, -2%) scale(1.01);
  }
  100% {
    transform: translate(-2%, 0%) scale(1.02);
  }
}
/* === END: layout/hero.scss === */
/* === START: layout/hero-features.scss === */
/* ==========================================
   HERO FEATURES
   ========================================== */
.hero-features {
  display: flex;
  justify-content: center;
  gap: var(--spacing-4);
  width: 100%;
  flex-wrap: wrap;
}
@media (max-width: 992px) {
  .hero-features {
    flex-direction: row;
    align-items: center;
    gap: var(--spacing-12);
    justify-content: center; /* Always center on mobile */
  }
}

/* Hero features alignment based on layout */
.hero--top .hero-features,
.hero--bottom .hero-features {
  justify-content: center; /* Center for top and bottom layouts */
}

.hero--left .hero-features,
.hero--right .hero-features {
  justify-content: flex-start; /* Left align for left and right layouts */
}
@media (max-width: 768px) {
  .hero--left .hero-features,
  .hero--right .hero-features {
    justify-content: center; /* Center on mobile for all layouts */
  }
}

.feature-badge {
  display: flex;
  background-color: var(--header-features);
  align-items: center;
  gap: var(--spacing-4);
  border-radius: var(--radius-full);
  padding: var(--spacing-8) var(--spacing-16);
  color: var(--body-white);
  font-weight: var(--body-large-bold-weight);
  font-size: var(--body-large-size);
  white-space: nowrap;
  flex: 0 0 auto;
}
@media (max-width: 992px) {
  .feature-badge {
    justify-content: center;
  }
}

.feature-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--size-24);
  height: var(--size-24);
}
.feature-icon img {
  width: var(--size-24);
  height: var(--size-24);
}

/* === END: layout/hero-features.scss === */
/* 
 * HERO DICE - NEW STRUCTURE
 * Hero image 500x400 with centered 400x300 container for original-sized dice
 */
/* === HERO IMAGE CONTAINER === */
.hero-img {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
@media (max-width: 768px) {
  .hero-img {
    width: 100%;
    max-width: 350px;
    height: 280px;
    margin: 0 auto;
  }
}
@media (max-width: 480px) {
  .hero-img {
    max-width: 300px;
    height: 240px;
  }
}

/* === INNER DICE CONTAINER === */
.hero__img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 400px;
  height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-20);
}
@media (max-width: 768px) {
  .hero__img {
    width: 280px;
    height: 210px;
    gap: var(--spacing-16);
  }
}
@media (max-width: 480px) {
  .hero__img {
    width: 240px;
    height: 180px;
    gap: var(--spacing-12);
  }
}

/* === DICE ELEMENTS === */
.dice-cube {
  flex-shrink: 0;
  /* Первый кубик - оригинальный размер 230x230 */
  /* Второй кубик - оригинальный размер 200x200 */
}
.dice-cube--1 {
  width: 230px;
  height: 230px;
}
.dice-cube--1 img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media (max-width: 768px) {
  .dice-cube--1 {
    width: 160px;
    height: 160px;
  }
}
@media (max-width: 480px) {
  .dice-cube--1 {
    width: 120px;
    height: 120px;
  }
}
.dice-cube--2 {
  width: 200px;
  height: 200px;
}
.dice-cube--2 img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media (max-width: 768px) {
  .dice-cube--2 {
    width: 140px;
    height: 140px;
  }
}
@media (max-width: 480px) {
  .dice-cube--2 {
    width: 105px;
    height: 105px;
  }
}

/* === ANIMATIONS (OPTIONAL) === */
.dice-cube {
  transition: transform 0.3s ease;
}
.dice-cube:hover {
  transform: scale(1.05);
}

/* === RESPONSIVE ADJUSTMENTS === */
@media (max-width: 768px) {
  .hero-img {
    width: 100%;
    /* Уменьшаем основной контейнер на мобильных */
  }
  .hero__img {
    width: 100%;
    /* Пропорционально уменьшаем внутренний контейнер */
  }
}
@media (max-width: 480px) {
  .hero-img {
    width: 100%;
    /* Дополнительные уменьшения для очень маленьких экранов */
  }
}
/* === START: layout/roulette.scss === */
/* ==========================================
   ROULETTE (WHEEL OF FORTUNE)
   ========================================== */
body.v4 .hero__roulette-container {
  position: absolute;
  top: 75px;
  width: 400px;
  left: 50%;
  transform: translateX(-50%); /* Center properly without negative margin */
  display: flex;
  justify-content: center;
  align-items: flex-end;
  /* Add continuous rotation animation */
  animation: wheelSpin 20s linear infinite; /* Linear timing for smooth continuous rotation */
}
body.v4 .hero__roulette-container img {
  display: block;
  height: auto;
  height: 330px;
  width: 330px;
}

.roulette-container {
  position: relative;
  width: 580px;
  height: 580px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  /* Define the continuous spin animation */
}
.roulette-container .wheel, .roulette-container .frame, .roulette-container .pin {
  position: absolute;
}
.roulette-container .hero__roulette-container {
  position: absolute;
  bottom: -158px;
  left: 50%;
  margin-left: -164px;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  align-items: flex-end;
  /* Add rotation animation */
  animation: spin 60s linear infinite; /* Adjust duration and timing as needed */
}
.roulette-container .hero__roulette-container img {
  display: block;
  height: auto;
  height: 320px;
  width: 320px;
}
@keyframes spin {
  0% {
    transform: translateX(-50%) rotate(0deg);
  }
  100% {
    transform: translateX(-50%) rotate(360deg);
  }
}
.roulette-container .wheel {
  width: 100%;
  height: auto;
  animation: spin 20s cubic-bezier(0.51, 0.92, 0.24, 1.15) infinite;
  transform-origin: center center;
}
.roulette-container .frame {
  width: 110%;
  height: auto;
  z-index: var(--z-content);
}
.roulette-container .pin {
  width: var(--size-32);
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: var(--z-overlay);
}
@media (max-width: 768px) {
  .roulette-container {
    width: 400px;
    height: 400px;
  }
  .roulette-container .pin {
    width: var(--size-24);
  }
}
@media (max-width: 480px) {
  .roulette-container {
    width: 280px;
    height: 280px;
  }
  .roulette-container .pin {
    width: var(--size-16);
  }
}

/* Simple continuous spinning animation for the roulette wheel */
@keyframes wheelSpin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* === END: layout/roulette.scss === */
/* 
 * FAQ SECTION STYLES
 * Components for displaying FAQ accordions
 */
/* === FAQ SECTION === */
.faq-section {
  padding-top: var(--section-tb-all);
  padding-bottom: var(--section-tb-all);
}
.faq-section p {
  margin-bottom: var(--spacing-32);
}
.faq-section .container-sm {
  max-width: var(--container-sm);
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-28);
}

.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-28);
  /* Two-column layout for homepage */
}
.faq-accordion.faq-accordion--two-column {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: start;
  grid-auto-rows: auto;
  gap: var(--spacing-24);
  /* Hide toggle but keep it in the document flow */
  /* Each FAQ item is a grid item */
  /* Return to single column on mobile */
}
.faq-accordion.faq-accordion--two-column .faq-toggle {
  display: none;
}
.faq-accordion.faq-accordion--two-column .faq-toggle + .faq-item {
  /* Reset any inherited styles that might cause issues */
  margin: 0;
}
@media (max-width: 768px) {
  .faq-accordion.faq-accordion--two-column {
    grid-template-columns: 1fr;
  }
}

.faq-item {
  background-color: var(--card-bg-default);
  border-radius: var(--radius-24);
  overflow: hidden;
  transition: border-color 0.3s ease;
}

.faq-toggle {
  display: none;
}

/* Style for active accordion item */
.faq-toggle:checked + .faq-item {
  border: none;
  position: relative;
  background-color: var(--main-bg);
  transition: border-color 0.3s ease;
  background-color: var(--card-bg-default);
}

.faq-question {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-32);
  cursor: pointer;
  text-align: left;
  width: 100%;
  background: none;
  border: none;
}

.faq-question-text {
  flex: 1;
  padding-right: var(--spacing-16);
  color: var(--body-white);
}

.faq-icon {
  flex-shrink: 0;
  position: relative;
}
.faq-icon svg {
  display: block;
  width: 24px;
  height: 24px;
  transition: opacity 0.3s ease;
}

/* Default state: show closed icon (plus), hide open icon (minus) */
.faq-icon-closed {
  opacity: 1;
}

.faq-icon-open {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
}

.faq-icon-open path {
  fill: var(--body-white);
}

.faq-icon-closed path {
  fill: var(--primary-500);
}

/* Open state: hide closed icon (plus), show open icon (minus) */
.faq-toggle:checked + .faq-item .faq-icon-closed {
  opacity: 0;
}

.faq-toggle:checked + .faq-item .faq-icon-open {
  opacity: 1;
}

.faq-answer {
  max-height: 0;
  padding: 0 var(--spacing-32) 0;
  overflow: hidden;
  opacity: 0;
  transition: all 0.5s ease;
}
.faq-answer p {
  margin-bottom: 0;
}

.faq-toggle:checked + .faq-item .faq-answer {
  max-height: 1000px;
  padding: 0 var(--spacing-32) var(--spacing-32);
  opacity: 1;
}

@media (max-width: 768px) {
  .faq-section p {
    margin-bottom: var(--spacing-24);
  }
  .faq-accordion {
    gap: var(--spacing-16);
  }
  .faq-question {
    padding: var(--spacing-20);
  }
  .faq-question-text {
    padding-right: var(--spacing-12);
  }
  .faq-toggle:checked + .faq-item .faq-answer {
    padding: 0 var(--spacing-20) var(--spacing-20);
  }
  .faq-answer {
    padding: 0 var(--spacing-20) 0;
  }
}
/* === END: layout/faq.scss === */
/* === START: layout/reviews.scss === */
/* ==========================================
   REVIEWS SECTION
   ========================================== */
.reviews-section {
  padding-top: var(--section-tb-all);
  padding-bottom: var(--section-tb-all);
}
.reviews-section p {
  margin-bottom: var(--spacing-40);
}
.reviews-section .container-sm {
  max-width: var(--container-sm);
}

.reviews-grid {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
}

/* Original review styles (for backward compatibility) */
.review-item:not(.review-item--v1):not(.review-item--v2) {
  display: flex;
  flex-direction: column;
  background-color: var(--neutral-900);
  border-radius: var(--radius-24);
  padding: var(--spacing-32);
  gap: var(--spacing-16);
  position: relative;
  border: none;
}
.review-item:not(.review-item--v1):not(.review-item--v2)::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-24);
  padding: 1px; /* Border width */
  background: linear-gradient(to bottom, var(--neutral-900), var(--primary-800));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
}
.review-item:not(.review-item--v1):not(.review-item--v2) p {
  margin-bottom: 0;
  position: relative;
  z-index: 2;
}

.review-header {
  display: flex;
  align-items: center;
}

.reviewer {
  display: flex;
  align-items: center;
  gap: var(--spacing-8);
  color: var(--body-muted);
}

.avatar {
  width: var(--size-32);
  height: var(--size-32);
  border-radius: 50%;
}

.rating {
  display: flex;
  gap: 0;
}
.rating img {
  width: var(--size-16);
  height: var(--size-16);
}

/* Reviews CTA Button */
.reviews-cta {
  display: flex;
  justify-content: center;
  margin-top: var(--spacing-32);
}
/* === END: layout/reviews.scss === */
/* === START: layout/seo.scss === */
/* ==========================================
   SEO TEXT SECTION
   ========================================== */
.seo-section {
  padding-top: var(--section-tb-all);
  padding-bottom: var(--section-tb-all);
}
.seo-section .container-sm {
  max-width: var(--container-sm);
}

.seo-content p {
  margin-bottom: var(--spacing-16);
}
.seo-content p:last-child {
  margin-bottom: 0;
}
.seo-content .headline-small {
  margin-top: var(--spacing-32);
  margin-bottom: var(--spacing-16);
}
.seo-content .headline-small:first-child {
  margin-top: 0;
}

/* Universal content list styling - global selector */
.content-list {
  list-style: none;
  padding-left: var(--spacing-16);
  margin-bottom: var(--spacing-16);
}
.content-list li {
  position: relative;
  padding-left: var(--spacing-16);
  margin-bottom: var(--spacing-8);
}
.content-list li:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.75em; /* Position the dot at 0.75em from the top of the text */
  transform: translateY(-50%); /* Additional offset for vertical centering */
  width: var(--size-8);
  height: var(--size-8);
  border-radius: 50%;
  background-color: var(--primary-500);
}
.content-list li:last-child {
  margin-bottom: 0;
}

.numbered-list {
  counter-reset: item;
  padding-left: 0;
}
.numbered-list li {
  counter-increment: item;
  padding-left: var(--spacing-32);
}
.numbered-list li:before {
  content: counter(item) ".";
  width: auto;
  height: auto;
  border-radius: 0;
  background-color: transparent;
  color: var(--primary-500);
  font-weight: 500;
  top: 0;
}

/* === END: layout/seo.scss === */
/* === START: layout/about.scss === */
/* About Us page styles */
.mission-list {
  background-color: rgba(0, 0, 0, 0.07);
  padding: var(--spacing-16) var(--spacing-20);
  margin-bottom: var(--spacing-24);
  border-radius: var(--radius-sm);
  list-style-type: disc;
  list-style-position: inside;
}
.mission-list li {
  margin-bottom: var(--spacing-8);
  padding-left: var(--spacing-8);
  /* List item styles */
}
.mission-list li:last-child {
  margin-bottom: 0;
}

/* === END: layout/about.scss === */
/* === START: layout/contact.scss === */
/* Contact wrapper with border and padding */
/* ==========================================
 CONTACT FORM STYLES
 ========================================== */
.contact-form {
  margin-top: var(--spacing-24);
  /* Two-row form layout: 
     First row: name and email inputs side by side
     Second row: textarea full width */
  /* Message textarea styles */
  /* Button wrapper for alignment */
}
.contact-form .contact-form-row {
  display: flex;
  gap: var(--spacing-24);
  margin-bottom: var(--spacing-24);
}
.contact-form .contact-form-row.form-row-inputs {
  /* First row: two inputs side by side */
}
.contact-form .contact-form-row.form-row-inputs .contact-form-col {
  flex: 1;
}
.contact-form .contact-form-row.form-row-message {
  /* Second row: full-width textarea */
}
.contact-form .contact-form-row.form-row-message .contact-form-col {
  flex: 1;
}
.contact-form .contact-form-col {
  display: flex;
  flex-direction: column;
}
.contact-form .input-wrapper {
  margin-bottom: var(--spacing-16);
}
.contact-form .input-wrapper:last-child {
  margin-bottom: 0;
}
.contact-form .message-wrapper {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}
.contact-form .message-wrapper .input-field {
  min-height: 150px;
  max-height: 300px;
  height: 150px;
  resize: vertical;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.contact-form .form-button-wrapper {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--spacing-24);
}
.contact-form .form-button-wrapper .button-primary {
  min-width: 200px;
  white-space: nowrap;
}

/* Responsive styles for mobile */
@media (max-width: 768px) {
  .contact-form .contact-form-row.form-row-inputs {
    flex-direction: column;
    gap: var(--spacing-16);
  }
  .contact-form .form-button-wrapper {
    justify-content: center;
  }
  .contact-form .form-button-wrapper .button-primary {
    width: 100%;
    max-width: 100%;
    min-width: auto;
  }
}
/* === END: layout/contact.scss === */
/* === START: layout/footer.scss === */
/* ==========================================
   FOOTER STYLES
   ========================================== */
footer {
  background-image: url("img/footer-bg.png");
  background-repeat: repeat-x;
  background-size: auto;
  background-position: bottom center;
  color: var(--body-main);
  padding-top: var(--spacing-64);
  padding-bottom: var(--spacing-64);
  border-top: 1px solid var(--global-stroke);
}

/* Footer Navigation */
.footer-nav {
  border-bottom: 1px solid var(--global-stroke);
  padding-bottom: var(--spacing-24);
  margin-bottom: var(--spacing-32);
}

.footer-nav nav {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--spacing-32);
}

.footer-nav a {
  color: var(--body-white);
  text-decoration: none;
  transition: color 0.2s ease;
}

.footer-nav a:hover {
  color: var(--primary-500);
}

/* Footer Info Columns */
.footer-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-32);
  margin-bottom: var(--spacing-32);
}

.footer-info-column h3 {
  color: var(--body-white);
  font-size: var(--body-large-size);
  font-weight: 600;
}

.footer-info-column p {
  font-size: var(--body-medium-size);
  line-height: 1.5;
}

/* Footer Support */
.footer-support {
  margin-bottom: var(--spacing-32);
}

.footer-support h3 {
  color: var(--body-white);
  font-size: var(--body-large-size);
  font-weight: 600;
}

.footer-support p {
  font-size: var(--body-medium-size);
  line-height: 1.5;
}

/* Footer Disclaimer */
.footer-disclaimer {
  border-radius: var(--radius-24);
  padding: var(--spacing-32);
  margin-bottom: var(--spacing-40);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--spacing-24);
  border: 1px solid var(--global-stroke);
}

.age-badge {
  margin-bottom: var(--spacing-8);
}

.age-badge img {
  width: var(--size-48);
  height: var(--size-48);
}

.disclaimer-text {
  width: 100%;
}

.disclaimer-text p {
  margin-bottom: var(--spacing-16);
  font-size: var(--body-medium-size);
  line-height: 1.5;
}

.disclaimer-text p:last-child {
  margin-bottom: 0;
}

/* Compliance Logos */
.footer-compliance {
  margin-bottom: var(--spacing-40);
  text-align: center;
}

.compliance-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-32);
}

.compliance-logos img {
  width: auto;
  opacity: 0.8;
  transition: opacity 0.2s ease;
  height: var(--size-48);
}

.compliance-logos img:hover {
  opacity: 1;
}

/* Company Info */
.footer-company {
  text-align: center;
  margin-bottom: var(--spacing-24);
}

.footer-company p {
  margin-bottom: var(--spacing-8);
  font-size: var(--body-small-size);
  color: var(--body-muted);
}

.footer-company a {
  color: var(--body-muted);
  text-decoration: none;
}

.footer-company a:hover {
  color: var(--primary-500);
}

/* Copyright */
.footer-copyright {
  text-align: center;
  font-size: var(--body-small-size);
  color: var(--body-muted);
  padding-top: var(--spacing-16);
  border-top: 1px solid var(--global-stroke);
}

/* Responsive footer styles */
@media (max-width: 768px) {
  .footer {
    padding-top: var(--spacing-40);
    padding-bottom: var(--spacing-24);
  }
  .footer-nav nav {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-16);
  }
  .footer-info {
    grid-template-columns: 1fr;
    gap: var(--spacing-24);
  }
  .compliance-logos {
    gap: var(--spacing-16);
  }
}
/* === END: layout/footer.scss === */
/* === START: layout/team.scss === */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-24);
}
@media (max-width: 768px) {
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.team-member {
  display: flex;
  flex-direction: column;
}
.team-member .team-member-image {
  width: 100%;
  margin-bottom: var(--spacing-12);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.team-member .team-member-image img {
  width: 100%;
  height: auto;
  display: block;
}
.team-member .team-member-name {
  font-family: var(--body-large-family);
  font-size: var(--body-large-size);
  line-height: var(--body-large-line-height);
  font-weight: var(--body-large-weight);
  color: var(--body-main);
  text-align: center;
}
.team-member .team-member-position {
  font-family: var(--body-medium-family);
  font-size: var(--body-medium-size);
  line-height: var(--body-medium-line-height);
  font-weight: var(--body-medium-weight);
  color: var(--body-muted);
  text-align: center;
}

/* === END: layout/team.scss === */
/* ==========================================
   SECTION HEADER WITH BUTTON
   ========================================== */
.section-header-with-button {
  margin-bottom: var(--spacing-32);
}
.section-header-with-button h1, .section-header-with-button .headline-large {
  margin-bottom: var(--spacing-16);
}
.section-header-with-button p {
  margin-bottom: var(--spacing-24);
}

/* === UI COMPONENTS === */
/* ==========================================
   BUTTON STYLES
   ========================================== */
/* === START: components/buttons.scss === */
/* Primary button style */
.button-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-24);
  border-radius: var(--radius-16);
  background: var(--primary-button-default);
  color: var(--primary-button-text);
  font-size: var(--label-medium-size);
  font-weight: var(--label-medium-weight);
  line-height: var(--label-medium-line-height);
  font-family: var(--label-medium-family);
  letter-spacing: var(--label-medium-letter-spacing);
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  text-decoration: none;
  width: 100%; /* Change to full width */
  max-width: 320px;
  /* Make buttons full width on mobile devices */
}
.button-primary path {
  fill: var(--primary-button-text) !important;
}
.button-primary:hover {
  opacity: 1;
  background: var(--primary-button-hover);
  color: var(--primary-button-text);
}
.button-primary:active {
  opacity: 0.8;
}
.button-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.button-primary .button-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--size-20);
  height: var(--size-20);
  display: none;
}
.button-primary .button-icon svg {
  margin-top: -2px;
}
.button-primary .button-icon path {
  fill: var(--body-white);
}
.button-primary.button-icon-only {
  padding: var(--size-20);
}
.button-primary.button-icon-only .button-icon {
  margin: 0;
}
@media (max-width: var(--breakpoint-tablet)) {
  .button-primary {
    width: 100%;
    max-width: 100%;
  }
}

/* Button size variations */
.button-small {
  padding: var(--spacing-12) var(--spacing-16);
  font-size: var(--body-small-size);
}

.button-large {
  padding: var(--spacing-20) var(--spacing-32);
  font-size: var(--body-large-size);
}

/* Secondary button style */
.button-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-20) var(--spacing-2);
  border-radius: var(--radius-16);
  background: var(--secondary-button-default);
  color: var(--secondary-button-text);
  font-size: var(--label-medium-size);
  font-weight: var(--label-medium-weight);
  line-height: var(--label-medium-line-height);
  font-family: var(--label-medium-family);
  letter-spacing: var(--label-medium-letter-spacing);
  text-transform: uppercase;
  border: 1px solid var(--secondary-button-stroke);
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
  width: 100%;
  /* Make buttons full width on mobile devices */
}
.button-secondary path {
  fill: var(--secondary-button-text);
}
.button-secondary:hover {
  background: var(--secondary-button-hover);
  color: var(--secondary-button-hover-text);
  border-color: var(--secondary-button-stroke);
}
.button-secondary:active {
  opacity: 0.8;
}
.button-secondary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.button-secondary .button-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--size-20);
  height: var(--size-20);
}
.button-secondary .button-icon svg {
  margin-top: -2px;
}
.button-secondary .button-icon path {
  fill: var(--secondary-button-text);
}
.button-secondary:hover .button-icon path {
  fill: var(--secondary-button-hover-text);
}
.button-secondary.button-icon-only {
  padding: var(--size-20);
}
.button-secondary.button-icon-only .button-icon {
  margin: 0;
}
@media (max-width: var(--breakpoint-tablet)) {
  .button-secondary {
    width: 100%;
    max-width: 100%;
  }
}

/* Ghost button style */
.button-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-20);
  border-radius: var(--radius-16);
  background: var(--ghost-button-default);
  color: var(--ghost-button-text);
  font-size: var(--label-medium-size);
  font-weight: var(--label-medium-weight);
  line-height: var(--label-medium-line-height);
  font-family: var(--label-medium-family);
  letter-spacing: var(--label-medium-letter-spacing);
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
  width: 100%;
  max-width: 320px;
  /* Make buttons full width on mobile devices */
}
.button-ghost path {
  fill: var(--ghost-button-text) !important;
}
.button-ghost:hover {
  opacity: 0.8;
  background: rgba(255, 255, 255, 0.05);
}
.button-ghost:active {
  opacity: 0.6;
}
.button-ghost:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.button-ghost .button-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--size-20);
  height: var(--size-20);
}
.button-ghost .button-icon svg {
  margin-top: -2px;
}
.button-ghost .button-icon path {
  fill: var(--ghost-button-text);
}
.button-ghost.button-icon-only {
  padding: var(--size-20);
}
.button-ghost.button-icon-only .button-icon {
  margin: 0;
}
@media (max-width: var(--breakpoint-tablet)) {
  .button-ghost {
    width: 100%;
    max-width: 100%;
  }
}

/* === END: components/buttons.scss === */
/* ==========================================
   INPUT FIELD STYLES
   ========================================== */
/* === START: components/inputs.scss === */
/* Base input field style */
.input-field {
  background-color: var(--neutral-900);
  border: 1px solid var(--global-stroke);
  border-radius: var(--radius-16);
  padding: var(--spacing-24);
  width: 100%;
  color: var(--body-white);
  font-size: var(--body-medium-size);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  box-sizing: border-box;
}
.input-field::placeholder {
  color: var(--body-muted);
}
.input-field:focus {
  outline: none;
  border-color: var(--primary-500);
  box-shadow: 0 0 0 2px rgba(118, 104, 252, 0.2);
}
.input-field:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Textarea specific styles */
textarea.input-field {
  resize: none !important; /* Disable browser resizing */
  overflow: auto !important; /* Prevent overflow */
  max-width: 100% !important;
  width: 100% !important;
  display: block !important;
  box-sizing: border-box !important;
  min-height: 150px !important;
  max-height: 300px !important; /* Limit maximum height */
  height: 150px !important; /* Fixed height */
  border-radius: var(--radius-16);
}

/* Form field wrapper */
.input-wrapper {
  margin-bottom: var(--spacing-24);
  position: relative;
}

/* Form labels */
.input-label {
  display: block;
  margin-bottom: var(--spacing-8);
  color: var(--body-white);
  font-weight: 500;
  font-size: var(--body-medium-size);
}

/* Form validation error messages */
.input-error {
  color: var(--error);
  font-size: var(--body-small-size);
  margin-top: var(--spacing-4);
  display: block;
}

/* Textarea style */
textarea.input-field {
  min-height: 150px;
  resize: vertical;
}

/* === END: components/inputs.scss === */
#top {
  position: absolute;
  top: 0;
  left: 0;
  height: 0;
  width: 0;
  opacity: 0;
}

/* Scroll to Top Button */
.scroll-to-top {
  position: fixed;
  bottom: var(--spacing-32);
  right: var(--spacing-32);
  background: var(--primary-900);
  color: var(--body-white);
  border: none;
  border-radius: var(--radius-full);
  width: auto;
  height: var(--size-48);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  text-decoration: none;
  padding: 0 var(--spacing-20);
  font-size: var(--body-medium-size);
  font-weight: 600;
  gap: var(--spacing-8);
  transition: background-color 0.3s ease, transform 0.2s ease, opacity 0.3s ease;
  z-index: var(--z-tooltip);
  /* Hidden by default for homepage */
  /* Visible when user scrolls on homepage */
}
.scroll-to-top.homepage-scroll-btn {
  opacity: 0;
  visibility: hidden;
}
.scroll-to-top.homepage-scroll-btn.visible {
  opacity: 1;
  visibility: visible;
}
.scroll-to-top:hover {
  background: var(--primary-800);
  transform: translateY(-2px);
  color: var(--body-white);
}
.scroll-to-top:hover svg {
  color: var(--body-white);
}
.scroll-to-top svg {
  width: var(--size-16);
  height: var(--size-16);
  transition: transform 0.2s ease;
  color: var(--body-white);
}

.opacity {
  opacity: 0;
}

/* 
 * TYPOGRAPHY STYLES
 * Text components and typography classes
 */
/* === START: typography/display === */
/* ==========================================
   DISPLAY STYLES
   Largest text styles for major page headers
   ========================================== */
.display-large {
  font-family: var(--display-large-family);
  font-size: var(--display-large-size);
  line-height: var(--display-large-line-height);
  font-weight: var(--display-large-weight);
  letter-spacing: var(--display-large-letter-spacing);
}

.display-medium {
  font-family: var(--display-medium-family);
  font-size: var(--display-medium-size);
  line-height: var(--display-medium-line-height);
  font-weight: var(--display-medium-weight);
  letter-spacing: var(--display-medium-letter-spacing);
}

.display-small {
  font-family: var(--display-small-family);
  font-size: var(--display-small-size);
  line-height: var(--display-small-line-height);
  font-weight: var(--display-small-weight);
  letter-spacing: var(--display-small-letter-spacing);
}

/* === END: typography/display === */
/* === START: typography/headline === */
/* ==========================================
   HEADLINE STYLES
   Section headers and prominent text
   ========================================== */
.headline-large, .headline {
  font-family: var(--headline-large-family);
  font-size: var(--headline-large-size);
  line-height: var(--headline-large-line-height);
  font-weight: var(--headline-large-weight);
  letter-spacing: var(--headline-large-letter-spacing);
}

.headline-medium {
  font-family: var(--headline-medium-family);
  font-size: var(--headline-medium-size);
  line-height: var(--headline-medium-line-height);
  font-weight: var(--headline-medium-weight);
  letter-spacing: var(--headline-medium-letter-spacing);
}

.headline-small {
  font-family: var(--headline-small-family);
  font-size: var(--headline-small-size);
  line-height: var(--headline-small-line-height);
  font-weight: var(--headline-small-weight);
  letter-spacing: var(--headline-small-letter-spacing);
}

/* === END: typography/headline === */
/* === START: typography/title === */
/* ==========================================
   TITLE STYLES
   Smaller headers and important text
   ========================================== */
.title-large {
  font-family: var(--title-large-family);
  font-size: var(--title-large-size);
  line-height: var(--title-large-line-height);
  font-weight: var(--title-large-weight);
  letter-spacing: var(--title-large-letter-spacing);
}

.title-medium {
  font-family: var(--title-medium-family);
  font-size: var(--title-medium-size);
  line-height: var(--title-medium-line-height);
  font-weight: var(--title-medium-weight);
  letter-spacing: var(--title-medium-letter-spacing);
}

.title-small {
  font-family: var(--title-small-family);
  font-size: var(--title-small-size);
  line-height: var(--title-small-line-height);
  font-weight: var(--title-small-weight);
  letter-spacing: var(--title-small-letter-spacing);
}

/* === END: typography/title === */
/* === START: typography/body === */
/* ==========================================
   BODY TEXT STYLES
   Main content text styles
   ========================================== */
.body-large {
  font-family: var(--body-large-family);
  font-size: var(--body-large-size);
  line-height: var(--body-large-line-height);
  font-weight: var(--body-large-weight);
  letter-spacing: var(--body-large-letter-spacing);
}

.body-medium {
  font-family: var(--body-medium-family);
  font-size: var(--body-medium-size);
  line-height: var(--body-medium-line-height);
  font-weight: var(--body-medium-weight);
  letter-spacing: var(--body-medium-letter-spacing);
}

.body-small {
  font-family: var(--body-small-family);
  font-size: var(--body-small-size);
  line-height: var(--body-small-line-height);
  font-weight: var(--body-small-weight);
  letter-spacing: var(--body-small-letter-spacing);
}

.body-large-bold {
  font-family: var(--body-large-bold-family);
  font-size: var(--body-large-bold-size);
  line-height: var(--body-large-bold-line-height);
  font-weight: var(--body-large-bold-weight);
  letter-spacing: var(--body-large-bold-letter-spacing);
}

/* === END: typography/body === */
/* === START: typography/label === */
/* ==========================================
   LABEL STYLES
   UI element labels, buttons, etc.
   ========================================== */
.label-large {
  font-family: var(--label-large-family);
  font-size: var(--label-large-size);
  line-height: var(--label-large-line-height);
  font-weight: var(--label-large-weight);
  letter-spacing: var(--label-large-letter-spacing);
}

.label-medium, .label {
  font-family: var(--label-medium-family);
  font-size: var(--label-medium-size);
  line-height: var(--label-medium-line-height);
  font-weight: var(--label-medium-weight);
  letter-spacing: var(--label-medium-letter-spacing);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.label-small {
  font-family: var(--label-small-family);
  font-size: var(--label-small-size);
  line-height: var(--label-small-line-height);
  font-weight: var(--label-small-weight);
  letter-spacing: var(--label-small-letter-spacing);
}

/* === END: typography/label === */
/* === START: typography/legacy === */
/* ==========================================
   LEGACY/COMPATIBILITY CLASSES
   For backwards compatibility with older code
   ========================================== */
/* Legacy class for headline-large */
/* Legacy class for label-medium */
/* Meta information style (small, muted text) */
.meta {
  font-size: var(--body-small-size);
  color: var(--body-muted);
}

/* === END: typography/legacy === */
/* === REVIEWS COMPONENTS === */
/* 
 * NEW REVIEWS COMPONENTS
 * Two distinct layouts with different visual styles
 */
/* V1 - Original Layout Style */
.review-item--v1 {
  display: flex;
  flex-direction: column;
  background-color: var(--neutral-900);
  border-radius: var(--radius-24);
  padding: var(--spacing-32);
  gap: var(--spacing-16);
  position: relative;
  border: none;
}
.review-item--v1::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-24);
  padding: 1px;
  background: linear-gradient(to bottom, var(--neutral-900), var(--primary-800));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
}
.review-item--v1 .review-header {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-16);
  position: relative;
  z-index: 2;
  margin-bottom: 0;
}
.review-item--v1 .review-avatar {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  position: relative;
  border-radius: 50%;
  overflow: hidden;
  background-color: var(--primary-800);
}
.review-item--v1 .review-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.review-item--v1 .review-author {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
}
.review-item--v1 .review-name {
  font-weight: 600;
  color: var(--body-white);
}
.review-item--v1 .review-stars {
  display: flex;
  gap: 0;
}
.review-item--v1 .review-content {
  position: relative;
  z-index: 2;
}
.review-item--v1 .review-text {
  margin-bottom: 0;
  position: relative;
  z-index: 2;
}

/* V2 - Premium Card Layout with Avatar */
.review-item--v2 {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-12);
  padding: var(--spacing-24);
  border-radius: var(--radius-24);
  position: relative;
  border: 1px solid var(--stroke);
  text-align: center;
}
.review-item--v2 .review-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-16);
  margin-bottom: 0;
}
.review-item--v2 .review-avatar {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  position: relative;
  border-radius: 50%;
  overflow: hidden;
  background-color: var(--primary-800);
}
@media (max-width: 768px) {
  .review-item--v2 .review-avatar {
    width: 48px;
    height: 48px;
  }
}
.review-item--v2 .review-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.review-item--v2 .review-avatar-default {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: var(--neutral-700);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  border: 2px solid var(--neutral-800);
}
.review-item--v2 .review-avatar-default img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.review-item--v2 .review-author {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
}
.review-item--v2 .review-name {
  color: var(--body-muted);
  font-size: var(--body-medium-size);
  font-weight: var(--body-medium-weight);
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.review-item--v2 .review-name::before {
  content: "";
  color: var(--text-muted);
}
.review-item--v2 .review-stars {
  display: flex;
  gap: 0;
  color: var(--warning);
  font-size: 1rem;
  letter-spacing: 2px;
  width: 100%;
  align-items: center;
  justify-content: center;
}
.review-item--v2 .review-stars-img {
  width: auto;
  height: 16px;
}
.review-item--v2 .review-content {
  position: relative;
  flex: 1;
  min-width: 0;
}
.review-item--v2 .review-rating {
  margin-bottom: var(--spacing-12);
  display: flex;
  align-items: center;
  gap: var(--spacing-8);
}
.review-item--v2 .review-text {
  margin-bottom: 0;
  color: var(--body-white);
  line-height: 1.6;
  font-weight: 400;
}
@media (max-width: 768px) {
  .review-item--v2 {
    padding: var(--spacing-16);
    gap: 0;
  }
  .review-item--v2 .review-content {
    width: 100%;
    padding: var(--spacing-20);
  }
}

/* Reviews container */
.reviews-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  /* Mixed layout support */
  /* V2 Grid Layout - 2 columns on desktop */
}
.reviews-list--mixed {
  gap: var(--spacing-12);
}
.reviews-list--v2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-28);
}
@media (max-width: 768px) {
  .reviews-list--v2 {
    grid-template-columns: 1fr;
    gap: var(--spacing-12);
  }
}

/* Reviews section wrapper */
.reviews-section {
  /* Section-specific overrides */
}
.reviews-section .reviews-title {
  font-size: var(--title-large-size);
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--spacing-24);
  text-align: center;
}
.reviews-section .reviews-list {
  margin-top: var(--spacing-16);
}

/* === CASINO CARDS COMPONENTS === */
/* 
 * CASINO CARDS - UNIFIED BASE SYSTEM
 * Shared styles for all casino card versions using BEM methodology
 */
/* === GRID SYSTEM FOR CASINO-CARDS BLOCK === */
.casino-cards-section {
  background-image: url("img/main-bg-bottom.png");
  background-position: top center;
  background-size: auto;
  background-repeat: repeat-x;
  position: relative;
  z-index: 10; /* Ensure casino cards section is above hero section */
}

.casino-cards-grid {
  display: flex;
  flex-direction: column;
  margin: 0 auto var(--spacing-64);
  gap: var(--size-24);
  width: 100%;
  max-width: 100%;
}
.casino-cards-row {
  display: grid;
  gap: 1.5rem;
  width: 100%;
  margin: 0 auto;
  justify-items: center;
}

/* Dynamic grid columns based on cards count */
.casino-cards-row[data-cards="1"] {
  grid-template-columns: 1fr;
}

.casino-cards-row[data-cards="2"] {
  grid-template-columns: 1fr 1fr;
}

.casino-cards-row[data-cards="3"] {
  grid-template-columns: 1fr 1fr 1fr;
}

.casino-cards-row[data-cards="4"] {
  grid-template-columns: 1fr 1fr 1fr 1fr;
}

.casino-cards-row[data-cards="5"] {
  grid-template-columns: repeat(5, 1fr);
}

.casino-cards-row[data-cards="6"] {
  grid-template-columns: repeat(6, 1fr);
}

.casino-cards-row[data-cards="7"] {
  grid-template-columns: repeat(7, 1fr);
}

.casino-cards-row[data-cards="8"] {
  grid-template-columns: repeat(8, 1fr);
}

.casino-cards-row[data-cards="9"] {
  grid-template-columns: repeat(9, 1fr);
}

.casino-cards-row[data-cards="10"] {
  grid-template-columns: repeat(10, 1fr);
}

/* Tablet - 2 columns */
@media (max-width: 1024px) and (min-width: 769px) {
  .casino-cards-row {
    grid-template-columns: 1fr 1fr !important;
    gap: 1rem;
  }
  .casino-cards-grid {
    gap: 1rem;
  }
  .casino-card {
    width: 100% !important;
    max-width: 100% !important;
  }
}
/* Mobile - 1 column, full width cards */
@media (max-width: 768px) {
  .casino-cards-row {
    grid-template-columns: 1fr !important;
    gap: 1rem;
  }
  .casino-cards-grid {
    gap: 1rem;
  }
  .casino-card {
    width: 100% !important;
    max-width: 100% !important;
  }
}
/* Mobile optimization */
@media (max-width: 768px) {
  .casino-cards-grid {
    gap: 0.75rem;
  }
  .casino-cards-row {
    gap: 0.75rem;
  }
}
/* === CASINO CARDS CONTAINER === */
.casino-cards {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  z-index: 1;
  /* Grid layout modifier for vertical cards */
}
.casino-cards--grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
  gap: var(--spacing-20);
  width: 100%;
  overflow: visible !important;
  /* 1 card - full width */
  /* 2 cards - each takes 50% */
  /* 3+ cards - auto-fit with stretch */
}
.casino-cards--grid:has(.casino-card:nth-child(1):last-child) {
  grid-template-columns: 1fr;
  max-width: 600px;
  margin: 0 auto;
}
.casino-cards--grid:has(.casino-card:nth-child(2):last-child) {
  grid-template-columns: 1fr 1fr;
}
@media (min-width: 1200px) {
  .casino-cards--grid {
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  }
}
@media (max-width: 1024px) and (min-width: 769px) {
  .casino-cards--grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-16);
  }
}
@media (max-width: 768px) {
  .casino-cards--grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-16);
  }
}

/* === CASINO CARD BASE === */
.casino-card {
  display: flex;
  align-items: stretch;
  padding: var(--spacing-20);
  position: relative;
  overflow: visible;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.3s ease;
  min-width: 0;
  /* Ensure cards never exceed container width */
  max-width: 100%;
  box-sizing: border-box;
  /* V1 - Horizontal Layout (default) - This will be the base horizontal style */
  /* V2 - Vertical Layout (default) - This will be the base vertical style */
}

.casino-card:hover {
  box-shadow: inset 0 0 0 1px var(--primary-800); /* <- inner border */
  border-radius: 12px; /* optional */
}

/* Mobile responsiveness for all cards */
@media (max-width: 768px) {
  .casino-card {
    padding: var(--spacing-16);
    min-width: 0;
    width: 100% !important;
    max-width: 100% !important;
  }
}
/* === GENERIC CASINO CARD ELEMENTS (styles that apply if not overridden by specific card type) === */
.casino-card__header {
  display: flex;
  align-items: center;
  width: 100%;
}

.casino-card__rank {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--neutral-900);
  border-radius: var(--radius-full);
  font-weight: bold;
  color: var(--body-white);
}

.casino-card__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  border-radius: var(--radius-16);
  padding: var(--spacing-8);
}
.casino-card__logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
  margin: 0 auto;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.casino-card__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  background-color: var(--badge-bg, var(--primary-500));
  color: var(--badge-text, var(--primary-400));
  font-size: var(--label-small-size);
  font-weight: var(--label-small-weight);
  text-transform: uppercase;
  padding: var(--spacing-4) var(--spacing-8);
  z-index: 3;
}
.casino-card__badge img {
  width: var(--size-16);
  height: var(--size-16);
  flex-shrink: 0;
}

.casino-card__title {
  font-size: var(--title-medium-size);
  color: var(--body-white);
  font-weight: var(--title-medium-weight);
  margin: var(--spacing-4) 0;
}

.casino-card__rating {
  display: flex;
  align-items: center;
  gap: var(--spacing-8);
}

.casino-card__stars {
  display: flex;
}
.casino-card__stars svg {
  width: var(--size-24, 16px);
  height: var(--size-24, 16px);
}
.casino-card__stars svg path {
  fill: var(--gold, #FFD500);
}
.casino-card__score-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}

.casino-card__score {
  font-weight: bold;
  color: var(--body-white);
}

.casino-card__votes {
  font-size: var(--body-small-size);
  color: var(--body-muted);
}

.casino-card__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.casino-card__online-users {
  font-size: var(--body-small-size);
  color: var(--body-muted);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-4);
}
.casino-card__online-users .user-count {
  color: var(--body-main, var(--primary-300));
  font-weight: bold;
}

.casino-card__payment-methods {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-8);
  margin-top: var(--spacing-8);
}
.casino-card__payment-methods .payment-logo {
  width: auto;
  height: var(--size-24, 24px);
  object-fit: contain;
  filter: grayscale(80%) opacity(0.7);
  transition: filter 0.3s ease;
}
.casino-card__payment-methods .payment-logo:hover {
  filter: grayscale(0%) opacity(1);
}

/*
.casino-card--v1 {
    @media (max-width: 768px) {
      flex-direction: column;
      padding-top: var(--spacing-40);
    }
  }

.casino-card--v2 {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-16);
    margin-bottom: var(--spacing-16);
    max-width: none;
    width: 100%;
    overflow: visible !important;
    border: 1px solid var(--main-stroke, #1C0034);

    &:hover {
      border-color: var(--primary-800);
    }
  }

.casino-card__header {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__rank {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__logo {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__content {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__badge {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__title {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__rating {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__stars {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__score-container {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__score {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__votes {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__cta {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__online-users {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}

.casino-card__payment-methods {
  .casino-card--v1 & { ... }
  .casino-card--v2 & { ... }
}
*/
/* Specific styles for card-uk-2-h (formerly card-h1-gb2) - Horizontal Layout for United Kingdom v2 */
.casino-card--uk-2-h {
  width: 100%;
  /* Inherits base .casino-card styles */
  /* Styles from original _casino-cards-v1.scss, adapted and scoped */
}
@media (max-width: 768px) {
  .casino-card--uk-2-h {
    flex-direction: column;
    padding-top: var(--spacing-40);
  }
}
.casino-card--uk-2-h .casino-card__header {
  max-width: 300px;
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__header {
    justify-content: center;
    position: relative;
  }
}
.casino-card--uk-2-h .casino-card__rank {
  width: var(--size-40);
  align-self: stretch;
  font-size: var(--title-medium-size);
  margin-right: var(--spacing-4);
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__rank {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    height: 100%;
    margin: 0;
    align-self: stretch;
  }
}
.casino-card--uk-2-h .casino-card__logo {
  padding: var(--spacing-16);
  width: 100%;
  height: 120px;
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__logo {
    height: 120px;
    padding: var(--spacing-16);
  }
}
.casino-card--uk-2-h .casino-card__content {
  padding: 0 var(--spacing-16);
  gap: var(--spacing-8);
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__content {
    padding: var(--spacing-16) var(--spacing-8);
    text-align: center;
    margin-top: var(--spacing-12);
    align-items: center;
  }
}
.casino-card--uk-2-h .casino-card__badge {
  text-transform: uppercase;
  font-weight: var(--label-small-weight);
  padding: var(--spacing-8) var(--spacing-12);
  border-radius: var(--radius-16);
  position: absolute;
  top: calc(var(--spacing-16) * -1);
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__badge {
    top: calc(var(--spacing-20) / 2);
    align-self: center;
    margin-top: 0;
  }
}
.casino-card--uk-2-h .casino-card__rating {
  gap: var(--spacing-8);
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__rating {
    flex-direction: row;
    gap: var(--spacing-4);
  }
}
.casino-card--uk-2-h .casino-card__score-container {
  gap: var(--spacing-8);
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__score-container {
    margin-top: var(--spacing-4);
  }
}
.casino-card--uk-2-h .casino-card__stars {
  gap: var(--spacing-0);
}
.casino-card--uk-2-h .casino-card__score {
  margin-right: var(--spacing-4);
}
@media (max-width: 768px) {
  .casino-card--uk-2-h .casino-card__online-users {
    margin-top: var(--spacing-12);
  }
}
/* Specific styles for card-fr-2-v (formerly card-2 / V2) */
.casino-card--fr-2-v {
  /* Inherits base .casino-card styles */
  /* Styles from original _casino-cards-v2.scss, adapted and scoped */
  /* The old file used .casino-card-vertical as a main class, here we use BEM modifier */
  flex-direction: column;
  text-align: center;
  border-radius: var(--radius-24);
  background-color: var(--card-bg-default, var(--neutral-800));
  gap: var(--spacing-16);
  gap: var(--spacing-8);
  overflow: visible !important;
  position: relative;
  border: 2px solid var(--main-stroke);
}
.casino-card--fr-2-v:hover {
  border-color: var(--primary-500) !important;
}
.casino-card--fr-2-v .casino-card__badge {
  text-transform: uppercase;
  gap: var(--spacing-2);
  background: var(--primary-900);
  color: var(--primary-100);
  padding: var(--spacing-8) var(--spacing-16);
  border-radius: var(--radius-8);
  position: absolute;
  top: calc(var(--spacing-16) * -1);
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  z-index: 10;
  white-space: nowrap;
  min-width: max-content;
  width: auto;
}
.casino-card--fr-2-v .casino-card__badge svg {
  flex-shrink: 0;
}
.casino-card--fr-2-v .casino-card__rank {
  position: absolute;
  top: var(--spacing-20);
  left: var(--spacing-20);
  width: var(--size-32);
  height: var(--size-32);
  aspect-ratio: 1/1;
  border-radius: var(--radius-8);
  background: var(--primary-900);
  color: var(--body-main);
  font-weight: 700;
  font-size: var(--body-medium-size);
  z-index: 2;
  margin-right: 0;
}
@media (max-width: 768px) {
  .casino-card--fr-2-v .casino-card__rank {
    left: var(--spacing-16);
    width: var(--size-40);
    height: var(--size-40);
    font-size: var(--title-small-size);
  }
}
.casino-card--fr-2-v .casino-card__header {
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-16);
  max-width: none;
  margin-bottom: var(--spacing-12);
  border-radius: var(--radius-16);
}
.casino-card--fr-2-v .casino-card__logo {
  height: 120px;
  width: 100%;
  padding: 0;
}
.casino-card--fr-2-v .casino-card__content {
  text-align: center;
  align-items: center;
  width: 100%;
  gap: var(--spacing-8);
}
@media (max-width: 768px) {
  .casino-card--fr-2-v .casino-card__content {
    padding: 0 var(--spacing-8);
    margin-top: 0px;
    gap: var(--spacing-16);
  }
}
.casino-card--fr-2-v .casino-card__title {
  margin: 0;
  font-weight: var(--title-small-weight) !important;
  font-size: var(--title-small-size) !important;
  line-height: var(--title-small-line-height) !important;
  text-align: center;
}
@media (max-width: 768px) {
  .casino-card--fr-2-v .casino-card__title {
    font-weight: var(--title-large-weight, 700);
    font-size: var(--title-large-size);
    line-height: var(--title-large-line-height);
  }
}
.casino-card--fr-2-v .casino-card__rating {
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-12);
  width: 100%;
}
.casino-card--fr-2-v .casino-card__score-container {
  gap: var(--spacing-4);
}
.casino-card--fr-2-v .casino-card__score {
  line-height: 1;
  font-size: var(--body-large-size);
}
.casino-card--fr-2-v .casino-card__votes {
  text-align: center;
}
.casino-card--fr-2-v .casino-card__cta {
  width: 100%;
  gap: var(--spacing-12);
}
.casino-card--fr-2-v .casino-card__cta .button-primary {
  width: 100% !important;
  max-width: none !important;
  margin: 0;
  text-align: center;
  padding: var(--spacing-16) var(--spacing-24);
}
.casino-card--fr-2-v .casino-card__payment-methods {
  gap: var(--spacing-8);
  width: 100%;
  margin-top: var(--spacing-12);
}
.casino-card--fr-2-v .casino-card__online-users {
  display: flex;
  flex-direction: row;
}

/* Specific styles for card-fr-2-vp (formerly card-vertical-premium-v1) */
.casino-card--fr-2-vp {
  /* Inherits base .casino-card styles */
  /* Styles from original _casino-cards-vertical-premium-v1.scss, adapted and scoped */
  /* Original file used .casino-card-vertical-premium-v1 as the main class */
  flex-direction: column;
  text-align: center;
  border-radius: var(--radius-24);
  background: var(--card-bg-premium);
  gap: var(--spacing-16);
  overflow: visible !important;
  position: relative;
  border: 2px solid var(--card-stroke);
  padding: var(--spacing-20);
  /* Hover effects */
}
.casino-card--fr-2-vp:hover {
  border-color: var(--primary-500);
}
.casino-card--fr-2-vp .casino-card__content-wrapper {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: calc(var(--radius-24) - 2px);
  background-color: var(--card-bg-premium, var(--neutral-700));
  display: flex;
  flex-direction: column;
}
.casino-card--fr-2-vp:hover {
  background-color: var(--bg-default);
  border-color: var(--primary-500);
}
.casino-card--fr-2-vp > .casino-card__content {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  padding: 0 !important;
}
.casino-card--fr-2-vp .casino-card__badge {
  white-space: nowrap;
  position: absolute;
  border-radius: var(--radius-8);
  top: calc(var(--spacing-16) * -1);
  left: 50%;
  transform: translateX(-50%);
  padding: var(--spacing-8) var(--spacing-12);
  z-index: 10;
  min-width: max-content;
  width: auto;
  color: var(--primary-100);
}
.casino-card--fr-2-vp .casino-card__rank {
  position: absolute;
  top: var(--spacing-20);
  left: var(--spacing-20);
  width: var(--size-32);
  height: var(--size-32);
  aspect-ratio: 1/1;
  border-radius: var(--radius-8);
  background: var(--primary-900);
  color: var(--body-main);
  font-weight: 700;
  font-size: var(--body-medium-size);
  z-index: 2;
  left: 0;
  top: 0;
  margin-right: 0;
}
@media (max-width: 768px) {
  .casino-card--fr-2-vp .casino-card__rank {
    left: var(--spacing-16);
    width: var(--size-40);
    height: var(--size-40);
    font-size: var(--title-small-size);
  }
}
.casino-card--fr-2-vp .casino-card__header {
  flex-direction: row;
  justify-content: center;
  gap: var(--spacing-16);
  max-width: none;
  position: relative;
  width: 100%;
  background-color: var(--neutral-900);
  border-radius: var(--radius-16);
}
.casino-card--fr-2-vp .casino-card__logo {
  max-width: 180px;
  height: 120px;
  flex: 1;
  padding: 0;
  position: relative;
}
.casino-card--fr-2-vp .casino-card__content {
  text-align: center;
  align-items: center;
  padding: var(--spacing-16) 0;
  width: 100%;
  justify-content: space-between;
  gap: var(--spacing-8);
}
@media (max-width: 768px) {
  .casino-card--fr-2-vp .casino-card__content {
    margin-top: 0px;
    gap: var(--spacing-16);
  }
}
.casino-card--fr-2-vp .casino-card__title {
  margin: 0;
  font-weight: var(--title-medium-weight, 700);
  font-size: var(--title-medium-size);
  line-height: var(--title-medium-line-height);
  text-align: center;
}
@media (max-width: 768px) {
  .casino-card--fr-2-vp .casino-card__title {
    font-weight: var(--title-large-weight, 700);
    font-size: var(--title-large-size);
    line-height: var(--title-large-line-height);
  }
}
.casino-card--fr-2-vp .casino-card__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: var(--radius-16);
  min-width: 80px;
}
.casino-card--fr-2-vp .casino-card__score-container {
  gap: var(--spacing-4);
  justify-content: center;
}
.casino-card--fr-2-vp .casino-card__score {
  font-size: var(--title-large-size);
  font-weight: var(--title-large-weight);
  line-height: var(--title-large-line-height);
}
.casino-card--fr-2-vp .casino-card__votes {
  text-align: center;
}
.casino-card--fr-2-vp .casino-card__cta {
  width: 100%;
  gap: var(--spacing-12);
}
.casino-card--fr-2-vp .casino-card__cta .button-primary {
  width: 100% !important;
  max-width: none !important;
  font-size: var(--label-large-size);
  font-weight: var(--label-large-weight);
  line-height: var(--label-large-line-height);
  font-family: var(--label-large-family);
  margin: 0;
  text-align: center;
  padding: var(--spacing-20) var(--spacing-24);
}
.casino-card--fr-2-vp .casino-card__payment-methods {
  gap: var(--spacing-8);
  width: 100%;
  margin-top: var(--spacing-12);
}
.casino-card--fr-2-vp .casino-card__online-users {
  display: flex;
  flex-direction: row;
}

/* Specific styles for card-fr-3-h - Horizontal card variant for FR design 3 */
.casino-card--fr-3-h {
  /* Base structure */
  display: flex;
  flex-direction: row;
  position: relative;
  border-radius: var(--radius-24);
  background-color: var(--card-bg-default, var(--neutral-800));
  gap: var(--spacing-16) !important;
  padding: var(--spacing-20);
  overflow: visible;
  border: 2px solid var(--main-stroke);
  min-height: unset !important;
  /* Rank indicator */
  /* Header section with logo */
  /* Rating section */
  /* Content section */
  /* CTA section */
  /* Tablet adjustments - enhanced for better tablet display */
  /* Mobile adjustments */
}
.casino-card--fr-3-h:hover {
  border-color: var(--primary-500);
}
.casino-card--fr-3-h .casino-card__badge {
  /* Badge styling */
  text-transform: uppercase;
  gap: var(--spacing-2);
  background: var(--primary-900);
  color: var(--primary-100);
  padding: var(--spacing-8) var(--spacing-16);
  border-radius: var(--radius-8);
  position: absolute;
  top: calc(var(--spacing-16) * -1);
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  z-index: 5; /* Уменьшаем z-index, чтобы не перекрывать мобильное меню */
  white-space: nowrap;
  min-width: max-content;
  width: auto;
}
.casino-card--fr-3-h .casino-card__badge svg {
  flex-shrink: 0;
}
.casino-card--fr-3-h .casino-card__rank {
  position: absolute;
  left: -16px;
  width: var(--size-32);
  height: var(--size-32);
  aspect-ratio: 1/1;
  border-radius: var(--radius-8);
  background: var(--primary-900);
  color: var(--body-main);
  font-weight: 700;
  font-size: var(--body-medium-size);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 768px) {
  .casino-card--fr-3-h .casino-card__rank {
    left: var(--spacing-12);
    top: var(--spacing-12);
    width: var(--size-28);
    height: var(--size-28);
    font-size: var(--body-small-size);
  }
}
.casino-card--fr-3-h .casino-card__header {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 160px;
  border-radius: var(--radius-16);
  margin: 0;
}
.casino-card--fr-3-h .casino-card__logo {
  max-width: 160px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}
.casino-card--fr-3-h .casino-card__rating {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-4); /* Reduce gap */
  flex-shrink: 0;
  min-width: 80px;
  margin: 0;
}
.casino-card--fr-3-h .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-2); /* Reduce gap */
  margin: 0;
}
.casino-card--fr-3-h .casino-card__rating .casino-card__stars svg, .casino-card--fr-3-h .casino-card__rating .casino-card__stars img {
  width: var(--size-20);
  height: var(--size-20);
  margin: 0;
}
.casino-card--fr-3-h .casino-card__rating .casino-card__votes {
  font-size: var(--body-medium-size);
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
  margin: 0;
}
.casino-card--fr-3-h .casino-card__score-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-4);
  margin: 0;
}
.casino-card--fr-3-h .casino-card__score-container .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--title-medium-size);
  font-weight: var(--title-medium-weight);
  color: var(--body-white);
  line-height: 1;
  margin: 0;
}
.casino-card--fr-3-h .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  margin: 0;
  padding: 0;
  width: 100%;
}
.casino-card--fr-3-h .casino-card__content .casino-card__title {
  font-size: var(--title-medium-size);
  font-weight: var(--title-medium-weight);
  color: var(--body-white);
  margin: 0;
  padding: 0;
  width: 100%;
}
.casino-card--fr-3-h .casino-card__features {
  display: flex;
  flex-direction: row;
  gap: var(--spacing-4);
  margin: 0; /* Remove margin */
}
.casino-card--fr-3-h .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--body-small-size);
  color: var(--body-muted);
}
.casino-card--fr-3-h .casino-card__feature-item::before {
  content: "🇫🇷";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--fr-3-h .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--fr-3-h .casino-card__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  margin: 0;
  padding: 0;
  width: 160px;
}
.casino-card--fr-3-h .casino-card__cta .button-primary,
.casino-card--fr-3-h .casino-card__cta .button-secondary,
.casino-card--fr-3-h .casino-card__cta .button-ghost {
  width: 100%;
  max-width: 200px;
  font-size: var(--label-medium-size);
  font-weight: var(--label-medium-weight);
  margin: 0;
}
.casino-card--fr-3-h .casino-card__cta .casino-card__online-users {
  font-size: var(--body-small-size);
  color: var(--body-main);
  text-align: right;
}
.casino-card--fr-3-h .casino-card__cta .casino-card__online-users .user-count {
  color: var(--accent-green);
  font-weight: var(--body-medium-weight);
}
@media (max-width: 1024px) and (min-width: 769px) {
  .casino-card--fr-3-h {
    padding: var(--spacing-16);
    gap: var(--spacing-12);
    min-height: 300px; /* Set minimum height for consistency */
  }
  .casino-card--fr-3-h .casino-card__badge {
    padding: var(--spacing-6) var(--spacing-12);
    font-size: var(--label-small-size);
  }
  .casino-card--fr-3-h .casino-card__rank {
    width: var(--size-30);
    height: var(--size-30);
    top: var(--spacing-16);
    left: var(--spacing-16);
  }
  .casino-card--fr-3-h .casino-card__header {
    margin: 0;
    max-width: 120px;
  }
  .casino-card--fr-3-h .casino-card__logo {
    height: 80px;
    max-width: 120px;
    margin: 0;
  }
  .casino-card--fr-3-h .casino-card__rating {
    margin: 0;
  }
  .casino-card--fr-3-h .casino-card__rating .casino-card__score {
    font-size: var(--title-medium-size);
  }
  .casino-card--fr-3-h .casino-card__content {
    gap: var(--spacing-2);
  }
  .casino-card--fr-3-h .casino-card__content .casino-card__title {
    font-size: var(--title-small-size);
  }
  .casino-card--fr-3-h .casino-card__cta .button-primary, .casino-card--fr-3-h .casino-card__cta .button-secondary, .casino-card--fr-3-h .casino-card__cta .button-ghost {
    padding: var(--spacing-12) var(--spacing-20);
    max-width: 220px;
    margin: 0;
  }
}
@media (max-width: 768px) {
  .casino-card--fr-3-h {
    padding: var(--spacing-16);
    min-height: 280px;
    border-width: 1px;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
  }
  .casino-card--fr-3-h .casino-card__badge {
    padding: var(--spacing-4) var(--spacing-12);
    font-size: 10px;
  }
  .casino-card--fr-3-h .casino-card__header {
    display: flex;
    position: relative;
    width: 100%;
    max-width: 100%;
    margin: 0;
    justify-content: center;
    order: 1; /* Изменение порядка - логотип первым */
  }
  .casino-card--fr-3-h .casino-card__logo {
    height: 70px;
    width: 100%;
    max-width: unset;
    margin: 0;
  }
  .casino-card--fr-3-h .casino-card__rating {
    margin: 0;
    width: 100%;
    justify-content: center;
  }
  .casino-card--fr-3-h .casino-card__rating .casino-card__score {
    font-size: var(--body-medium-size);
  }
  .casino-card--fr-3-h .casino-card__rating .casino-card__votes {
    font-size: 10px;
  }
  .casino-card--fr-3-h .casino-card__score-container {
    width: auto;
    justify-content: center;
  }
  .casino-card--fr-3-h .casino-card__content {
    display: flex;
    flex-direction: column;
    align-self: stretch; /* Растягиваем на всю ширину */
    order: 2; /* Изменение порядка - контент вторым */
    margin: 0;
    padding: 0;
    flex: 0 0 auto; /* Отключаем flex-grow и flex-shrink */
    height: auto; /* Автоматическая высота */
    justify-content: flex-start; /* Выравнивание сверху */
  }
  .casino-card--fr-3-h .casino-card__content .casino-card__title {
    font-size: var(--title-large-size);
    font-weight: var(--title-large-weight);
    text-align: center;
    margin: 0;
    padding: 0;
    line-height: 1.2;
  }
  .casino-card--fr-3-h .casino-card__features {
    display: none; /* Hide features on mobile */
  }
  .casino-card--fr-3-h .casino-card__cta {
    width: 100%;
    margin-top: var(--spacing-8);
    padding: 0;
    gap: var(--spacing-8);
    order: 3; /* Изменение порядка - кнопка третьей */
  }
  .casino-card--fr-3-h .casino-card__cta .button-primary, .casino-card--fr-3-h .casino-card__cta .button-secondary, .casino-card--fr-3-h .casino-card__cta .button-ghost {
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
  .casino-card--fr-3-h .casino-card__cta .casino-card__online-users {
    font-size: 10px;
    width: 100%;
    text-align: center;
  }
}

/* Casino cards row spacing for this specific card type */
@media (max-width: 768px) {
  .casino-cards-row:has(.casino-card--fr-3-h) {
    margin-top: var(--spacing-16);
  }
}
/* Specific styles for card-fr-3-hp - Horizontal card variant for FR design 3 */
.casino-card--fr-3-hp {
  /* Base structure */
  display: flex;
  flex-direction: row;
  position: relative;
  border-radius: var(--radius-24);
  background-color: var(--card-bg-premium);
  gap: var(--spacing-16) !important;
  padding: var(--spacing-20);
  overflow: visible;
  border: 2px solid var(--card-stroke);
  min-height: unset !important;
  /* Rank indicator */
  /* Header section with logo */
  /* Rating section */
  /* Content section */
  /* CTA section */
  /* Tablet adjustments - enhanced for better tablet display */
  /* Mobile adjustments */
}
.casino-card--fr-3-hp:hover {
  border-color: var(--primary-500);
}
.casino-card--fr-3-hp .casino-card__badge {
  /* Badge styling */
  text-transform: uppercase;
  gap: var(--spacing-0);
  background: var(--primary-900);
  color: var(--primary-100);
  padding: var(--spacing-8) var(--spacing-16);
  border-radius: var(--radius-8);
  position: absolute;
  top: calc(var(--spacing-16) * -1);
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  z-index: 5; /* Уменьшаем z-index, чтобы не перекрывать мобильное меню */
  white-space: nowrap;
  min-width: max-content;
  width: auto;
}
.casino-card--fr-3-hp .casino-card__badge svg {
  flex-shrink: 0;
}
.casino-card--fr-3-hp .casino-card__rank {
  position: absolute;
  left: -16px;
  width: var(--size-32);
  height: var(--size-32);
  aspect-ratio: 1/1;
  border-radius: var(--radius-8);
  background: var(--primary-900);
  color: var(--body-main);
  font-weight: 700;
  font-size: var(--body-medium-size);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 768px) {
  .casino-card--fr-3-hp .casino-card__rank {
    left: var(--spacing-12);
    top: var(--spacing-12);
    width: var(--size-28);
    height: var(--size-28);
    font-size: var(--body-small-size);
  }
}
.casino-card--fr-3-hp .casino-card__header {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 160px;
  border-radius: var(--radius-16);
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__logo {
  max-width: 160px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__rating {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-4); /* Reduce gap */
  flex-shrink: 0;
  min-width: 80px;
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-2); /* Reduce gap */
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__rating .casino-card__stars svg, .casino-card--fr-3-hp .casino-card__rating .casino-card__stars img {
  width: var(--size-20);
  height: var(--size-20);
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__rating .casino-card__votes {
  font-size: var(--body-medium-size);
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__score-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-4);
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__score-container .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--title-medium-size);
  font-weight: var(--title-medium-weight);
  color: var(--body-white);
  line-height: 1;
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  margin: 0;
  padding: 0;
  width: 100%;
}
.casino-card--fr-3-hp .casino-card__content .casino-card__title {
  font-size: var(--title-medium-size);
  font-weight: var(--title-medium-weight);
  color: var(--body-white);
  margin: 0;
  padding: 0;
  width: 100%;
}
.casino-card--fr-3-hp .casino-card__features {
  display: flex;
  flex-direction: row;
  gap: var(--spacing-4);
  margin: 0; /* Remove margin */
}
.casino-card--fr-3-hp .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--body-small-size);
  color: var(--body-muted);
}
.casino-card--fr-3-hp .casino-card__feature-item::before {
  content: "🇫🇷";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--fr-3-hp .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--fr-3-hp .casino-card__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  margin: 0;
  padding: 0;
  width: 160px;
}
.casino-card--fr-3-hp .casino-card__cta .button-primary,
.casino-card--fr-3-hp .casino-card__cta .button-secondary,
.casino-card--fr-3-hp .casino-card__cta .button-ghost {
  width: 100%;
  max-width: 200px;
  font-size: var(--label-medium-size);
  font-weight: var(--label-medium-weight);
  margin: 0;
}
.casino-card--fr-3-hp .casino-card__cta .casino-card__online-users {
  font-size: var(--body-small-size);
  color: var(--body-main);
  text-align: right;
}
.casino-card--fr-3-hp .casino-card__cta .casino-card__online-users .user-count {
  color: var(--accent-green);
  font-weight: var(--body-medium-weight);
}
@media (max-width: 1024px) and (min-width: 769px) {
  .casino-card--fr-3-hp {
    padding: var(--spacing-16);
    gap: var(--spacing-12);
    min-height: 300px; /* Set minimum height for consistency */
  }
  .casino-card--fr-3-hp .casino-card__badge {
    padding: var(--spacing-6) var(--spacing-12);
    font-size: var(--label-small-size);
  }
  .casino-card--fr-3-hp .casino-card__rank {
    width: var(--size-30);
    height: var(--size-30);
    top: var(--spacing-16);
    left: var(--spacing-16);
  }
  .casino-card--fr-3-hp .casino-card__header {
    margin: 0;
    max-width: 120px;
  }
  .casino-card--fr-3-hp .casino-card__logo {
    height: 80px;
    max-width: 120px;
    margin: 0;
  }
  .casino-card--fr-3-hp .casino-card__rating {
    margin: 0;
  }
  .casino-card--fr-3-hp .casino-card__rating .casino-card__score {
    font-size: var(--title-medium-size);
  }
  .casino-card--fr-3-hp .casino-card__content {
    gap: var(--spacing-2);
  }
  .casino-card--fr-3-hp .casino-card__content .casino-card__title {
    font-size: var(--title-small-size);
  }
  .casino-card--fr-3-hp .casino-card__cta .button-primary, .casino-card--fr-3-hp .casino-card__cta .button-secondary, .casino-card--fr-3-hp .casino-card__cta .button-ghost {
    padding: var(--spacing-12) var(--spacing-20);
    max-width: 220px;
    margin: 0;
  }
}
@media (max-width: 768px) {
  .casino-card--fr-3-hp {
    padding: var(--spacing-16);
    min-height: 280px;
    border-width: 1px;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
  }
  .casino-card--fr-3-hp .casino-card__badge {
    padding: var(--spacing-4) var(--spacing-12);
    font-size: 10px;
  }
  .casino-card--fr-3-hp .casino-card__header {
    display: flex;
    position: relative;
    width: 100%;
    max-width: 100%;
    margin: 0;
    justify-content: center;
    order: 1; /* Изменение порядка - логотип первым */
  }
  .casino-card--fr-3-hp .casino-card__logo {
    height: 70px;
    width: 100%;
    max-width: unset;
    margin: 0;
  }
  .casino-card--fr-3-hp .casino-card__rating {
    margin: 0;
    width: 100%;
    justify-content: center;
  }
  .casino-card--fr-3-hp .casino-card__rating .casino-card__score {
    font-size: var(--body-medium-size);
  }
  .casino-card--fr-3-hp .casino-card__rating .casino-card__votes {
    font-size: 10px;
  }
  .casino-card--fr-3-hp .casino-card__score-container {
    width: auto;
    justify-content: center;
  }
  .casino-card--fr-3-hp .casino-card__content {
    display: flex;
    flex-direction: column;
    align-self: stretch; /* Растягиваем на всю ширину */
    order: 2; /* Изменение порядка - контент вторым */
    margin: 0;
    padding: 0;
    flex: 0 0 auto; /* Отключаем flex-grow и flex-shrink */
    height: auto; /* Автоматическая высота */
    justify-content: flex-start; /* Выравнивание сверху */
  }
  .casino-card--fr-3-hp .casino-card__content .casino-card__title {
    font-size: var(--title-large-size);
    font-weight: var(--title-large-weight);
    text-align: center;
    margin: 0;
    padding: 0;
    line-height: 1.2;
  }
  .casino-card--fr-3-hp .casino-card__features {
    display: none; /* Hide features on mobile */
  }
  .casino-card--fr-3-hp .casino-card__cta {
    width: 100%;
    margin-top: var(--spacing-8);
    padding: 0;
    gap: var(--spacing-8);
    order: 3; /* Изменение порядка - кнопка третьей */
  }
  .casino-card--fr-3-hp .casino-card__cta .button-primary, .casino-card--fr-3-hp .casino-card__cta .button-secondary, .casino-card--fr-3-hp .casino-card__cta .button-ghost {
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
  .casino-card--fr-3-hp .casino-card__cta .casino-card__online-users {
    font-size: 10px;
    width: 100%;
    text-align: center;
  }
}

/* Casino cards row spacing for this specific card type */
@media (max-width: 768px) {
  .casino-cards-row:has(.casino-card--fr-3-hp) {
    margin-top: var(--spacing-16);
  }
}
/* Specific styles for card-fr-4-h - Horizontal Layout for France v4 */
.casino-card--fr-4-h {
  /* Override base card to be horizontal */
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-24);
  padding: var(--spacing-16);
  border-radius: var(--radius-12);
  min-height: 80px;
  width: 100%;
  background-color: var(--card-bg-default);
  max-width: none; /* Allow full width usage */
  overflow: visible; /* Prevent overflow */
  position: relative; /* Ensure proper positioning of absolute elements */
  margin-bottom: var(--spacing-20); /* Add margin between cards */
  text-decoration: none; /* Remove underline from anchor */
  /* Logo and header section */
  /* Rank badge */
  /* Logo container */
  /* Rating section */
  /* Badge */
  /* Content section */
  /* Features section */
  /* CTA section */
  /* Mobile adjustments */
}
.casino-card--fr-4-h .casino-card__header {
  display: block;
  align-items: center;
  gap: var(--spacing-12);
  width: auto !important;
  margin: 0;
  min-width: 200px;
}
.casino-card--fr-4-h .casino-card__rank {
  background: var(--badge-bg);
  margin-left: -32px;
  position: absolute;
  width: var(--size-32);
  height: var(--size-32);
  border-radius: var(--radius-8);
  color: var(--body-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--body-bold-weight);
  font-size: var(--body-medium-size);
  flex-shrink: 0;
  z-index: 1; /* Ensure it's above other elements */
}
.casino-card--fr-4-h .casino-card__logo {
  max-width: 200px;
  width: 100%;
  height: 100px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.casino-card--fr-4-h .casino-card__logo img {
  height: 100%;
  width: auto;
  max-width: 100%;
  object-fit: contain;
}
.casino-card--fr-4-h .casino-card__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
  min-width: 80px;
}
.casino-card--fr-4-h .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--fr-4-h .casino-card__rating .casino-card__stars img {
  width: var(--size-24);
  height: var(--size-24);
  flex-shrink: 0;
}
.casino-card--fr-4-h .casino-card__rating .casino-card__stars .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--headline-small-size);
  font-weight: var(--headline-small-weight);
  color: var(--body-white);
  line-height: 1;
}
.casino-card--fr-4-h .casino-card__rating .casino-card__score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--fr-4-h .casino-card__rating .casino-card__score-container .casino-card__votes {
  font-size: var(--body-small-size) !important;
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
}
.casino-card--fr-4-h .casino-card__badge {
  position: absolute;
  top: -16px;
  left: 20px;
  border-radius: var(--radius-8);
  font-size: var(--label-small-size);
  font-weight: var(--label-small-weight);
  text-transform: uppercase;
  color: var(--primary-100);
  margin: 0;
  white-space: nowrap;
  padding: var(--spacing-8) var(--spacing-12);
  background-color: var(--primary-700); /* Ensure background color */
  z-index: 2; /* Above rank badge */
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--fr-4-h .casino-card__badge .badge-icon {
  width: 16px;
  height: 16px;
  object-fit: contain;
}
.casino-card--fr-4-h .casino-card__badge span {
  line-height: 1;
}
@media (max-width: 768px) {
  .casino-card--fr-4-h .casino-card__badge {
    left: 50%;
    transform: translateX(-50%);
    white-space: normal;
    text-align: center;
    max-width: 80%;
  }
}
.casino-card--fr-4-h .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  min-width: 0; /* Allow content to shrink */
  overflow: hidden; /* Prevent text overflow */
}
.casino-card--fr-4-h .casino-card__content .casino-card__title {
  font-size: var(--title-large-size);
  font-weight: var(--title-large-weight);
  color: var(--body-white);
  margin: 0;
  line-height: var(--title-medium-line-height);
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2; /* Limit to 2 lines */
  line-clamp: 2; /* Standard property for compatibility */
  -webkit-box-orient: vertical;
}
.casino-card--fr-4-h .casino-card__features {
  display: flex;
  flex-direction: row; /* Stack features vertically */
  gap: var(--spacing-8);
  width: 100%;
}
.casino-card--fr-4-h .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-8);
  font-size: var(--body-small-size);
  color: var(--body-muted);
  padding: var(--spacing-4) 0;
}
.casino-card--fr-4-h .casino-card__feature-item::before {
  content: "🇫🇷"; /* Changed to a more universal icon */
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--fr-4-h .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.3;
  display: flex;
  align-items: center;
}
.casino-card--fr-4-h .casino-card__cta {
  display: flex;
  max-width: 300px;
  width: 100%;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-12);
  flex-shrink: 0;
  margin-left: var(--spacing-16);
}
.casino-card--fr-4-h .casino-card__cta .button-primary,
.casino-card--fr-4-h .casino-card__cta .button-secondary,
.casino-card--fr-4-h .casino-card__cta .button-ghost {
  width: 100%; /* Full width buttons */
  margin-bottom: var(--spacing-4);
}
.casino-card--fr-4-h .casino-card__cta .casino-card__online-users {
  display: flex;
  flex-direction: row;
  align-items: center;
  font-size: var(--body-small-size);
  color: var(--body-main);
  text-align: center;
  gap: var(--spacing-2);
}
.casino-card--fr-4-h .casino-card__cta .casino-card__online-users img {
  width: var(--size-16);
  height: var(--size-16);
}
.casino-card--fr-4-h .casino-card__cta .casino-card__online-users .user-count {
  color: var(--accent-green);
  font-weight: var(--body-medium-weight);
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
@media (max-width: 768px) {
  .casino-card--fr-4-h {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-16);
    padding: var(--spacing-20) var(--spacing-16) var(--spacing-16);
  }
  .casino-card--fr-4-h .casino-card__rank {
    left: var(--spacing-16);
    top: var(--spacing-16);
    margin-left: 0;
  }
  .casino-card--fr-4-h .casino-card__badge {
    top: -10px;
    transform: translateX(-50%) scale(0.9);
  }
  .casino-card--fr-4-h .casino-card__header {
    width: 100% !important;
    min-width: unset !important;
    display: flex;
    justify-content: center;
    margin-bottom: var(--spacing-16);
  }
  .casino-card--fr-4-h .casino-card__logo {
    max-width: 160px;
    height: 80px;
  }
  .casino-card--fr-4-h .casino-card__rating {
    margin: var(--spacing-8) 0;
  }
  .casino-card--fr-4-h .casino-card__content {
    width: 100%;
    align-items: center;
    text-align: center;
  }
  .casino-card--fr-4-h .casino-card__features {
    align-items: flex-start;
    width: 100%;
  }
  .casino-card--fr-4-h .casino-card__cta {
    margin-left: 0;
    width: 100%;
    max-width: 100%;
    margin-top: var(--spacing-16);
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .casino-card--fr-4-h .casino-card__logo {
    width: 100%;
    max-width: 100% !important;
  }
  .casino-card--fr-4-h .casino-card__rating {
    width: 100%;
    align-items: center;
  }
  .casino-card--fr-4-h .casino-card__content {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--fr-4-h .casino-card__features {
    justify-content: center;
    flex-wrap: wrap;
  }
  .casino-card--fr-4-h .casino-card__cta {
    width: 100%;
    max-width: 100%;
    align-items: center;
  }
  .casino-card--fr-4-h .casino-card__cta .casino-card__online-users {
    text-align: center;
    width: 100%;
  }
}

/* Specific styles for card-fr-4-hp - Horizontal Premium Layout for France v4 */
.casino-card--fr-4-hp {
  /* Copy all styles from h2-fr4 instead of @extend to avoid import issues */
  /* Override base card to be horizontal */
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-16);
  padding: var(--spacing-16);
  border-radius: var(--radius-12);
  min-height: 80px;
  width: 100%;
  background-color: var(--card-bg-premium);
  max-width: none; /* Allow full width usage */
  overflow: visible; /* Prevent overflow */
  /* Premium styling - add border */
  border: 2px solid var(--stroke);
}
.casino-card--fr-4-hp .casino-card__header {
  display: block;
  align-items: center;
  gap: var(--spacing-12);
  width: auto !important;
  margin: 0;
  min-width: 200px;
}
.casino-card--fr-4-hp .casino-card__rank {
  background: var(--badge-bg);
  margin-left: -32px;
  position: absolute;
  width: var(--size-32);
  height: var(--size-32);
  border-radius: var(--radius-8);
  color: var(--body-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--body-bold-weight);
  font-size: var(--body-medium-size);
  flex-shrink: 0;
}
.casino-card--fr-4-hp .casino-card__logo {
  max-width: 200px;
  width: 100%;
  height: 100px;
  flex-shrink: 0;
}
.casino-card--fr-4-hp .casino-card__logo img {
  height: 100%;
  object-fit: contain;
}
.casino-card--fr-4-hp .casino-card__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
  min-width: 80px;
}
.casino-card--fr-4-hp .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--fr-4-hp .casino-card__rating .casino-card__stars svg {
  width: var(--size-20);
  height: var(--size-20);
}
.casino-card--fr-4-hp .casino-card__rating .casino-card__stars .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--headline-medium-size);
  font-weight: var(--headline-medium-weight);
  color: var(--body-white);
  line-height: 1;
}
.casino-card--fr-4-hp .casino-card__rating .casino-card__score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--fr-4-hp .casino-card__rating .casino-card__score-container .casino-card__votes {
  font-size: var(--body-small-size) !important;
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
}
.casino-card--fr-4-hp .casino-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: var(--radius-8);
  font-size: var(--label-small-size);
  font-weight: var(--label-small-weight);
  text-transform: uppercase;
  color: var(--primary-100);
  margin: 0;
  white-space: nowrap;
  padding: var(--spacing-8) var(--spacing-12);
}
.casino-card--fr-4-hp .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  min-width: 0; /* Allow content to shrink */
}
.casino-card--fr-4-hp .casino-card__content .casino-card__title {
  font-size: var(--title-large-size);
  font-weight: var(--title-large-weight);
  color: var(--body-white);
  margin: 0;
  line-height: var(--title-medium-line-height);
}
.casino-card--fr-4-hp .casino-card__features {
  display: flex;
  flex-direction: row;
  gap: var(--spacing-4);
  margin-top: var(--spacing-8);
}
.casino-card--fr-4-hp .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--body-small-size);
  color: var(--body-muted);
}
.casino-card--fr-4-hp .casino-card__feature-item::before {
  content: "🇫🇷";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--fr-4-hp .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--fr-4-hp .casino-card__cta {
  display: flex;
  max-width: 300px;
  width: 100%;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
}
.casino-card--fr-4-hp .casino-card__cta .casino-card__online-users {
  font-size: var(--body-small-size);
  color: var(--body-main);
  text-align: right;
}
.casino-card--fr-4-hp .casino-card__cta .casino-card__online-users .user-count {
  color: var(--accent-green);
  font-weight: var(--body-medium-weight);
}
@media (max-width: 768px) {
  .casino-card--fr-4-hp {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-12);
  }
  .casino-card--fr-4-hp .casino-card__rank {
    left: 20px;
    top: 20px;
    margin-left: 0;
  }
  .casino-card--fr-4-hp .casino-card__header {
    width: 100% !important;
    min-width: unset !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .casino-card--fr-4-hp .casino-card__logo {
    width: 100%;
    max-width: 100% !important;
  }
  .casino-card--fr-4-hp .casino-card__rating {
    width: 100%;
    align-items: center;
  }
  .casino-card--fr-4-hp .casino-card__content {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--fr-4-hp .casino-card__features {
    justify-content: center;
    flex-wrap: wrap;
  }
  .casino-card--fr-4-hp .casino-card__cta {
    width: 100%;
    max-width: 100%;
    align-items: center;
  }
  .casino-card--fr-4-hp .casino-card__cta .casino-card__online-users {
    text-align: center;
    width: 100%;
  }
}

/* Specific styles for card-ro-7-h - Horizontal Layout for Romania v7 */
.casino-card--ro-7-h {
  /* Override base card to be horizontal */
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-16);
  padding: var(--spacing-16);
  border-radius: var(--radius-32);
  min-height: 80px;
  width: 100%;
  background-color: var(--card-bg-default);
  max-width: none; /* Allow full width usage */
  overflow: visible; /* Prevent overflow */
}
.casino-card--ro-7-h .casino-card__header {
  background-color: var(--card-logo-bg);
  display: block;
  align-items: center;
  gap: var(--spacing-12);
  width: auto !important;
  margin: 0;
  min-width: 200px;
}
.casino-card--ro-7-h .casino-card__rank {
  background: var(--badge-bg);
  left: 20px;
  top: 20px;
  position: absolute;
  width: var(--size-32);
  height: var(--size-32);
  border-radius: var(--radius-full);
  color: var(--body-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--body-bold-weight);
  font-size: var(--body-medium-size);
  flex-shrink: 0;
}
.casino-card--ro-7-h .casino-card__logo {
  max-width: 200px;
  width: 100%;
  height: 100px;
  flex-shrink: 0;
}
.casino-card--ro-7-h .casino-card__logo img {
  height: 100%;
  object-fit: contain;
}
.casino-card--ro-7-h .casino-card__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
  min-width: 80px;
}
.casino-card--ro-7-h .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--ro-7-h .casino-card__rating .casino-card__stars svg {
  width: var(--size-20);
  height: var(--size-20);
}
.casino-card--ro-7-h .casino-card__rating .casino-card__stars .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--headline-medium-size);
  font-weight: var(--headline-medium-weight);
  color: var(--body-white);
  line-height: 1;
}
.casino-card--ro-7-h .casino-card__rating .casino-card__score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--ro-7-h .casino-card__rating .casino-card__score-container .casino-card__votes {
  font-size: var(--body-small-size) !important;
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
}
.casino-card--ro-7-h .casino-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: var(--radius-8);
  font-size: var(--label-small-size);
  color: var(--primary-400);
  text-transform: uppercase;
  font-weight: var(--label-small-weight);
  margin: 0;
  white-space: nowrap;
  padding: var(--spacing-8) var(--spacing-12);
}
.casino-card--ro-7-h .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  min-width: 0; /* Allow content to shrink */
}
.casino-card--ro-7-h .casino-card__content .casino-card__title {
  font-size: var(--title-large-size);
  font-weight: var(--title-large-weight);
  color: var(--body-white);
  margin: 0;
  line-height: var(--title-medium-line-height);
}
.casino-card--ro-7-h .casino-card__features {
  display: flex;
  flex-direction: row;
  gap: var(--spacing-4);
  margin-top: var(--spacing-8);
}
.casino-card--ro-7-h .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--label-small-size);
  color: var(--body-muted);
}
.casino-card--ro-7-h .casino-card__feature-item::before {
  content: "🇷🇴";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--ro-7-h .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--ro-7-h .casino-card__online-users {
  font-size: var(--label-small-size);
  color: var(--body-main);
  text-align: right;
  display: flex;
  flex-direction: column;
}
.casino-card--ro-7-h .casino-card__online-users .user-count {
  display: flex;
  flex-direction: row;
  color: var(--body-white);
  font-size: var(--body-large-size);
  font-weight: var(--label-small-weight);
}
.casino-card--ro-7-h .casino-card__cta {
  display: flex;
  max-width: 300px;
  width: 100%;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
}
@media (max-width: 768px) {
  .casino-card--ro-7-h {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-12);
  }
  .casino-card--ro-7-h .casino-card__badge {
    left: 50%;
    top: -12px;
    transform: translateX(-50%);
  }
  .casino-card--ro-7-h .casino-card__header {
    width: 100% !important;
    min-width: unset !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .casino-card--ro-7-h .casino-card__logo {
    width: 100%;
    max-width: 100% !important;
  }
  .casino-card--ro-7-h .casino-card__rating {
    width: 100%;
    align-items: center;
  }
  .casino-card--ro-7-h .casino-card__content {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--ro-7-h .casino-card__features {
    justify-content: center;
    flex-wrap: wrap;
  }
  .casino-card--ro-7-h .casino-card__online-users {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--ro-7-h .casino-card__cta {
    width: 100%;
    max-width: 100%;
    align-items: center;
  }
}

/* Specific styles for card-ro-5-h - Horizontal Layout for Romania v5 */
.casino-card--ro-5-h {
  /* Override base card to be horizontal */
  /* Override base card to be horizontal */
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-16);
  padding: var(--spacing-16);
  border-radius: var(--radius-32);
  min-height: 80px;
  width: 100%;
  background-color: var(--card-bg-default);
  max-width: none; /* Allow full width usage */
  overflow: visible; /* Prevent overflow */
}
.casino-card--ro-5-h .casino-card__header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-12);
  width: auto !important;
  margin: 0;
  min-width: 200px;
  align-self: stretch;
}
.casino-card--ro-5-h .casino-card__rank {
  background: var(--badge-bg);
  position: absolute;
  top: var(--spacing-20);
  left: var(--spacing-20);
  width: var(--size-32);
  height: var(--size-32);
  border-radius: var(--radius-8);
  color: var(--body-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--body-bold-weight);
  font-size: var(--body-medium-size);
  flex-shrink: 0;
}
.casino-card--ro-5-h .casino-card__logo {
  background-color: transparent;
  max-width: 200px;
  width: 100%;
  height: 100px;
  flex-shrink: 0;
}
.casino-card--ro-5-h .casino-card__logo img {
  height: 100%;
  object-fit: contain;
}
.casino-card--ro-5-h .casino-card__rating {
  background-color: var(--card-bg-default);
  display: flex;
  border-radius: var(--radius-16);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
  min-width: 80px;
  align-self: stretch;
}
.casino-card--ro-5-h .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--ro-5-h .casino-card__rating .casino-card__stars svg {
  width: var(--size-20);
  height: var(--size-20);
}
.casino-card--ro-5-h .casino-card__rating .casino-card__stars .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--headline-small-size);
  font-weight: var(--headline-small-weight);
  color: var(--body-white);
  line-height: 1;
}
.casino-card--ro-5-h .casino-card__rating .casino-card__score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--ro-5-h .casino-card__rating .casino-card__score-container .casino-card__votes {
  font-size: var(--body-small-size) !important;
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
}
.casino-card--ro-5-h .casino-card__badge {
  position: absolute;
  top: -12px;
  left: 240px;
  border-radius: var(--radius-8);
  font-size: var(--label-small-size);
  text-transform: uppercase;
  color: var(--primary-400);
  font-weight: var(--label-small-weight);
  margin: 0;
  z-index: 2;
  white-space: nowrap;
  padding: var(--spacing-8) var(--spacing-12);
}
.casino-card--ro-5-h .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-24);
  min-width: 0;
  align-self: stretch;
  padding: var(--spacing-4) var(--spacing-24);
  background-color: var(--card-bg-default);
  border-radius: var(--radius-16);
  width: fit-content;
}
.casino-card--ro-5-h .casino-card__content .casino-card__title {
  width: 100%;
  font-size: var(--title-medium-size);
  font-weight: var(--title-medium-weight);
  color: var(--body-white);
  line-height: var(--title-medium-line-height);
}
.casino-card--ro-5-h .casino-card__features {
  display: flex;
  width: 300px; /* Use actual size */
  flex-direction: column;
  justify-content: center;
  gap: var(--spacing-4);
  margin: 0 auto; /* Center horizontally */
  align-self: center; /* Center in flex container */
  padding: var(--spacing-12);
  background-color: var(--card-bg-default);
  border-radius: var(--radius-16);
}
.casino-card--ro-5-h .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--body-small-size);
  color: var(--body-muted);
}
.casino-card--ro-5-h .casino-card__feature-item::before {
  content: "🇷🇴";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--ro-5-h .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--ro-5-h .casino-card__cta {
  display: flex;
  max-width: 300px;
  width: 100%;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
  /* Десктопный вид: сначала кнопка, потом счетчик */
  flex-direction: column-reverse;
}
.casino-card--ro-5-h .casino-card__cta .button-primary,
.casino-card--ro-5-h .casino-card__cta .button-secondary,
.casino-card--ro-5-h .casino-card__cta .button-ghost {
  width: 100%;
  order: 2;
}
.casino-card--ro-5-h .casino-card__cta .casino-card__online-users {
  font-size: var(--body-small-size);
  color: var(--body-main);
  order: 1;
}
.casino-card--ro-5-h .casino-card__cta .casino-card__online-users .user-count {
  color: var(--accent-green);
  font-weight: var(--body-medium-weight);
}
@media (max-width: 768px) {
  .casino-card--ro-5-h {
    flex-direction: column;
    align-items: center;
    padding: var(--spacing-20);
    /* Applying flexbox order to elements to control their position */
    display: flex;
    flex-direction: column;
    /* Rating appears after CTA */
    /* CTA container styles */
  }
  .casino-card--ro-5-h .casino-card__header {
    order: 1;
  }
  .casino-card--ro-5-h .casino-card__content {
    order: 2;
  }
  .casino-card--ro-5-h .casino-card__features {
    order: 3;
  }
  .casino-card--ro-5-h .casino-card__cta {
    order: 4;
  }
  .casino-card--ro-5-h .casino-card__rating {
    order: 5;
  }
  .casino-card--ro-5-h .casino-card__badge {
    left: 50%;
    top: -12px;
    transform: translateX(-50%);
  }
  .casino-card--ro-5-h .casino-card__header {
    width: 100% !important;
    min-width: unset !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .casino-card--ro-5-h .casino-card__logo {
    width: 100%;
    max-width: 100% !important;
    height: 60px !important; /* Уменьшенная высота контейнера на мобильных устройствах */
    overflow: visible !important; /* Позволяет логотипу выходить за пределы контейнера */
    position: relative;
  }
  .casino-card--ro-5-h .casino-card__logo img {
    height: 80px !important; /* Сохраняем оригинальную высоту логотипа */
    max-width: 100%;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    object-fit: contain;
  }
  .casino-card--ro-5-h .casino-card__rating {
    width: 100%;
    align-items: center;
    padding: 0;
    flex-direction: row;
  }
  .casino-card--ro-5-h .casino-card__content {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--ro-5-h .casino-card__features {
    width: auto; /* Use actual size */
    max-width: 100%; /* Not larger than parent */
    margin: 0 auto; /* Center horizontally */
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    padding: 0;
  }
  .casino-card--ro-5-h .casino-card__online-users {
    width: 100%;
    text-align: center;
    align-items: center;
    margin: 0 !important;
  }
  .casino-card--ro-5-h .casino-card__cta {
    width: 100%;
    max-width: 100%;
    align-items: center;
    display: flex !important;
    flex-direction: column !important;
    /* Правим порядок элементов */
    /* Счетчик пользователей после кнопки */
  }
  .casino-card--ro-5-h .casino-card__cta .button-primary,
  .casino-card--ro-5-h .casino-card__cta .button-secondary,
  .casino-card--ro-5-h .casino-card__cta .button-ghost {
    order: 1 !important; /* Кнопка ПЕРВОЙ */
    width: 100%;
    margin-bottom: 10px !important;
  }
  .casino-card--ro-5-h .casino-card__cta .casino-card__online-users {
    order: 2 !important; /* Счетчик ВТОРЫМ */
  }
  .casino-card--ro-5-h .casino-card__cta * {
    max-width: none !important;
  }
}

/* Specific styles for card-ro-5-h - Horizontal Layout for Romania v5 */
.casino-card--ro-6-h {
  /* Override base card to be horizontal */
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-16);
  padding: var(--spacing-16);
  border-radius: var(--radius-32);
  min-height: 80px;
  width: 100%;
  background-color: var(--card-bg-default);
  max-width: none; /* Allow full width usage */
  overflow: visible; /* Prevent overflow */
}
.casino-card--ro-6-h .casino-card__header {
  display: block;
  align-items: center;
  width: auto !important;
  margin: 0;
  min-width: 200px;
}
.casino-card--ro-6-h .casino-card__rank {
  background: var(--badge-bg);
  left: 20px;
  top: 20px;
  position: absolute;
  width: var(--size-32);
  height: var(--size-32);
  border-radius: var(--radius-full);
  color: var(--body-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--body-bold-weight);
  font-size: var(--body-medium-size);
  flex-shrink: 0;
}
.casino-card--ro-6-h .casino-card__logo {
  max-width: 200px;
  width: 100%;
  height: 100px;
  background-color: transparent;
  flex-shrink: 0;
}
.casino-card--ro-6-h .casino-card__logo img {
  height: 100%;
  object-fit: contain;
}
.casino-card--ro-6-h .casino-card__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
  min-width: 80px;
}
.casino-card--ro-6-h .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--ro-6-h .casino-card__rating .casino-card__stars svg {
  width: var(--size-20);
  height: var(--size-20);
}
.casino-card--ro-6-h .casino-card__rating .casino-card__stars .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--headline-small-size);
  font-weight: var(--headline-small-weight);
  color: var(--body-white);
  line-height: 1;
}
.casino-card--ro-6-h .casino-card__rating .casino-card__score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--ro-6-h .casino-card__rating .casino-card__score-container .casino-card__votes {
  font-size: var(--body-small-size) !important;
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
}
.casino-card--ro-6-h .casino-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: var(--radius-full);
  font-size: var(--label-small-size);
  color: var(--primary-400) !important;
  text-transform: uppercase;
  font-weight: var(--label-small-weight);
  margin: 0;
  white-space: nowrap;
  padding: var(--spacing-8) var(--spacing-12);
}
.casino-card--ro-6-h .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  min-width: 0;
}
.casino-card--ro-6-h .casino-card__content .casino-card__title {
  font-size: var(--title-medium-size);
  font-weight: var(--title-medium-weight);
  color: var(--body-white);
  margin: 0;
  line-height: var(--title-medium-line-height);
}
.casino-card--ro-6-h .casino-card__features {
  width: 100%;
  max-width: 200px;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
  margin-top: var(--spacing-8);
}
.casino-card--ro-6-h .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--body-small-size);
  color: var(--body-muted);
}
.casino-card--ro-6-h .casino-card__feature-item::before {
  content: "🇷🇴";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--ro-6-h .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--ro-6-h .casino-card__online-users {
  display: flex;
  flex-direction: row;
}
.casino-card--ro-6-h .casino-card__cta {
  display: flex;
  max-width: 300px;
  width: 100%;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
}
.casino-card--ro-6-h .casino-card__cta .button-primary,
.casino-card--ro-6-h .casino-card__cta .button-secondary,
.casino-card--ro-6-h .casino-card__cta .button-ghost {
  width: 100%;
}
@media (max-width: 768px) {
  .casino-card--ro-6-h {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-12);
  }
  .casino-card--ro-6-h .casino-card__badge {
    left: 50%;
    top: -12px;
    transform: translateX(-50%);
  }
  .casino-card--ro-6-h .casino-card__header {
    width: 100% !important;
    min-width: unset !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .casino-card--ro-6-h .casino-card__logo {
    width: 100%;
    max-width: 100% !important;
  }
  .casino-card--ro-6-h .casino-card__rating {
    width: 100%;
    align-items: center;
  }
  .casino-card--ro-6-h .casino-card__content {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--ro-6-h .casino-card__features {
    width: 100%;
    max-width: 100%;
    justify-content: center;
    flex-wrap: wrap;
  }
  .casino-card--ro-6-h .casino-card__online-users {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--ro-6-h .casino-card__cta {
    width: 100%;
    max-width: 100%;
    align-items: center;
  }
}

/* Specific styles for card-uk-3-v - Vertical Layout for United Kingdom v3 */
.casino-card--uk-3-v {
  /* Inherits base .casino-card styles */
  flex-direction: column;
  align-items: stretch;
  gap: var(--spacing-16);
  padding: var(--spacing-16);
  border-radius: var(--radius-24);
  background-color: var(--card-bg-default);
  max-width: none; /* Allow full width usage */
  overflow: visible; /* Prevent overflow */
}
.casino-card--uk-3-v .casino-card__header {
  background-color: var(--card-logo-bg);
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: 100%;
  margin: 0;
  height: 80px; /* Set explicit height */
  gap: var(--spacing-16);
}
.casino-card--uk-3-v .casino-card__rank {
  background: var(--badge-bg);
  left: 20px;
  top: 20px;
  position: absolute;
  width: var(--size-32);
  height: var(--size-32);
  border-radius: var(--radius-full);
  color: var(--body-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--body-bold-weight);
  font-size: var(--body-medium-size);
  flex-shrink: 0;
}
.casino-card--uk-3-v .casino-card__logo {
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
}
.casino-card--uk-3-v .casino-card__logo img {
  height: 100%;
  object-fit: contain;
}
.casino-card--uk-3-v .casino-card__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center; /* Center content vertically */
  gap: var(--spacing-8);
  width: 100%; /* Take full width of container */
  padding: var(--spacing-8);
}
.casino-card--uk-3-v .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-4);
}
.casino-card--uk-3-v .casino-card__rating .casino-card__stars svg {
  width: var(--size-24);
  height: var(--size-24);
}
.casino-card--uk-3-v .casino-card__rating .casino-card__stars .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--title-medium-size);
  font-weight: var(--title-medium-weight);
  color: var(--body-white);
  line-height: 1;
}
.casino-card--uk-3-v .casino-card__rating .casino-card__score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--uk-3-v .casino-card__rating .casino-card__score-container .casino-card__votes {
  font-size: var(--body-small-size) !important;
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
  display: block;
  width: 100%;
}
.casino-card--uk-3-v .casino-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: var(--radius-8);
  font-size: var(--label-small-size);
  color: var(--primary-100);
  text-transform: uppercase;
  font-weight: var(--label-small-weight);
  margin: 0;
  white-space: nowrap;
  padding: var(--spacing-8) var(--spacing-12);
}
@media (max-width: 768px) {
  .casino-card--uk-3-v {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-12);
  }
  .casino-card--uk-3-v .casino-card__badge {
    left: 50%;
    top: -12px;
    transform: translateX(-50%);
  }
  .casino-card--uk-3-v .casino-card__header {
    width: 100% !important;
    min-width: unset !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-16) !important;
    /* Ensure all direct children have equal width on mobile too */
  }
  .casino-card--uk-3-v .casino-card__header > * {
    flex: 1;
    width: 100%;
  }
  .casino-card--uk-3-v .casino-card__logo {
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .casino-card--uk-3-v .casino-card__logo img {
    height: 100%;
    object-fit: contain;
  }
  .casino-card--uk-3-v .casino-card__rating {
    align-items: center;
  }
  .casino-card--uk-3-v .casino-card__content {
    width: 100%;
    text-align: center;
    align-items: center;
  }
  .casino-card--uk-3-v .casino-card__features {
    justify-content: center;
    flex-wrap: wrap;
  }
  .casino-card--uk-3-v .casino-card__online-users {
    text-align: center;
    align-items: center;
  }
  .casino-card--uk-3-v .casino-card__cta {
    display: flex;
    width: 100%;
    gap: var(--spacing-8);
    flex-shrink: 0;
  }
  .casino-card--uk-3-v .casino-card__cta .button-primary,
  .casino-card--uk-3-v .casino-card__cta .button-secondary,
  .casino-card--uk-3-v .casino-card__cta .button-ghost {
    display: block;
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
}
.casino-card--uk-3-v .casino-card__rating-container {
  background-color: var(--neutral-900);
  display: flex;
  flex-direction: column; /* Change to column layout */
  width: 100%;
  height: 80px; /* Match the logo height exactly */
  align-items: center; /* Center items horizontally */
  justify-content: center; /* Center items vertically */
  gap: var(--spacing-4);
  border-radius: var(--radius-16);
  flex: 1;
  padding: var(--spacing-8);
}
.casino-card--uk-3-v .casino-card__content {
  display: block;
  width: 100%;
  text-align: center;
}
.casino-card--uk-3-v .casino-card__features {
  display: flex;
  flex-direction: row;
  gap: var(--spacing-4);
  margin-top: var(--spacing-8);
}
.casino-card--uk-3-v .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--label-small-size);
  color: var(--body-muted);
}
.casino-card--uk-3-v .casino-card__feature-item::before {
  content: "🇬🇧";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--uk-3-v .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--uk-3-v .casino-card__online-users {
  font-size: var(--label-small-size);
  color: var(--body-main);
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-8);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.casino-card--uk-3-v .casino-card__online-users img {
  width: var(--size-24);
  height: var(--size-24);
  object-fit: contain;
}
.casino-card--uk-3-v .casino-card__online-users .user-count {
  display: flex;
  flex-direction: row;
  gap: var(--spacing-4);
  color: var(--body-white);
  font-size: var(--body-medium-size);
  font-weight: var(--body-medium-weight);
}
.casino-card--uk-3-v .casino-card__online-users .user-count span {
  color: var(--body-muted);
}
.casino-card--uk-3-v .casino-card__cta {
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: stretch;
  gap: var(--spacing-8);
  flex-shrink: 0;
}
.casino-card--uk-3-v .casino-card__cta .button-primary,
.casino-card--uk-3-v .casino-card__cta .button-secondary,
.casino-card--uk-3-v .casino-card__cta .button-ghost {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 0;
}

/* Specific styles for card-uk-3-vp - Vertical Layout for United Kingdom v3 */
.casino-card--uk-3-vp {
  /* Inherits base .casino-card styles */
  flex-direction: row;
  align-items: stretch;
  gap: var(--spacing-16);
  padding: var(--spacing-16);
  border-radius: var(--radius-24);
  min-height: 80px;
  background-color: var(--card-bg-premium);
  max-width: none; /* Allow full width usage */
  overflow: visible; /* Prevent overflow */
  position: relative;
  /* Create a gradient border using a linear gradient */
  background-image: linear-gradient(var(--card-bg-premium), var(--card-bg-premium)), linear-gradient(to top, var(--primary-500), transparent);
  background-origin: border-box;
  background-clip: padding-box, border-box;
  border: 2px solid transparent;
}
.casino-card--uk-3-vp .casino-card__header {
  background-color: var(--card-logo-bg);
  display: flex;
  flex-direction: row;
  align-items: stretch;
  justify-content: center;
  width: auto !important;
  margin: 0;
  min-width: 240px;
}
.casino-card--uk-3-vp .casino-card__rank {
  background: var(--badge-bg);
  left: 20px;
  top: 20px;
  position: absolute;
  width: var(--size-32);
  height: var(--size-32);
  border-radius: var(--radius-full);
  color: var(--body-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--body-bold-weight);
  font-size: var(--body-medium-size);
  flex-shrink: 0;
}
.casino-card--uk-3-vp .casino-card__logo {
  max-width: 240px;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.casino-card--uk-3-vp .casino-card__logo img {
  height: 100%;
  object-fit: contain;
}
.casino-card--uk-3-vp .casino-card__rating {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
  min-width: 80px;
}
.casino-card--uk-3-vp .casino-card__rating .casino-card__stars {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--uk-3-vp .casino-card__rating .casino-card__stars svg {
  width: var(--size-20);
  height: var(--size-20);
}
.casino-card--uk-3-vp .casino-card__rating .casino-card__stars .casino-card__score {
  font-family: var(--font-family-headline);
  font-size: var(--body-medium-size);
  font-weight: var(--body-medium-weight);
  color: var(--body-white);
  line-height: 1;
}
.casino-card--uk-3-vp .casino-card__rating .casino-card__score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-4);
}
.casino-card--uk-3-vp .casino-card__rating .casino-card__score-container .casino-card__votes {
  font-size: var(--body-small-size) !important;
  color: var(--body-muted);
  line-height: 1;
  text-align: center;
}
.casino-card--uk-3-vp .casino-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: var(--radius-8);
  font-size: var(--label-small-size);
  color: var(--primary-100);
  text-transform: uppercase;
  font-weight: var(--label-small-weight);
  margin: 0;
  white-space: nowrap;
  padding: var(--spacing-8) var(--spacing-12);
}
@media (max-width: 768px) {
  .casino-card--uk-3-vp {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-12);
  }
  .casino-card--uk-3-vp .casino-card__badge {
    left: 50%;
    top: -12px;
    transform: translateX(-50%);
  }
  .casino-card--uk-3-vp .casino-card__header {
    width: 100% !important;
    min-width: unset !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .casino-card--uk-3-vp .casino-card__logo {
    width: 100%;
    height: 100px !important;
    max-width: 100% !important;
    display: flex;
    align-self: stretch;
  }
  .casino-card--uk-3-vp .casino-card__logo img {
    height: 100%;
    object-fit: contain;
  }
  .casino-card--uk-3-vp .casino-card__rating {
    align-items: center;
  }
  .casino-card--uk-3-vp .casino-card__content {
    width: 100%;
    text-align: center;
    align-items: center;
    justify-content: center; /* Center text vertically */
  }
  .casino-card--uk-3-vp .casino-card__features {
    justify-content: center;
    flex-wrap: wrap;
  }
  .casino-card--uk-3-vp .casino-card__online-users {
    text-align: right;
    align-items: right;
  }
  .casino-card--uk-3-vp .casino-card__cta {
    width: 100%;
    max-width: 100%;
    align-items: center;
  }
}
.casino-card--uk-3-vp .casino-card__footer {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--spacing-4);
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__rating-container {
  display: flex;
  flex-direction: row;
  width: 100%;
  justify-content: space-between;
  gap: var(--spacing-8);
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
  min-width: 0; /* Allow content to shrink */
  width: 100%; /* Stretch to full available width */
  justify-content: center; /* Center text vertically */
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__content .casino-card__title {
  font-size: var(--title-large-size);
  font-weight: var(--title-large-weight);
  color: var(--body-white);
  margin: 0;
  line-height: var(--title-medium-line-height);
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__features {
  display: flex;
  flex-direction: row;
  gap: var(--spacing-4);
  margin-top: var(--spacing-8);
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__feature-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  font-size: var(--label-small-size);
  color: var(--body-muted);
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__feature-item::before {
  content: "🇬🇧";
  font-size: var(--body-large-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  line-height: 1;
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__feature-item .casino-card__feature-text {
  flex-grow: 1;
  color: var(--body-main);
  font-size: var(--body-medium-size);
  line-height: 1.2;
  display: flex;
  align-items: center;
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__online-users {
  font-size: var(--label-small-size);
  color: var(--body-main);
  text-align: left;
  display: flex;
  flex-direction: row;
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__online-users .user-count {
  display: flex;
  flex-direction: row;
  color: var(--body-white);
  font-size: var(--body-medium-size);
  font-weight: var(--body-medium-weight);
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__cta {
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-8);
  flex-shrink: 0;
}
.casino-card--uk-3-vp .casino-card__footer .casino-card__cta .button-primary,
.casino-card--uk-3-vp .casino-card__footer .casino-card__cta .button-secondary,
.casino-card--uk-3-vp .casino-card__footer .casino-card__cta .button-ghost {
  max-width: unset;
  width: 100%;
}

/* Specific styles for card-ie-1-v (formerly card-2 / V2) */
.casino-card--ie-1-v {
  /* Inherits base .casino-card styles */
  /* Styles from original _casino-cards-v2.scss, adapted and scoped */
  /* The old file used .casino-card-vertical as a main class, here we use BEM modifier */
  flex-direction: column;
  text-align: center;
  border-radius: var(--radius-24);
  background: linear-gradient(180deg, rgba(26, 26, 23, 0.3), rgba(26, 26, 23, 0.8));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  gap: var(--spacing-16);
  gap: var(--spacing-8);
  overflow: visible !important;
  position: relative;
}
.casino-card--ie-1-v:hover {
  box-shadow: none !important;
  border-radius: var(--radius-24);
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.6), rgb(0, 0, 0));
}
.casino-card--ie-1-v .casino-card__badge {
  text-transform: uppercase;
  gap: var(--spacing-2);
  background: var(--badge-bg);
  color: var(--primary-100);
  padding: var(--spacing-8) var(--spacing-16);
  border-radius: var(--radius-full);
  position: absolute;
  top: calc(var(--spacing-16) * -1);
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  z-index: 10;
  white-space: nowrap;
  min-width: max-content;
  width: auto;
}
.casino-card--ie-1-v .casino-card__badge svg {
  flex-shrink: 0;
}
.casino-card--ie-1-v .casino-card__rank {
  position: absolute;
  top: var(--spacing-20);
  left: var(--spacing-20);
  width: var(--size-32);
  height: var(--size-32);
  aspect-ratio: 1/1;
  border-radius: var(--radius-full);
  background: rgba(13, 13, 12, 0.2);
  color: var(--body-main);
  font-weight: 700;
  font-size: var(--body-medium-size);
  z-index: 2;
  margin-right: 0;
}
@media (max-width: 768px) {
  .casino-card--ie-1-v .casino-card__rank {
    left: var(--spacing-16);
    width: var(--size-40);
    height: var(--size-40);
    font-size: var(--title-small-size);
  }
}
.casino-card--ie-1-v .casino-card__header {
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-16);
  max-width: none;
  margin-bottom: var(--spacing-12);
  border-radius: var(--radius-24);
}
.casino-card--ie-1-v .casino-card__logo {
  height: 120px;
  width: 100%;
  padding: 0;
}
.casino-card--ie-1-v .casino-card__content {
  text-align: center;
  align-items: center;
  width: 100%;
  gap: var(--spacing-8);
  padding: var(--spacing-16) 0;
}
@media (max-width: 768px) {
  .casino-card--ie-1-v .casino-card__content {
    padding: 0 var(--spacing-8);
    margin-top: 0px;
    gap: var(--spacing-16);
  }
}
.casino-card--ie-1-v .casino-card__title {
  margin: 0;
  text-align: center;
}
@media (max-width: 768px) {
  .casino-card--ie-1-v .casino-card__title {
    font-weight: var(--title-large-weight, 700);
    font-size: var(--title-large-size);
    line-height: var(--title-large-line-height);
  }
}
.casino-card--ie-1-v .casino-card__rating {
  flex-direction: column;
  align-items: center;
  text-align: center;
  justify-content: center;
  gap: var(--spacing-4);
  width: 100%;
}
.casino-card--ie-1-v .casino-card__score-container {
  gap: var(--spacing-4);
}
.casino-card--ie-1-v .casino-card__score {
  line-height: 1;
  font-size: var(--body-large-size);
}
.casino-card--ie-1-v .casino-card__votes {
  text-align: center;
}
.casino-card--ie-1-v .casino-card__cta {
  width: 100%;
  gap: var(--spacing-12);
}
.casino-card--ie-1-v .casino-card__cta .button-primary {
  width: 100% !important;
  max-width: none !important;
  margin: 0;
  text-align: center;
}
.casino-card--ie-1-v .casino-card__payment-methods {
  gap: var(--spacing-8);
  width: 100%;
  margin-top: var(--spacing-12);
}
.casino-card--ie-1-v .casino-card__online-users {
  display: flex;
  flex-direction: row;
}

/* === ADAPTIVE SYSTEM === */
/* 
 * ADAPTIVE BADGES SYSTEM
 * =====================
 * 
 * This file defines nearly transparent backgrounds for badge containers
 * to enable automatic badge-18 color adaptation based on page context.
 * 
 * PROBLEM: Badge containers (top-bar-disclaimer, footer-disclaimer) have no background,
 * making it impossible to detect light/dark theme for proper badge color selection.
 * 
 * SOLUTION: Add nearly transparent backgrounds (0.01 opacity) that:
 * 1. Don't visually affect the design
 * 2. Provide detectable background color for JavaScript adaptation logic
 * 3. Allow automatic switching between badge-18-black.svg and badge-18-white.svg
 * 
 * ADAPTATION RULES:
 * - footer-disclaimer: Always dark background → white badge (badge-18-white.svg)
 * - top-bar-disclaimer: 
 *   └─ Homepage (index): Light background → black badge (badge-18-black.svg)
 *   └─ Internal pages: Dark background → white badge (badge-18-white.svg)
 */
/* Footer disclaimer: Always dark theme */
.footer-disclaimer {
  /* Nearly transparent black background for badge adaptation detection */
  /* Opacity 0.01 = invisible but detectable by JavaScript */
  background-color: rgba(0, 0, 0, 0.01);
  /* This will trigger JavaScript to use badge-18-white.svg */
  /* because luminance of rgba(0,0,0,0.01) ≈ 0 (dark) */
}

/* Top bar disclaimer: Context-dependent theme */
.top-bar-disclaimer {
  /* Default: Dark background for internal pages */
  background-color: rgba(0, 0, 0, 0.01);
  /* This will trigger JavaScript to use badge-18-white.svg by default */
  /* because luminance of rgba(0,0,0,0.01) ≈ 0 (dark) */
}

/* Homepage-specific override for top bar */
body.page-index .top-bar-disclaimer {
  /* Light background for homepage only */
  background-color: rgba(255, 255, 255, 0.01);
  /* This will trigger JavaScript to use badge-18-black.svg on homepage */
  /* because luminance of rgba(255,255,255,0.01) ≈ 1 (light) */
}

/* 
 * HOW TO MODIFY:
 * ==============
 * 
 * To change badge adaptation behavior, modify the rgba values:
 * 
 * FOR LIGHT BACKGROUND (black badge):
 *   background-color: rgba(255, 255, 255, 0.01);
 * 
 * FOR DARK BACKGROUND (white badge):
 *   background-color: rgba(0, 0, 0, 0.01);
 * 
 * The 0.01 opacity ensures:
 * - No visual impact on design
 * - JavaScript can detect the color
 * - CSS specificity works correctly
 * 
 * IMPORTANT: Keep opacity very low (0.01-0.05) to avoid visual changes!
 */
/* ===== ADAPTIVE HAMBURGER ICON SYSTEM ===== */
/* 
  ADAPTIVE HAMBURGER ICON: Cross-Platform Color Detection
  =====================================================

  This system automatically adapts hamburger icon color based on header background:
  - Light header background → Black hamburger icon  
  - Dark header background → White hamburger icon

  The system uses JavaScript to:
  1. Detect header background color via getComputedStyle()
  2. Calculate luminance using standard formula
  3. Switch between white/black hamburger icon colors dynamically

  Implementation:
  - Hamburger icon gets --hamburger-color CSS variable
  - JavaScript sets this variable based on luminance calculation
  - Supports rgb/rgba color formats with regex parsing
  - Fallback to white icon for transparent/undetectable backgrounds
*/
.hamburger-icon {
  --hamburger-color: var(--body-white);
  background-color: var(--hamburger-color) !important;
}
.hamburger-icon::before, .hamburger-icon::after {
  background-color: var(--hamburger-color) !important;
}

/* Transition for smooth color changes */
.hamburger-icon,
.hamburger-icon::before,
.hamburger-icon::after {
  transition: background-color 0.3s ease !important;
}

/* Dark hamburger (for light backgrounds) */
.hamburger-dark {
  --hamburger-color: var(--neutral-900);
}

/* Light hamburger (for dark backgrounds) */
.hamburger-light {
  --hamburger-color: var(--body-white);
}

/* === DEV PANEL === */
.header-menu-title,
.footer-menu-title {
  margin: 1rem 0 0.5rem 0;
  color: var(--primary-600);
}

.header-menu-add-form,
.footer-menu-add-form {
  margin-top: 1rem;
}

.menu-layout-config {
  margin-bottom: 1rem;
  padding: 1rem;
  background: var(--neutral-50);
  border-radius: 8px;
  border-left: 3px solid var(--info-500);
}
.menu-layout-config label {
  display: inline-block;
  margin-right: 1rem;
  margin-bottom: 0.5rem;
}
.menu-layout-config .layout-input {
  width: 60px;
  margin-left: 0.5rem;
}

.add-menu-form {
  display: inline-block;
  margin-right: 1rem;
}

.menu-input {
  width: 140px;
  margin-right: 0.5rem;
}
.menu-input:last-child {
  margin-right: 0;
}

.menu-add-form {
  margin-top: 1rem;
}

.menu-badge {
  color: white;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 10px;
  margin-left: 8px;
}
.menu-badge--system {
  background: var(--primary-500);
}
.menu-badge--custom {
  background: var(--success-500);
}

.menu-item.system-item {
  background: var(--neutral-50);
  border-left: 3px solid var(--primary-500);
}
.menu-item.custom-item {
  background: var(--success-50);
  border-left: 3px solid var(--success-500);
}

.hidden {
  display: none;
}

.footer-menu-version-content[data-version]:not([data-version=v1]) {
  display: none;
}
.footer-menu-version-content[data-version=v1] {
  display: block;
}

.menu-info .menu-title input,
.menu-info .menu-url input {
  width: 200px;
}

.sortable-ghost {
  opacity: 0.4;
  background: var(--warning-200) !important;
  transform: rotate(2deg);
}

.sortable-chosen {
  transform: scale(1.02);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
  z-index: 999;
}

.sortable-drag {
  transform: rotate(5deg);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.25);
  opacity: 0.9;
}

.menu-handle {
  cursor: grab;
  user-select: none;
  color: var(--text-muted);
  font-weight: bold;
  padding: 0.5rem;
  transition: color 0.2s ease;
}
.menu-handle:hover {
  color: var(--primary-500);
}
.menu-handle:active {
  cursor: grabbing;
  color: var(--primary-600);
}
