/*
 * JOKERY CASINO - DESIGN SYSTEM
 * Cinematic dark Joker-villain aesthetic
 * Mobile-first, single dark theme (no toggle)
 */

/* ============================================
   DESIGN TOKENS
   Single dark theme - :root holds all values
   .dark mirrors for compatibility but values identical
   ============================================ */
:root {
    /* Backgrounds - deep cinematic blacks */
    --background: #0A0A0A;
    --background-graphite: #111117;
    --card: #1A1A22;
    --card-slate: #1E1E28;
    --card-elevated: #232330;

    /* Foreground - warm cream-white */
    --foreground: #F5F2EA;
    --foreground-cream: #F5F2EA;
    --foreground-muted: #C2CCD4;

    /* Borders - storm clouds */
    --border: #2A2A38;
    --border-storm: #334155;
    --border-muted: #1E1E28;

    /* Neon accents */
    --accent-red: #FF3B5C;
    --accent-red-solid: #B5182E;
    --accent-red-glow: rgba(255, 59, 92, 0.4);
    --accent-yellow: #FFE600;
    --accent-green: #00FF88;
    --accent-gold: #D4AF37;
    --accent-gold-glow: rgba(212, 175, 55, 0.3);

    /* Typography */
    --font-heading: "Unbounded", sans-serif;
    --font-body: "Manrope", sans-serif;

    /* Spacing - 8px base grid */
    --space-xs: 4px;
    --space-sm: 8px;
    --space-md: 16px;
    --space-lg: 24px;
    --space-xl: 32px;
    --space-2xl: 48px;
    --space-3xl: 64px;
    --space-4xl: 96px;

    /* Layout */
    --max-width: 1200px;
    --header-height: 64px;

    /* Transitions */
    --transition: 300ms ease-out;
}

.dark {
    --background: #0A0A0A;
    --foreground: #F5F2EA;
    --foreground-muted: #C2CCD4;
    --card: #1A1A22;
    --border: #2A2A38;
    --accent-red: #FF3B5C;
    --accent-red-solid: #B5182E;
}

/* ============================================
   RESET & BASE
   ============================================ */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    background-color: var(--background);
    color: var(--foreground);
    font-family: var(--font-body);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

img, video, iframe, embed, object, svg {
    max-width: 100%;
    height: auto;
}

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

ul {
    list-style: none;
}

p, li, td, th {
    overflow-wrap: break-word;
}

section {
    overflow: clip;
}

/* ============================================
   TYPOGRAPHY
   Unbounded for headings, Manrope for body
   ============================================ */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--foreground-cream);
}

h1 {
    font-size: 28px;
    font-weight: 700;
}

h2 {
    font-size: 24px;
    font-weight: 600;
}

h3 {
    font-size: 20px;
    font-weight: 500;
}

h4 {
    font-size: 18px;
    font-weight: 500;
}

p {
    font-size: 16px;
    line-height: 1.6;
    color: var(--foreground-muted);
}

@media (min-width: 768px) {
    h1 { font-size: 36px; }
    h2 { font-size: 28px; }
    h3 { font-size: 22px; }
    h4 { font-size: 20px; }
}

@media (min-width: 1024px) {
    h1 { font-size: 48px; }
    h2 { font-size: 36px; }
    h3 { font-size: 28px; }
    h4 { font-size: 22px; }
}

/* ============================================
   LAYOUT UTILITIES
   ============================================ */
.container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 var(--space-lg);
}

.container-narrow {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 var(--space-lg);
}

.section {
    padding: 56px 0;
}

@media (min-width: 1024px) {
    .section {
        padding: 96px 0;
    }
}

.text-accent-red { color: var(--accent-red); }
.text-accent-yellow { color: var(--accent-yellow); }
.text-accent-green { color: var(--accent-green); }
.text-accent-gold { color: var(--accent-gold); }
.text-cream { color: var(--foreground-cream); }
.text-muted { color: var(--foreground-muted); }

