/* Mobile banners */
.mobile-banners { padding: 0 16px; margin-top: 12px; display: grid; gap: 12px; }
.mobile-banner { border-radius: 16px; overflow: hidden; box-shadow: 0 8px 24px rgba(0,0,0,.3); }
.m-banner-inner { position: relative; height: 160px; border-radius: 16px; overflow: hidden; }
.m-banner-text { position: absolute; left: 16px; top: 16px; right: 16px; z-index: 2; }
.m-banner-text h3 { color: #fff; font-size: 20px; font-weight: 900; margin: 0 0 12px; letter-spacing: -.3px; }
.m-banner-img { 
    position: absolute; 
    inset: 0; 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    opacity: .9; 
    will-change: transform;
}

@media (min-width: 769px) { .mobile-banners { display: none; } }
/* Mobile install bar */
.install-bar {
    position: sticky;
    top: 0;
    z-index: 1100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    background: #111026;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.install-left { display: flex; align-items: center; gap: 12px; }
.install-logo { width: 36px; height: 36px; border-radius: 10px; }
.install-info { color: #fff; }
.install-title { font-weight: 800; font-size: 14px; }
.install-meta { display: flex; align-items: center; gap: 6px; font-size: 12px; color: #E5E7EB; }
.install-stars { color: #F59E0B; letter-spacing: 1px; }
.install-bonus { margin-top: 4px; padding: 2px 8px; background: rgba(139, 92, 246, 0.2); color: #D8B4FE; border-radius: 999px; font-size: 11px; font-weight: 700; }

.install-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.install-btn { padding: 8px 14px; background: #5CB87B; color: #fff; font-weight: 800; border: none; border-radius: 10px; }
.install-platforms { font-size: 11px; color: #9CA3AF; }
.install-close { background: transparent; border: none; color: #9CA3AF; font-size: 18px; }

@media (min-width: 769px) { .install-bar { display: none; } }
/* Reset and Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background-color: #1A0F33;
    color: #ffffff;
    line-height: 1.4;
    overflow-x: hidden;
    font-size: 14px;
}

/* Custom Vector Icons */
.icon-menu::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='3' y1='6' x2='21' y2='6'/%3E%3Cline x1='3' y1='12' x2='21' y2='12'/%3E%3Cline x1='3' y1='18' x2='21' y2='18'/%3E%3C/svg%3E");
}

.icon-casino::before { 
    content: "";
    background-image: url("images/favicon.svg");
    background-size: 20px 20px;
    background-repeat: no-repeat;
    background-position: center;
    width: 20px;
    height: 20px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
    margin: 0 auto;
}

.icon-deposit::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 12c0 1.2-4.03 6-9 6s-9-4.8-9-6c0-1.2 4.03-6 9-6s9 4.8 9 6z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E");
}

.icon-bonus::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z'/%3E%3C/svg%3E");
}

.icon-sport::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M8 12h8'/%3E%3Cpath d='M12 8v8'/%3E%3C/svg%3E");
}

.icon-home::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 9 9-7 9 7v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/%3E%3Cpolyline points='9,22 9,12 15,12 15,22'/%3E%3C/svg%3E");
}

.icon-settings::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1 1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1z'/%3E%3C/svg%3E");
}

.icon-user::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
}

.icon-heart::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E");
}

.icon-document::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/%3E%3Cpolyline points='14,2 14,8 20,8'/%3E%3Cline x1='16' y1='13' x2='8' y2='13'/%3E%3Cline x1='16' y1='17' x2='8' y2='17'/%3E%3Cpolyline points='10,9 9,9 8,9'/%3E%3C/svg%3E");
}

.icon-headphones::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 14v3a2 2 0 0 0 2 2h1a2 2 0 0 0 2-2v-3a2 2 0 0 0-2-2H5a2 2 0 0 0-2 2z'/%3E%3Cpath d='M21 14v3a2 2 0 0 1-2 2h-1a2 2 0 0 1-2-2v-3a2 2 0 0 1 2-2h1a2 2 0 0 1 2 2z'/%3E%3Cpath d='M7 14v3a2 2 0 0 0 2 2h1a2 2 0 0 0 2-2v-3a2 2 0 0 0-2-2H9a2 2 0 0 0-2 2z'/%3E%3Cpath d='M17 14v3a2 2 0 0 1-2 2h-1a2 2 0 0 1-2-2v-3a2 2 0 0 1 2-2h1a2 2 0 0 1 2 2z'/%3E%3C/svg%3E");
}

