/* Hero */
    .heroSection {
      position: relative;
      background: var(--gradient-hero);
      padding: var(--spacing-4xl) 0 var(--spacing-3xl);
      overflow: hidden;
    }
    .heroSection::before {
      content: '';
      position: absolute;
      top: -50%; right: -5%;
      width: 600px; height: 600px;
      background: radial-gradient(circle, rgba(255, 45, 85, 0.12) 0%, transparent 70%);
      border-radius: 50%;
      pointer-events: none;
    }
    .heroSection::after {
      content: '';
      position: absolute;
      bottom: -30%; left: -5%;
      width: 500px; height: 500px;
      background: radial-gradient(circle, rgba(123, 47, 247, 0.15) 0%, transparent 70%);
      border-radius: 50%;
      pointer-events: none;
    }

    .heroContent {
      position: relative;
      z-index: 2;
      text-align: center;
      max-width: 900px;
      margin: 0 auto;
    }

    .heroTrustRow {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: var(--spacing-md);
      margin-bottom: var(--spacing-xl);
      animation: fadeInDown 0.8s ease;
    }

    .heroSection h1 {
      margin-bottom: var(--spacing-lg);
      background: linear-gradient(135deg, var(--color-text-primary) 0%, var(--color-accent-gold) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      animation: fadeInUp 0.8s ease 0.2s both;
    }

    .heroSection p {
      font-size: clamp(1rem, 1.5vw, 1.2rem);
      color: var(--color-text-secondary);
      max-width: 700px;
      margin: 0 auto var(--spacing-xl);
      animation: fadeInUp 0.8s ease 0.4s both;
    }

    .heroActions {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: var(--spacing-md);
      margin-bottom: var(--spacing-2xl);
      animation: fadeInUp 0.8s ease 0.6s both;
    }

    .heroStats {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: var(--spacing-2xl);
      padding-top: var(--spacing-2xl);
      border-top: 1px solid rgba(123, 47, 247, 0.15);
      animation: fadeInUp 0.8s ease 0.8s both;
    }

    .heroStatItem {
      text-align: center;
    }
    .heroStatItem .statValue {
      display: block;
      font-family: var(--font-heading);
      font-size: clamp(1.8rem, 3vw, 2.5rem);
      font-weight: 900;
      color: var(--color-accent-gold);
      line-height: 1.2;
    }
    .heroStatItem .statLabel {
      font-size: 0.85rem;
      color: var(--color-text-secondary);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      font-weight: 600;
    }

    .heroImageWrap {
      position: relative;
      z-index: 2;
      margin-bottom: var(--spacing-2xl);
      animation: fadeInUp 0.6s ease both;
    }
    .heroImageWrap .contentImage {
      border: 1px solid rgba(123, 47, 247, 0.2);
      box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5), 0 0 40px rgba(123, 47, 247, 0.1);
    }

    .limitedBanner {
      display: inline-flex;
      align-items: center;
      gap: var(--spacing-sm);
      padding: 10px 20px;
      background: linear-gradient(135deg, rgba(255, 45, 85, 0.15) 0%, rgba(255, 200, 55, 0.1) 100%);
      border: 1px solid rgba(255, 45, 85, 0.3);
      border-radius: var(--radius-full);
      font-size: 0.9rem;
      font-weight: 700;
      color: var(--color-accent-gold);
      animation: pulse 2s infinite;
      margin-bottom: var(--spacing-lg);
    }

    /* UK Players */
    .ukPlayers {
      position: relative;
      padding: var(--spacing-4xl) 0;
      background: var(--gradient-section-alt);
      overflow: hidden;
    }

    .ukPlayers h2 {
      text-align: center;
      margin-bottom: var(--spacing-sm);
    }

    .ukPlayersDivider {
      margin: 0 auto var(--spacing-xl);
    }

    .ukPlayers > .container > p {
      max-width: 800px;
      margin-left: auto;
      margin-right: auto;
      text-align: center;
    }

    .gamesGrid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: var(--spacing-lg);
      margin-top: var(--spacing-xl);
    }

    .gameCard {
      position: relative;
      border-radius: var(--radius-lg);
      overflow: hidden;
      border: 1px solid rgba(123, 47, 247, 0.15);
      box-shadow: var(--shadow-card);
      transition: all var(--transition-smooth);
    }
    .gameCard:hover {
      transform: translateY(-8px) scale(1.02);
      box-shadow: var(--shadow-card-hover);
      border-color: rgba(255, 45, 85, 0.4);
    }
    .gameCard img {
      display: block;
      width: 100%;
      height: auto;
      transition: transform var(--transition-smooth);
    }
    .gameCard:hover img {
      transform: scale(1.05);
    }
    .gameCardOverlay {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      padding: var(--spacing-md);
      background: linear-gradient(transparent, rgba(15, 11, 36, 0.9));
      opacity: 0;
      transition: opacity var(--transition-smooth);
    }
    .gameCard:hover .gameCardOverlay {
      opacity: 1;
    }
    .gameCardOverlay .btnPrimary {
      width: 100%;
      padding: 8px 16px;
      font-size: 0.8rem;
    }

    /* Login Guide */
    .loginGuide {
      position: relative;
      padding: var(--spacing-4xl) 0;
      background: var(--color-neutral-950);
      overflow: hidden;
    }

    .loginGuide h2 {
      margin-bottom: var(--spacing-sm);
    }

    .stepsGrid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: var(--spacing-xl);
      margin-top: var(--spacing-2xl);
    }

    .stepCard {
      position: relative;
      padding-top: var(--spacing-md);
    }
    .stepCard .stepNumber {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 48px; height: 48px;
      background: var(--gradient-cta);
      color: var(--color-neutral-950);
      font-family: var(--font-heading);
      font-weight: 900;
      font-size: 1.2rem;
      border-radius: 50%;
      margin-bottom: var(--spacing-md);
      box-shadow: var(--shadow-glow-primary);
    }
    .stepCard h3 {
      font-size: 1.1rem;
      margin-bottom: var(--spacing-sm);
    }
    .stepCard p {
      font-size: 0.95rem;
      color: var(--color-text-secondary);
      margin: 0;
    }

    /* Mobile App */
    .mobileApp {
      position: relative;
      padding: var(--spacing-4xl) 0;
      background: var(--gradient-section-alt);
      overflow: hidden;
    }

    .mobileApp h2 {
      text-align: center;
      margin-bottom: var(--spacing-sm);
    }

    .appHighlights {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: var(--spacing-xl);
      margin-top: var(--spacing-2xl);
    }

    .highlightBox {
      position: relative;
      overflow: hidden;
    }
    .highlightBox .highlightIcon {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 56px; height: 56px;
      background: rgba(123, 47, 247, 0.15);
      border-radius: var(--radius-md);
      margin-bottom: var(--spacing-md);
      font-size: 1.5rem;
    }
    .highlightBox h3 {
      font-size: 1.15rem;
      margin-bottom: var(--spacing-sm);
    }
    .highlightBox p {
      font-size: 0.95rem;
      color: var(--color-text-secondary);
      margin: 0;
    }

    /* Bonuses */
    .bonusesSection {
      position: relative;
      padding: var(--spacing-4xl) 0;
      background: var(--color-neutral-950);
      overflow: hidden;
    }
    .bonusesSection::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(255, 200, 55, 0.3), transparent);
    }

    .bonusesSection h2 {
      text-align: center;
      margin-bottom: var(--spacing-sm);
    }

    .bonusHighlight {
      position: relative;
      padding: var(--spacing-2xl);
      background: linear-gradient(135deg, rgba(255, 45, 85, 0.08) 0%, rgba(123, 47, 247, 0.08) 100%);
      border: 1px solid rgba(255, 45, 85, 0.2);
      border-radius: var(--radius-xl);
      text-align: center;
      margin: var(--spacing-xl) 0;
    }

    /* Payments */
    .paymentsSection {
      position: relative;
      padding: var(--spacing-4xl) 0;
      background: var(--gradient-section-alt);
      overflow: hidden;
    }

    .paymentsSection h2 {
      text-align: center;
      margin-bottom: var(--spacing-sm);
    }

    .paymentGrid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: var(--spacing-lg);
      margin: var(--spacing-2xl) 0;
    }

    .paymentCard {
      display: flex;
      align-items: flex-start;
      gap: var(--spacing-md);
    }
    .paymentCard .paymentIcon {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      width: 48px; height: 48px;
      background: rgba(0, 212, 255, 0.1);
      border: 1px solid rgba(0, 212, 255, 0.2);
      border-radius: var(--radius-md);
      font-size: 1.2rem;
    }
    .paymentCard dt {
      font-family: var(--font-heading);
      font-weight: 700;
      font-size: 1.05rem;
      color: var(--color-text-primary);
      margin-bottom: 4px;
    }
    .paymentCard dd {
      margin: 0;
      font-size: 0.9rem;
      color: var(--color-text-secondary);
      line-height: 1.5;
    }

    /* Responsible Gambling */
    .responsibleSection {
      position: relative;
      padding: var(--spacing-4xl) 0;
      background: var(--color-neutral-950);
      overflow: hidden;
    }

    .responsibleSection h2 {
      text-align: center;
      margin-bottom: var(--spacing-sm);
    }

    .responsibleList {
      list-style: none;
      padding: 0;
      margin: var(--spacing-xl) 0;
    }
    .responsibleList li {
      position: relative;
      padding: var(--spacing-md) var(--spacing-lg);
      padding-left: calc(var(--spacing-xl) + 12px);
      margin-bottom: var(--spacing-md);
      background: rgba(46, 42, 69, 0.3);
      border: 1px solid rgba(123, 47, 247, 0.1);
      border-radius: var(--radius-md);
      transition: all var(--transition-fast);
    }
    .responsibleList li::before {
      content: '';
      position: absolute;
      left: var(--spacing-lg);
      top: 50%;
      transform: translateY(-50%);
      width: 8px; height: 8px;
      background: var(--color-success);
      border-radius: 50%;
      box-shadow: 0 0 10px rgba(0, 230, 118, 0.4);
    }
    .responsibleList li:hover {
      background: rgba(46, 42, 69, 0.5);
      border-color: rgba(0, 230, 118, 0.2);
    }

    /* FAQ */
    .faqSection {
      position: relative;
      padding: var(--spacing-4xl) 0;
      background: var(--gradient-section-alt);
      overflow: hidden;
    }

    .faqSection h2 {
      text-align: center;
      margin-bottom: var(--spacing-2xl);
    }

    .accordionItem {
      margin-bottom: var(--spacing-md);
      border: 1px solid rgba(123, 47, 247, 0.15);
      border-radius: var(--radius-md);
      overflow: hidden;
      background: rgba(28, 24, 52, 0.5);
      transition: all var(--transition-smooth);
    }
    .accordionItem:hover {
      border-color: rgba(123, 47, 247, 0.3);
    }
    .accordionItem.active {
      border-color: rgba(255, 45, 85, 0.3);
      box-shadow: 0 4px 20px rgba(255, 45, 85, 0.1);
    }

    .accordionHeader {
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      padding: var(--spacing-lg) var(--spacing-xl);
      background: none;
      border: none;
      cursor: pointer;
      text-align: left;
      font-family: var(--font-heading);
      font-weight: 700;
      font-size: 1.05rem;
      color: var(--color-text-primary);
      transition: color var(--transition-fast);
      margin: 0;
      gap: var(--spacing-md);
    }
    .accordionHeader:hover {
      color: var(--color-accent-gold);
    }
    .accordionToggle {
      flex-shrink: 0;
      width: 32px; height: 32px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      background: rgba(123, 47, 247, 0.15);
      transition: all var(--transition-smooth);
      font-size: 1.2rem;
      color: var(--color-brand-secondary);
    }
    .accordionItem.active .accordionToggle {
      transform: rotate(45deg);
      background: rgba(255, 45, 85, 0.2);
      color: var(--color-brand-primary);
    }

    .accordionBody {
      max-height: 0;
      overflow: hidden;
      transition: max-height var(--transition-smooth), padding var(--transition-smooth);
    }
    .accordionBody .accordionContent {
      padding: 0 var(--spacing-xl) var(--spacing-lg);
    }
    .accordionBody .accordionContent p {
      margin: 0;
      color: var(--color-text-secondary);
      font-size: 0.95rem;
      line-height: 1.7;
    }

    /* Animations */
    @keyframes fadeInUp {
      from { opacity: 0; transform: translateY(30px); }
      to { opacity: 1; transform: translateY(0); }
    }
    @keyframes fadeInDown {
      from { opacity: 0; transform: translateY(-20px); }
      to { opacity: 1; transform: translateY(0); }
    }
    @keyframes pulse {
      0%, 100% { opacity: 1; }
      50% { opacity: 0.75; }
    }
    @keyframes float {
      0%, 100% { transform: translateY(0); }
      50% { transform: translateY(-10px); }
    }

    .animateOnScroll {
      opacity: 0;
      transform: translateY(40px);
      transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
    }
    .animateOnScroll.visible {
      opacity: 1;
      transform: translateY(0);
    }

    /* Responsive */
    @media (max-width: 767px) {
      .heroSection {
        padding: var(--spacing-2xl) 0;
      }
      .heroStats {
        gap: var(--spacing-lg);
      }
      .gamesGrid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-md);
      }
      .stepsGrid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
      }
      .appHighlights {
        grid-template-columns: 1fr;
      }
      .paymentGrid {
        grid-template-columns: 1fr;
      }
      .heroActions {
        flex-direction: column;
        align-items: center;
      }
      .heroActions .btnPrimary,
      .heroActions .btnSecondary {
        width: 100%;
        max-width: 320px;
      }
    }

    @media (min-width: 768px) and (max-width: 1023px) {
      .gamesGrid {
        grid-template-columns: repeat(2, 1fr);
      }
      .stepsGrid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    @media (min-width: 1024px) {
      .heroSection {
        padding: var(--spacing-4xl) 0 var(--spacing-3xl);
      }
    }