/* ============================================
   HEADER
   Sticky, blurred background, neon accents
   ============================================ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(10, 10, 10, 0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
    height: var(--header-height);
    display: flex;
    align-items: center;
}

.header-inner {
    max-width: var(--max-width);
    width: 100%;
    margin: 0 auto;
    padding: 0 var(--space-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-lg);
}

.site-brand {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    flex-shrink: 0;
}

.logo {
    border-radius: 6px;
}

.brand-name {
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: 700;
    color: var(--foreground-cream);
    letter-spacing: -0.02em;
}

/* Mobile menu toggle */
.mobile-menu-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    cursor: pointer;
    z-index: 1001;
}

.mobile-menu-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--foreground-cream);
    border-radius: 2px;
    transition: var(--transition);
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}
.mobile-menu-toggle[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
}
.mobile-menu-toggle[aria-expanded="true"] span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* Primary navigation */
.primary-nav {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: var(--header-height);
    left: 0;
    right: 0;
    height: calc(100vh - var(--header-height));
    background: var(--background);
    z-index: 999;
    overflow-y: auto;
    padding: var(--space-lg);
    visibility: hidden;
    opacity: 0;
    transform: translateX(-100%);
    transition: opacity var(--transition), visibility var(--transition), transform var(--transition);
    pointer-events: none;
}

.primary-nav.is-open {
    visibility: visible;
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
    height: calc(100vh - var(--header-height));
}

.primary-nav.is-open {
    visibility: visible;
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

.nav-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    list-style: none;
}

.nav-link {
    display: flex;
    align-items: center;
    min-height: 48px;
    font-family: var(--font-body);
    font-size: 18px;
    font-weight: 500;
    color: var(--foreground-cream);
    padding: var(--space-md);
    border-radius: 8px;
    transition: var(--transition);
}

.nav-link:hover {
    color: var(--accent-red);
    background: rgba(255, 0, 51, 0.08);
}

.nav-cta-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--border);
}

.nav-cta-group .btn {
    width: 100%;
    text-align: center;
}

@media (min-width: 1024px) {
    .mobile-menu-toggle {
        display: none;
    }

    .primary-nav {
        display: flex;
        position: static;
        padding: 0;
        background: transparent;
        overflow: visible;
        visibility: visible;
        opacity: 1;
        transform: none;
        pointer-events: auto;
        height: auto;
    }

    .nav-list {
        flex-direction: row;
        align-items: center;
        gap: var(--space-lg);
    }

    .nav-cta-group {
        flex-direction: row;
        gap: var(--space-md);
        margin-top: 0;
        padding-top: 0;
        border-top: none;
        margin-left: auto;
    }
}

/* ============================================
   BUTTONS
   Neon red CTA with pulsing glow
   ============================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 16px;
    border-radius: 8px;
    padding: 0 var(--space-xl);
    min-height: 52px;
    cursor: pointer;
    transition: var(--transition);
    border: 2px solid transparent;
    text-align: center;
    white-space: nowrap;
}

.btn-primary {
    background: var(--accent-red-solid);
    color: #ffffff;
    border-color: var(--accent-red-solid);
    box-shadow: 0 0 20px var(--accent-red-glow);
}

.btn-primary:hover {
    transform: scale(1.02);
    box-shadow: 0 0 32px var(--accent-red-glow), 0 0 60px var(--accent-red-glow);
}

.btn-outline {
    background: transparent;
    color: var(--foreground-cream);
    border-color: var(--border-storm);
}

.btn-outline:hover {
    border-color: var(--accent-red);
    color: var(--accent-red);
}

.btn-cta {
    font-size: 18px;
    padding: 0 var(--space-2xl);
    min-height: 52px;
    animation: pulse-glow 2s ease-in-out infinite;
}

@keyframes pulse-glow {
    0%, 100% {
        box-shadow: 0 0 20px var(--accent-red-glow);
    }
    50% {
        box-shadow: 0 0 40px var(--accent-red-glow), 0 0 80px var(--accent-red-glow);
    }
}

.btn-play {
    min-height: 44px;
    font-size: 15px;
    padding: 0 var(--space-xl);
}

/* ============================================
   HERO SECTIONS
   Full-width, cinematic Joker mascot, neon
   ============================================ */
.hero {
    position: relative;
    min-height: 500px;
    padding: 56px 0;
    display: flex;
    align-items: center;
    overflow: clip;
}