.icon-telegram::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='%23FFFFFF'%3E%3Cpath d='M11.944 0A12 12 0 0 0 0 12a12 12 0 0 0 12 12 12 12 0 0 0 12-12A12 12 0 0 0 12 0a12 12 0 0 0-.056 0zm4.962 7.224c.1-.002.321.023.465.14a.506.506 0 0 1 .171.325c.016.093.036.306.02.472-.18 1.898-.962 6.502-1.36 8.627-.168.9-.499 1.201-.82 1.23-.696.065-1.225-.46-1.9-.902-1.056-.693-1.653-1.124-2.678-1.8-1.185-.78-.417-1.21.258-1.91.177-.184 3.247-2.977 3.307-3.23.007-.032.014-.15-.056-.212s-.174-.041-.249-.024c-.106.024-1.793 1.14-5.061 3.345-.48.33-.913.49-1.302.48-.428-.008-1.252-.241-1.865-.44-.752-.245-1.349-.374-1.297-.789.027-.216.325-.437.893-.663 3.498-1.524 5.83-2.529 6.998-3.014 3.332-1.386 4.025-1.627 4.476-1.635z'/%3E%3C/svg%3E");
}

.icon-vk::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='%23FFFFFF'%3E%3Cpath d='M15.684 0H8.316C1.592 0 0 1.592 0 8.316v7.368C0 22.408 1.592 24 8.316 24h7.368C22.408 24 24 22.408 24 15.684V8.316C24 1.592 22.408 0 15.684 0zm3.692 17.123h-1.744c-.66 0-.864-.525-2.05-1.727-1.033-1.01-1.49-.864-1.744-.864-.356 0-.458.102-.458.593v1.575c0 .424-.135.678-1.253.678-1.846 0-3.896-1.118-5.335-3.202C4.624 10.857 4.03 8.57 4.03 8.096c0-.254.102-.491.593-.491h1.744c.44 0 .61.203.78.677.863 2.49 2.303 4.675 2.896 4.675.22 0 .322-.102.322-.66V9.721c-.068-1.186-.695-1.287-.695-1.71 0-.203.17-.407.44-.407h2.744c.373 0 .508.203.508.643v3.473c0 .372.17.508.271.508.22 0 .407-.136.813-.542 1.254-1.406 2.151-3.574 2.151-3.574.119-.254.322-.491.763-.491h1.744c.525 0 .644.271.525.643-.22 1.017-2.354 4.031-2.354 4.031-.186.305-.254.44 0 .78.186.254.795.780 1.203 1.253.745.847 1.32 1.558 1.473 2.05.17.49-.085.744-.576.744z'/%3E%3C/svg%3E");
}

.icon-search::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");
}

.icon-star::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='12,2 15.09,8.26 22,9.27 17,14.14 18.18,21.02 12,17.77 5.82,21.02 7,14.14 2,9.27 8.91,8.26'/%3E%3C/svg%3E");
}

.icon-crown::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M11.562 3.266a.5.5 0 0 1 .876 0L15.39 8.87a1 1 0 0 0 1.516.294L21.183 5.5a.5.5 0 0 1 .798.519L20.5 10.5a1 1 0 0 0 .5 1.5h3a.5.5 0 0 1 .5.5v8a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-8a.5.5 0 0 1 .5-.5h3a1 1 0 0 0 .5-1.5L1.02 6.02a.5.5 0 0 1 .798-.519l4.277 3.664a1 1 0 0 0 1.516-.294z'/%3E%3C/svg%3E");
}

.icon-target::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Ccircle cx='12' cy='12' r='6'/%3E%3Ccircle cx='12' cy='12' r='2'/%3E%3C/svg%3E");
}

.icon-lightning::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='13,2 3,14 12,14 11,22 21,10 12,10'/%3E%3C/svg%3E");
}

.icon-spade::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='%23FFFFFF'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-1 17.93c-3.94-.49-7-3.85-7-7.93 0-.62.08-1.21.21-1.79L9 15v1c0 1.1.9 2 2 2v1.93zm6.9-2.54c-.26-.81-1-1.39-1.9-1.39h-1v-3c0-.55-.45-1-1-1H8v-2h2c.55 0 1-.45 1-1V7h2c1.1 0 2-.9 2-2v-.41c2.93 1.19 5 4.06 5 7.41 0 2.08-.8 3.97-2.1 5.39z'/%3E%3C/svg%3E");
}

.icon-puzzle::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19.439 13.269l-.896 5.378a1 1 0 0 1-1.03.781l-5.38-.896a1 1 0 0 0-.684.12l-3.26 1.97a1 1 0 0 1-1.5-.5l-1.97-3.26a1 1 0 0 0-.12-.684l-.896-5.38a1 1 0 0 1 .781-1.03l5.378-.896a1 1 0 0 0 .684-.12l3.26-1.97a1 1 0 0 1 1.5.5l1.97 3.26a1 1 0 0 0 .12.684l.896 5.378a1 1 0 0 1-.781 1.03z'/%3E%3C/svg%3E");
}

.icon-arrow-left::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='15,18 9,12 15,6'/%3E%3C/svg%3E");
}

.icon-arrow-right::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9,18 15,12 9,6'/%3E%3C/svg%3E");
}

.icon-play::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='5,3 19,12 5,21'/%3E%3C/svg%3E");
}

.icon-close::before { 
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}

