/* Root Variables - Two-Color Design System */

           :root {
            --accent-500: #FF6B35;
            --accent-600: #E55A2B;
            --success: #10B981;
            --warning: #F59E0B;
            --danger: #EF4444;
            --neutral-50: #FAFAFA;
            --neutral-100: #F5F5F5;
            --neutral-200: #E5E5E5;
            --neutral-600: #525252;
            --neutral-700: #404040;
            --neutral-900: #2D2D2D;
        }

        * {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
        }

        body {
            font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
            line-height: 1.6;
            color: var(--neutral-900);
            background: var(--neutral-50);
        }

        .container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 2rem 1rem;
        }

        .header {
            text-align: center;
            margin-bottom: 3rem;
        }

        h1 {
            font-size: 2.5rem;
            font-weight: 700;
            margin-bottom: 1rem;
            color: var(--neutral-900);
        }

        .subtitle {
            font-size: 1.125rem;
            color: var(--neutral-600);
            margin-bottom: 2rem;
        }

        .stats-bar {
            display: flex;
            justify-content: center;
            gap: 2rem;
            flex-wrap: wrap;
            margin-bottom: 3rem;
        }

        .stat-item {
            background: white;
            padding: 1rem 2rem;
            border-radius: 12px;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
            display: flex;
            align-items: center;
            gap: 1rem;
        }

        .stat-number {
            font-size: 2rem;
            font-weight: 700;
        }

        .stat-label {
            font-size: 0.875rem;
            color: var(--neutral-600);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .legal {
            color: var(--success);
        }

        .restricted {
            color: var(--warning);
        }

        .banned {
            color: var(--danger);
        }

        .legend {
            background: white;
            padding: 1.5rem;
            border-radius: 12px;
            margin-bottom: 2rem;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }

        .legend-title {
            font-weight: 600;
            margin-bottom: 1rem;
        }

        .legend-items {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 1rem;
        }

        .legend-item {
            display: flex;
            align-items: center;
            gap: 0.5rem;
        }

        .status-indicator {
            width: 12px;
            height: 12px;
            border-radius: 50%;
        }

        .status-legal {
            background: var(--success);
        }

        .status-restricted {
            background: var(--warning);
        }

        .status-banned {
            background: var(--danger);
        }

        .states-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
            gap: 1rem;
            margin-bottom: 3rem;
        }

        .state-card {
            background: white;
            border-radius: 12px;
            padding: 1.5rem;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
            transition: transform 0.2s, box-shadow 0.2s;
            border: 2px solid transparent;
        }

        .state-card:hover {
            transform: translateY(-2px);
            box-shadow: 0 4px 8px rgba(0,0,0,0.15);
        }

        .state-card.legal {
            border-color: var(--success);
        }

        .state-card.restricted {
            border-color: var(--warning);
        }

        .state-card.banned {
            border-color: var(--danger);
        }

        .state-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 0.75rem;
        }

        .state-name {
            font-size: 1.25rem;
            font-weight: 600;
        }

        .state-status {
            padding: 0.25rem 0.75rem;
            border-radius: 20px;
            font-size: 0.75rem;
            font-weight: 600;
            text-transform: uppercase;
        }

        .status-legal-bg {
            background: rgba(16, 185, 129, 0.1);
            color: var(--success);
        }

        .status-restricted-bg {
            background: rgba(245, 158, 11, 0.1);
            color: var(--warning);
        }

        .status-banned-bg {
            background: rgba(239, 68, 68, 0.1);
            color: var(--danger);
        }

        .state-notes {
            font-size: 0.875rem;
            color: var(--neutral-600);
            line-height: 1.5;
        }

        .info-section {
            background: white;
            padding: 2rem;
            border-radius: 12px;
            margin-bottom: 2rem;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }

        .info-section h2 {
            font-size: 1.5rem;
            margin-bottom: 1rem;
            color: var(--neutral-900);
        }

        .info-section p {
            color: var(--neutral-700);
            margin-bottom: 1rem;
            line-height: 1.7;
        }

        .info-section ul {
            margin-left: 1.5rem;
            color: var(--neutral-700);
        }

        .info-section li {
            margin-bottom: 0.5rem;
        }

        .disclaimer {
            background: rgba(255, 107, 53, 0.1);
            border-left: 4px solid var(--accent-500);
            padding: 1rem 1.5rem;
            border-radius: 8px;
            margin-top: 2rem;
        }

        .disclaimer strong {
            color: var(--accent-600);
        }

        .last-updated {
            text-align: center;
            color: var(--neutral-600);
            font-size: 0.875rem;
            margin-top: 2rem;
            padding-top: 2rem;
            border-top: 1px solid var(--neutral-200);
        }

        @media (max-width: 768px) {
            h1 {
                font-size: 1.75rem;
            }

            .states-grid {
                grid-template-columns: 1fr;
            }

            .stat-item {
                padding: 0.75rem 1rem;
            }

            .stat-number {
                font-size: 1.5rem;
            }
        }

        :root {
            /* Primary Accent - Orange */
            --accent-500: #FF6B35;
            --accent-600: #E55A2B;
            --accent-50: rgba(255, 107, 53, 0.1);
            
            /* Neutrals */
            --neutral-white: #FFFFFF;
            --neutral-50: #FAFAFA;
            --neutral-100: #F5F5F5;
            --neutral-200: #E5E5E5;
            --neutral-400: #A3A3A3;
            --neutral-600: #525252;
            --neutral-700: #404040;
            --neutral-900: #2D2D2D;
            
            /* Semantic Colors */
            --success: #10B981;
            --warning: #F59E0B;
            
            /* Typography */
            --text-xs: 0.75rem;
            --text-sm: 0.875rem;
            --text-base: 1rem;
            --text-lg: 1.125rem;
            
            /* Spacing */
            --space-1: 0.25rem;
            --space-2: 0.5rem;
            --space-3: 0.75rem;
            --space-4: 1rem;
            --space-6: 1.5rem;
            
            /* Shadows */
            --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
            --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
            --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
            
            /* Radii */
            --radius-md: 0.5rem;
            --radius-lg: 0.75rem;
            --radius-xl: 1rem;
            --radius-2xl: 1.5rem;
            --radius-full: 9999px;
        }

        /* Reset */
        *, *::before, *::after {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
        }

        html {
            scroll-behavior: smooth;
            font-size: 16px;
        }

        body {
            font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
            font-size: var(--text-base);
            line-height: 1.6;
            color: var(--neutral-900);
            background-color: var(--neutral-50);
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            /*padding: var(--space-4);*/
        }

        /* Screen Reader 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;
        }

        /* Focus Styles */
        button:focus-visible, input:focus-visible, select:focus-visible {
            outline: 2px solid var(--accent-500);
            outline-offset: 2px;
        }

        /* Container */
        .container {
            max-width: 1400px;
            margin: 0 auto;
            padding: var(--space-4) 0;
        }

        /* Save Actions Bar */
        .save-actions-bar {
            background: linear-gradient(135deg, var(--accent-500), var(--accent-600));
            padding: var(--space-3);
            margin-bottom: var(--space-4);
            border-radius: var(--radius-xl);
            box-shadow: var(--shadow-md);
            display: flex;
            justify-content: center;
            align-items: center;
            gap: var(--space-4);
            flex-wrap: wrap;
            position: relative;
            overflow: hidden;
        }

        .save-actions-bar::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
            animation: shimmer 3s infinite;
        }

        @keyframes shimmer {
            0% { left: -100%; }
            100% { left: 100%; }
        }

        .save-action-content {
            display: flex;
            align-items: center;
            gap: var(--space-4);
            flex-wrap: wrap;
            justify-content: center;
        }

        .save-action-text {
            color: var(--neutral-white);
            font-size: var(--text-sm);
            font-weight: 500;
            display: flex;
            align-items: center;
            gap: var(--space-2);

        }

        .save-action-text .icon {
            font-size: 1.25rem;
        }

        .cta-button {
            background: var(--neutral-white);
            color: var(--accent-600);
            border: 2px solid var(--neutral-white);
            padding: var(--space-2) var(--space-4);
            border-radius: var(--radius-full);
            font-size: var(--text-sm);
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
            display: flex;
            align-items: center;
            gap: var(--space-2);
            white-space: nowrap;
            position: relative;
            overflow: hidden;
        }

        .cta-button:hover {
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(0,0,0,0.2);
            background: var(--neutral-50);
        }

        .cta-button:active {
            transform: translateY(0);
        }

        .cta-button .button-icon {
            font-size: 1.125rem;
        }

        .cta-button.install-button {
            background: linear-gradient(135deg, var(--neutral-white), var(--neutral-50));
        }

        .cta-button.bookmark-button {
            background: linear-gradient(135deg, #FFD700, #FFA500);
            color: var(--neutral-white);
            border-color: #FFD700;
        }

        .cta-button.bookmark-button:hover {
            background: linear-gradient(135deg, #FFA500, #FF8C00);
            border-color: #FFA500;
        }

        /* PWA Install Prompt (Hidden by default) */
        .install-prompt {
            display: none;
            position: fixed;
            bottom: 20px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--neutral-white);
            padding: var(--space-4);
            border-radius: var(--radius-xl);
            box-shadow: var(--shadow-lg);
            z-index: 1000;
            max-width: 90%;
            width: 400px;
            border: 2px solid var(--accent-500);
            animation: slideUp 0.3s ease;
        }

        @keyframes slideUp {
            from {
                bottom: -100px;
                opacity: 0;
            }
            to {
                bottom: 20px;
                opacity: 1;
            }
        }

        .install-prompt.show {
            display: block;
        }

        .install-prompt-header {
            display: flex;
            align-items: center;
            gap: var(--space-3);
            margin-bottom: var(--space-3);
        }

        .install-prompt-icon {
            width: 48px;
            height: 48px;
            background: var(--accent-500);
            border-radius: var(--radius-lg);
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--neutral-white);
            font-size: 1.5rem;
        }

        .install-prompt-title {
            font-size: var(--text-lg);
            font-weight: 700;
            color: var(--neutral-900);
        }

        .install-prompt-text {
            font-size: var(--text-sm);
            color: var(--neutral-600);
            margin-bottom: var(--space-4);
        }

        .install-prompt-buttons {
            display: flex;
            gap: var(--space-2);
        }

        .install-prompt-button {
            flex: 1;
            padding: var(--space-3);
            border-radius: var(--radius-lg);
            font-size: var(--text-sm);
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            border: none;
        }

        .install-prompt-button.primary {
            background: var(--accent-500);
            color: var(--neutral-white);
        }

        .install-prompt-button.primary:hover {
            background: var(--accent-600);
        }

        .install-prompt-button.secondary {
            background: var(--neutral-100);
            color: var(--neutral-700);
        }

        .install-prompt-button.secondary:hover {
            background: var(--neutral-200);
        }

        .close-prompt {
            position: absolute;
            top: var(--space-2);
            right: var(--space-2);
            width: 24px;
            height: 24px;
            background: var(--neutral-100);
            border: none;
            border-radius: var(--radius-full);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--neutral-600);
            font-size: 1rem;
            transition: all 0.2s;
        }

        .close-prompt:hover {
            background: var(--neutral-200);
            color: var(--neutral-900);
        }

        /* Mobile responsive */
        @media (max-width: 640px) {
            .save-actions-bar {
                padding: var(--space-2);
            }

            .save-action-text {
                font-size: var(--text-xs);
            }

            .cta-button {
                padding: var(--space-2) var(--space-3);
                font-size: var(--text-xs);
            }

            .save-action-text .icon {
                display: none;
            }

            .install-prompt {
                width: calc(100% - 40px);
                bottom: 10px;
            }
        }

        /* Page Header */
        .page-header {
            text-align: center;
            margin-bottom: var(--space-4);
        }

        .page-title {
            font-size: clamp(1.5rem, 4vw, 2.5rem);
            font-weight: 700;
            color: var(--neutral-900);
            margin-bottom: var(--space-1);
        }

        .page-subtitle {
            font-size: var(--text-lg);
            color: var(--neutral-600);
            margin-bottom: var(--space-3);
        }

        /* Inline Stats Grid - Compact horizontal layout */
        .stats-grid-inline {
            display: inline-flex;
            gap: var(--space-3);
            justify-content: center;
            align-items: center;
            flex-wrap: wrap;
            margin: 0 auto;
        }

        .stat-item-inline {
            display: flex;
            align-items: center;
            gap: var(--space-2);
            background: var(--neutral-white);
            padding: var(--space-2) var(--space-3);
            border-radius: var(--radius-full);
            box-shadow: var(--shadow-sm);
            border: 1px solid var(--neutral-200);
            transition: all 0.2s;
        }

        .stat-item-inline:hover {
            transform: translateY(-1px);
            box-shadow: var(--shadow-md);
            border-color: var(--accent-500);
        }

        .stat-value-inline {
            font-size: var(--text-base);
            font-weight: 700;
            color: var(--accent-500);
        }

        .stat-label-inline {
            font-size: var(--text-xs);
            color: var(--neutral-600);
            text-transform: uppercase;
            letter-spacing: 0.3px;
            font-weight: 600;
        }

        /* Mobile responsive for inline stats */
        @media (max-width: 640px) {
            .stats-grid-inline {
                gap: var(--space-2);
            }
            
            .stat-item-inline {
                padding: var(--space-1) var(--space-2);
                gap: var(--space-1);
            }
            
            .stat-value-inline {
                font-size: var(--text-sm);
            }
            
            .stat-label-inline {
                font-size: 10px;
            }
        }

        /* Controls Section */
        .controls-section {
            background: var(--neutral-white);
            border-radius: var(--radius-xl);
            padding: var(--space-4);
            margin-bottom: var(--space-4);
            box-shadow: var(--shadow-sm);
        }

        .controls-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: var(--space-3);
        }

        @media (min-width: 768px) {
            .controls-grid {
                grid-template-columns: 2fr 1fr 1fr;
                align-items: center;
            }
        }

        /* Search Bar */
        .search-input {
            width: 100%;
            padding: var(--space-3);
            border: 2px solid var(--neutral-200);
            border-radius: var(--radius-lg);
            font-size: var(--text-base);
            transition: all 0.2s;
        }

        .search-input:focus {
            outline: none;
            border-color: var(--accent-500);
            box-shadow: 0 0 0 3px var(--accent-50);
        }

        /* Filter Select */
        .filter-select {
            width: 100%;
            padding: var(--space-3);
            border: 2px solid var(--neutral-200);
            border-radius: var(--radius-lg);
            font-size: var(--text-base);
            background: var(--neutral-white);
            cursor: pointer;
            transition: all 0.2s;
        }

        .filter-select:hover {
            border-color: var(--accent-500);
        }

        /* Sort Buttons */
        .sort-controls {
            display: flex;
            gap: var(--space-2);
        }

        .sort-btn {
            flex: 1;
            padding: var(--space-3);
            border: 2px solid var(--neutral-200);
            border-radius: var(--radius-lg);
            background: var(--neutral-white);
            color: var(--neutral-700);
            font-size: var(--text-sm);
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }

        .sort-btn:hover {
            border-color: var(--accent-500);
            color: var(--accent-500);
        }

        .sort-btn.active {
            background: var(--accent-500);
            color: var(--neutral-white);
            border-color: var(--accent-500);
        }

        /* Casino Table Container */
        .casino-table-container {
            background: var(--neutral-white);
            border-radius: var(--radius-2xl);
            overflow: hidden;
            box-shadow: var(--shadow-lg);
            border: 1px solid var(--neutral-200);
            margin: var(--space-4) 0;
            position: relative;
        }

        /* Table Wrapper - Enables horizontal scroll */
        .table-wrapper {
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: thin;
            scrollbar-color: var(--accent-500) var(--neutral-100);
            position: relative;
        }

        .table-wrapper::-webkit-scrollbar {
            height: 12px;
        }

        .table-wrapper::-webkit-scrollbar-track {
            background: var(--neutral-100);
            border-radius: var(--radius-full);
        }

        .table-wrapper::-webkit-scrollbar-thumb {
            background: var(--accent-500);
            border-radius: var(--radius-full);
            border: 2px solid var(--neutral-100);
        }

        .table-wrapper::-webkit-scrollbar-thumb:hover {
            background: var(--accent-600);
        }

        /* Table Styles */
        .casino-table {
            width: 100%;
            border-collapse: collapse;
            min-width: 900px;
        }

        /* Table Header */
        .table-header {
            background: linear-gradient(135deg, var(--accent-50), var(--neutral-50));
            border-bottom: 2px solid var(--neutral-200);
            position: sticky;
            top: 0;
            z-index: 5;
        }

        .casino-initials{
            color: #ff6b35!important;
        }

        .table-header th {
            padding: var(--space-4) var(--space-3);
            text-align: left;
            font-weight: 600;
            color: var(--neutral-900);
            font-size: var(--text-sm);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            white-space: nowrap;
            background: linear-gradient(135deg, var(--accent-50), var(--neutral-50));
        }

        /* Sticky first column (Rank) */
        .table-header th:first-child {
            width: 60px;
            text-align: center;
            border-radius: var(--radius-lg) 0 0 0;
            position: sticky;
            left: 0;
            z-index: 6;
            background: linear-gradient(135deg, var(--accent-50), var(--neutral-50));
            border-right: 2px solid var(--accent-500);
            box-shadow: 2px 0 4px rgba(255, 107, 53, 0.1);
        }

        /* Sticky last column (Action) */
        .table-header th:last-child {
            text-align: center;
            border-radius: 0 var(--radius-lg) 0 0;
            position: sticky;
            right: 0;
            z-index: 6;
            width: 120px;
            background: linear-gradient(135deg, var(--accent-50), var(--neutral-50));
            border-left: 2px solid var(--accent-500);
            box-shadow: -2px 0 4px rgba(255, 107, 53, 0.1);
        }

        /* Table Rows */
        .casino-row {
            border-bottom: 1px solid var(--neutral-100);
            transition: all 0.2s ease;
            background: var(--neutral-white);
        }

        .casino-row:hover {
            background: var(--accent-50);
            transform: translateX(2px);
        }

        .casino-row:last-child {
            border-bottom: none;
        }

        /* Table Cells */
        .casino-cell {
            padding: var(--space-4) var(--space-3);
            vertical-align: middle;
            border-right: 1px solid var(--neutral-100);
        }

        .casino-cell:last-child {
            border-right: none;
            position: sticky;
            right: 0;
            z-index: 3;
            background: var(--neutral-white);
            text-align: center;
            width: 120px;
            border-left: 2px solid var(--accent-500);
            box-shadow: -2px 0 4px rgba(255, 107, 53, 0.1);
        }

        .casino-row:hover .casino-cell:last-child {
            background: var(--accent-50);
        }

        /* Rank Cell - Sticky */
        .rank-cell {
            font-weight: 700;
            font-size: var(--text-lg);
            text-align: center;
            width: 60px;
            position: sticky;
            left: 0;
            z-index: 4;
            border-right: 2px solid var(--accent-500);
        }

        .rank-top3 {
            background: var(--accent-500);
            color: var(--neutral-white);
        }

        .rank-top10 {
            background: var(--accent-50);
            color: var(--accent-500);
        }

        .rank-regular {
            background: var(--neutral-50);
            color: var(--neutral-700);
        }

        /* Casino Info */
        .casino-info-cell {
            min-width: 220px;
        }

        .casino-info {
            display: flex;
            align-items: center;
            gap: var(--space-3);
        }

        .casino-logo {
                width: 100px;
                height: 75px;
                border-radius: var(--radius-xl);
                display: flex;
                align-items: center;
                justify-content: center;
                font-weight: 700;
                color: var(--neutral-white);
                font-size: var(--text-sm);
                flex-shrink: 0;
                /*background: linear-gradient(135deg, var(--accent-500), var(--accent-600));*/
                border: 2px solid rgba(255, 255, 255, 0.2);
                transition: transform 0.2s ease;
                padding: 6px; 
                box-sizing: border-box;
            }

            .casino-logo img {
                max-width: 100%;
                max-height: 100%;
                object-fit: contain;
                display: block;
            }
           
              
         
                @media (max-width: 767px) {

              
                  .casino-table {
                    table-layout: fixed;
                    width: 100%;
                  }

           
                  .casino-cell.casino-info-cell {
                    width: 75%; 
                    position: relative;
                  }

             
                  .casino-cell.bonus-cell {
                    width: 30%;
                    overflow: hidden;
                  }


                  .casino-info {
                    display: flex;
                    align-items: center;
                    gap: 8px;
                  }

                
                  .casino-logo {
                    flex: 0 0 70px; 
                    max-width: 70px;
                  }

                 
                  .casino-details {
                    flex: 1 1 auto;
                    min-width: 0;
                  
                    white-space: nowrap;
                    text-overflow: ellipsis;
                    font-size: 14px;
                    padding-right: 2px;
                     max-width: 100%;
                  }

                  
                  .casino-cell.bonus-cell  {
                    position: relative;
                    left: -15px; 
                    z-index: 1;
                    
                  }

                }


            @media (max-width: 767px) {

                .casino-table td.casino-cell.payout-cell.payout-fast,
                .casino-table th:nth-child(5) {
                    width: 10% !important; 
                    min-width: 50px !important; 
                    max-width: 80px !important; 
                    text-align: center; 
                }


                .table-header th:first-child {
                   width: 25px!important;  
                  }

                 .rank-cell{
                    width: 25px!important; 
                 }

                .casino-logo {
                    width: 75px;
                    height: 60px;
                    padding: 4px;
                }

                /*.bookmark-button{
                    display: none;
                }*/

                .casino-logo img {
                    max-width: 100%;
                    max-height: 100%;
                }

                .tag-hot, .tag-new, .tag-vip{
                    padding: 3px 4px!important;
                    font-size: 8px!important;
                    height: 20px;
                    max-height: 20px;
                }

               

                .save-action-text {
                    font-weight: 0!important;
                    font-size: 10px!important;
                }

                .save-action-content{
                    gap: 3px!important;
                }

            }