@media (min-width: 1024px) {
    .hero {
        min-height: 600px;
        padding: 96px 0;
    }
}

.hero-inner {
    max-width: var(--max-width);
    width: 100%;
    margin: 0 auto;
    padding: 0 var(--space-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
    position: relative;
    z-index: 2;
}

@media (min-width: 1024px) {
    .hero-inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
}

.hero-content {
    flex: 1;
    max-width: 600px;
}

.hero h1 {
    margin-bottom: var(--space-lg);
    font-size: 32px;
    line-height: 1.1;
}

@media (min-width: 768px) {
    .hero h1 { font-size: 44px; }
}

@media (min-width: 1024px) {
    .hero h1 { font-size: 52px; }
}

.hero-subtitle {
    font-size: 18px;
    color: var(--foreground-muted);
    margin-bottom: var(--space-xl);
    max-width: 480px;
}

@media (min-width: 1024px) {
    .hero-subtitle { font-size: 20px; }
}

.hero-cta-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

@media (min-width: 768px) {
    .hero-cta-group {
        flex-direction: row;
        align-items: center;
    }
}

.hero-mascot {
    flex: 0 0 auto;
    display: none;
    position: relative;
}

@media (min-width: 1024px) {
    .hero-mascot {
        display: block;
    }
}

.hero-mascot img {
    max-width: 400px;
    height: auto;
}

/* ============================================
   STAT / ADVANTAGES BLOCK
   Dark cards with neon icons
   ============================================ */
.stat-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 768px) {
    .stat-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .stat-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.stat-card {
    background: var(--card-slate);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: var(--space-xl);
    min-width: 0;
    transition: var(--transition);
}

.stat-card:hover {
    border-color: var(--accent-red);
    transform: translateY(-4px);
}

.stat-number {
    font-family: var(--font-heading);
    font-size: 42px;
    font-weight: 700;
    line-height: 1;
    margin-bottom: var(--space-sm);
}

.stat-label {
    font-family: var(--font-body);
    font-size: 15px;
    color: var(--foreground-muted);
    line-height: 1.5;
}

/* ============================================
   SLOT CARD
   280px width, neon red hover glow
   ============================================ */
.slot-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 640px) {
    .slot-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .slot-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.slot-card {
    background: var(--card-slate);
    border-radius: 8px;
    overflow: hidden;
    min-width: 0;
    transition: var(--transition);
    border: 1px solid var(--border-muted);
}

.slot-card:hover {
    transform: translateY(-4px);
    border-color: var(--accent-red);
    box-shadow: 0 0 24px var(--accent-red-glow);
}

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

.slot-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.slot-badge {
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
    background: var(--accent-yellow);
    color: var(--background);
    font-family: var(--font-heading);
    font-size: 11px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.slot-card-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 10, 10, 0.75);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: var(--transition);
}

.slot-card:hover .slot-card-overlay {
    opacity: 1;
}

.slot-card-info {
    padding: var(--space-md);
    text-align: left;
}

.slot-title {
    font-family: var(--font-heading);
    font-size: 16px;
    font-weight: 500;
    color: var(--foreground-cream);
    margin-bottom: 4px;
}

.slot-provider {
    font-family: var(--font-body);
    font-size: 12px;
    color: var(--foreground-muted);
}

/* ============================================
   CTA BANNER
   Full-width conversion section
   ============================================ */
.cta-banner {
    background: var(--background-graphite);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 56px var(--space-lg);
    text-align: center;
    position: relative;
}

@media (min-width: 1024px) {
    .cta-banner {
        padding: 96px var(--space-lg);
    }
}

.cta-banner-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-lg);
}

.cta-heading {
    font-family: var(--font-heading);
    font-size: 28px;
    font-weight: 600;
    color: var(--foreground-cream);
    max-width: 700px;
}

@media (min-width: 1024px) {
    .cta-heading { font-size: 36px; }
}

.cta-subheading {
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--foreground-muted);
    max-width: 600px;
}

.cta-microcopy {
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--foreground-muted);
}

/* ============================================
   FAQ ACCORDION
   Storm cloud borders, neon red active
   ============================================ */