/* Desktop Header */
.desktop-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 70px;
    background-color: #1A0F33;
    z-index: 1000;
    display: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    padding: 0 30px;
    max-width: 1400px;
    margin: 0 auto;
}

.logo {
    display: flex;
    align-items: center;
    gap: 12px;
}

.logo-icon {
    width: 45px;
    height: 45px;
    background: linear-gradient(135deg, #8B5CF6, #A855F7);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 22px;
    color: white;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
}

.logo-image {
    width: 45px;
    height: 45px;
    border-radius: 10px;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
}

.logo-text {
    font-size: 32px;
    font-weight: 900;
    color: white;
    letter-spacing: 1px;
    font-family: 'Arial Black', Arial, sans-serif;
    text-transform: uppercase;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.header-actions {
    display: flex;
    gap: 15px;
}

.btn-login {
    padding: 12px 24px;
    background-color: #4A1A8C;
    color: white;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.btn-login:hover {
    background-color: #5A2A9C;
    transform: translateY(-1px);
}

.btn-register {
    padding: 12px 24px;
    background: #5CB87B;
    color: white;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(92, 184, 123, 0.3);
}

.btn-register:hover {
    background: #4CA66B;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(92, 184, 123, 0.4);
}

/* Mobile App Banner */
.mobile-app-banner {
    background: linear-gradient(135deg, #8B5CF6, #A855F7);
    padding: 24px;
    margin: 20px;
    margin-bottom: 24px;
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(139, 92, 246, 0.3);
    position: relative;
    overflow: hidden;
}

.mobile-app-banner::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20px;
    width: 100px;
    height: 100px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
    border-radius: 50%;
}

.banner-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 2;
}

.app-info {
    display: flex;
    align-items: center;
    gap: 16px;
    flex: 1;
}

.app-logo {
    width: 60px;
    height: 60px;
    background-color: white;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 28px;
    color: #8B5CF6;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.app-logo img {
    width: 100%;
    height: 100%;
    border-radius: 16px;
    object-fit: cover;
}

.app-text {
    color: white;
}

.app-title {
    font-size: 24px;
    font-weight: 800;
    margin-bottom: 6px;
    letter-spacing: -0.5px;
}

.app-bonus {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 4px;
}

.app-subtitle {
    font-size: 14px;
    opacity: 0.9;
    font-weight: 500;
}

.app-visual {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.app-icons {
    display: flex;
    gap: 10px;
}

.app-icon {
    width: 36px;
    height: 36px;
    background: linear-gradient(135deg, #FFD700, #FFA500);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    box-shadow: 0 4px 12px rgba(255, 215, 0, 0.3);
}

.app-icon.ios::before {
    content: "🍎";
}

.app-icon.android::before {
    content: "🤖";
}

.btn-install {
    padding: 12px 20px;
    background-color: white;
    color: #1A1A2E;
    border: none;
    border-radius: 10px;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.btn-install:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

.apple-logo {
    font-size: 18px;
}

/* Desktop Sidebar */
.desktop-sidebar {
    position: fixed;
    left: 0;
    top: 70px;
    width: 70px;
    height: calc(100vh - 70px);
    background-color: #1A0F33;
    z-index: 999;
    display: none;
    flex-direction: column;
    align-items: center;
    padding: 25px 0;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.sidebar-toggle {
    color: white;
    font-size: 20px;
    margin-bottom: 35px;
    cursor: pointer;
    padding: 8px;
    border-radius: 6px;
    transition: background-color 0.3s;
    background-color: rgba(255, 255, 255, 0.1);
    font-weight: 600;
}

.sidebar-toggle:hover {
    background-color: rgba(255, 255, 255, 0.2);
    transform: scale(1.1);
}

.sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 25px;
    flex: 1;
}

.nav-item {
    position: relative;
    width: 45px;
    height: 45px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    background-color: transparent;
}

.nav-item:hover {
    background-color: rgba(255, 255, 255, 0.15);
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.nav-item:hover .nav-icon {
    color: white;
    filter: brightness(1.8);
}

.nav-item.active {
    background: linear-gradient(135deg, #7B33E0, #8B5CF6);
    box-shadow: 0 4px 16px rgba(123, 51, 224, 0.3);
}

.nav-icon {
    font-size: 22px;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
}

.nav-icon::before {
    width: 20px;
    height: 20px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
}

.nav-item.active .nav-icon {
    color: white;
}

.notification-badge {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 20px;
    height: 20px;
    background: linear-gradient(135deg, #10B981, #059669);
    color: white;
    border-radius: 50%;
    font-size: 11px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
}

.sidebar-social {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.social-icon {
    width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    cursor: pointer;
    font-size: 16px;
    transition: all 0.3s ease;
    opacity: 1;
    color: white;
}

.social-icon::before {
    width: 16px;
    height: 16px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
}

.social-icon:hover {
    transform: scale(1.1);
    background-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.social-icon.telegram {
    background: linear-gradient(135deg, #0088CC, #006699);
    color: white;
}

.social-icon.vk {
    background: linear-gradient(135deg, #0077FF, #0055CC);
    color: white;
    font-weight: 700;
    font-size: 14px;
}

.social-icon.flag {
    background-color: rgba(255, 255, 255, 0.1);
    color: white;
}

/* Main Content */
.main-content {
    padding: 30px;
    margin-left: 0;
    min-height: 100vh;
    padding-bottom: 100px;
    background-color: #1A0F33;
}

/* Desktop Banners */
.desktop-banners {
    margin-bottom: 40px;
    display: none;
}

.banner-carousel {
    position: relative;
    height: 240px;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 20px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.banner-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.6s ease;
}

.banner-slide.active {
    opacity: 1;
}

.banner-slide:first-child {
    background: linear-gradient(135deg, #4A1A8C, #7B33E0, #8B5CF6);
}

.banner-slide:nth-child(2) {
    background: linear-gradient(135deg, #1A1A8C, #337BE0, #3B82F6);
}

.banner-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    padding: 40px;
    position: relative;
    overflow: hidden;
}

.banner-text {
    position: relative;
    z-index: 2;
    width: 50%;
    padding-right: 20px;
}

.banner-text h2 {
    font-size: 36px;
    font-weight: 800;
    margin-bottom: 20px;
    letter-spacing: -1px;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.btn-details {
    padding: 14px 28px;
    background-color: #4A1A8C;
    color: white;
    border: none;
    border-radius: 10px;
    font-weight: 700;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(74, 26, 140, 0.3);
}

.btn-details:hover {
    background-color: #5A2A9C;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(74, 26, 140, 0.4);
}

.banner-character {
    width: 50%;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 80px;
    filter: drop-shadow(0 4px 16px rgba(0, 0, 0, 0.3));
    z-index: 1;
}

.banner-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px;
    filter: blur(1px) brightness(0.8);
}

.game-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px;
}

/* Mobile responsive styles for banners */
@media (max-width: 768px) {
    .banner-character {
        width: 120px;
        height: 120px;
    }
    
    .banner-image {
        border-radius: 8px;
    }
    
    .game-card {
        background: transparent;
        border-radius: 16px; /* slightly smaller */
        overflow: hidden;
        box-shadow: 0 6px 18px rgba(0, 0, 0, 0.28);
        transition: all 0.25s ease;
        position: relative;
        aspect-ratio: 10/13; /* a bit shorter to reduce visual size */
    }
    
    .game-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
    }
    
    .game-image {
        width: 100%;
        height: 100%;
        position: relative;
        border-radius: 16px;
        overflow: hidden;
    }
    
    .game-img {
        width: 100%;
        height: 100%;
        object-fit: cover; /* fill entire card */
        object-position: center;
        border-radius: 16px;
        background: transparent;
    }
    
    .game-badge {
        position: absolute;
        top: 12px;
        left: 12px;
        background: rgba(0, 0, 0, 0.8);
        color: white;
        padding: 6px 10px;
        border-radius: 8px;
        font-size: 10px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        z-index: 3;
    }
    
    .game-title {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        padding: 16px 14px 12px 14px;
        font-size: 15px;
        font-weight: 800;
        color: #fff;
        margin: 0;
        text-align: left;
        border-radius: 0 0 16px 16px;
        z-index: 2;
    }
    
    .game-brand,
    .game-provider {
        display: none;
    }
    
    .games-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr); /* slightly smaller, two per row */
        gap: 12px;
        padding: 0 16px;
        overflow: visible;
    }
    
    .games-grid::-webkit-scrollbar { display: none; }
    
    /* Дополнительные стили для карточек */
    .game-card {
        scroll-snap-align: start;
        min-width: 0;
    }
    
    /* Улучшенные стили для текста на карточках */
    .game-title {
        text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
        line-height: 1.2;
    }
    
    .game-brand,
    .game-provider {
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
        line-height: 1.3;
    }
    
    /* Улучшенные стили для секций игр */
    .games-section {
        margin-bottom: 32px;
    }
    
    .section-title {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 20px;
        padding: 0 16px;
    }
    
    .section-title h3 {
        font-size: 20px;
        font-weight: 800;
        color: white;
        display: flex;
        align-items: center;
        gap: 8px;
    }
    
    .section-actions {
        display: flex;
        align-items: center;
        gap: 12px;
    }
    
    .btn-all-games {
        color: #3B82F6;
        background: none;
        border: none;
        font-weight: 600;
        font-size: 14px;
        cursor: pointer;
        transition: color 0.3s ease;
    }
    
    /* Скрываем стрелки навигации в мобильной версии */
    .nav-arrows {
        display: none;
    }
    
    .nav-arrow-left,
    .nav-arrow-right {
        display: none;
    }
}

.carousel-dots {
    display: flex;
    justify-content: center;
    gap: 12px;
}

.dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.4);
    cursor: pointer;
    transition: all 0.3s ease;
}

.dot.active {
    background-color: white;
    transform: scale(1.2);
}

.dot:hover {
    background-color: rgba(255, 255, 255, 0.7);
}

/* Search Section */
.search-section {
    display: flex;
    gap: 20px;
    margin-bottom: 30px;
    align-items: center;
    justify-content: center;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

.search-bar {
    flex: 1;
    position: relative;
}

.search-icon {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: #F3F4F6;
    font-size: 20px;
    z-index: 2;
}

.search-icon::before {
    width: 20px;
    height: 20px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
}

.search-input {
    width: 100%;
    padding: 16px 18px 16px 50px;
    background-color: #2C1E52;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 12px;
    color: white;
    font-size: 16px;
    font-weight: 500;
    transition: all 0.3s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.search-input:focus {
    outline: none;
    border-color: #8B5CF6;
    box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}

.search-input::placeholder {
    color: #9CA3AF;
    font-weight: 500;
}

.btn-providers {
    padding: 16px 24px;
    background-color: #2C1E52;
    color: #F9FAFB;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 12px;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: all 0.3s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.btn-providers:hover {
    background-color: #3C2E62;
    border-color: rgba(255, 255, 255, 0.4);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.provider-icon {
    font-size: 18px;
    color: #F9FAFB;
}

.provider-icon::before {
    width: 18px;
    height: 18px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
}

/* Category Navigation */
.category-nav {
    margin-bottom: 40px;
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: center;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

.category-tabs {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    flex: 1;
    padding-bottom: 12px;
}

.category-tabs::-webkit-scrollbar {
    height: 8px;
}

.category-tabs::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 4px;
}

.category-tabs::-webkit-scrollbar-thumb {
    background: #8B5CF6;
    border-radius: 4px;
    min-width: 30px;
}

.category-tabs::-webkit-scrollbar-thumb:hover {
    background: #A855F7;
}

.tab {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    background-color: #2C1E52;
    color: #F9FAFB;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
    font-size: 15px;
    font-weight: 600;
    min-width: fit-content;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.tab:hover {
    background-color: #3C2E62;
    border-color: rgba(255, 255, 255, 0.4);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.tab:hover .tab-icon {
    color: white;
    filter: brightness(1.8);
}

.tab.active {
    background: linear-gradient(135deg, #7B33E0, #8B5CF6);
    border-color: #7B33E0;
    box-shadow: 0 4px 16px rgba(123, 51, 224, 0.3);
}

.tab-icon {
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #F9FAFB;
}

.tab-icon::before {
    width: 18px;
    height: 18px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
}


/* Games Section */
.games-section {
    margin-bottom: 40px;
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
}

.section-title {
    display: flex;
    align-items: center;
    gap: 12px;
}

.title-icon {
    width: 35px;
    height: 35px;
    background: linear-gradient(135deg, #8B5CF6, #A855F7);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 18px;
    color: white;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
}

.title-icon::before {
    width: 18px;
    height: 18px;
    display: block;
}

.section-title h3 {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -0.5px;
}

.section-actions {
    display: flex;
    align-items: center;
    gap: 20px;
}

.btn-all-games {
    color: #3B82F6;
    background: none;
    border: none;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    transition: color 0.3s ease;
}

.btn-all-games:hover {
    color: #60A5FA;
}

.nav-arrows {
    display: flex;
    gap: 10px;
}

.nav-arrow-left,
.nav-arrow-right {
    width: 40px;
    height: 40px;
    background-color: #1A1A2E;
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 600;
    transition: all 0.3s ease;
}

.nav-arrow-left:hover,
.nav-arrow-right:hover {
    background-color: #2A2A3E;
    border-color: rgba(255, 255, 255, 0.2);
    transform: translateY(-1px);
}

/* Games Grid */
.games-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 20px;
}

.game-card {
    background-color: #1A1A2E;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    will-change: transform;
}

.game-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(139, 92, 246, 0.2);
    border-color: rgba(139, 92, 246, 0.3);
}

.game-image {
    position: relative;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 50px;
    background: linear-gradient(135deg, #3B82F6, #1D4ED8);
    overflow: hidden;
}

.game-image.coinflip {
    background: linear-gradient(135deg, #3B82F6, #1D4ED8);
}

.game-image.penalty {
    background: linear-gradient(135deg, #10B981, #059669);
}

.game-image.crash {
    background: linear-gradient(135deg, #F59E0B, #D97706);
}

.game-image.dice {
    background: linear-gradient(135deg, #8B5CF6, #7C3AED);
}

.game-image.mines {
    background: linear-gradient(135deg, #EF4444, #DC2626);
}

.game-image.poker {
    background: linear-gradient(135deg, #06B6D4, #0891B2);
}

.game-placeholder {
    font-size: 50px;
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.3));
}

.game-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background-color: #000000;
    color: white;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.5px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.game-title {
    padding: 16px;
    font-weight: 700;
    font-size: 16px;
    text-align: center;
    letter-spacing: -0.3px;
}

.game-provider,
.game-brand {
    padding: 0 16px 16px;
    font-size: 13px;
    color: #9CA3AF;
    text-align: center;
    font-weight: 600;
    letter-spacing: 0.5px;
}

/* Jackpot Banner */
.jackpot-banner {
    background: linear-gradient(135deg, #8B5CF6, #EC4899, #F472B6);
    border-radius: 16px;
    padding: 40px;
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(139, 92, 246, 0.3);
}

.jackpot-banner::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -20px;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
    border-radius: 50%;
}

.jackpot-content {
    position: relative;
    z-index: 2;
}

.jackpot-content h3 {
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 20px;
    letter-spacing: -0.5px;
}

.jackpot-amount {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    margin-bottom: 25px;
}

.play-icon {
    font-size: 24px;
    color: white;
}

.play-icon::before {
    width: 24px;
    height: 24px;
    display: block;
}

.amount {
    font-size: 42px;
    font-weight: 800;
    letter-spacing: -1px;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.btn-jackpots {
    padding: 16px 32px;
    background: linear-gradient(135deg, #EF4444, #DC2626);
    color: white;
    border: none;
    border-radius: 12px;
    font-weight: 700;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 16px rgba(239, 68, 68, 0.3);
}

.btn-jackpots:hover {
    background: linear-gradient(135deg, #DC2626, #B91C1C);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.4);
}

/* Mobile Support Section */
.mobile-support {
    margin-bottom: 40px;
}

.support-card {
    background-color: #1A1A2E;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    padding: 24px;
    position: relative;
    display: flex;
    align-items: center;
    gap: 24px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.support-badge {
    position: absolute;
    top: 20px;
    right: 20px;
    background-color: #9CA3AF;
    color: #1A1A2E;
    padding: 6px 12px;
    border-radius: 16px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.5px;
}

.support-content {
    flex: 1;
}

.support-content h3 {
    font-size: 24px;
    font-weight: 800;
    margin-bottom: 10px;
    letter-spacing: -0.5px;
}

.support-content p {
    color: #9CA3AF;
    font-size: 16px;
    margin-bottom: 20px;
    font-weight: 500;
    line-height: 1.5;
}

.btn-support {
    padding: 14px 28px;
    background: linear-gradient(135deg, #8B5CF6, #A855F7);
    color: white;
    border: none;
    border-radius: 10px;
    font-weight: 700;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 16px rgba(139, 92, 246, 0.3);
}

.btn-support:hover {
    background: linear-gradient(135deg, #7C3AED, #9333EA);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(139, 92, 246, 0.4);
}

.support-character {
    width: 100px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 60px;
    filter: drop-shadow(0 4px 16px rgba(0, 0, 0, 0.3));
}

/* Contact Information */
.contact-info {
    margin-bottom: 40px;
}

.contact-item {
    margin-bottom: 20px;
}

.contact-label {
    display: block;
    color: #9CA3AF;
    font-size: 16px;
    margin-bottom: 8px;
    font-weight: 500;
}

.contact-link {
    color: white;
    font-weight: 700;
    text-decoration: none;
    font-size: 18px;
    transition: color 0.3s ease;
}

.contact-link:hover {
    color: #8B5CF6;
}

.social-links {
    display: flex;
    gap: 20px;
    margin-top: 30px;
}

.social-link {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    text-decoration: none;
    font-size: 20px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    opacity: 1;
}

.social-link::before {
    width: 20px;
    height: 20px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
}

.social-link:hover {
    transform: translateY(-2px) scale(1.05);
}

.social-link.telegram {
    background: linear-gradient(135deg, #0088CC, #006699);
    color: white;
}

.social-link.vk {
    background: linear-gradient(135deg, #0077FF, #0055CC);
    color: white;
    font-weight: 700;
    font-size: 16px;
}

/* Legal Information */
.legal-info {
    margin-bottom: 30px;
    padding: 30px;
    background-color: #1A1A2E;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.legal-info p {
    color: #9CA3AF;
    font-size: 13px;
    line-height: 1.6;
    margin-bottom: 15px;
    font-weight: 500;
}

.legal-info a {
    color: #8B5CF6;
    text-decoration: none;
    font-weight: 600;
}

.legal-info a:hover {
    text-decoration: underline;
}

/* Certifications */
.certifications {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
}

.gcb-logo {
    background: linear-gradient(135deg, #10B981, #059669);
    color: white;
    padding: 15px 20px;
    border-radius: 12px;
    font-weight: 800;
    font-size: 18px;
    text-align: center;
    box-shadow: 0 4px 16px rgba(16, 185, 129, 0.3);
}

.gcb-logo small {
    font-size: 12px;
    display: block;
    font-weight: 600;
    margin-top: 4px;
}

.age-restriction {
    font-size: 32px;
    font-weight: 800;
    color: white;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* SEO Content Section */
.seo-content {
    padding: 40px 20px;
    max-width: 1200px;
    margin: 0 auto;
    color: #E5E7EB;
    line-height: 1.6;
}

.seo-content h1 {
    font-size: 32px;
    font-weight: 900;
    color: white;
    margin-bottom: 20px;
    line-height: 1.2;
}

.seo-content h2 {
    font-size: 24px;
    font-weight: 700;
    color: #8B5CF6;
    margin: 30px 0 15px 0;
    line-height: 1.3;
}

.seo-content h3 {
    font-size: 20px;
    font-weight: 600;
    color: #A855F7;
    margin: 25px 0 12px 0;
    line-height: 1.3;
}

.seo-content p {
    margin-bottom: 15px;
    font-size: 16px;
}

.seo-content ul {
    margin: 15px 0;
    padding-left: 20px;
}

.seo-content li {
    margin-bottom: 8px;
    font-size: 16px;
}

.seo-content strong {
    color: #F3F4F6;
    font-weight: 600;
}

/* Steps Table */
.steps-table {
    margin: 20px 0;
    border-radius: 12px;
    overflow: hidden;
    background: rgba(139, 92, 246, 0.1);
    border: 1px solid rgba(139, 92, 246, 0.2);
}

.step-row {
    display: flex;
    align-items: flex-start;
    padding: 20px;
    border-bottom: 1px solid rgba(139, 92, 246, 0.1);
    transition: background-color 0.3s ease;
}

.step-row:last-child {
    border-bottom: none;
}

.step-row:hover {
    background: rgba(139, 92, 246, 0.05);
}

.step-number {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #8B5CF6, #A855F7);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 18px;
    margin-right: 20px;
    flex-shrink: 0;
}

.step-content {
    flex: 1;
}

.step-title {
    font-size: 18px;
    font-weight: 600;
    color: white;
    margin-bottom: 8px;
    line-height: 1.3;
}

.step-description {
    font-size: 15px;
    color: #D1D5DB;
    line-height: 1.5;
}

/* FAQ Accordion */
.faq-container {
    margin: 20px 0;
}

.faq-item {
    margin-bottom: 12px;
    border-radius: 12px;
    overflow: hidden;
    background: rgba(31, 41, 55, 0.5);
    border: 1px solid rgba(139, 92, 246, 0.2);
}

.faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    user-select: none;
}

.faq-question:hover {
    background: rgba(139, 92, 246, 0.1);
}

.faq-question span {
    font-size: 16px;
    font-weight: 600;
    color: white;
    flex: 1;
    margin-right: 15px;
}

.faq-icon {
    width: 30px;
    height: 30px;
    background: linear-gradient(135deg, #8B5CF6, #A855F7);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 700;
    transition: transform 0.3s ease;
}

.faq-item.active .faq-icon {
    transform: rotate(45deg);
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.faq-item.active .faq-answer {
    max-height: 200px;
}

.faq-answer p {
    padding: 0 20px 20px 20px;
    margin: 0;
    color: #D1D5DB;
    line-height: 1.5;
}

@media (max-width: 768px) {
    .seo-content {
        padding: 30px 15px;
    }
    
    .seo-content h1 {
        font-size: 28px;
    }
    
    .seo-content h2 {
        font-size: 22px;
    }
    
    .seo-content h3 {
        font-size: 18px;
    }
    
    .seo-content p,
    .seo-content li {
        font-size: 15px;
    }
    
    .step-row {
        padding: 15px;
    }
    
    .step-number {
        width: 35px;
        height: 35px;
        font-size: 16px;
        margin-right: 15px;
    }
    
    .step-title {
        font-size: 16px;
    }
    
    .step-description {
        font-size: 14px;
    }
    
    .faq-question {
        padding: 15px;
    }
    
    .faq-question span {
        font-size: 15px;
    }
    
    .faq-icon {
        width: 25px;
        height: 25px;
        font-size: 16px;
    }
    
    .faq-answer p {
        padding: 0 15px 15px 15px;
        font-size: 14px;
    }
}

/* Mobile Bottom Navigation */
.mobile-bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 80px;
    background-color: #1A0F33;
    display: flex;
    justify-content: space-around;
    align-items: center;
    z-index: 1000;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
}

.mobile-bottom-nav .nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    padding: 8px;
    border-radius: 12px;
}

.mobile-bottom-nav .nav-item:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.mobile-bottom-nav .nav-item:hover .nav-icon {
    color: white;
    filter: brightness(1.8);
}

.mobile-bottom-nav .nav-item:hover span {
    color: white;
}

.mobile-bottom-nav .nav-item.active {
    background: linear-gradient(135deg, #7B33E0, #8B5CF6);
    box-shadow: 0 6px 18px rgba(139, 92, 246, 0.35);
    border-radius: 20px;
    padding: 20px 16px;
    min-width: 80px;
    min-height: 80px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 6px;
}

.mobile-bottom-nav .nav-item.active .nav-icon {
    color: white;
}

.mobile-bottom-nav .nav-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    font-size: 24px;
    background-color: transparent;
    transition: all 0.3s ease;
    color: #F3F4F6;
}

.mobile-bottom-nav .nav-icon::before {
    width: 24px;
    height: 24px;
    display: block;
    filter: brightness(2) drop-shadow(0 0 3px rgba(255, 255, 255, 0.5));
}

.mobile-bottom-nav .nav-item.active .nav-icon {
    color: white;
}

.mobile-bottom-nav .nav-item span {
    font-size: 11px;
    font-weight: 600;
    color: #F3F4F6;
    transition: color 0.3s ease;
}

.mobile-bottom-nav .nav-item.active span {
    color: white;
}

.mobile-bottom-nav .notification-badge {
    position: absolute;
    top: 4px;
    right: 8px;
    width: 18px;
    height: 18px;
    background: linear-gradient(135deg, #10B981, #059669);
    color: white;
    border-radius: 50%;
    font-size: 10px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
}

/* Responsive Design */
@media (min-width: 768px) {
    .desktop-header {
        display: block;
    }
    
    .desktop-sidebar {
        display: flex;
    }
    
    .main-content {
        margin-left: 70px;
        padding-top: 100px;
    }
    
    .desktop-banners {
        display: block;
    }
    
    .mobile-app-banner {
        display: none;
    }
    
    .mobile-support {
        display: none;
    }
    
    .mobile-bottom-nav {
        display: none;
    }
    
    .games-grid {
        grid-template-columns: repeat(6, 1fr);
    }
    
    .search-section {
        max-width: 90%;
        margin-left: auto;
        margin-right: auto;
        justify-content: center;
    }
    
    .category-nav {
        max-width: 90%;
        margin-left: auto;
        margin-right: auto;
        justify-content: center;
    }
    
    .main-content {
        padding-bottom: 40px;
    }
}

@media (min-width: 1024px) {
    .main-content {
        max-width: 1400px;
        margin-left: 70px;
        margin-right: auto;
    }
    
    .games-grid {
        grid-template-columns: repeat(6, 1fr);
    }
    
    .banner-carousel {
        height: 280px;
    }
    
    .banner-text h2 {
        font-size: 42px;
    }
}

@media (min-width: 1200px) {
    .games-grid {
        grid-template-columns: repeat(6, 1fr);
        gap: 24px;
    }
    
    .game-card {
        min-height: 200px;
    }
    
    .game-image {
        height: 140px;
    }
}

/* Utility Classes */
.hidden {
    display: none !important;
}

.text-center {
    text-align: center;
}

.mb-20 {
    margin-bottom: 20px;
}

.mt-20 {
    margin-top: 20px;
}

/* Animation Classes */
.fade-in {
    animation: fadeIn 0.6s ease-in;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.slide-in {
    animation: slideIn 0.4s ease-out;
}

@keyframes slideIn {
    from {
        transform: translateX(-100%);
    }
    to {
        transform: translateX(0);
    }
}

.scale-in {
    animation: scaleIn 0.3s ease-out;
}

@keyframes scaleIn {
    from {
        transform: scale(0.8);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}

/* Loading Animation */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(15, 15, 35, 0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    backdrop-filter: blur(10px);
}

.loading-spinner {
    text-align: center;
    color: white;
}

.spinner {
    width: 50px;
    height: 50px;
    border: 4px solid rgba(255, 255, 255, 0.1);
    border-top: 4px solid #8B5CF6;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto 20px;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Scrollbar Styling */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, #8B5CF6, #A855F7);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, #7C3AED, #9333EA);
}

/* Focus States */
button:focus,
input:focus,
.nav-item:focus {
    outline: 2px solid #8B5CF6;
    outline-offset: 2px;
}

/* Mobile overrides (placed at end to win cascade) */
@media (max-width: 768px) {
    /* Hide navigation elements in mobile */
    .btn-all-games {
        display: none !important;
    }
    
    .nav-arrows {
        display: none !important;
    }
    
    .section-actions {
        display: none !important;
    }
    
    .games-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
        padding: 0 16px;
    }
    .game-card {
        background: transparent !important;
        border: none !important;
        border-radius: 16px;
        box-shadow: 0 6px 18px rgba(0, 0, 0, 0.28);
        position: relative;
        aspect-ratio: 10/13;
    }
    .game-card .game-image {
        height: 100% !important;
        border-radius: 16px;
        position: absolute !important;
        top: 0; right: 0; bottom: 0; left: 0; /* fill card */
    }
    .game-card .game-img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        object-position: center;
        border-radius: 16px;
    }
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    .game-card,
    .support-card,
    .legal-info {
        border-width: 2px;
    }
    
    .btn-login,
    .btn-providers,
    .tab {
        border-width: 2px;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