/*
            @media (max-width: 480px) {
                .casino-logo {
                    width: 100px;
                    height: 60px;
                }

                .casino-logo img {
                    max-width: 85%;
                    max-height: 85%;
                }

                .tag-hot, .tag-new, .tag-vip{
                    padding: 3px 6px!important;
                    font-size: 8px!important;
                }
            }*/


        .casino-logo:hover {
            transform: scale(1.05);
        }

        .casino-details h3 {
            font-size: var(--text-base);
            font-weight: 700;
            color: var(--neutral-900);
            margin-bottom: var(--space-1);
            line-height: 1.2;
        }

        .casino-tags {
            display: flex;
            gap: var(--space-1);
        }

        .tag {
            padding: 2px 6px;
            border-radius: var(--radius-md);
            font-size: 10px;
            font-weight: 700;
            text-transform: uppercase;
        }

        .tag-hot {
            background: var(--accent-500);
            color: var(--neutral-white);
        }

        .tag-new {
            background: var(--success);
            color: var(--neutral-white);
        }

        .tag-vip {
            background: var(--neutral-900);
            color: var(--neutral-white);
        }

        .tag-recommended {
            background: linear-gradient(135deg, rgba(255, 215, 0, 0.15), rgba(255, 165, 0, 0.15));
            color: var(--accent-600);
            border: 1px solid rgba(255, 165, 0, 0.3);
            font-weight: 600;
            font-size: 9px;
            padding: 1px 5px;
            letter-spacing: 0.3px;
        }

        /* Bonus Cell */
        .bonus-cell {
            min-width: 180px;
        }

        .bonus-amount {
            font-weight: 700;
            color: var(--accent-500);
            font-size: var(--text-base);
            margin-bottom: var(--space-1);
            line-height: 1.2;
        }

        .bonus-description {
            font-size: var(--text-xs);
            color: var(--neutral-600);
            line-height: 1.3;
        }

        /* Features */
        .features-cell {
            min-width: 200px;
        }

        .feature-tags {
            display: flex;
            flex-wrap: wrap;
            gap: var(--space-1);
        }

        .feature-tag {
            background: var(--neutral-100);
            color: var(--neutral-700);
            padding: var(--space-1) var(--space-2);
            border-radius: var(--radius-full);
            font-size: var(--text-xs);
            font-weight: 500;
            white-space: nowrap;
            transition: all 0.2s ease;
        }

        .feature-tag.highlighted {
            background: var(--accent-500);
            color: var(--neutral-white);
        }

        .feature-tag:hover {
            transform: scale(1.05);
        }

        /* Payout Cell */
        .payout-cell {
            min-width: 100px;
            text-align: center;
            font-weight: 600;
            color: var(--neutral-700);
        }

        .payout-fast {
            color: var(--success);
        }

        /* Play Button */
        .play-button {
            background: var(--accent-500);
            color: var(--neutral-white);
            border: none;
            padding: var(--space-3) var(--space-6);
            border-radius: var(--radius-full);
            font-size: var(--text-sm);
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
            min-height: 44px;
            min-width: 100px;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: var(--space-1);
            box-shadow: var(--shadow-sm);
            position: relative;
            overflow: hidden;
            white-space: nowrap;
        }

        .play-button::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
            transition: left 0.5s ease;
        }

        .play-button:hover::before {
            left: 100%;
        }

        .play-button:hover {
            background: var(--accent-600);
            transform: translateY(-1px);
            box-shadow: var(--shadow-md);
        }

        .play-button:active {
            transform: translateY(0);
        }

        /* Pagination */
        .pagination {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: var(--space-3);
            padding: var(--space-6) 0;
        }

        .page-btn {
            padding: var(--space-2) var(--space-4);
            border: 2px solid var(--neutral-200);
            border-radius: var(--radius-lg);
            background: var(--neutral-white);
            color: var(--neutral-700);
            font-size: var(--text-sm);
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }

        .page-btn:hover:not(:disabled) {
            border-color: var(--accent-500);
            color: var(--accent-500);
        }

        .page-btn.active {
            background: var(--accent-500);
            color: var(--neutral-white);
            border-color: var(--accent-500);
        }

        .page-btn:disabled {
            opacity: 0.3;
            cursor: not-allowed;
        }

        .page-info {
            font-size: var(--text-sm);
            color: var(--neutral-600);
        }

        /* No results message */
        .no-results {
            text-align: center;
            padding: var(--space-6);
            color: var(--neutral-600);
            font-size: var(--text-lg);
        }

        /* Info Section Under Table */
        .info-section {
            background: var(--neutral-white);
            border-radius: var(--radius-xl);
            padding: 2rem;
            margin: 2rem 0;
            box-shadow: var(--shadow-sm);
            border: 1px solid var(--neutral-200);
        }

        .info-section h2 {
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--neutral-900);
            margin-bottom: 1rem;
            display: flex;
            align-items: center;
            gap: 0.5rem;
        }

        .info-section h3 {
            font-size: 1.125rem;
            font-weight: 600;
            color: var(--neutral-800);
            margin-top: 1.5rem;
            margin-bottom: 0.75rem;
        }

        .info-section p {
            color: var(--neutral-700);
            line-height: 1.7;
            margin-bottom: 1rem;
        }

        .info-section ul {
            color: var(--neutral-700);
            line-height: 1.7;
            margin-left: 1.5rem;
            margin-bottom: 1rem;
        }

        .info-section ul li {
            margin-bottom: 0.5rem;
        }

        .verified-badge {
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
            background: var(--success);
            color: white;
            padding: 0.25rem 0.75rem;
            border-radius: var(--radius-full);
            font-size: 0.75rem;
            font-weight: 600;
        }

        /* Footer Styles */
        .site-footer {
            background: linear-gradient(135deg, #1a1a1a, #2d2d2d);
            color: var(--neutral-200);
            padding: 3rem 0 1.5rem;
            margin-top: 4rem;
        }

        .footer-container {
            max-width: 1400px;
            margin: 0 auto;
            padding: 0 1rem;
        }

        .footer-top {
            display: grid;
            grid-template-columns: 1fr;
            gap: 2rem;
            padding-bottom: 2rem;
            border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        }

        @media (min-width: 768px) {
            .footer-top {
                grid-template-columns: 2fr 1fr 1fr 1fr;
            }
        }

        .footer-brand h3 {
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--neutral-white);
            margin-bottom: 1rem;
        }

        .footer-brand p {
            font-size: 0.875rem;
            line-height: 1.6;
            margin-bottom: 1rem;
            color: var(--neutral-400);
        }

        .trust-badges {
            display: flex;
            gap: 0.75rem;
            flex-wrap: wrap;
            margin-top: 1rem;
        }

        .trust-badge {
            background: rgba(255, 255, 255, 0.05);
            border: 1px solid rgba(255, 255, 255, 0.1);
            padding: 0.5rem 1rem;
            border-radius: var(--radius-md);
            font-size: 0.75rem;
            font-weight: 600;
            color: var(--neutral-300);
        }

        .footer-column h4 {
            font-size: 0.875rem;
            font-weight: 700;
            text-transform: uppercase;
            color: var(--neutral-white);
            margin-bottom: 1rem;
            letter-spacing: 0.5px;
        }

        .footer-column ul {
            list-style: none;
            padding: 0;
        }

        .footer-column ul li {
            margin-bottom: 0.75rem;
        }

        .footer-column ul li a {
            color: var(--neutral-400);
            text-decoration: none;
            font-size: 0.875rem;
            transition: color 0.2s;
        }

        .footer-column ul li a:hover {
            color: var(--accent-500);
        }

        .footer-bottom {
            padding-top: 2rem;
            display: flex;
            flex-direction: column;
            gap: 1rem;
            align-items: center;
            text-align: center;
        }

        @media (min-width: 768px) {
            .footer-bottom {
                flex-direction: row;
                justify-content: space-between;
                text-align: left;
            }
        }

        .footer-bottom p {
            font-size: 0.75rem;
            color: var(--neutral-500);
        }

        .social-links {
            display: flex;
            gap: 0.75rem;
        }

        .social-link {
            width: 36px;
            height: 36px;
            background: rgba(255, 255, 255, 0.05);
            border: 1px solid rgba(255, 255, 255, 0.1);
            border-radius: var(--radius-full);
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--neutral-400);
            text-decoration: none;
            transition: all 0.2s;
        }

        .social-link:hover {
            background: var(--accent-500);
            border-color: var(--accent-500);
            color: white;
            transform: translateY(-2px);
        }

        .compliance-badges {
            display: flex;
            gap: 1rem;
            align-items: center;
            flex-wrap: wrap;
        }

        .compliance-badge {
            background: rgba(255, 255, 255, 0.05);
            padding: 0.25rem 0.75rem;
            border-radius: var(--radius-md);
            font-size: 0.625rem;
            color: var(--neutral-500);
            border: 1px solid rgba(255, 255, 255, 0.1);
        }

        /* Responsive Breakpoints */
        @media (max-width: 767px) {

            .stats-bar{
                flex-wrap: nowrap;
            }
            
            body {
                padding: var(--space-2);
            }

            .casino-table {
                min-width: 600px;
            }
            
            .table-header th,
            .casino-cell {
                padding: var(--space-2) var(--space-1);
            }

            .play-button {
                padding: var(--space-1) var(--space-1);
                min-width: 90px;
                font-size: 12px;
                min-height: 32px;
            }
            .info-section h2{
                flex-wrap:  wrap;
            }
        }

        .casino-table-container .table-wrapper{
          overflow-x: auto;
          -webkit-overflow-scrolling: touch;
          width: 100%;
        }

        @media (max-width:600px){
          
          .casino-table{ min-width: 900px; } 
        }

        }

        .disclaimer-container {
    border-radius: 5px;
    border: 1px solid #D8D8D8;
    padding: .75rem 1rem;
    display: flex;
    gap: 10px;
    position: relative;
  }

  .disclaimer-title {
    font-size: 16px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .disclaimer-text {
    font-size: 14px;
    line-height: 1.5;
  }

  .extra-text {
    display: none;
    color: #555;
  }

  .disclaimer-toggle {
    display: none;
  }

  .disclaimer-toggle:checked ~ .disclaimer-text .extra-text {
    display: inline;
  }

  .read-more-label {
    color: #fca033;
    cursor: pointer;
    text-decoration: underline;
    font-size: 14px;
    margin-top: 5px;
    align-self: flex-start;
  }


@media (max-width: 768px) {
  td.casino-cell.features-cell .feature-tags {
    display: flex !important;    
    flex-wrap: wrap;
    gap: 6px;
  }

  td.casino-cell.features-cell .feature-tag.is-hidden {
    display: none !important;
  }

  td.casino-cell.features-cell .feature-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1px solid #e0e0e0;
    background: #fff;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    user-select: none;
  }


  td.casino-cell.features-cell .feature-tags.expanded .feature-tag {
    display: inline-block !important;
  }
  td.casino-cell.features-cell .feature-tags.expanded .feature-more {
    display: none !important;
  }
}

   
.subscribe-container{
    max-width: 1100px;
    margin: 0 auto;
    background: rgba(255,255,255,.9);
    backdrop-filter: blur(8px);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 40px;
    display: grid;
    grid-template-columns: 1.2fr 1fr;   
    gap: 36px;
    align-items: center;
    transition: transform .25s ease, box-shadow .25s ease;
  }
 /* .subscribe-container:hover{
    transform: translateY(-2px);
    box-shadow: 0 20px 45px rgba(17,24,39,.08);
  }*/

  .subscribe-left{ text-align: left; }
  .subscribe-right{ width: 100%; }

  .subscribe-title{
    margin: 0 0 10px;
    font-weight: 800;
    font-size: clamp(28px, 3.2vw, 42px);
    color: var(--text);
    letter-spacing: -0.02em;
  }
  .subscribe-subtitle{
    margin: 0 0 18px;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.65;
  }
  .privacy-text{
    margin-top: 14px;
    color: var(--muted);
    font-size: .95rem;
    line-height: 1.55;
  }

  .form-group{ width: 100%; }
  .form-group label{
    display:block;
    margin-bottom: 10px;
    font-weight: 600;
    color: var(--text);
  }

  .input-row{
    display: flex;
    gap: 12px;
    align-items: stretch;
    transition: transform .2s ease;
  }
  .input-row.focused{ transform: translateY(-2px); }

  .input-row input{
    flex: 1 1 auto;
    min-width: 0;
    height: 52px;
    padding: 0 16px;
    border: 2px solid #e5e7eb;
    border-radius: 12px;
    background:#f9fafb;
    font-size: 1rem;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
  }
  .input-row input:focus{
    outline: none;
    background:#fff;
    border-color: var(--accent-500);
    box-shadow: 0 0 0 4px var(--ring);
  }

  .subscribe-btn{
    flex: 0 0 auto;
    height: 52px;
    padding: 0 20px;
    border: 0;
    border-radius: 12px;
    background: var(--accent-500);
    color:#fff;
    font-weight: 700;
    font-size: 1rem;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .2s ease, background .2s;
    white-space: nowrap;
  }
  .subscribe-btn:hover{ transform: translateY(-1px); box-shadow: 0 12px 24px rgba(102,126,234,.28); background: var(--accent-600); }
  .subscribe-btn:active{ transform: translateY(0); box-shadow:none; }

  .help-text{
    display:block;
    margin-top:10px;
    color: var(--muted);
    font-size: .9rem;
  }

 
  .form-message{ 
    margin-top:14px; padding:12px 14px; border-radius: 10px; display:none; border:1px solid transparent;
    font-size:.95rem;
  }
  .form-message.success{ display:block; background: var(--success-bg); color: var(--success-text); border-color: rgba(16,185,129,.25); }
  .form-message.error{ display:block; background: var(--error-bg); color: var(--error-text); border-color: rgba(239,68,68,.25); }

  .is-invalid{ border-color:#ef4444 !important; box-shadow: 0 0 0 4px rgba(239,68,68,.12) !important; background:#fff !important; }
  .is-valid{ border-color:#10b981 !important; box-shadow: 0 0 0 4px rgba(16,185,129,.12) !important; }

  @media (max-width: 900px){
    .subscribe-container{
      grid-template-columns: 1fr;
      gap: 22px;
      padding: 28px;
    }
    .input-row{ flex-direction: column; }
    .subscribe-btn{ width: 100%; }
  }
  @media (max-width: 480px){
    .subscribe-title{ font-size: 1.8rem; }
  }

.hero-subscribe {
            background: linear-gradient(135deg, #ff6b35 0%, #ff914d 100%);

            border-radius: 24px;
            padding: 60px 40px;
            max-width: 900px;
            width: 100%;
            box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15);
            position: relative;
            overflow: hidden;
            margin: auto;
        }

        .hero-subscribe::before {
            content: '';
            position: absolute;
            top: -50%;
            right: -10%;
            width: 300px;
            height: 300px;
            background: rgba(255, 255, 255, 0.1);
            border-radius: 50%;
            backdrop-filter: blur(10px);
        }

        .hero-subscribe::after {
            content: '🎲';
            position: absolute;
            top: 30px;
            right: 50px;
            font-size: 48px;
            opacity: 0.3;
            transform: rotate(-15deg);
        }

        .promo-content {
            position: relative;
            z-index: 2;
        }

        .promo-title {
            color: white;
            font-size: clamp(28px, 4vw, 42px);
            font-weight: 800;
            margin-bottom: 16px;
            text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
            line-height: 1.2;
        }

        .promo-subtitle {
            color: rgba(255, 255, 255, 0.95);
            font-size: 18px;
            margin-bottom: 32px;
            line-height: 1.6;
            max-width: 600px;
        }

        .subscription-form {
            display: flex;
            gap: 0;
            background: white;
            border-radius: 50px;
            padding: 6px;
            box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
            max-width: 500px;
            transition: all 0.3s ease;
        }

        .subscription-form:focus-within {
            box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
            transform: translateY(-2px);
        }

        .email-input {
            flex: 1;
            border: none;
            padding: 16px 24px;
            font-size: 16px;
            border-radius: 50px;
            background: transparent;
            color: #333;
            outline: none;
        }

        .email-input::placeholder {
            color: #999;
            font-weight: 400;
        }

        .submit-button {
         background: linear-gradient(135deg, #ff6b35 0%, #ff914d 100%);
            color: white;
            border: none;
            padding: 16px 32px;
            border-radius: 50px;
            font-size: 16px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
            white-space: nowrap;
            box-shadow: 0 4px 15px rgba(24, 119, 242, 0.3);
        }

        .submit-button:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 25px rgba(24, 119, 242, 0.4);
        }

        .submit-button:active {
            transform: translateY(0);
        }

        .trust-indicators {
            display: flex;
            align-items: center;
            gap: 20px;
            margin-top: 24px;
            flex-wrap: wrap;
        }

        .trust-item {
            display: flex;
            align-items: center;
            gap: 8px;
            color: rgba(255, 255, 255, 0.9);
            font-size: 14px;
        }

        .trust-icon {
            width: 16px;
            height: 16px;
            background: rgba(255, 255, 255, 0.2);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 10px;
        }

        .form-status {
            margin-top: 16px;
            padding: 12px 20px;
            border-radius: 12px;
            font-size: 14px;
            font-weight: 500;
            display: none;
        }

        .form-status.success {
            background: white;
            color: #ff914d!important;
            border: 1px solid #ff6b35;
            font-size: 19px;
        }

          .form-status.info {
            background: white;
            color: #ff914d!important;
            border: 1px solid #ff6b35;
            font-size: 19px;
        }

        .form-status.error {
            background: white;
            color:#ff914d!important;
            border: 1px solid #ff6b35;
            font-size: 19px;
        }

        @media (max-width: 768px) {

            .cta-button.install-button{
                width: 100%;
                text-align: center;
                justify-content: center;
            }
            a[href="#subs"] {
              width: 100%;
                text-align: center;
                justify-content: center;
            }

            .cta-button.bookmark-button{
                width: 100%;
                justify-content: center;
            }


            .hero-subscribe {
                padding: 40px 24px;
            }

            .subscription-form {
                flex-direction: column;
                border-radius: 16px;
            }

            .email-input {
                border-radius: 12px;
                padding: 16px 20px;
            }

            .submit-button {
                border-radius: 12px;
                margin-top: 8px;
            }

            .trust-indicators {
                justify-content: center;
            }
        }

        @keyframes pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.05); }
        }

        .submit-button:hover {
            animation: pulse 2s infinite;
        }

        .form-status { display: none; margin-top: 12px; font-size: 14px; line-height: 1.4; }
        .form-status:not(:empty) { display: block; }
        .form-status.success { color: #fff; }
        .form-status.error   { color: #fff; }


.info-section .sweepstakes-container{
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 12px;
  /*padding: 40px 60px;*/
  text-align: center;
  box-sizing: border-box;  
}

.section-title{
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 30px;
}

.faq-block{ margin-bottom: 50px; text-align: left; }
.faq-item{ margin-bottom: 20px; font-size: 1rem; line-height: 1.6; color:#333; }
.faq-item strong{ display:block; margin-bottom:5px; font-weight:600; font-size:1.05rem; }

@media (max-width: 768px){
  section.info-section .sweepstakes-container{
    padding: 16px 18px !important;  
  }

  .section-title{ font-size: 1.3rem; margin-bottom: 20px; }
  .faq-block{ margin-bottom: 32px; }
  .faq-item{ margin-bottom: 16px; }
}

.info-section{ padding-left: 12px; padding-right: 12px; }

.logo-brand{
    display: flex;
    gap: 10px;
    align-items: center;
}

.contact-info {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
}

.contact-info i {
  color: #333;
  font-size: 16px;
}

.contact-info a {
  color: #0073e6;
  text-decoration: none;
}

.contact-info a:hover {
  text-decoration: underline;
}


.sweepstakes-container a {
    color: #ff6b35!important;
}


.table-wrap {
  width: 100%;
  overflow-x: auto;
}


table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  font-size: 16px;
}


thead th {
  background: #f7f7f9;
  color: #111;
  font-weight: 600;
  text-align: left;
  padding: 12px 14px;
  border-bottom: 2px solid #e6e6e6;
  white-space: nowrap;
}

tbody td {
  padding: 12px 14px;
  border-bottom: 1px solid #eee;
  vertical-align: top;
}

tbody tr:nth-child(odd) {
  background: #fcfcfd;
}

tbody tr:hover {
  background: #f5f8ff;
}

@media (max-width: 640px) {
  table { font-size: 15px; }
  thead th, tbody td { padding: 10px 12px; }
}