.faq-accordion {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.faq-item {
    background: var(--card);
    border: 1px solid var(--border-storm);
    border-left: 3px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    transition: var(--transition);
}

.faq-item[open] {
    border-left-color: var(--accent-red);
}

.faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-lg);
    cursor: pointer;
    font-family: var(--font-body);
    font-size: 18px;
    font-weight: 500;
    color: var(--foreground-cream);
    list-style: none;
    user-select: none;
}

@media (min-width: 1024px) {
    .faq-question {
        padding: var(--space-xl);
    }
}

.faq-question::-webkit-details-marker {
    display: none;
}

.faq-icon {
    flex-shrink: 0;
    font-size: 20px;
    color: var(--accent-red);
    transition: var(--transition);
}

.faq-item[open] .faq-icon {
    transform: rotate(180deg);
}

.faq-answer {
    padding: 0 var(--space-lg) var(--space-lg);
}

@media (min-width: 1024px) {
    .faq-answer {
        padding: 0 var(--space-xl) var(--space-xl);
    }
}

.faq-answer p {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--foreground-muted);
}

/* ============================================
   BONUS / WELCOME PACKAGE
   Dark cinematic banner with neon red numbers
   ============================================ */
.bonus-banner {
    background: linear-gradient(135deg, var(--card-slate) 0%, var(--background) 100%);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: var(--space-2xl);
    position: relative;
    overflow: clip;
}

@media (min-width: 1024px) {
    .bonus-banner {
        padding: var(--space-3xl);
    }
}

.bonus-amount {
    font-family: var(--font-heading);
    font-size: 42px;
    font-weight: 800;
    color: var(--accent-red);
    text-shadow: 0 0 30px var(--accent-red-glow);
    line-height: 1;
    margin-bottom: var(--space-sm);
}

@media (min-width: 768px) {
    .bonus-amount { font-size: 56px; }
}

@media (min-width: 1024px) {
    .bonus-amount { font-size: 64px; }
}

.bonus-fs {
    font-family: var(--font-heading);
    font-size: 32px;
    font-weight: 700;
    color: var(--accent-yellow);
}

/* ============================================
   WELCOME PACKAGE TIMELINE
   3-step visual with neon red dashed lines
   ============================================ */
.welcome-steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 1024px) {
    .welcome-steps {
        grid-template-columns: repeat(3, 1fr);
    }
}

.welcome-step {
    background: var(--card-slate);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: var(--space-xl);
    position: relative;
}

.welcome-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: var(--accent-red-solid);
    color: #fff;
    border-radius: 50%;
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 16px;
    margin-bottom: var(--space-md);
}

/* ============================================
   HIGHROLLER / VIP SECTIONS
   Gold accents for premium feel
   ============================================ */
.highroller-card {
    background: var(--card-slate);
    border: 1px solid var(--accent-gold);
    border-radius: 12px;
    padding: var(--space-xl);
    box-shadow: 0 0 20px var(--accent-gold-glow);
}

.vip-tier {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    border-bottom: 1px solid var(--border);
}

.vip-tier:last-child {
    border-bottom: none;
}

.vip-level-indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--accent-green);
    flex-shrink: 0;
}

/* ============================================
   BONUS SHOP
   Neon yellow price tags in loyalty coins
   ============================================ */
.shop-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 640px) {
    .shop-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .shop-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.shop-item {
    background: var(--card-slate);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: var(--space-lg);
    text-align: center;
    min-width: 0;
}

.shop-item h3 {
    font-family: var(--font-heading);
    font-size: 18px;
    font-weight: 500;
}

.shop-price {
    display: inline-block;
    background: rgba(255, 230, 0, 0.1);
    color: var(--accent-yellow);
    font-family: var(--font-heading);
    font-size: 14px;
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 4px;
    margin-top: var(--space-md);
}

/* ============================================
   WAGERING TABLE
   Styled HTML table, neon red header
   ============================================ */
.wagering-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--card);
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--border-storm);
}

.wagering-table thead {
    background: var(--accent-red-solid);
}

.wagering-table th {
    padding: var(--space-md);
    text-align: left;
    font-family: var(--font-heading);
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    border-bottom: 1px solid var(--border-storm);
}

.wagering-table td {
    padding: var(--space-md);
    font-family: var(--font-body);
    font-size: 15px;
    color: var(--foreground-muted);
    border-bottom: 1px solid var(--border);
}

.wagering-table tr:last-child td {
    border-bottom: none;
}

.wagering-table tr:hover td {
    background: rgba(255, 0, 51, 0.04);
}

.table-wrapper {
    overflow-x: auto;
    max-width: 100%;
    border-radius: 8px;
}

.table-wrapper:focus-visible {
    outline: 2px solid var(--accent-yellow);
    outline-offset: 2px;
}

.table-wrapper:focus {
    outline: 2px solid var(--accent-yellow);
    outline-offset: 2px;
}

/* ============================================
   TWO-COLUMN COMPARISON
   ============================================ */
.two-col {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 768px) {
    .two-col {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ============================================
   PROVIDER GRID
   Grayscale logos with neon red hover
   ============================================ */
.provider-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
}

@media (min-width: 768px) {
    .provider-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (min-width: 1024px) {
    .provider-grid {
        grid-template-columns: repeat(6, 1fr);
    }
}

.provider-card {
    background: var(--card-slate);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: var(--space-lg);
    text-align: center;
    font-family: var(--font-heading);
    font-size: 14px;
    font-weight: 500;
    color: var(--foreground-muted);
    transition: var(--transition);
    min-width: 0;
}

.provider-card:hover {
    color: var(--accent-red);
    border-color: var(--accent-red);
}

/* ============================================
   CATEGORY FILTER CHIPS
   ============================================ */
.filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
}

.filter-chip {
    display: inline-block;
    padding: var(--space-sm) var(--space-md);
    background: var(--card-slate);
    border: 1px solid var(--border-storm);
    border-radius: 24px;
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    color: var(--foreground-muted);
    cursor: pointer;
    transition: var(--transition);
}

.filter-chip:hover,
.filter-chip.active {
    border-color: var(--accent-red);
    color: var(--accent-red);
    background: rgba(255, 0, 51, 0.06);
}

/* ============================================
   TOURNAMENT LEADERBOARD
   Neon green for top 3
   ============================================ */
.tournament-card {
    background: var(--card-slate);
    border: 1px solid var(--border-storm);
    border-radius: 8px;
    padding: var(--space-lg);
    margin-bottom: var(--space-md);
}

.leaderboard {
    width: 100%;
    border-collapse: collapse;
}

.leaderboard td {
    padding: var(--space-sm) var(--space-md);
    font-size: 15px;
    border-bottom: 1px solid var(--border);
}

.leaderboard tr:last-child td {
    border-bottom: none;
}

.leaderboard .rank-top {
    color: var(--accent-green);
    font-weight: 700;
}

/* ============================================
   SITEMAP PAGE
   Minimalist list, no CTA
   ============================================ */
.sitemap-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
}

.sitemap-item {
    border-bottom: 1px solid var(--border);
    padding-bottom: var(--space-lg);
}

.sitemap-item-title {
    font-family: var(--font-heading);
    font-size: 18px;
    font-weight: 500;
    color: var(--foreground-cream);
    margin-bottom: var(--space-sm);
}

.sitemap-item-title a {
    color: var(--foreground-cream);
    transition: var(--transition);
}

.sitemap-item-title a:hover {
    color: var(--accent-red);
}

.sitemap-item-desc {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--foreground-muted);
}

/* ============================================
   CALL-OUT / HIGHLIGHT BOX
   ============================================ */
.callout {
    background: var(--card-slate);
    border-left: 3px solid var(--accent-yellow);
    border-radius: 8px;
    padding: var(--space-lg);
    margin: var(--space-lg) 0;
}

.callout p {
    color: var(--foreground-cream);
}

/* ============================================
   PULL QUOTE
   ============================================ */
.pull-quote {
    border-left: 3px solid var(--accent-red);
    padding: var(--space-lg) var(--space-xl);
    margin: var(--space-xl) 0;
    font-family: var(--font-heading);
    font-size: 22px;
    font-weight: 500;
    color: var(--foreground-cream);
    line-height: 1.4;
}

.pull-quote cite {
    display: block;
    margin-top: var(--space-md);
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 400;
    font-style: normal;
    color: var(--foreground-muted);
}

/* ============================================
   SEO TEXT BLOCK
   Constrained content, inline anchors
   ============================================ */
.seo-text {
    max-width: 800px;
    margin: 0 auto;
}

.seo-text p {
    margin-bottom: var(--space-lg);
    font-size: 16px;
    line-height: 1.6;
    color: var(--foreground-muted);
}

.seo-text a {
    color: var(--accent-red);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: var(--transition);
}

.seo-text a:hover {
    color: var(--accent-yellow);
}

/* ============================================
   TRUST BADGES ROW
   ============================================ */
.trust-badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    align-items: center;
    justify-content: center;
}

.trust-badge {
    background: var(--card-slate);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: var(--space-sm) var(--space-md);
    font-size: 14px;
    color: var(--foreground-muted);
}

/* ============================================
   LIVE CASINO / SPORTSBOOK
   Two-column layout with imagery
   ============================================ */
.live-casino-block,
.sportsbook-block {
    background: var(--card-slate);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: var(--space-xl);
    min-width: 0;
}

.live-indicator {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 600;
    color: var(--accent-green);
}

.live-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent-green);
    animation: blink 1.5s ease-in-out infinite;
}

@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}

/* ============================================
   FOOTER
   Four-column, payment, license, 18+
   ============================================ */
.site-footer {
    background: var(--background-graphite);
    border-top: 1px solid var(--border);
    padding: var(--space-3xl) var(--space-lg) var(--space-xl);
}

.footer-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
}

@media (min-width: 768px) {
    .footer-inner {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .footer-inner {
        grid-template-columns: repeat(4, 1fr);
    }
}

.footer-col {
    min-width: 0;
}

.footer-heading {
    font-family: var(--font-heading);
    font-size: 16px;
    font-weight: 600;
    color: var(--foreground-cream);
    margin-bottom: var(--space-md);
    letter-spacing: -0.01em;
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.footer-links a {
    font-size: 15px;
    color: var(--foreground-muted);
    transition: var(--transition);
}

.footer-links a:hover {
    color: var(--accent-red);
}

.footer-links li {
    font-size: 15px;
    color: var(--foreground-muted);
}

.footer-bottom {
    max-width: var(--max-width);
    margin: var(--space-2xl) auto 0;
    padding-top: var(--space-lg);
    border-top: 1px solid var(--border);
    text-align: center;
}

.footer-copy {
    font-size: 14px;
    color: var(--foreground-muted);
    margin-bottom: var(--space-sm);
}

.footer-disclaimer {
    font-size: 13px;
    color: var(--foreground-muted);
    opacity: 0.7;
}

/* ============================================
   SCROLL ANIMATIONS
   ============================================ */
.animate-on-scroll {
    transform: translateY(30px);
    transition: transform 600ms ease-out;
}

.animate-on-scroll.is-visible {
    transform: translateY(0);
}

.animate-delay-1 { transition-delay: 100ms; }
.animate-delay-2 { transition-delay: 200ms; }
.animate-delay-3 { transition-delay: 300ms; }

/* ============================================
   WATERMARK / DECORATIVE JOKER
   ============================================ */
.joker-watermark {
    position: absolute;
    opacity: 0.05;
    pointer-events: none;
    z-index: 0;
}

/* ============================================
   SECTION HEADER
   ============================================ */
.section-header {
    margin-bottom: var(--space-2xl);
    text-align: center;
}

.section-header h2 {
    margin-bottom: var(--space-md);
}

.section-header p {
    max-width: 600px;
    margin: 0 auto;
    font-size: 17px;
}

/* ============================================
   SR ONLY
   ============================================ */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ============================================
   SUMMARY / TL;DR BOX
   ============================================ */
.summary-box {
    background: var(--card-slate);
    border: 1px solid var(--border);
    border-left: 3px solid var(--accent-green);
    border-radius: 8px;
    padding: var(--space-lg);
    margin: var(--space-xl) 0;
}

.summary-box p {
    color: var(--foreground-cream);
}

/* ============================================
   RESPONSIVE OVERRIDES
   ============================================ */
@media (min-width: 1024px) {
    .container {
        padding: 0 var(--space-xl);
    }
}